Projects
Multimedia
linuxsampler
Sign Up
Log In
Username
Password
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
Expand all
Collapse all
Changes of Revision 2
View file
linuxsampler.changes
Changed
@@ -1,4 +1,9 @@ ------------------------------------------------------------------- +Mon Apr 16 17:57:32 UTC 2012 - pascal.bleser@opensuse.org + +- update to svn rev 2342 + +------------------------------------------------------------------- Sat Feb 27 00:00:00 UTC 2010 - toni@links2linux.de - update to 1.0.0
View file
linuxsampler.spec
Changed
@@ -1,38 +1,48 @@ +# vim: set sw=4 ts=4 et: + # Copyright (c) 2005-2010 oc2pus -# This file and all modifications and additions to the pristine -# package are under the same license as the package itself. +# Copyright (c) 2012 Pascal Bleser <pascal.bleser@opensuse.org> +# +# All modifications and additions to the file contributed by third parties +# remain the property of their copyright owners, unless otherwise agreed +# upon. The license for this file, and modifications and additions to the +# file, is the same license as for the pristine package itself (unless the +# license for the pristine package is not an Open Source License, in which +# case the license is the MIT License). An "Open Source License" is a +# license that conforms to the Open Source Definition (Version 1.9) +# published by the Open Source Initiative. # -# Please submit bugfixes or comments to toni@links2linux.de - -# norootforbuild - -%define _SOnr 3 - -Name: linuxsampler -Summary: LinuxSampler - modular, streaming capable sampler -Version: 1.0.0 -Release: 0.pm.1 -License: GPL -Group: Productivity/Multimedia/Sound/Utilities -URL: http://www.linuxsampler.org/ -Source0: http://download.linuxsampler.org/packages/%{name}-%{version}.tar.bz2 -Source1: %{name}.png -BuildRoot: %{_tmppath}/%{name}-%{version}-build -BuildRequires: arts-devel -BuildRequires: alsa-devel >= 1.0.9 -BuildRequires: automake >= 1.5 -BuildRequires: bison -BuildRequires: dssi-devel -BuildRequires: doxygen -BuildRequires: ladspa-devel -BuildRequires: libgig-devel -BuildRequires: libjack-devel >= 0.103 -BuildRequires: lv2core-devel -BuildRequires: pkg-config -BuildRequires: sqlite3-devel -BuildRequires: update-desktop-files -Requires: alsa >= 1.0.9 -Requires: jack >= 0.103 +# Please submit bugfixes or comments to packman@links2linux.de + +%define soname 3 + +Name: linuxsampler +Summary: LinuxSampler - modular, streaming capable sampler +%define rev 2342 +Version: 1.0.0+r%{rev} +Release: 0.pm.1 +License: GPL-2.0+ +Group: Productivity/Multimedia/Sound/Utilities +URL: http://www.linuxsampler.org/ +## http://download.linuxsampler.org/packages/linuxsampler-%{version}.tar.bz2 +Source0: linuxsampler-%{rev}.tar.bz2 +Source1: linuxsampler.png +Patch1: linuxsampler-fix_lv2_include_path.patch +BuildRoot: %{_tmppath}/%{name}-%{version}-build +BuildRequires: alsa-devel >= 1.0.9 +BuildRequires: automake >= 1.5 +BuildRequires: bison +BuildRequires: dssi-devel +BuildRequires: ladspa-devel +BuildRequires: libgig-devel +BuildRequires: libjack-devel >= 0.103 +BuildRequires: lv2core-devel +BuildRequires: pkgconfig +BuildRequires: sqlite3-devel +BuildRequires: libsndfile-devel >= 1.0.0 +BuildRequires: update-desktop-files +Requires: alsa >= 1.0.9 +Requires: jack >= 0.103 %description LinuxSampler is a work in progress. The goal is to produce a free, @@ -66,67 +76,63 @@ to any sampler format currently available in the world. Be encouraged to share your ideas about such a new format with us! -Authors: -Benno Senoner <benno@gardena.net> -Christian Schoenebeck <cuse@users.sourceforge.net> -Vladimir Senkov <hangup@users.sourceforge.net> +%package -n liblinuxsampler%{soname} +Summary: Shared libraries for linuxsampler +Group: System/Libraries +Provides: liblinuxsampler1 = 0.5.1 +Obsoletes: liblinuxsampler1 < 0.5.1 -%package -n liblinuxsampler%{_SOnr} -Summary: Shared libraries for linuxsampler -Group: System/Libraries -Provides: liblinuxsampler1 = 0.5.1 -Obsoletes: liblinuxsampler1 < 0.5.1 - -%description -n liblinuxsampler%{_SOnr} +%description -n liblinuxsampler%{soname} This package contains the shared libraries for linuxsampler. %package -n liblinuxsampler-devel -Summary: Development files for linuxsampler -Group: Development/Languages/C and C++ -Requires: liblinuxsampler%{_SOnr} = %{version} -Requires: dssi-devel -Requires: ladspa-devel +Summary: Development files for linuxsampler +Group: Development/Languages/C and C++ +Requires: liblinuxsampler%{soname} = %{version} +Requires: dssi-devel +Requires: ladspa-devel %description -n liblinuxsampler-devel This package contains header files, libraries and documentation for writing and compiling programs using linuxsampler. %package doc -Summary: Documentation for linuxampler -Group: Documentation/HTML +Summary: Documentation for linuxampler +Group: Documentation/HTML %description doc This package contains the documentation for linuxampler. %package -n dssi-linuxsampler -Summary: DSSI plugin -Group: System/Libraries -Requires: dssi +Summary: DSSI plugin +Group: System/Libraries +Requires: dssi %description -n dssi-linuxsampler This package contains the dssi-plugin for package linuxsampler. %package -n lv2-linuxsampler -Summary: LV2 plugin -Group: System/Libraries +Summary: LV2 plugin +Group: System/Libraries %description -n lv2-linuxsampler This package contains the lv2-plugin for package linuxsampler. - - %prep -%setup -q -n %{name}-%{version} - -%{?suse_update_config:%{suse_update_config -f}} +%setup -q -n linuxsampler +%patch1 %build + -e ./configure || %__make -f Makefile.cvs configure + %configure \ - --disable-static \ - --enable-optimize + --disable-static \ + --enable-optimize \ + --disable-arts-driver \ + --enable-plugin-dir="%{_prefix}/lib/%{name}/plugins" \ + --enable-default-instruments-db-location="%{_var}/lib/%{name}/instruments.db" -%__make -#%{?jobs:-j%{jobs}} +%__make %{?_smp_flags} %install %makeinstall @@ -134,7 +140,7 @@ # icon and menu-entry %__install -dm 755 %{buildroot}%{_datadir}/pixmaps %__install -m 644 %{SOURCE1} \ - %{buildroot}%{_datadir}/pixmaps + %{buildroot}%{_datadir}/pixmaps %__cat > %{name}.desktop << EOF Desktop Entry @@ -165,12 +171,13 @@ %__rm %{buildroot}%{_libdir}/lv2/%{name}.lv2/%{name}.la %__rm Documentation/Engines/gig/Makefile* -%clean - -d "%{buildroot}" -a "%{buildroot}" != "" && %__rm -rf "%{buildroot}" +%__install -d "%{buildroot}%{_usr}/lib/%{name}/plugins" -%post -n liblinuxsampler%{_SOnr} -p /sbin/ldconfig +%clean +%{?buildroot:%__rm -rf "%{buildroot}"} -%postun -n liblinuxsampler%{_SOnr} -p /sbin/ldconfig +%post -n liblinuxsampler%{soname} -p /sbin/ldconfig +%postun -n liblinuxsampler%{soname} -p /sbin/ldconfig %files %defattr(-,root,root) @@ -179,13 +186,16 @@ %{_mandir}/man1/* %{_datadir}/pixmaps/%{name}.png %{_datadir}/applications/%{name}.desktop -%dir /var/lib/%{name} -/var/lib/%{name}/instruments.db +%dir %{_usr}/lib/%{name} +%dir %{_usr}/lib/%{name}/plugins +%dir %{_var}/lib/%{name} +%{_var}/lib/%{name}/instruments.db -%files -n liblinuxsampler%{_SOnr} +%files -n liblinuxsampler%{soname} %defattr(-,root,root) %dir %{_libdir}/%{name} -%{_libdir}/%{name}/*.so.* +%{_libdir}/%{name}/*.so.%{soname} +%{_libdir}/%{name}/*.so.%{soname}.* %files -n liblinuxsampler-devel %defattr(-,root,root) @@ -197,7 +207,6 @@ %files doc %defattr(-,root,root) %doc Documentation/* -%doc doc/html/* %files -n dssi-linuxsampler %defattr(-,root,root) @@ -212,4 +221,3 @@ %{_libdir}/lv2/%{name}.lv2/*.ttl %changelog -# vim: set sw=4 ts=4 et:
View file
linuxsampler-fix_lv2_include_path.patch
Added
@@ -0,0 +1,11 @@ +--- src/hostplugins/lv2/lv2_state.h.orig 2012-04-16 18:31:29.532947979 +0200 ++++ src/hostplugins/lv2/lv2_state.h 2012-04-16 18:32:05.548946688 +0200 +@@ -26,7 +26,7 @@ + #include <stddef.h> + #include <stdint.h> + +-#include "lv2/lv2plug.in/ns/lv2core/lv2.h" ++#include <lv2.h> + + #define LV2_STATE_URI "http://lv2plug.in/ns/ext/state" + #define LV2_STATE_PREFIX LV2_STATE_URI "#"
View file
linuxsampler-1.0.0.tar.bz2/Artwork/Makefile.in
Deleted
@@ -1,377 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = Artwork -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -EXTRA_DIST = LinuxSampler_Logo.svg -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Artwork/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu Artwork/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-generic \ - mostlyclean-libtool pdf pdf-am ps ps-am uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/Documentation/Engines/Makefile.in
Deleted
@@ -1,520 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = Documentation/Engines -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -SUBDIRS = gig -all: all-recursive - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Documentation/Engines/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu Documentation/Engines/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile -installdirs: installdirs-recursive -installdirs-am: -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-recursive - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool \ - distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-recursive ctags \ - ctags-recursive distclean distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-man install-strip installcheck \ - installcheck-am installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-generic mostlyclean-libtool \ - mostlyclean-recursive pdf pdf-am ps ps-am tags tags-recursive \ - uninstall uninstall-am uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/Documentation/Engines/gig/Makefile.in
Deleted
@@ -1,377 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = Documentation/Engines/gig -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -EXTRA_DIST = EGADSR.scd -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Documentation/Engines/gig/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu Documentation/Engines/gig/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-generic \ - mostlyclean-libtool pdf pdf-am ps ps-am uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/Documentation/Makefile.in
Deleted
@@ -1,521 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = Documentation -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -SUBDIRS = Engines -EXTRA_DIST = lscp.xml -all: all-recursive - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Documentation/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu Documentation/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile -installdirs: installdirs-recursive -installdirs-am: -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-recursive - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool \ - distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-recursive ctags \ - ctags-recursive distclean distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-man install-strip installcheck \ - installcheck-am installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-generic mostlyclean-libtool \ - mostlyclean-recursive pdf pdf-am ps ps-am tags tags-recursive \ - uninstall uninstall-am uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/Makefile.in
Deleted
@@ -1,737 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = . -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -DIST_COMMON = README $(am__configure_deps) $(srcdir)/Doxyfile.in \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in \ - $(srcdir)/config.h.in $(srcdir)/linuxsampler.pc.in \ - $(srcdir)/linuxsampler.spec.in $(top_srcdir)/configure AUTHORS \ - COPYING ChangeLog INSTALL NEWS config.guess config.sub depcomp \ - install-sh ltmain.sh missing -subdir = . -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ - configure.lineno configure.status.lineno -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = config.h -CONFIG_CLEAN_FILES = linuxsampler.spec linuxsampler.pc Doxyfile -SOURCES = -DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -am__installdirs = "$(DESTDIR)$(pkgconfigdir)" -pkgconfigDATA_INSTALL = $(INSTALL_DATA) -DATA = $(pkgconfig_DATA) -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -distdir = $(PACKAGE)-$(VERSION) -top_distdir = $(distdir) -am__remove_distdir = \ - { test ! -d $(distdir) \ - || { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \ - && rm -fr $(distdir); }; } -DIST_ARCHIVES = $(distdir).tar.gz $(distdir).tar.bz2 -GZIP_ENV = --best -distuninstallcheck_listfiles = find . -type f -print -distcleancheck_listfiles = find . -type f -print -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ - -# require automake (>= 1.5) due to 'dist-bzip2' option -AUTOMAKE_OPTIONS = 1.5 dist-bzip2 -SUBDIRS = man src scripts osx Artwork Documentation debian -pkgconfigdir = $(libdir)/pkgconfig -pkgconfig_DATA = linuxsampler.pc -EXTRA_DIST = Doxyfile.in \ - linuxsampler.pc.in \ - linuxsampler.kdevelop \ - benchmarks/gigsynth.cpp \ - benchmarks/Makefile \ - benchmarks/triang.cpp - -@HAVE_SQLITE3_FALSE@have_sqlite = "no" -@HAVE_SQLITE3_TRUE@have_sqlite = "yes" -all: config.h - $(MAKE) $(AM_MAKEFLAGS) all-recursive - -.SUFFIXES: -am--refresh: - @: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - echo ' cd $(srcdir) && $(AUTOMAKE) --gnu '; \ - cd $(srcdir) && $(AUTOMAKE) --gnu \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - echo ' $(SHELL) ./config.status'; \ - $(SHELL) ./config.status;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - $(SHELL) ./config.status --recheck - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(srcdir) && $(AUTOCONF) -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) - -config.h: stamp-h1 - @if test ! -f $@; then \ - rm -f stamp-h1; \ - $(MAKE) stamp-h1; \ - else :; fi - -stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status - @rm -f stamp-h1 - cd $(top_builddir) && $(SHELL) ./config.status config.h -$(srcdir)/config.h.in: $(am__configure_deps) - cd $(top_srcdir) && $(AUTOHEADER) - rm -f stamp-h1 - touch $@ - -distclean-hdr: - -rm -f config.h stamp-h1 -linuxsampler.spec: $(top_builddir)/config.status $(srcdir)/linuxsampler.spec.in - cd $(top_builddir) && $(SHELL) ./config.status $@ -linuxsampler.pc: $(top_builddir)/config.status $(srcdir)/linuxsampler.pc.in - cd $(top_builddir) && $(SHELL) ./config.status $@ -Doxyfile: $(top_builddir)/config.status $(srcdir)/Doxyfile.in - cd $(top_builddir) && $(SHELL) ./config.status $@ - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-pkgconfigDATA: $(pkgconfig_DATA) - @$(NORMAL_INSTALL) - test -z "$(pkgconfigdir)" || $(mkdir_p) "$(DESTDIR)$(pkgconfigdir)" - @list='$(pkgconfig_DATA)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(pkgconfigDATA_INSTALL) '$$d$$p' '$(DESTDIR)$(pkgconfigdir)/$$f'"; \ - $(pkgconfigDATA_INSTALL) "$$d$$p" "$(DESTDIR)$(pkgconfigdir)/$$f"; \ - done - -uninstall-pkgconfigDATA: - @$(NORMAL_UNINSTALL) - @list='$(pkgconfig_DATA)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(pkgconfigdir)/$$f'"; \ - rm -f "$(DESTDIR)$(pkgconfigdir)/$$f"; \ - done - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - $(am__remove_distdir) - mkdir $(distdir) - $(mkdir_p) $(distdir)/. $(distdir)/benchmarks $(distdir)/m4 $(distdir)/man - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done - -find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \ - ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ - ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ - ! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \ - || chmod -R a+r $(distdir) -dist-gzip: distdir - $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz - $(am__remove_distdir) -dist-bzip2: distdir - $(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2 - $(am__remove_distdir) - -dist-tarZ: distdir - $(AMTAR) chof - $(distdir) | compress -c >$(distdir).tar.Z - $(am__remove_distdir) - -dist-shar: distdir - shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz - $(am__remove_distdir) - -dist-zip: distdir - -rm -f $(distdir).zip - zip -rq $(distdir).zip $(distdir) - $(am__remove_distdir) - -dist dist-all: distdir - $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz - $(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2 - $(am__remove_distdir) - -# This target untars the dist file and tries a VPATH configuration. Then -# it guarantees that the distribution is self-contained by making another -# tarfile. -distcheck: dist - case '$(DIST_ARCHIVES)' in \ - *.tar.gz*) \ - GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(AMTAR) xf - ;;\ - *.tar.bz2*) \ - bunzip2 -c $(distdir).tar.bz2 | $(AMTAR) xf - ;;\ - *.tar.Z*) \ - uncompress -c $(distdir).tar.Z | $(AMTAR) xf - ;;\ - *.shar.gz*) \ - GZIP=$(GZIP_ENV) gunzip -c $(distdir).shar.gz | unshar ;;\ - *.zip*) \ - unzip $(distdir).zip ;;\ - esac - chmod -R a-w $(distdir); chmod a+w $(distdir) - mkdir $(distdir)/_build - mkdir $(distdir)/_inst - chmod a-w $(distdir) - dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^^:\\/:\\/,/,'` \ - && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ - && cd $(distdir)/_build \ - && ../configure --srcdir=.. --prefix="$$dc_install_base" \ - $(DISTCHECK_CONFIGURE_FLAGS) \ - && $(MAKE) $(AM_MAKEFLAGS) \ - && $(MAKE) $(AM_MAKEFLAGS) dvi \ - && $(MAKE) $(AM_MAKEFLAGS) check \ - && $(MAKE) $(AM_MAKEFLAGS) install \ - && $(MAKE) $(AM_MAKEFLAGS) installcheck \ - && $(MAKE) $(AM_MAKEFLAGS) uninstall \ - && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ - distuninstallcheck \ - && chmod -R a-w "$$dc_install_base" \ - && ({ \ - (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ - distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ - } || { rm -rf "$$dc_destdir"; exit 1; }) \ - && rm -rf "$$dc_destdir" \ - && $(MAKE) $(AM_MAKEFLAGS) dist \ - && rm -rf $(DIST_ARCHIVES) \ - && $(MAKE) $(AM_MAKEFLAGS) distcleancheck - $(am__remove_distdir) - @(echo "$(distdir) archives ready for distribution: "; \ - list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ - sed -e '1{h;s/./=/g;p;x;}' -e '$${p;x;}' -distuninstallcheck: - @cd $(distuninstallcheck_dir) \ - && test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \ - || { echo "ERROR: files left after uninstall:" ; \ - if test -n "$(DESTDIR)"; then \ - echo " (check DESTDIR support)"; \ - fi ; \ - $(distuninstallcheck_listfiles) ; \ - exit 1; } >&2 -distcleancheck: distclean - @if test '$(srcdir)' = . ; then \ - echo "ERROR: distcleancheck can only run from a VPATH build" ; \ - exit 1 ; \ - fi - @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ - || { echo "ERROR: files left in build directory after distclean:" ; \ - $(distcleancheck_listfiles) ; \ - exit 1; } >&2 -check-am: all-am -check: check-recursive -all-am: Makefile $(DATA) config.h -installdirs: installdirs-recursive -installdirs-am: - for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-recursive - -rm -f $(am__CONFIG_DISTCLEAN_FILES) - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-hdr \ - distclean-libtool distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: install-data-local install-pkgconfigDATA - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -f $(am__CONFIG_DISTCLEAN_FILES) - -rm -rf $(top_srcdir)/autom4te.cache - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am uninstall-pkgconfigDATA - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am am--refresh check \ - check-am clean clean-generic clean-libtool clean-recursive \ - ctags ctags-recursive dist dist-all dist-bzip2 dist-gzip \ - dist-shar dist-tarZ dist-zip distcheck distclean \ - distclean-generic distclean-hdr distclean-libtool \ - distclean-recursive distclean-tags distcleancheck distdir \ - distuninstallcheck dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am \ - install-data-local install-exec install-exec-am install-info \ - install-info-am install-man install-pkgconfigDATA \ - install-strip installcheck installcheck-am installdirs \ - installdirs-am maintainer-clean maintainer-clean-generic \ - maintainer-clean-recursive mostlyclean mostlyclean-generic \ - mostlyclean-libtool mostlyclean-recursive pdf pdf-am ps ps-am \ - tags tags-recursive uninstall uninstall-am uninstall-info-am \ - uninstall-pkgconfigDATA - - -.PHONY: parser testcases - -@CROSS_COMPILING_FALSE@install-data-local: -@CROSS_COMPILING_FALSE@ @if ! -e "$(DESTDIR)/var/lib/linuxsampler/instruments.db" -a \ -@CROSS_COMPILING_FALSE@ $(have_sqlite) = "yes" ; then \ -@CROSS_COMPILING_FALSE@ echo "****************************************************************"; \ -@CROSS_COMPILING_FALSE@ echo "*** LinuxSampler was compiled with instruments DB support and"; \ -@CROSS_COMPILING_FALSE@ echo "*** $(DESTDIR)/var/lib/linuxsampler/instruments.db"; \ -@CROSS_COMPILING_FALSE@ echo "*** doesn't exist yet, creating it now:"; \ -@CROSS_COMPILING_FALSE@ mkdir -p $(DESTDIR)/var/lib/linuxsampler && ./src/linuxsampler \ -@CROSS_COMPILING_FALSE@ --create-instruments-db $(DESTDIR)/var/lib/linuxsampler/instruments.db ; \ -@CROSS_COMPILING_FALSE@ fi - -# generate parser with yacc -parser: - @cd $(srcdir)/src/network && make $@ - -# compile test cases for the LinuxSampler codebase -testcases: - @cd $(srcdir)/src/testcases && make linuxsamplertest - -tests: testcases - -docs: Doxyfile - @echo '*** Running doxygen ***' - doxygen Doxyfile -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/aclocal.m4
Deleted
@@ -1,7745 +0,0 @@ -# generated automatically by aclocal 1.8.5 -*- Autoconf -*- - -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004 -# Free Software Foundation, Inc. -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- - -# serial 52 Debian 1.5.26-4 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 AM_PROG_GCJ so that aclocal doesn't bring it in needlessly. -dnl If either AC_PROG_GCJ or AM_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(AM_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(AM_PROG_GCJ, - define(AM_PROG_GCJ, defn(AM_PROG_GCJ)AC_LIBTOOL_GCJ)) - ifdef(LT_AC_PROG_GCJ, - define(LT_AC_PROG_GCJ, - defn(LT_AC_PROG_GCJ)AC_LIBTOOL_GCJ)))) -))# AC_PROG_LIBTOOL - - -# _AC_PROG_LIBTOOL -# ---------------- -AC_DEFUN(_AC_PROG_LIBTOOL, -AC_REQUIRE(AC_LIBTOOL_SETUP)dnl -AC_BEFORE($0,AC_LIBTOOL_CXX)dnl -AC_BEFORE($0,AC_LIBTOOL_F77)dnl -AC_BEFORE($0,AC_LIBTOOL_GCJ)dnl - -# This can be used to rebuild libtool when needed -LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh" - -# Always use our own libtool. -LIBTOOL='$(SHELL) $(top_builddir)/libtool' -AC_SUBST(LIBTOOL)dnl - -# Prevent multiple expansion -define(AC_PROG_LIBTOOL, ) -)# _AC_PROG_LIBTOOL - - -# AC_LIBTOOL_SETUP -# ---------------- -AC_DEFUN(AC_LIBTOOL_SETUP, -AC_PREREQ(2.50)dnl -AC_REQUIRE(AC_ENABLE_SHARED)dnl -AC_REQUIRE(AC_ENABLE_STATIC)dnl -AC_REQUIRE(AC_ENABLE_FAST_INSTALL)dnl -AC_REQUIRE(AC_CANONICAL_HOST)dnl -AC_REQUIRE(AC_CANONICAL_BUILD)dnl -AC_REQUIRE(AC_PROG_CC)dnl -AC_REQUIRE(AC_PROG_LD)dnl -AC_REQUIRE(AC_PROG_LD_RELOAD_FLAG)dnl -AC_REQUIRE(AC_PROG_NM)dnl - -AC_REQUIRE(AC_PROG_LN_S)dnl -AC_REQUIRE(AC_DEPLIBS_CHECK_METHOD)dnl -# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers! -AC_REQUIRE(AC_OBJEXT)dnl -AC_REQUIRE(AC_EXEEXT)dnl -dnl -AC_LIBTOOL_SYS_MAX_CMD_LEN -AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE -AC_LIBTOOL_OBJDIR - -AC_REQUIRE(_LT_AC_SYS_COMPILER)dnl -_LT_AC_PROG_ECHO_BACKSLASH - -case $host_os in -aix3*) - # AIX sometimes has problems with the GCC collect2 program. For some - # reason, if we set the COLLECT_NAMES environment variable, the problems - # vanish in a puff of smoke. - if test "X${COLLECT_NAMES+set}" != Xset; then - COLLECT_NAMES= - export COLLECT_NAMES - fi - ;; -esac - -# Sed substitution that helps us do robust quoting. It backslashifies -# metacharacters that are still active within double-quoted strings. -Xsed='sed -e 1s/^X//' -sed_quote_subst='s/\(\\"\\`$\\\\\)/\\\1/g' - -# Same as above, but do not quote variable references. -double_quote_subst='s/\(\\"\\`\\\\\)/\\\1/g' - -# Sed substitution to delay expansion of an escaped shell variable in a -# double_quote_subst'ed string. -delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' - -# Sed substitution to avoid accidental globbing in evaled expressions -no_glob_subst='s/\*/\\\*/g' - -# Constants: -rm="rm -f" - -# Global variables: -default_ofile=libtool -can_build_shared=yes - -# All known linkers require a `.a' archive for static linking (except MSVC, -# which needs '.lib'). -libext=a -ltmain="$ac_aux_dir/ltmain.sh" -ofile="$default_ofile" -with_gnu_ld="$lt_cv_prog_gnu_ld" - -AC_CHECK_TOOL(AR, ar, false) -AC_CHECK_TOOL(RANLIB, ranlib, :) -AC_CHECK_TOOL(STRIP, strip, :) - -old_CC="$CC" -old_CFLAGS="$CFLAGS" - -# Set sane defaults for various variables -test -z "$AR" && AR=ar -test -z "$AR_FLAGS" && AR_FLAGS=cru -test -z "$AS" && AS=as -test -z "$CC" && CC=cc -test -z "$LTCC" && LTCC=$CC -test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS -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_postinstall_cmds='chmod 644 $oldlib' -old_postuninstall_cmds= - -if test -n "$RANLIB"; then - case $host_os in - openbsd*) - old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib" - ;; - *) - old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib" - ;; - 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 - -_LT_REQUIRED_DARWIN_CHECKS - -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"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# 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_REQUIRE(LT_AC_PROG_SED)dnl -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/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_REQUIRE(LT_AC_PROG_SED)dnl -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* -)# _LT_LINKER_BOILERPLATE - -# _LT_REQUIRED_DARWIN_CHECKS -# -------------------------- -# Check for some things on darwin -AC_DEFUN(_LT_REQUIRED_DARWIN_CHECKS, - case $host_os in - rhapsody* | darwin*) - AC_CHECK_TOOL(DSYMUTIL, dsymutil, :) - AC_CHECK_TOOL(NMEDIT, nmedit, :) - - AC_CACHE_CHECK(for -single_module linker flag,lt_cv_apple_cc_single_mod, - lt_cv_apple_cc_single_mod=no - if test -z "${LT_MULTI_MODULE}"; then - # By default we will add the -single_module flag. You can override - # by either setting the environment variable LT_MULTI_MODULE - # non-empty at configure time, or by adding -multi_module to the - # link flags. - echo "int foo(void){return 1;}" > conftest.c - $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ - -dynamiclib ${wl}-single_module conftest.c - if test -f libconftest.dylib; then - lt_cv_apple_cc_single_mod=yes - rm -rf libconftest.dylib* - fi - rm conftest.c - fi) - AC_CACHE_CHECK(for -exported_symbols_list linker flag, - lt_cv_ld_exported_symbols_list, - lt_cv_ld_exported_symbols_list=no - save_LDFLAGS=$LDFLAGS - echo "_main" > conftest.sym - LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" - AC_LINK_IFELSE(AC_LANG_PROGRAM(,), - lt_cv_ld_exported_symbols_list=yes, - lt_cv_ld_exported_symbols_list=no) - LDFLAGS="$save_LDFLAGS" - ) - case $host_os in - rhapsody* | darwin1.0123) - _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; - darwin1.*) - _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; - darwin*) - # if running on 10.5 or later, the deployment target defaults - # to the OS version, if on x86, and 10.4, the deployment - # target defaults to 10.4. Don't you love it? - case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in - 10.0,*86*-darwin8*|10.0,*-darwin91*) - _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; - 10.012*) - _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; - 10.*) - _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; - esac - ;; - esac - if test "$lt_cv_apple_cc_single_mod" = "yes"; then - _lt_dar_single_mod='$single_module' - fi - if test "$lt_cv_ld_exported_symbols_list" = "yes"; then - _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' - else - _lt_dar_export_syms="~$NMEDIT -s \$output_objdir/\${libname}-symbols.expsym \${lib}" - fi - if test "$DSYMUTIL" != ":"; then - _lt_dsymutil="~$DSYMUTIL \$lib || :" - else - _lt_dsymutil= - fi - ;; - esac -) - -# _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_REQUIRE(LT_AC_PROG_SED)dnl -AC_LINK_IFELSE(AC_LANG_PROGRAM, -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -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-*kfreebsd*-gnu|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-*kfreebsd*-gnu) - LD="${LD-ld} -m elf_i386_fbsd" - ;; - 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-*kfreebsd*-gnu) - LD="${LD-ld} -m elf_x86_64_fbsd" - ;; - 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 - ;; -sparc*-*solaris*) - # 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 - *64-bit*) - case $lt_cv_prog_gnu_ld in - yes*) LD="${LD-ld} -m elf64_sparc" ;; - *) - if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then - LD="${LD-ld} -64" - fi - ;; - esac - ;; - esac - fi - rm -rf conftest* - ;; - -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) - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="$3" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&AS_MESSAGE_LOG_FD - echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || 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_REQUIRE(LT_AC_PROG_SED)dnl -AC_CACHE_CHECK($1, $2, - $2=no - save_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS $3" - echo "$lt_simple_link_test_code" > conftest.$ac_ext - if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then - # The linker can only warn and ignore the option if not recognized - # So say no if there are warnings - if test -s conftest.err; then - # Append any errors to the config.log. - cat conftest.err 1>&AS_MESSAGE_LOG_FD - $echo "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if diff conftest.exp conftest.er2 >/dev/null; then - $2=yes - fi - else - $2=yes - fi - fi - $rm -r conftest* - LDFLAGS="$save_LDFLAGS" -) - -if test x"$$2" = xyes; then - ifelse($4, , :, $4) -else - ifelse($5, , :, $5) -fi -)# AC_LIBTOOL_LINKER_OPTION - - -# AC_LIBTOOL_SYS_MAX_CMD_LEN -# -------------------------- -AC_DEFUN(AC_LIBTOOL_SYS_MAX_CMD_LEN, -# find the maximum length of command line arguments -AC_MSG_CHECKING(the maximum length of command line arguments) -AC_CACHE_VAL(lt_cv_sys_max_cmd_len, dnl - i=0 - teststring="ABCD" - - case $build_os in - msdosdjgpp*) - # On DJGPP, this test can blow up pretty badly due to problems in libc - # (any single argument exceeding 2000 bytes causes a buffer overrun - # during glob expansion). Even if it were fixed, the result of this - # check would be larger than it should be. - lt_cv_sys_max_cmd_len=12288; # 12K is about right - ;; - - gnu*) - # Under GNU Hurd, this test is not required because there is - # no limit to the length of command line arguments. - # Libtool will interpret -1 as no limit whatsoever - lt_cv_sys_max_cmd_len=-1; - ;; - - cygwin* | mingw*) - # On Win9x/ME, this test blows up -- it succeeds, but takes - # about 5 minutes as the teststring grows exponentially. - # Worse, since 9x/ME are not pre-emptively multitasking, - # you end up with a "frozen" computer, even though with patience - # the test eventually succeeds (with a max line length of 256k). - # Instead, let's just punt: use the minimum linelength reported by - # all of the supported platforms: 8192 (on NT/2K/XP). - lt_cv_sys_max_cmd_len=8192; - ;; - - amigaos*) - # On AmigaOS with pdksh, this test takes hours, literally. - # So we just punt and use a minimum line length of 8192. - lt_cv_sys_max_cmd_len=8192; - ;; - - netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) - # This has been around since 386BSD, at least. Likely further. - if test -x /sbin/sysctl; then - lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` - elif test -x /usr/sbin/sysctl; then - lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` - else - lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs - fi - # And add a safety zone - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` - ;; - - interix*) - # We know the value 262144 and hardcode it with a safety zone (like BSD) - lt_cv_sys_max_cmd_len=196608 - ;; - - 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 - ;; - sco3.2v5*) - lt_cv_sys_max_cmd_len=102400 - ;; - sysv5* | sco5v6* | sysv4.2uw2*) - kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` - if test -n "$kargmax"; then - lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.* //'` - else - lt_cv_sys_max_cmd_len=32768 - fi - ;; - *) - lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` - if test -n "$lt_cv_sys_max_cmd_len"; then - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` - else - 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` - fi - ;; - 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); */ - } - else - puts (dlerror ()); - - exit (status); -} -EOF - if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then - (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null - lt_status=$? - case x$lt_status in - x$lt_dlno_uscore) $1 ;; - x$lt_dlneed_uscore) $2 ;; - x$lt_dlunknown|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="-ldld", - 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="-ldld") - ) - ) - ) - ) - ) - ;; - 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" - wl=$lt_prog_compiler_wl 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 - wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" - AC_CACHE_CHECK(whether a statically linked program can dlopen itself, - lt_cv_dlopen_self_static, dnl - _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_PROG_SED)dnl -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 - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - lt_compiler_flag="-o out/conftest2.$ac_objext" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) - (eval "$lt_compile" 2>out/conftest.err) - ac_status=$? - cat out/conftest.err >&AS_MESSAGE_LOG_FD - echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD - if (exit $ac_status) && test -s out/conftest2.$ac_objext - then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp - $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 - if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then - _LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes - fi - fi - chmod u+w . 2>&AS_MESSAGE_LOG_FD - $rm conftest* - # SGI C++ compiler will create directory out/ii_files/ for - # template instantiation - test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files - $rm out/* && rmdir out - cd .. - rmdir conftest - $rm conftest* -) -)# AC_LIBTOOL_PROG_CC_C_O - - -# AC_LIBTOOL_SYS_HARD_LINK_LOCKS(TAGNAME) -# ----------------------------------------- -# Check to see if we can do hard links to lock some files if needed -AC_DEFUN(AC_LIBTOOL_SYS_HARD_LINK_LOCKS, -AC_REQUIRE(_LT_AC_LOCK)dnl - -hard_links="nottested" -if test "$_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then - # do not overwrite the value of need_locks provided by the user - AC_MSG_CHECKING(if we can lock with hard links) - hard_links=yes - $rm conftest* - ln conftest.a conftest.b 2>/dev/null && hard_links=no - touch conftest.a - ln conftest.a conftest.b 2>&5 || hard_links=no - ln conftest.a conftest.b 2>/dev/null && hard_links=no - AC_MSG_RESULT($hard_links) - if test "$hard_links" = no; then - AC_MSG_WARN(`$CC' does not support `-c -o', so `make -j' may be unsafe) - need_locks=warn - fi -else - need_locks=no -fi -)# AC_LIBTOOL_SYS_HARD_LINK_LOCKS - - -# AC_LIBTOOL_OBJDIR -# ----------------- -AC_DEFUN(AC_LIBTOOL_OBJDIR, -AC_CACHE_CHECK(for objdir, lt_cv_objdir, -rm -f .libs 2>/dev/null -mkdir .libs 2>/dev/null -if test -d .libs; then - lt_cv_objdir=.libs -else - # MS-DOS does not allow filenames that begin with a dot. - lt_cv_objdir=_libs -fi -rmdir .libs 2>/dev/null) -objdir=$lt_cv_objdir -)# AC_LIBTOOL_OBJDIR - - -# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH(TAGNAME) -# ---------------------------------------------- -# Check hardcoding attributes. -AC_DEFUN(AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH, -AC_MSG_CHECKING(how to hardcode library paths into programs) -_LT_AC_TAGVAR(hardcode_action, $1)= -if test -n "$_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)" || \ - test -n "$_LT_AC_TAGVAR(runpath_var, $1)" || \ - test "X$_LT_AC_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then - - # We can hardcode non-existant directories. - if test "$_LT_AC_TAGVAR(hardcode_direct, $1)" != no && - # If the only mechanism to avoid hardcoding is shlibpath_var, we - # have to relink, otherwise we might link with an installed library - # when we should be linking with a yet-to-be-installed one - ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)" != no && - test "$_LT_AC_TAGVAR(hardcode_minus_L, $1)" != no; then - # Linking always hardcodes the temporary library directory. - _LT_AC_TAGVAR(hardcode_action, $1)=relink - else - # We can link without hardcoding, and we can hardcode nonexisting dirs. - _LT_AC_TAGVAR(hardcode_action, $1)=immediate - fi -else - # We cannot hardcode anything, or else we can only hardcode existing - # directories. - _LT_AC_TAGVAR(hardcode_action, $1)=unsupported -fi -AC_MSG_RESULT($_LT_AC_TAGVAR(hardcode_action, $1)) - -if test "$_LT_AC_TAGVAR(hardcode_action, $1)" = relink; then - # Fast installation is not supported - enable_fast_install=no -elif test "$shlibpath_overrides_runpath" = yes || - test "$enable_shared" = no; then - # Fast installation is not necessary - enable_fast_install=needless -fi -)# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH - - -# AC_LIBTOOL_SYS_LIB_STRIP -# ------------------------ -AC_DEFUN(AC_LIBTOOL_SYS_LIB_STRIP, -striplib= -old_striplib= -AC_MSG_CHECKING(whether stripping libraries is possible) -if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then - test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" - test -z "$striplib" && striplib="$STRIP --strip-unneeded" - AC_MSG_RESULT(yes) -else -# FIXME - insert some real tests, host_os isn't really good enough - case $host_os in - darwin*) - if test -n "$STRIP" ; then - striplib="$STRIP -x" - old_striplib="$STRIP -S" - 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_REQUIRE(LT_AC_PROG_SED)dnl -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" -m4_if($1,, -if test "$GCC" = yes; then - case $host_os in - darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; - *) lt_awk_arg="/^libraries:/" ;; - esac - lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$lt_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. - lt_search_path_spec=`echo "$lt_search_path_spec" | $SED -e 's/;/ /g'` - else - lt_search_path_spec=`echo "$lt_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - # Ok, now we have the path, separated by spaces, we can step through it - # and add multilib dir if necessary. - lt_tmp_lt_search_path_spec= - lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` - for lt_sys_path in $lt_search_path_spec; do - if test -d "$lt_sys_path/$lt_multi_os_dir"; then - lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" - else - test -d "$lt_sys_path" && \ - lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" - fi - done - lt_search_path_spec=`echo $lt_tmp_lt_search_path_spec | awk ' -BEGIN {RS=" "; FS="/|\n";} { - lt_foo=""; - lt_count=0; - for (lt_i = NF; lt_i > 0; lt_i--) { - if ($lt_i != "" && $lt_i != ".") { - if ($lt_i == "..") { - lt_count++; - } else { - if (lt_count == 0) { - lt_foo="/" $lt_i lt_foo; - } else { - lt_count--; - } - } - } - } - if (lt_foo != "") { lt_freqlt_foo++; } - if (lt_freqlt_foo == 1) { print lt_foo; } -}'` - sys_lib_search_path_spec=`echo $lt_search_path_spec` -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-9*) - 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 - ;; - -bsdi45*) - version_type=linux - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' - shlibpath_var=LD_LIBRARY_PATH - sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" - sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" - # the default ld.so.conf also contains /usr/contrib/lib and - # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow - # libtool to hard-code these into programs - ;; - -cygwin* | mingw* | pw32*) - version_type=windows - shrext_cmds=".dll" - need_version=no - need_lib_prefix=no - - case $GCC,$host_os in - yes,cygwin* | yes,mingw* | yes,pw32*) - library_names_spec='$libname.dll.a' - # DLL is installed to $(libdir)/../bin by postinstall_cmds - postinstall_cmds='base_file=`basename \${file}`~ - dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ - dldir=$destdir/`dirname \$dlpath`~ - test -d \$dldir || mkdir -p \$dldir~ - $install_prog $dir/$dlname \$dldir/$dlname~ - chmod a+x \$dldir/$dlname' - postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ - dlpath=$dir/\$dldll~ - $rm \$dlpath' - shlibpath_overrides_runpath=yes - - case $host_os in - cygwin*) - # Cygwin DLLs use 'cyg' prefix rather than 'lib' - soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" - ;; - mingw*) - # MinGW DLLs use traditional 'lib' prefix - soname_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$sys_lib_search_path_spec" | grep ';c-zC-Z:/' >/dev/null; then - # It is most probably a Windows format PATH printed by - # mingw gcc, but we are running on Cygwin. Gcc prints its search - # path with ; separators, and with drive letters. We can handle the - # drive letters (cygwin fileutils understands them), so leave them, - # especially as we might pass files found there to a mingw objdump, - # which wouldn't understand a cygwinified path. Ahh. - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` - else - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - ;; - pw32*) - # pw32 DLLs use 'pw' prefix rather than 'lib' - library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - ;; - esac - ;; - - *) - library_names_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext} $libname.lib' - ;; - esac - dynamic_linker='Win32 ld.exe' - # FIXME: first we should search . and the directory the executable is in - shlibpath_var=PATH - ;; - -darwin* | rhapsody*) - dynamic_linker="$host_os dyld" - version_type=darwin - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' - soname_spec='${libname}${release}${major}$shared_ext' - shlibpath_overrides_runpath=yes - shlibpath_var=DYLD_LIBRARY_PATH - shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' - m4_if($1, , - sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib") - 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 - ;; - -freebsd* | dragonfly*) - # DragonFly does not have aout. When/if they implement a new - # versioning mechanism, adjust this. - if test -x /usr/bin/objformat; then - objformat=`/usr/bin/objformat` - else - case $host_os in - freebsd123*) objformat=aout ;; - *) objformat=elf ;; - esac - fi - version_type=freebsd-$objformat - case $version_type in - freebsd-elf*) - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - need_version=no - need_lib_prefix=no - ;; - freebsd-*) - library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' - need_version=yes - ;; - esac - shlibpath_var=LD_LIBRARY_PATH - case $host_os in - freebsd2*) - shlibpath_overrides_runpath=yes - ;; - freebsd3.01* | freebsdelf3.01*) - shlibpath_overrides_runpath=yes - hardcode_into_libs=yes - ;; - freebsd3.2-9* | freebsdelf3.2-9* | \ - freebsd4.0-5 | freebsdelf4.0-5 | freebsd4.1.1 | freebsdelf4.1.1) - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - *) # from 4.6 on, and DragonFly - shlibpath_overrides_runpath=yes - 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' - ;; - -interix3-9*) - 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' - dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - -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* | k*bsd*-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' - 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>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^ *hwcap /d;s/:, / /g;s/=^=*$//;s/=^= * / /g;/^$/d' | tr '\n' ' '` - sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" - fi - - # We used to test for /lib/ld.so.1 and disable shared libraries on - # powerpc, because MkLinux only supported shared libraries with the - # GNU dynamic linker. Since this was broken with cross compilers, - # most powerpc-linux boxes support dynamic linking these days and - # people can always --disable-shared, the test was removed, and we - # assume the GNU/Linux dynamic linker is in use. - dynamic_linker='GNU/Linux ld.so' - ;; - -netbsdelf*-gnu) - version_type=linux - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - dynamic_linker='NetBSD ld.elf_so' - ;; - -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 - sys_lib_dlsearch_path_spec="/usr/lib" - need_lib_prefix=no - # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. - case $host_os in - openbsd3.3 | openbsd3.3.*) need_version=yes ;; - *) need_version=no ;; - esac - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' - finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' - shlibpath_var=LD_LIBRARY_PATH - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - case $host_os in - openbsd2.89 | openbsd2.89.*) - shlibpath_overrides_runpath=no - ;; - *) - shlibpath_overrides_runpath=yes - ;; - esac - 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" - ;; - -rdos*) - dynamic_linker=no - ;; - -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.3*) - 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 - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - version_type=freebsd-elf - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - hardcode_into_libs=yes - if test "$with_gnu_ld" = yes; then - sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' - shlibpath_overrides_runpath=no - else - sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' - shlibpath_overrides_runpath=yes - case $host_os in - sco3.2v5*) - sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" - ;; - esac - fi - sys_lib_dlsearch_path_spec='/usr/lib' - ;; - -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_CACHE_VAL(lt_cv_sys_lib_search_path_spec, -lt_cv_sys_lib_search_path_spec="$sys_lib_search_path_spec") -sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" -AC_CACHE_VAL(lt_cv_sys_lib_dlsearch_path_spec, -lt_cv_sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec") -sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" - -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 -)# AC_LIBTOOL_SYS_DYNAMIC_LINKER - - -# _LT_AC_TAGCONFIG -# ---------------- -AC_DEFUN(_LT_AC_TAGCONFIG, -AC_REQUIRE(LT_AC_PROG_SED)dnl -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 - if test -z "$LTCFLAGS"; then - eval "`$SHELL ${ofile} --config | grep '^LTCFLAGS='`" - fi - - # Extract list of available tagged configurations in $ofile. - # Note that this assumes the entire list is on one line. - available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'` - - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for tagname in $tagnames; do - IFS="$lt_save_ifs" - # Check whether tagname contains only valid characters - case `$echo "X$tagname" | $Xsed -e 's:-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/::g'` in - "") ;; - *) AC_MSG_ERROR(invalid tag name: $tagname) - ;; - esac - - if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null - then - AC_MSG_ERROR(tag name \"$tagname\" already exists) - fi - - # Update the list of available tags. - if test -n "$tagname"; then - echo appending configuration tag \"$tagname\" to $ofile - - case $tagname in - CXX) - if test -n "$CXX" && ( test "X$CXX" != "Xno" && - ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || - (test "X$CXX" != "Xg++"))) ; then - AC_LIBTOOL_LANG_CXX_CONFIG - else - tagname="" - fi - ;; - - F77) - if test -n "$F77" && test "X$F77" != "Xno"; then - AC_LIBTOOL_LANG_F77_CONFIG - else - tagname="" - fi - ;; - - GCJ) - if test -n "$GCJ" && test "X$GCJ" != "Xno"; then - AC_LIBTOOL_LANG_GCJ_CONFIG - else - tagname="" - fi - ;; - - RC) - AC_LIBTOOL_LANG_RC_CONFIG - ;; - - *) - AC_MSG_ERROR(Unsupported tag name: $tagname) - ;; - esac - - # Append the new tag name to the list of available tags. - if test -n "$tagname" ; then - available_tags="$available_tags $tagname" - fi - fi - done - IFS="$lt_save_ifs" - - # Now substitute the updated list of available tags. - if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then - mv "${ofile}T" "$ofile" - chmod +x "$ofile" - else - rm -f "${ofile}T" - AC_MSG_ERROR(unable to update list of available tagged configurations.) - fi -fi -)# _LT_AC_TAGCONFIG - - -# AC_LIBTOOL_DLOPEN -# ----------------- -# enable checks for dlopen support -AC_DEFUN(AC_LIBTOOL_DLOPEN, - AC_BEFORE($0,AC_LIBTOOL_SETUP) -)# AC_LIBTOOL_DLOPEN - - -# AC_LIBTOOL_WIN32_DLL -# -------------------- -# declare package support for building win32 DLLs -AC_DEFUN(AC_LIBTOOL_WIN32_DLL, -AC_BEFORE($0, AC_LIBTOOL_SETUP) -)# AC_LIBTOOL_WIN32_DLL - - -# AC_ENABLE_SHARED(DEFAULT) -# --------------------------- -# implement the --enable-shared flag -# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. -AC_DEFUN(AC_ENABLE_SHARED, -define(AC_ENABLE_SHARED_DEFAULT, ifelse($1, no, no, yes))dnl -AC_ARG_ENABLE(shared, - AC_HELP_STRING(--enable-shared@<:@=PKGS@:>@, - build shared libraries @<:@default=AC_ENABLE_SHARED_DEFAULT@:>@), - p=${PACKAGE-default} - case $enableval in - yes) enable_shared=yes ;; - no) enable_shared=no ;; - *) - enable_shared=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_shared=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac, - enable_shared=AC_ENABLE_SHARED_DEFAULT) -)# AC_ENABLE_SHARED - - -# AC_DISABLE_SHARED -# ----------------- -# set the default shared flag to --disable-shared -AC_DEFUN(AC_DISABLE_SHARED, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl -AC_ENABLE_SHARED(no) -)# AC_DISABLE_SHARED - - -# AC_ENABLE_STATIC(DEFAULT) -# --------------------------- -# implement the --enable-static flag -# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. -AC_DEFUN(AC_ENABLE_STATIC, -define(AC_ENABLE_STATIC_DEFAULT, ifelse($1, no, no, yes))dnl -AC_ARG_ENABLE(static, - AC_HELP_STRING(--enable-static@<:@=PKGS@:>@, - build static libraries @<:@default=AC_ENABLE_STATIC_DEFAULT@:>@), - p=${PACKAGE-default} - case $enableval in - yes) enable_static=yes ;; - no) enable_static=no ;; - *) - enable_static=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_static=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac, - enable_static=AC_ENABLE_STATIC_DEFAULT) -)# AC_ENABLE_STATIC - - -# AC_DISABLE_STATIC -# ----------------- -# set the default static flag to --disable-static -AC_DEFUN(AC_DISABLE_STATIC, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl -AC_ENABLE_STATIC(no) -)# AC_DISABLE_STATIC - - -# AC_ENABLE_FAST_INSTALL(DEFAULT) -# --------------------------------- -# implement the --enable-fast-install flag -# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. -AC_DEFUN(AC_ENABLE_FAST_INSTALL, -define(AC_ENABLE_FAST_INSTALL_DEFAULT, ifelse($1, no, no, yes))dnl -AC_ARG_ENABLE(fast-install, - AC_HELP_STRING(--enable-fast-install@<:@=PKGS@:>@, - optimize for fast installation @<:@default=AC_ENABLE_FAST_INSTALL_DEFAULT@:>@), - p=${PACKAGE-default} - case $enableval in - yes) enable_fast_install=yes ;; - no) enable_fast_install=no ;; - *) - enable_fast_install=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_fast_install=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac, - enable_fast_install=AC_ENABLE_FAST_INSTALL_DEFAULT) -)# AC_ENABLE_FAST_INSTALL - - -# AC_DISABLE_FAST_INSTALL -# ----------------------- -# set the default to --disable-fast-install -AC_DEFUN(AC_DISABLE_FAST_INSTALL, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl -AC_ENABLE_FAST_INSTALL(no) -)# AC_DISABLE_FAST_INSTALL - - -# AC_LIBTOOL_PICMODE(MODE) -# -------------------------- -# implement the --with-pic flag -# MODE is either `yes' or `no'. If omitted, it defaults to `both'. -AC_DEFUN(AC_LIBTOOL_PICMODE, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl -pic_mode=ifelse($#,1,$1,default) -)# AC_LIBTOOL_PICMODE - - -# AC_PROG_EGREP -# ------------- -# This is predefined starting with Autoconf 2.54, so this conditional -# definition can be removed once we require Autoconf 2.54 or later. -m4_ifndef(AC_PROG_EGREP, AC_DEFUN(AC_PROG_EGREP, -AC_CACHE_CHECK(for egrep, ac_cv_prog_egrep, - if echo a | (grep -E '(a|b)') >/dev/null 2>&1 - then ac_cv_prog_egrep='grep -E' - else ac_cv_prog_egrep='egrep' - fi) - EGREP=$ac_cv_prog_egrep - AC_SUBST(EGREP) -)) - - -# AC_PATH_TOOL_PREFIX -# ------------------- -# find a file program which can recognize 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@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 recognize a shared library -AC_DEFUN(AC_PATH_MAGIC, -AC_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) -if test -z "$lt_cv_path_MAGIC_CMD"; then - if test -n "$ac_tool_prefix"; then - AC_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) - else - MAGIC_CMD=: - fi -fi -)# AC_PATH_MAGIC - - -# AC_PROG_LD -# ---------- -# find the pathname to the GNU or non-GNU linker -AC_DEFUN(AC_PROG_LD, -AC_ARG_WITH(gnu-ld, - AC_HELP_STRING(--with-gnu-ld, - assume the C compiler uses GNU ld @<:@default=no@:>@), - test "$withval" = no || with_gnu_ld=yes, - with_gnu_ld=no) -AC_REQUIRE(LT_AC_PROG_SED)dnl -AC_REQUIRE(AC_PROG_CC)dnl -AC_REQUIRE(AC_CANONICAL_HOST)dnl -AC_REQUIRE(AC_CANONICAL_BUILD)dnl -ac_prog=ld -if test "$GCC" = yes; then - # Check if gcc -print-prog-name=ld gives a path. - AC_MSG_CHECKING(for ld used by $CC) - case $host in - *-*-mingw*) - # gcc leaves a trailing carriage return which upsets mingw - ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; - *) - ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; - esac - case $ac_prog in - # Accept absolute paths. - \\/* | ?:\\/*) - re_direlt='/^/^/*/\.\./' - # Canonicalize the pathname of ld - ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` - while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do - ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` - done - test -z "$LD" && LD="$ac_prog" - ;; - "") - # If it fails, then pretend we aren't using GCC. - ac_prog=ld - ;; - *) - # If it is relative, then search for the first ld in PATH. - with_gnu_ld=unknown - ;; - esac -elif test "$with_gnu_ld" = yes; then - AC_MSG_CHECKING(for GNU ld) -else - AC_MSG_CHECKING(for non-GNU ld) -fi -AC_CACHE_VAL(lt_cv_path_LD, -if test -z "$LD"; then - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - for ac_dir in $PATH; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then - lt_cv_path_LD="$ac_dir/$ac_prog" - # Check to see if the program is GNU ld. I'd rather use --version, - # but apparently some variants of GNU ld only accept -v. - # Break only if it was the GNU/non-GNU ld that we prefer. - case `"$lt_cv_path_LD" -v 2>&1 </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 lds 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='$LTCC $LTCFLAGS -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 recognize 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-9*) - lt_cv_deplibs_check_method=pass_all - ;; - -beos*) - lt_cv_deplibs_check_method=pass_all - ;; - -bsdi45*) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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', - # unless we find 'file', for example because we are cross-compiling. - if ( file / ) >/dev/null 2>&1; then - lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' - lt_cv_file_magic_cmd='func_win32_libid' - else - lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' - lt_cv_file_magic_cmd='$OBJDUMP -f' - fi - ;; - -darwin* | rhapsody*) - lt_cv_deplibs_check_method=pass_all - ;; - -freebsd* | 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)/i3-986 (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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|PA-RISC0-9.0-9) shared library' - lt_cv_file_magic_test_file=/usr/lib/libc.sl - ;; - esac - ;; - -interix3-9*) - # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so|\.a)$' - ;; - -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* | k*bsd*-gnu) - lt_cv_deplibs_check_method=pass_all - ;; - -netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so\.0-9+\.0-9+|_pic\.a)$' - else - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so|_pic\.a)$' - fi - ;; - -newos6*) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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 - ;; - -rdos*) - lt_cv_deplibs_check_method=pass_all - ;; - -solaris*) - lt_cv_deplibs_check_method=pass_all - ;; - -sysv4 | sysv4.3*) - case $host_vendor in - motorola) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (shared object|dynamic lib) M0-90-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-90-9*-bit LMSB (shared object|dynamic lib )' - ;; - sni) - lt_cv_file_magic_cmd='/bin/file' - lt_cv_deplibs_check_method="file_magic ELF 0-90-9*-bit LMSB dynamic lib" - lt_cv_file_magic_test_file=/lib/libc.so - ;; - siemens) - lt_cv_deplibs_check_method=pass_all - ;; - pc) - lt_cv_deplibs_check_method=pass_all - ;; - esac - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | 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_nm_to_check="${ac_tool_prefix}nm" - if test -n "$ac_tool_prefix" && test "$build" = "$host"; then - lt_nm_to_check="$lt_nm_to_check nm" - fi - for lt_tmp_nm in $lt_nm_to_check; do - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - tmp_nm="$ac_dir/$lt_tmp_nm" - if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then - # 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" - done - test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm -fi) -NM="$lt_cv_path_NM" -)# AC_PROG_NM - - -# AC_CHECK_LIBM -# ------------- -# check for math library -AC_DEFUN(AC_CHECK_LIBM, -AC_REQUIRE(AC_CANONICAL_HOST)dnl -LIBM= -case $host in -*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*) - # These system don't have libm, or don't need it - ;; -*-ncr-sysv4.3*) - AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw") - AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") - ;; -*) - AC_CHECK_LIB(m, cos, LIBM="-lm") - ;; -esac -)# AC_CHECK_LIBM - - -# AC_LIBLTDL_CONVENIENCE(DIRECTORY) -# ----------------------------------- -# sets LIBLTDL to the link flags for the libltdl convenience library and -# LTDLINCL to the include flags for the libltdl header and adds -# --enable-ltdl-convenience to the configure arguments. Note that -# AC_CONFIG_SUBDIRS is not called here. If DIRECTORY is not provided, -# it is assumed to be `libltdl'. LIBLTDL will be prefixed with -# '${top_builddir}/' and LTDLINCL will be prefixed with '${top_srcdir}/' -# (note the single quotes!). If your package is not flat and you're not -# using automake, define top_builddir and top_srcdir appropriately in -# the Makefiles. -AC_DEFUN(AC_LIBLTDL_CONVENIENCE, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl - case $enable_ltdl_convenience in - no) AC_MSG_ERROR(this package needs a convenience libltdl) ;; - "") enable_ltdl_convenience=yes - ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;; - esac - LIBLTDL='${top_builddir}/'ifelse($#,1,$1,'libltdl')/libltdlc.la - LTDLINCL='-I${top_srcdir}/'ifelse($#,1,$1,'libltdl') - # For backwards non-gettext consistent compatibility... - INCLTDL="$LTDLINCL" -)# AC_LIBLTDL_CONVENIENCE - - -# AC_LIBLTDL_INSTALLABLE(DIRECTORY) -# ----------------------------------- -# sets LIBLTDL to the link flags for the libltdl installable library and -# LTDLINCL to the include flags for the libltdl header and adds -# --enable-ltdl-install to the configure arguments. Note that -# AC_CONFIG_SUBDIRS is not called here. If DIRECTORY is not provided, -# and an installed libltdl is not found, it is assumed to be `libltdl'. -# LIBLTDL will be prefixed with '${top_builddir}/'# and LTDLINCL with -# '${top_srcdir}/' (note the single quotes!). If your package is not -# flat and you're not using automake, define top_builddir and top_srcdir -# appropriately in the Makefiles. -# In the future, this macro may have to be called after AC_PROG_LIBTOOL. -AC_DEFUN(AC_LIBLTDL_INSTALLABLE, -AC_BEFORE($0,AC_LIBTOOL_SETUP)dnl - AC_CHECK_LIB(ltdl, lt_dlinit, - test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no, - if test x"$enable_ltdl_install" = xno; then - AC_MSG_WARN(libltdl not installed, but installation disabled) - else - enable_ltdl_install=yes - fi - ) - if test x"$enable_ltdl_install" = x"yes"; then - ac_configure_args="$ac_configure_args --enable-ltdl-install" - LIBLTDL='${top_builddir}/'ifelse($#,1,$1,'libltdl')/libltdl.la - LTDLINCL='-I${top_srcdir}/'ifelse($#,1,$1,'libltdl') - else - ac_configure_args="$ac_configure_args --enable-ltdl-install=no" - LIBLTDL="-lltdl" - LTDLINCL= - fi - # For backwards non-gettext consistent compatibility... - INCLTDL="$LTDLINCL" -)# AC_LIBLTDL_INSTALLABLE - - -# AC_LIBTOOL_CXX -# -------------- -# enable support for C++ libraries -AC_DEFUN(AC_LIBTOOL_CXX, -AC_REQUIRE(_LT_AC_LANG_CXX) -)# AC_LIBTOOL_CXX - - -# _LT_AC_LANG_CXX -# --------------- -AC_DEFUN(_LT_AC_LANG_CXX, -AC_REQUIRE(AC_PROG_CXX) -AC_REQUIRE(_LT_AC_PROG_CXXCPP) -_LT_AC_SHELL_INIT(tagnames=${tagnames+${tagnames},}CXX) -)# _LT_AC_LANG_CXX - -# _LT_AC_PROG_CXXCPP -# ------------------ -AC_DEFUN(_LT_AC_PROG_CXXCPP, - -AC_REQUIRE(AC_PROG_CXX) -if test -n "$CXX" && ( test "X$CXX" != "Xno" && - ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || - (test "X$CXX" != "Xg++"))) ; then - AC_PROG_CXXCPP -fi -)# _LT_AC_PROG_CXXCPP - -# AC_LIBTOOL_F77 -# -------------- -# enable support for Fortran 77 libraries -AC_DEFUN(AC_LIBTOOL_F77, -AC_REQUIRE(_LT_AC_LANG_F77) -)# AC_LIBTOOL_F77 - - -# _LT_AC_LANG_F77 -# --------------- -AC_DEFUN(_LT_AC_LANG_F77, -AC_REQUIRE(AC_PROG_F77) -_LT_AC_SHELL_INIT(tagnames=${tagnames+${tagnames},}F77) -)# _LT_AC_LANG_F77 - - -# AC_LIBTOOL_GCJ -# -------------- -# enable support for GCJ libraries -AC_DEFUN(AC_LIBTOOL_GCJ, -AC_REQUIRE(_LT_AC_LANG_GCJ) -)# AC_LIBTOOL_GCJ - - -# _LT_AC_LANG_GCJ -# --------------- -AC_DEFUN(_LT_AC_LANG_GCJ, -AC_PROVIDE_IFELSE(AC_PROG_GCJ,, - AC_PROVIDE_IFELSE(AM_PROG_GCJ,, - AC_PROVIDE_IFELSE(LT_AC_PROG_GCJ,, - ifdef(AC_PROG_GCJ,AC_REQUIRE(AC_PROG_GCJ), - ifdef(AM_PROG_GCJ,AC_REQUIRE(AM_PROG_GCJ), - AC_REQUIRE(AC_PROG_GCJ_OR_AM_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;" - -# Code to be used in simple link tests -lt_simple_link_test_code='int main(){return(0);}' - -_LT_AC_SYS_COMPILER - -# save warnings/boilerplate of simple test code -_LT_COMPILER_BOILERPLATE -_LT_LINKER_BOILERPLATE - -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 - -# Report which library types will actually be built -AC_MSG_CHECKING(if libtool supports shared libraries) -AC_MSG_RESULT($can_build_shared) - -AC_MSG_CHECKING(whether to build shared libraries) -test "$can_build_shared" = "no" && enable_shared=no - -# 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-9*) - 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_shlibpath_var, $1)=unsupported -_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)= -_LT_AC_TAGVAR(compiler_lib_search_dirs, $1)= - -# Source file extension for C++ test sources. -ac_ext=cpp - -# Object file extension for compiled C++ test sources. -objext=o -_LT_AC_TAGVAR(objext, $1)=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code="int some_variable = 0;" - -# Code to be used in simple link tests -lt_simple_link_test_code='int main(int, char *) { return(0); }' - -# 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 - $as_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 - $as_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-9*) - 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-9*) - 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 - : - 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 '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${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 '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - _LT_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' - # Exported symbols can be pulled into shared objects from archives - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='$convenience' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes - # This is similar to how AIX traditionally builds its shared libraries. - _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' - fi - fi - ;; - - beos*) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported - # Joseph Beckenbach <jrb3@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 - ;; - - 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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - _LT_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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - fi - ;; - darwin* | rhapsody*) - _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 - _LT_AC_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined" - if test "$GXX" = 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_dar_single_mod${_lt_dsymutil}" - _LT_AC_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - _LT_AC_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - _LT_AC_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - if test "$lt_cv_apple_cc_single_mod" != "yes"; then - _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${_lt_dsymutil}" - _LT_AC_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" - fi - else - 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` $xlcverstring' - _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~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 - ;; - freebsd12*) - # 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* | 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 - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: - - case $host_cpu in - hppa*64*|ia64*) ;; - *) - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' - ;; - esac - fi - case $host_cpu in - hppa*64*|ia64*) - _LT_AC_TAGVAR(hardcode_direct, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - ;; - *) - _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*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - ia64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - *) - _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 - hppa*64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - ia64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - *) - _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 - ;; - interix3-9*) - _LT_AC_TAGVAR(hardcode_direct, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - irix5* | irix6*) - case $cc_basename in - CC*) - # SGI C++ - _LT_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* | k*bsd*-gnu) - 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* | pgcpp*) - # Portland Group C++ compiler - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' - - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - ;; - cxx*) - # Compaq C++ - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' - - runpath_var=LD_RUN_PATH - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - _LT_AC_TAGVAR(no_undefined_flag, $1)=' -zdefs' - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - - # Not sure whether something based on - # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 - # would be better. - output_verbose_link_cmd='echo' - - # Archives containing C++ object files must be created using - # "CC -xar", where "CC" is the Sun C++ compiler. This is - # necessary to make sure instantiated templates are included - # in the archive. - _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' - ;; - esac - ;; - esac - ;; - lynxos*) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - m88k*) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - mvs*) - case $cc_basename in - cxx*) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - *) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - esac - ;; - netbsd* | netbsdelf*-gnu) - 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*) - if test -f /usr/libexec/ld.so; then - _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' - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - fi - ;; - 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 - ;; - sunos4*) - case $cc_basename in - CC*) - # Sun C++ 4.x - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - lcc*) - # Lucid - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - *) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - esac - ;; - solaris*) - case $cc_basename in - CC*) - # Sun C++ 4.2, 5.x and Centerline C++ - _LT_AC_TAGVAR(archive_cmds_need_lc,$1)=yes - _LT_AC_TAGVAR(no_undefined_flag, $1)=' -zdefs' - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - # The compiler driver will combine and reorder linker options, - # but understands `-z linker_flag'. - # Supported since Solaris 2.6 (maybe 2.5.1?) - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' - ;; - esac - _LT_AC_TAGVAR(link_all_deplibs, $1)=yes - - output_verbose_link_cmd='echo' - - # Archives containing C++ object files must be created using - # "CC -xar", where "CC" is the Sun C++ compiler. This is - # necessary to make sure instantiated templates are included - # in the archive. - _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' - ;; - gcx*) - # Green Hills C++ Compiler - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - - # The C++ compiler must be used to create the archive. - _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' - ;; - *) - # GNU C++ compiler with Solaris linker - if test "$GXX" = yes && test "$with_gnu_ld" = no; then - _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs' - if $CC --version | grep -v '^2\.7' > /dev/null; then - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" - else - # g++ 2.7 appears to require `-G' NOT `-shared' on this - # platform. - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" - fi - - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir' - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - ;; - esac - fi - ;; - esac - ;; - sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - runpath_var='LD_RUN_PATH' - - case $cc_basename in - CC*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - ;; - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - # For security reasons, it is highly recommended that you always - # use absolute paths for naming shared libraries, and exclude the - # DT_RUNPATH tag from executables and libraries. But doing so - # requires that you compile everything twice, which is a pain. - # So that behaviour is only enabled if SCOABSPATH is set to a - # non-empty value in the environment. Most likely only useful for - # creating official distributions of packages. - # This is a hack until libtool officially supports absolute path - # names for shared libraries. - _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' - _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' - _LT_AC_TAGVAR(link_all_deplibs, $1)=yes - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - case $cc_basename in - CC*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - ;; - tandem*) - case $cc_basename in - NCC*) - # NonStop-UX NCC 3.20 - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - *) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - esac - ;; - vxworks*) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; - *) - # FIXME: insert proper C++ library support - _LT_AC_TAGVAR(ld_shlibs, $1)=no - ;; -esac -AC_MSG_RESULT($_LT_AC_TAGVAR(ld_shlibs, $1)) -test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no - -_LT_AC_TAGVAR(GCC, $1)="$GXX" -_LT_AC_TAGVAR(LD, $1)="$LD" - -AC_LIBTOOL_POSTDEP_PREDEP($1) -AC_LIBTOOL_PROG_COMPILER_PIC($1) -AC_LIBTOOL_PROG_CC_C_O($1) -AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1) -AC_LIBTOOL_PROG_LD_SHLIBS($1) -AC_LIBTOOL_SYS_DYNAMIC_LINKER($1) -AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1) - -AC_LIBTOOL_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, -AC_REQUIRE(LT_AC_PROG_SED)dnl -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 - -_LT_AC_TAGVAR(compiler_lib_search_dirs, $1)= -if test -n "$_LT_AC_TAGVAR(compiler_lib_search_path, $1)"; then - _LT_AC_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_AC_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` -fi - -# PORTME: override above test on systems where it is broken -ifelse($1,CXX, -case $host_os in -interix3-9*) - # Interix 3.5 installs completely hosed .la files for C++, so rather than - # hack all around it, let's just trust "g++" to DTRT. - _LT_AC_TAGVAR(predep_objects,$1)= - _LT_AC_TAGVAR(postdep_objects,$1)= - _LT_AC_TAGVAR(postdeps,$1)= - ;; - -linux*) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - # - # The more standards-conforming stlport4 library is - # incompatible with the Cstd library. Avoid specifying - # it if it's in CXXFLAGS. Ignore libCrun as - # -library=stlport4 depends on it. - case " $CXX $CXXFLAGS " in - *" -library=stlport4 "*) - solaris_use_stlport4=yes - ;; - esac - if test "$solaris_use_stlport4" != yes; then - _LT_AC_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' - fi - ;; - esac - ;; - -solaris*) - case $cc_basename in - CC*) - # The more standards-conforming stlport4 library is - # incompatible with the Cstd library. Avoid specifying - # it if it's in CXXFLAGS. Ignore libCrun as - # -library=stlport4 depends on it. - case " $CXX $CXXFLAGS " in - *" -library=stlport4 "*) - solaris_use_stlport4=yes - ;; - esac - - # Adding this requires a known-good setup of shared libraries for - # Sun compiler versions before 5.6, else PIC objects from an old - # archive will be linked into the output, leading to subtle bugs. - if test "$solaris_use_stlport4" != yes; then - _LT_AC_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun' - fi - ;; - esac - ;; -esac -) -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 - return - end -" - -# Code to be used in simple link tests -lt_simple_link_test_code="\ - program t - end -" - -# 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-9*) - 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) - -_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_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 {}" - -# Code to be used in simple link tests -lt_simple_link_test_code='public class conftest { public static void main(String argv) {}; }' - -# 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 - -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_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 }' - -# 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 LTCFLAGS 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(compiler_lib_search_dirs, $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(fix_srcfile_path, $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, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -# Free Software Foundation, Inc. -# -# This file is part of GNU Libtool: -# Originally by Gordon Matzigkeit <gord@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 - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# 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 directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt__LT_AC_TAGVAR(compiler_lib_search_dirs, $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_fix_srcfile_path - -# 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(LT_AC_PROG_SED) -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* | k*bsd*-gnu) - 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*) - symcode='BDRT' - ;; -sco3.2v5*) - symcode='DT' - ;; -sysv4.2uw2*) - symcode='DT' - ;; -sysv5* | sco5v6* | unixware* | OpenUNIX*) - symcode='ABDT' - ;; -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 -rf 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* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - m4_if($1, GCJ, , - _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)= - ;; - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - 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-9*) - # 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* | 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)='${wl}-a ${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)='${wl}-a ${wl}archive' - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' - ;; - esac - ;; - *) - ;; - esac - ;; - interix*) - # This is c89, which is MS Visual C++ (no shared libs) - # Anyone wants to do a port? - ;; - 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* | k*bsd*-gnu) - 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* | pgcpp*) - # Portland Group C++ compiler. - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' - ;; - cxx*) - # Compaq C++ - # Make sure the PIC flag is empty. It appears that all Alpha - # Linux and Compaq Tru64 Unix objects are PIC. - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - _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 ' - ;; - esac - ;; - esac - ;; - lynxos*) - ;; - m88k*) - ;; - mvs*) - case $cc_basename in - cxx*) - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' - ;; - *) - ;; - esac - ;; - netbsd* | netbsdelf*-gnu) - ;; - osf3* | osf4* | osf5*) - case $cc_basename in - KCC*) - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' - ;; - RCC*) - # Rational C++ 2.4.1 - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' - ;; - cxx*) - # Digital/Compaq C++ - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - # Make sure the PIC flag is empty. It appears that all Alpha - # Linux and Compaq Tru64 Unix objects are PIC. - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' - ;; - *) - ;; - esac - ;; - psos*) - ;; - 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 - ;; - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - case $cc_basename in - CC*) - _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' - ;; - esac - ;; - 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* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - m4_if($1, GCJ, , - _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' - ;; - - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - - 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* | cygwin* | 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). - m4_if($1, GCJ, , - _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* | k*bsd*-gnu) - case $cc_basename in - icc* | ecc*) - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' - ;; - pgcc* | pgf77* | pgf90* | pgf95*) - # Portland Group compilers (*not* the Pentium gcc compiler, - # which looks to be a dead project) - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' - ;; - ccc*) - _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' - # All Alpha code is PIC. - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C 5.9 - _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)='-Wl,' - ;; - *Sun\ F*) - # Sun Fortran 8.3 passes all unrecognized flags to the linker - _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)='' - ;; - esac - ;; - 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' - ;; - - rdos*) - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' - ;; - - 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*) - _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 - ;; - - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - _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' - ;; - - 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_cv_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 - -# -# Check to make sure the static flag actually works. -# -wl=$_LT_AC_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_AC_TAGVAR(lt_prog_compiler_static, $1)\" -AC_LIBTOOL_LINKER_OPTION(if $compiler static flag $lt_tmp_static_flag works, - _LT_AC_TAGVAR(lt_cv_prog_compiler_static_works, $1), - $lt_tmp_static_flag, - , - _LT_AC_TAGVAR(lt_prog_compiler_static, $1)=) -) - - -# AC_LIBTOOL_PROG_LD_SHLIBS(TAGNAME) -# ------------------------------------ -# See if the linker supports building shared libraries. -AC_DEFUN(AC_LIBTOOL_PROG_LD_SHLIBS, -AC_REQUIRE(LT_AC_PROG_SED)dnl -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-9*) - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to AIX nm, but means don't demangle with GNU nm - if $NM -V 2>&1 | grep 'GNU' > /dev/null; then - _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - else - _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - fi - ;; - pw32*) - _LT_AC_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds" - ;; - cygwin* | mingw*) - _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^BCDGRS /s/.* \(^ *\)/\1 DATA/;/^.* __nm__/s/^.* __nm__\(^ *\) ^ */\1 DATA/;/^I /d;/^AITW /s/.* //'\'' | sort | uniq > $export_symbols' - ;; - linux* | k*bsd*-gnu) - _LT_AC_TAGVAR(link_all_deplibs, $1)=no - ;; - *) - _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - ;; - esac - _LT_AC_TAGVAR(exclude_expsyms, $1)='_GLOBAL_OFFSET_TABLE_|_GLOBAL__FID_.*' -, - 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_|_GLOBAL__FID_.*' - # 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. - # Exclude shared library initialization/finalization symbols. -dnl Note also adjust exclude_expsyms for C++ above. - 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 - ;; - interix*) - # we just hope/assume this is gcc and not c89 (= MSVC++) - with_gnu_ld=yes - ;; - 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-9*) - # 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@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@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/'\'' -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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - _LT_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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - fi - ;; - - interix3-9*) - _LT_AC_TAGVAR(hardcode_direct, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - - gnu* | linux* | k*bsd*-gnu) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - tmp_addflag= - case $cc_basename,$host_cpu in - pgcc*) # Portland Group C compiler - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag' - ;; - pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag -Mnomain' ;; - ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 - tmp_addflag=' -i_dynamic' ;; - efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 - tmp_addflag=' -i_dynamic -nofor_main' ;; - ifc* | ifort*) # Intel Fortran compiler - tmp_addflag=' -nofor_main' ;; - esac - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) # Sun C 5.9 - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_sharedflag='-G' ;; - *Sun\ F*) # Sun Fortran 8.3 - tmp_sharedflag='-G' ;; - *) - tmp_sharedflag='-shared' ;; - esac - _LT_AC_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$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 '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' - fi - _LT_AC_TAGVAR(link_all_deplibs, $1)=no - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - fi - ;; - - netbsd* | netbsdelf*-gnu) - 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*) - 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 - ;; - - sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) - case `$LD -v 2>&1` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10-5.*) - _LT_AC_TAGVAR(ld_shlibs, $1)=no - cat <<_LT_EOF 1>&2 - -*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not -*** reliably create shared libraries on SCO systems. Therefore, libtool -*** is disabling shared libraries support. We urge you to upgrade GNU -*** binutils to release 2.16.91.0.3 or newer. Another option is to modify -*** your PATH or compiler configuration so that the native linker is -*** used, and then restart. - -_LT_EOF - ;; - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname,-retain-symbols-file,$export_symbols -o $lib' - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - fi - ;; - esac - ;; - - 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 "$lt_prog_compiler_static"; then - # Neither direct hardcoding nor static linking is supported with a - # broken collect2. - _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported - fi - ;; - - aix4-9*) - 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-9*) - 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 - : - 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 '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${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 '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - _LT_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' - # Exported symbols can be pulled into shared objects from archives - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='$convenience' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes - # This is similar to how AIX traditionally builds its shared libraries. - _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${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 - ;; - - bsdi45*) - _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_dar_single_mod${_lt_dsymutil}" - _LT_AC_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - _LT_AC_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - _LT_AC_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - 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` $xlcverstring' - _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~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* | 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*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - else - _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' - fi - if test "$with_gnu_ld" = no; then - _LT_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 - fi - ;; - - hpux11*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - case $host_cpu in - hppa*64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -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*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - fi - if test "$with_gnu_ld" = no; then - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: - - case $host_cpu in - hppa*64*|ia64*) - _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' - _LT_AC_TAGVAR(hardcode_direct, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - ;; - *) - _LT_AC_TAGVAR(hardcode_direct, $1)=yes - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes - ;; - esac - fi - ;; - - irix5* | irix6* | nonstopux*) - if test "$GCC" = yes; then - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir' - fi - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: - _LT_AC_TAGVAR(link_all_deplibs, $1)=yes - ;; - - netbsd* | netbsdelf*-gnu) - 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*) - if test -f /usr/libexec/ld.so; then - _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 - openbsd01.* | 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 - else - _LT_AC_TAGVAR(ld_shlibs, $1)=no - 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)=: - ;; - - 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 and reorder linker options, - # but understands `-z linker_flag'. GCC discards it without `$wl', - # but is careful enough not to reorder. - # Supported since Solaris 2.6 (maybe 2.5.1?) - if test "$GCC" = yes; then - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - else - _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' - fi - ;; - 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*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - else - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z,text' - _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs' - _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no - _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no - _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' - _LT_AC_TAGVAR(link_all_deplibs, $1)=yes - _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - else - _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - 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 - -# -# 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* - echo "$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) - pic_flag=$_LT_AC_TAGVAR(lt_prog_compiler_pic, $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) -) - - -# Cheap backport of AS_EXECUTABLE_P and required macros -# from Autoconf 2.59; we should not use $as_executable_p directly. - -# _AS_TEST_PREPARE -# ---------------- -m4_ifndef(_AS_TEST_PREPARE, -m4_defun(_AS_TEST_PREPARE, -if test -x / >/dev/null 2>&1; then - as_executable_p='test -x' -else - as_executable_p='test -f' -fi -))# _AS_TEST_PREPARE - -# AS_EXECUTABLE_P -# --------------- -# Check whether a file is executable. -m4_ifndef(AS_EXECUTABLE_P, -m4_defun(AS_EXECUTABLE_P, -AS_REQUIRE(_AS_TEST_PREPARE)dnl -$as_executable_p $1dnl -))# AS_EXECUTABLE_P - -# 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 -IFS=$as_save_IFS -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_SUBST(SED) -AC_MSG_RESULT($SED) -) - -# pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- -# -# Copyright © 2004 Scott James Remnant <scott@netsplit.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 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. - -# PKG_PROG_PKG_CONFIG(MIN-VERSION) -# ---------------------------------- -AC_DEFUN(PKG_PROG_PKG_CONFIG, -m4_pattern_forbid(^_?PKG_A-Z_+$) -m4_pattern_allow(^PKG_CONFIG(_PATH)?$) -AC_ARG_VAR(PKG_CONFIG, path to pkg-config utility)dnl -if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then - AC_PATH_TOOL(PKG_CONFIG, pkg-config) -fi -if test -n "$PKG_CONFIG"; then - _pkg_min_version=m4_default($1, 0.9.0) - AC_MSG_CHECKING(pkg-config is at least version $_pkg_min_version) - if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then - AC_MSG_RESULT(yes) - else - AC_MSG_RESULT(no) - PKG_CONFIG="" - fi - -fidnl -)# PKG_PROG_PKG_CONFIG - -# PKG_CHECK_EXISTS(MODULES, ACTION-IF-FOUND, ACTION-IF-NOT-FOUND) -# -# Check to see whether a particular set of modules exists. Similar -# to PKG_CHECK_MODULES(), but does not set variables or print errors. -# -# -# Similar to PKG_CHECK_MODULES, make sure that the first instance of -# this or PKG_CHECK_MODULES is called, or make sure to call -# PKG_CHECK_EXISTS manually -# -------------------------------------------------------------- -AC_DEFUN(PKG_CHECK_EXISTS, -AC_REQUIRE(PKG_PROG_PKG_CONFIG)dnl -if test -n "$PKG_CONFIG" && \ - AC_RUN_LOG($PKG_CONFIG --exists --print-errors "$1"); then - m4_ifval($2, $2, :) -m4_ifvaln($3, else - $3)dnl -fi) - - -# _PKG_CONFIG(VARIABLE, COMMAND, MODULES) -# --------------------------------------------- -m4_define(_PKG_CONFIG, -if test -n "$PKG_CONFIG"; then - if test -n "$$1"; then - pkg_cv_$1="$$1" - else - PKG_CHECK_EXISTS($3, - pkg_cv_$1=`$PKG_CONFIG --$2 "$3" 2>/dev/null`, - pkg_failed=yes) - fi -else - pkg_failed=untried -fidnl -)# _PKG_CONFIG - -# _PKG_SHORT_ERRORS_SUPPORTED -# ----------------------------- -AC_DEFUN(_PKG_SHORT_ERRORS_SUPPORTED, -AC_REQUIRE(PKG_PROG_PKG_CONFIG) -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fidnl -)# _PKG_SHORT_ERRORS_SUPPORTED - - -# PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, ACTION-IF-FOUND, -# ACTION-IF-NOT-FOUND) -# -# -# Note that if there is a possibility the first call to -# PKG_CHECK_MODULES might not happen, you should be sure to include an -# explicit call to PKG_PROG_PKG_CONFIG in your configure.ac -# -# -# -------------------------------------------------------------- -AC_DEFUN(PKG_CHECK_MODULES, -AC_REQUIRE(PKG_PROG_PKG_CONFIG)dnl -AC_ARG_VAR($1_CFLAGS, C compiler flags for $1, overriding pkg-config)dnl -AC_ARG_VAR($1_LIBS, linker flags for $1, overriding pkg-config)dnl - -pkg_failed=no -AC_MSG_CHECKING(for $1) - -_PKG_CONFIG($1_CFLAGS, cflags, $2) -_PKG_CONFIG($1_LIBS, libs, $2) - -m4_define(_PKG_TEXT, Alternatively, you may set the environment variables $1_CFLAGS -and $1_LIBS to avoid the need to call pkg-config. -See the pkg-config man page for more details.) - -if test $pkg_failed = yes; then - _PKG_SHORT_ERRORS_SUPPORTED - if test $_pkg_short_errors_supported = yes; then - $1_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "$2"` - else - $1_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "$2"` - fi - # Put the nasty error message in config.log where it belongs - echo "$$1_PKG_ERRORS" >&AS_MESSAGE_LOG_FD - - ifelse($4, , AC_MSG_ERROR(dnl -Package requirements ($2) were not met: - -$$1_PKG_ERRORS - -Consider adjusting the PKG_CONFIG_PATH environment variable if you -installed software in a non-standard prefix. - -_PKG_TEXT -), - AC_MSG_RESULT(no) - $4) -elif test $pkg_failed = untried; then - ifelse($4, , AC_MSG_FAILURE(dnl -The pkg-config script could not be found or is too old. Make sure it -is in your PATH or set the PKG_CONFIG environment variable to the full -path to pkg-config. - -_PKG_TEXT - -To get pkg-config, see <http://pkg-config.freedesktop.org/>.), - $4) -else - $1_CFLAGS=$pkg_cv_$1_CFLAGS - $1_LIBS=$pkg_cv_$1_LIBS - AC_MSG_RESULT(yes) - ifelse($3, , :, $3) -fidnl -)# PKG_CHECK_MODULES - -# -*- Autoconf -*- -# Copyright (C) 2002, 2003 Free Software Foundation, Inc. -# Generated from amversion.in; do not edit by hand. - -# 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 - -# AM_AUTOMAKE_VERSION(VERSION) -# ---------------------------- -# Automake X.Y traces this macro to ensure aclocal.m4 has been -# generated from the m4 files accompanying Automake X.Y. -AC_DEFUN(AM_AUTOMAKE_VERSION, am__api_version="1.8") - -# AM_SET_CURRENT_AUTOMAKE_VERSION -# ------------------------------- -# Call AM_AUTOMAKE_VERSION so it can be traced. -# This function is AC_REQUIREd by AC_INIT_AUTOMAKE. -AC_DEFUN(AM_SET_CURRENT_AUTOMAKE_VERSION, - AM_AUTOMAKE_VERSION(1.8.5)) - -# AM_AUX_DIR_EXPAND - -# Copyright (C) 2001, 2003 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. - -# For projects using AC_CONFIG_AUX_DIR(foo), Autoconf sets -# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to -# `$srcdir', `$srcdir/..', or `$srcdir/../..'. -# -# Of course, Automake must honor this variable whenever it calls a -# tool from the auxiliary directory. The problem is that $srcdir (and -# therefore $ac_aux_dir as well) can be either absolute or relative, -# depending on how configure is run. This is pretty annoying, since -# it makes $ac_aux_dir quite unusable in subdirectories: in the top -# source directory, any form will work fine, but in subdirectories a -# relative path needs to be adjusted first. -# -# $ac_aux_dir/missing -# fails when called from a subdirectory if $ac_aux_dir is relative -# $top_srcdir/$ac_aux_dir/missing -# fails if $ac_aux_dir is absolute, -# fails when called from a subdirectory in a VPATH build with -# a relative $ac_aux_dir -# -# The reason of the latter failure is that $top_srcdir and $ac_aux_dir -# are both prefixed by $srcdir. In an in-source build this is usually -# harmless because $srcdir is `.', but things will broke when you -# start a VPATH build or use an absolute $srcdir. -# -# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, -# iff we strip the leading $srcdir from $ac_aux_dir. That would be: -# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` -# and then we would define $MISSING as -# MISSING="\${SHELL} $am_aux_dir/missing" -# This will work as long as MISSING is not called from configure, because -# unfortunately $(top_srcdir) has no meaning in configure. -# However there are other variables, like CC, which are often used in -# configure, and could therefore not use this "fixed" $ac_aux_dir. -# -# Another solution, used here, is to always expand $ac_aux_dir to an -# absolute PATH. The drawback is that using absolute paths prevent a -# configured tree to be moved without reconfiguration. - -AC_DEFUN(AM_AUX_DIR_EXPAND, -dnl Rely on autoconf to set up CDPATH properly. -AC_PREREQ(2.50)dnl -# expand $ac_aux_dir to an absolute path -am_aux_dir=`cd $ac_aux_dir && pwd` -) - -# AM_CONDITIONAL -*- Autoconf -*- - -# Copyright (C) 1997, 2000, 2001, 2003 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. - -# serial 6 - -# AM_CONDITIONAL(NAME, SHELL-CONDITION) -# ------------------------------------- -# Define a conditional. -AC_DEFUN(AM_CONDITIONAL, -AC_PREREQ(2.52)dnl - ifelse($1, TRUE, AC_FATAL($0: invalid condition: $1), - $1, FALSE, AC_FATAL($0: invalid condition: $1))dnl -AC_SUBST($1_TRUE) -AC_SUBST($1_FALSE) -if $2; then - $1_TRUE= - $1_FALSE='#' -else - $1_TRUE='#' - $1_FALSE= -fi -AC_CONFIG_COMMANDS_PRE( -if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then - AC_MSG_ERROR(conditional "$1" was never defined. -Usually this means the macro was only invoked conditionally.) -fi)) - -# serial 7 -*- Autoconf -*- - -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004 -# 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. - - -# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be -# written in clear, in which case automake, when reading aclocal.m4, -# will think it sees a *use*, and therefore will trigger all it's -# C support machinery. Also note that it means that autoscan, seeing -# CC etc. in the Makefile, will ask for an AC_PROG_CC use... - - - -# _AM_DEPENDENCIES(NAME) -# ---------------------- -# See how the compiler implements dependency checking. -# NAME is "CC", "CXX", "GCJ", or "OBJC". -# We try a few techniques and use that to set a single cache variable. -# -# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was -# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular -# dependency, and given that the user is not expected to run this macro, -# just rely on AC_PROG_CC. -AC_DEFUN(_AM_DEPENDENCIES, -AC_REQUIRE(AM_SET_DEPDIR)dnl -AC_REQUIRE(AM_OUTPUT_DEPENDENCY_COMMANDS)dnl -AC_REQUIRE(AM_MAKE_INCLUDE)dnl -AC_REQUIRE(AM_DEP_TRACK)dnl - -ifelse($1, CC, depcc="$CC" am_compiler_list=, - $1, CXX, depcc="$CXX" am_compiler_list=, - $1, OBJC, depcc="$OBJC" am_compiler_list='gcc3 gcc', - $1, GCJ, depcc="$GCJ" am_compiler_list='gcc3 gcc', - depcc="$$1" am_compiler_list=) - -AC_CACHE_CHECK(dependency style of $depcc, - am_cv_$1_dependencies_compiler_type, -if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then - # We make a subdir and do the tests there. Otherwise we can end up - # making bogus files that we don't know about and never remove. For - # instance it was reported that on HP-UX the gcc test will end up - # making a dummy file named `D' -- because `-MD' means `put the output - # in D'. - mkdir conftest.dir - # Copy depcomp to subdir because otherwise we won't find it if we're - # using a relative directory. - cp "$am_depcomp" conftest.dir - cd conftest.dir - # We will build objects and dependencies in a subdirectory because - # it helps to detect inapplicable dependency modes. For instance - # both Tru64's cc and ICC support -MD to output dependencies as a - # side effect of compilation, but ICC will put the dependencies in - # the current directory while Tru64 will put them in the object - # directory. - mkdir sub - - am_cv_$1_dependencies_compiler_type=none - if test "$am_compiler_list" = ""; then - am_compiler_list=`sed -n 's/^#*\(a-zA-Z0-9*\))$/\1/p' < ./depcomp` - fi - for depmode in $am_compiler_list; do - # Setup a source with many dependencies, because some compilers - # like to wrap large dependency lists on column 80 (with \), and - # we should not choose a depcomp mode which is confused by this. - # - # We need to recreate these files for each test, as the compiler may - # overwrite some of them when testing with obscure command lines. - # This happens at least with the AIX C compiler. - : > sub/conftest.c - for i in 1 2 3 4 5 6; do - echo '#include "conftst'$i'.h"' >> sub/conftest.c - # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with - # Solaris 8's {/usr,}/bin/sh. - touch sub/conftst$i.h - done - echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf - - case $depmode in - nosideeffect) - # after this tag, mechanisms are not by side-effect, so they'll - # only be used when explicitly requested - if test "x$enable_dependency_tracking" = xyes; then - continue - else - break - fi - ;; - none) break ;; - esac - # We check with `-c' and `-o' for the sake of the "dashmstdout" - # mode. It turns out that the SunPro C++ compiler does not properly - # handle `-M -o', and we need to detect this. - if depmode=$depmode \ - source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ - depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ - $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ - >/dev/null 2>conftest.err && - grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && - grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && - ${MAKE-make} -s -f confmf > /dev/null 2>&1; then - # icc doesn't choke on unknown options, it will just issue warnings - # or remarks (even with -Werror). So we grep stderr for any message - # that says an option was ignored or not supported. - # When given -MP, icc 7.0 and 7.1 complain thusly: - # icc: Command line warning: ignoring option '-M'; no argument required - # The diagnosis changed in icc 8.0: - # icc: Command line remark: option '-MP' not supported - if (grep 'ignoring option' conftest.err || - grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else - am_cv_$1_dependencies_compiler_type=$depmode - break - fi - fi - done - - cd .. - rm -rf conftest.dir -else - am_cv_$1_dependencies_compiler_type=none -fi -) -AC_SUBST($1DEPMODE, depmode=$am_cv_$1_dependencies_compiler_type) -AM_CONDITIONAL(am__fastdep$1, - test "x$enable_dependency_tracking" != xno \ - && test "$am_cv_$1_dependencies_compiler_type" = gcc3) -) - - -# AM_SET_DEPDIR -# ------------- -# Choose a directory name for dependency files. -# This macro is AC_REQUIREd in _AM_DEPENDENCIES -AC_DEFUN(AM_SET_DEPDIR, -AC_REQUIRE(AM_SET_LEADING_DOT)dnl -AC_SUBST(DEPDIR, "${am__leading_dot}deps")dnl -) - - -# AM_DEP_TRACK -# ------------ -AC_DEFUN(AM_DEP_TRACK, -AC_ARG_ENABLE(dependency-tracking, - --disable-dependency-tracking speeds up one-time build - --enable-dependency-tracking do not reject slow dependency extractors) -if test "x$enable_dependency_tracking" != xno; then - am_depcomp="$ac_aux_dir/depcomp" - AMDEPBACKSLASH='\' -fi -AM_CONDITIONAL(AMDEP, test "x$enable_dependency_tracking" != xno) -AC_SUBST(AMDEPBACKSLASH) -) - -# Generate code to set up dependency tracking. -*- Autoconf -*- - -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004 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. - -#serial 2 - -# _AM_OUTPUT_DEPENDENCY_COMMANDS -# ------------------------------ -AC_DEFUN(_AM_OUTPUT_DEPENDENCY_COMMANDS, -for mf in $CONFIG_FILES; do - # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named `Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # So let's grep whole file. - if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then - dirpart=`AS_DIRNAME("$mf")` - else - continue - fi - grep '^DEP_FILES *= *^ @%:@' < "$mf" > /dev/null || continue - # Extract the definition of DEP_FILES from the Makefile without - # running `make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - # When using ansi2knr, U may be empty or an underscore; expand it - U=`sed -n 's/^U = //p' < "$mf"` - test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR" - # We invoke sed twice because it is the simplest approach to - # changing $(DEPDIR) to its actual value in the expansion. - for file in `sed -n ' - /^DEP_FILES = .*\\\\$/ { - s/^DEP_FILES = // - :loop - s/\\\\$// - p - n - /\\\\$/ b loop - p - } - /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`AS_DIRNAME("$file")` - AS_MKDIR_P($dirpart/$fdir) - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done -done -)# _AM_OUTPUT_DEPENDENCY_COMMANDS - - -# AM_OUTPUT_DEPENDENCY_COMMANDS -# ----------------------------- -# This macro should only be invoked once -- use via AC_REQUIRE. -# -# This code is only required when automatic dependency tracking -# is enabled. FIXME. This creates each `.P' file that we will -# need in order to bootstrap the dependency handling code. -AC_DEFUN(AM_OUTPUT_DEPENDENCY_COMMANDS, -AC_CONFIG_COMMANDS(depfiles, - test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS, - AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir") -) - -# Like AC_CONFIG_HEADER, but automatically create stamp file. -*- Autoconf -*- - -# Copyright (C) 1996, 1997, 2000, 2001, 2003 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. - -# serial 7 - -# AM_CONFIG_HEADER is obsolete. It has been replaced by AC_CONFIG_HEADERS. -AU_DEFUN(AM_CONFIG_HEADER, AC_CONFIG_HEADERS($@)) - -# Do all the work for Automake. -*- Autoconf -*- - -# This macro actually does too much some checks are only needed if -# your package does certain things. But this isn't really a big deal. - -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003 -# 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. - -# serial 11 - -# AM_INIT_AUTOMAKE(PACKAGE, VERSION, NO-DEFINE) -# AM_INIT_AUTOMAKE(OPTIONS) -# ----------------------------------------------- -# The call with PACKAGE and VERSION arguments is the old style -# call (pre autoconf-2.50), which is being phased out. PACKAGE -# and VERSION should now be passed to AC_INIT and removed from -# the call to AM_INIT_AUTOMAKE. -# We support both call styles for the transition. After -# the next Automake release, Autoconf can make the AC_INIT -# arguments mandatory, and then we can depend on a new Autoconf -# release and drop the old call support. -AC_DEFUN(AM_INIT_AUTOMAKE, -AC_PREREQ(2.58)dnl -dnl Autoconf wants to disallow AM_ names. We explicitly allow -dnl the ones we care about. -m4_pattern_allow(^AM_A-Z+FLAGS$)dnl -AC_REQUIRE(AM_SET_CURRENT_AUTOMAKE_VERSION)dnl -AC_REQUIRE(AC_PROG_INSTALL)dnl -# test to see if srcdir already configured -if test "`cd $srcdir && pwd`" != "`pwd`" && - test -f $srcdir/config.status; then - AC_MSG_ERROR(source directory already configured; run "make distclean" there first) -fi - -# test whether we have cygpath -if test -z "$CYGPATH_W"; then - if (cygpath --version) >/dev/null 2>/dev/null; then - CYGPATH_W='cygpath -w' - else - CYGPATH_W=echo - fi -fi -AC_SUBST(CYGPATH_W) - -# Define the identity of the package. -dnl Distinguish between old-style and new-style calls. -m4_ifval($2, -m4_ifval($3, _AM_SET_OPTION(no-define))dnl - AC_SUBST(PACKAGE, $1)dnl - AC_SUBST(VERSION, $2), -_AM_SET_OPTIONS($1)dnl - AC_SUBST(PACKAGE, 'AC_PACKAGE_TARNAME')dnl - AC_SUBST(VERSION, 'AC_PACKAGE_VERSION'))dnl - -_AM_IF_OPTION(no-define,, -AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", Name of package) - AC_DEFINE_UNQUOTED(VERSION, "$VERSION", Version number of package))dnl - -# Some tools Automake needs. -AC_REQUIRE(AM_SANITY_CHECK)dnl -AC_REQUIRE(AC_ARG_PROGRAM)dnl -AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) -AM_MISSING_PROG(AUTOCONF, autoconf) -AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) -AM_MISSING_PROG(AUTOHEADER, autoheader) -AM_MISSING_PROG(MAKEINFO, makeinfo) -AM_MISSING_PROG(AMTAR, tar) -AM_PROG_INSTALL_SH -AM_PROG_INSTALL_STRIP -AC_REQUIRE(AM_PROG_MKDIR_P)dnl -# We need awk for the "check" target. The system "awk" is bad on -# some platforms. -AC_REQUIRE(AC_PROG_AWK)dnl -AC_REQUIRE(AC_PROG_MAKE_SET)dnl -AC_REQUIRE(AM_SET_LEADING_DOT)dnl - -_AM_IF_OPTION(no-dependencies,, -AC_PROVIDE_IFELSE(AC_PROG_CC, - _AM_DEPENDENCIES(CC), - define(AC_PROG_CC, - defn(AC_PROG_CC)_AM_DEPENDENCIES(CC)))dnl -AC_PROVIDE_IFELSE(AC_PROG_CXX, - _AM_DEPENDENCIES(CXX), - define(AC_PROG_CXX, - defn(AC_PROG_CXX)_AM_DEPENDENCIES(CXX)))dnl -) -) - - -# When config.status generates a header, we must update the stamp-h file. -# This file resides in the same directory as the config header -# that is generated. The stamp files are numbered to have different names. - -# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the -# loop where config.status creates the headers, so we can generate -# our stamp files there. -AC_DEFUN(_AC_AM_CONFIG_HEADER_HOOK, -# Compute $1's index in $config_headers. -_am_stamp_count=1 -for _am_header in $config_headers :; do - case $_am_header in - $1 | $1:* ) - break ;; - * ) - _am_stamp_count=`expr $_am_stamp_count + 1` ;; - esac -done -echo "timestamp for $1" >`AS_DIRNAME($1)`/stamp-h$_am_stamp_count) - -# AM_PROG_INSTALL_SH -# ------------------ -# Define $install_sh. - -# Copyright (C) 2001, 2003 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. - -AC_DEFUN(AM_PROG_INSTALL_SH, -AC_REQUIRE(AM_AUX_DIR_EXPAND)dnl -install_sh=${install_sh-"$am_aux_dir/install-sh"} -AC_SUBST(install_sh)) - -# -*- Autoconf -*- -# Copyright (C) 2003 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. - -# serial 1 - -# Check whether the underlying file-system supports filenames -# with a leading dot. For instance MS-DOS doesn't. -AC_DEFUN(AM_SET_LEADING_DOT, -rm -rf .tst 2>/dev/null -mkdir .tst 2>/dev/null -if test -d .tst; then - am__leading_dot=. -else - am__leading_dot=_ -fi -rmdir .tst 2>/dev/null -AC_SUBST(am__leading_dot)) - -# Check to see how 'make' treats includes. -*- Autoconf -*- - -# Copyright (C) 2001, 2002, 2003 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. - -# serial 2 - -# AM_MAKE_INCLUDE() -# ----------------- -# Check to see how make treats includes. -AC_DEFUN(AM_MAKE_INCLUDE, -am_make=${MAKE-make} -cat > confinc << 'END' -am__doit: - @echo done -.PHONY: am__doit -END -# If we don't find an include directive, just comment out the code. -AC_MSG_CHECKING(for style of include used by $am_make) -am__include="#" -am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# We grep out `Entering directory' and `Leaving directory' -# messages which can occur if `w' ends up in MAKEFLAGS. -# In particular we don't look at `^make:' because GNU make might -# be invoked under some other name (usually "gmake"), in which -# case it prints its new name instead of `make'. -if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then - am__include=include - am__quote= - _am_result=GNU -fi -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then - am__include=.include - am__quote="\"" - _am_result=BSD - fi -fi -AC_SUBST(am__include) -AC_SUBST(am__quote) -AC_MSG_RESULT($_am_result) -rm -f confinc confmf -) - -# -*- Autoconf -*- - - -# Copyright (C) 1997, 1999, 2000, 2001, 2003 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. - -# serial 3 - -# AM_MISSING_PROG(NAME, PROGRAM) -# ------------------------------ -AC_DEFUN(AM_MISSING_PROG, -AC_REQUIRE(AM_MISSING_HAS_RUN) -$1=${$1-"${am_missing_run}$2"} -AC_SUBST($1)) - - -# AM_MISSING_HAS_RUN -# ------------------ -# Define MISSING if not defined so far and test if it supports --run. -# If it does, set am_missing_run to use it, otherwise, to nothing. -AC_DEFUN(AM_MISSING_HAS_RUN, -AC_REQUIRE(AM_AUX_DIR_EXPAND)dnl -test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" -# Use eval to expand $SHELL -if eval "$MISSING --run true"; then - am_missing_run="$MISSING --run " -else - am_missing_run= - AC_MSG_WARN(`missing' script is too old or missing) -fi -) - -# AM_PROG_MKDIR_P -# --------------- -# Check whether `mkdir -p' is supported, fallback to mkinstalldirs otherwise. - -# Copyright (C) 2003, 2004 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. - -# Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories -# created by `make install' are always world readable, even if the -# installer happens to have an overly restrictive umask (e.g. 077). -# This was a mistake. There are at least two reasons why we must not -# use `-m 0755': -# - it causes special bits like SGID to be ignored, -# - it may be too restrictive (some setups expect 775 directories). -# -# Do not use -m 0755 and let people choose whatever they expect by -# setting umask. -# -# We cannot accept any implementation of `mkdir' that recognizes `-p'. -# Some implementations (such as Solaris 8's) are not thread-safe: if a -# parallel make tries to run `mkdir -p a/b' and `mkdir -p a/c' -# concurrently, both version can detect that a/ is missing, but only -# one can create it and the other will error out. Consequently we -# restrict ourselves to GNU make (using the --version option ensures -# this.) -AC_DEFUN(AM_PROG_MKDIR_P, -if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then - # Keeping the `.' argument allows $(mkdir_p) to be used without - # argument. Indeed, we sometimes output rules like - # $(mkdir_p) $(somedir) - # where $(somedir) is conditionally defined. - # (`test -n '$(somedir)' && $(mkdir_p) $(somedir)' is a more - # expensive solution, as it forces Make to start a sub-shell.) - mkdir_p='mkdir -p -- .' -else - # On NextStep and OpenStep, the `mkdir' command does not - # recognize any option. It will interpret all options as - # directories to create, and then abort because `.' already - # exists. - for d in ./-p ./--version; - do - test -d $d && rmdir $d - done - # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. - if test -f "$ac_aux_dir/mkinstalldirs"; then - mkdir_p='$(mkinstalldirs)' - else - mkdir_p='$(install_sh) -d' - fi -fi -AC_SUBST(mkdir_p)) - -# Helper functions for option handling. -*- Autoconf -*- - -# Copyright (C) 2001, 2002, 2003 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. - -# serial 2 - -# _AM_MANGLE_OPTION(NAME) -# ----------------------- -AC_DEFUN(_AM_MANGLE_OPTION, -_AM_OPTION_m4_bpatsubst($1, ^a-zA-Z0-9_, _)) - -# _AM_SET_OPTION(NAME) -# ------------------------------ -# Set option NAME. Presently that only means defining a flag for this option. -AC_DEFUN(_AM_SET_OPTION, -m4_define(_AM_MANGLE_OPTION($1), 1)) - -# _AM_SET_OPTIONS(OPTIONS) -# ---------------------------------- -# OPTIONS is a space-separated list of Automake options. -AC_DEFUN(_AM_SET_OPTIONS, -AC_FOREACH(_AM_Option, $1, _AM_SET_OPTION(_AM_Option))) - -# _AM_IF_OPTION(OPTION, IF-SET, IF-NOT-SET) -# ------------------------------------------- -# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. -AC_DEFUN(_AM_IF_OPTION, -m4_ifset(_AM_MANGLE_OPTION($1), $2, $3)) - -# -# Check to make sure that the build environment is sane. -# - -# Copyright (C) 1996, 1997, 2000, 2001, 2003 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. - -# serial 3 - -# AM_SANITY_CHECK -# --------------- -AC_DEFUN(AM_SANITY_CHECK, -AC_MSG_CHECKING(whether build environment is sane) -# Just in case -sleep 1 -echo timestamp > conftest.file -# Do `set' in a subshell so we don't clobber the current shell's -# arguments. Must try -L first in case configure is actually a -# symlink; some systems play weird games with the mod time of symlinks -# (eg FreeBSD returns the mod time of the symlink's containing -# directory). -if ( - set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` - if test "$*" = "X"; then - # -L didn't work. - set X `ls -t $srcdir/configure conftest.file` - fi - rm -f conftest.file - if test "$*" != "X $srcdir/configure conftest.file" \ - && test "$*" != "X conftest.file $srcdir/configure"; then - - # If neither matched, then we have a broken ls. This can happen - # if, for instance, CONFIG_SHELL is bash and it inherits a - # broken ls alias from the environment. This has actually - # happened. Such a system could not be considered "sane". - AC_MSG_ERROR(ls -t appears to fail. Make sure there is not a broken -alias in your environment) - fi - - test "$2" = conftest.file - ) -then - # Ok. - : -else - AC_MSG_ERROR(newly created file is older than distributed files! -Check your system clock) -fi -AC_MSG_RESULT(yes)) - -# AM_PROG_INSTALL_STRIP - -# Copyright (C) 2001, 2003 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. - -# One issue with vendor `install' (even GNU) is that you can't -# specify the program used to strip binaries. This is especially -# annoying in cross-compiling environments, where the build's strip -# is unlikely to handle the host's binaries. -# Fortunately install-sh will honor a STRIPPROG variable, so we -# always use install-sh in `make install-strip', and initialize -# STRIPPROG with the value of the STRIP variable (set by the user). -AC_DEFUN(AM_PROG_INSTALL_STRIP, -AC_REQUIRE(AM_PROG_INSTALL_SH)dnl -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'. However `strip' might not be the right -# tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. -dnl Don't test for $cross_compiling = yes, because it might be `maybe'. -if test "$cross_compiling" != no; then - AC_CHECK_TOOL(STRIP, strip, :) -fi -INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" -AC_SUBST(INSTALL_STRIP_PROGRAM)) - -m4_include(m4/arts.m4) -m4_include(m4/nptl_bug.m4) -m4_include(m4/pthread.m4)
View file
linuxsampler-1.0.0.tar.bz2/config.guess
Deleted
@@ -1,1526 +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, 2006, 2007, 2008 -# Free Software Foundation, Inc. - -timestamp='2008-01-23' - -# This file is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, but -# WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA -# 02110-1301, USA. -# -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - - -# Originally written by Per Bothner <per@bothner.com>. -# Please send patches to <config-patches@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@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, 2006, 2007, 2008 Free Software Foundation, Inc. - -This is free software; see the source for copying conditions. There is NO -warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." - -help=" -Try \`$me --help' for more information." - -# Parse command line -while test $# -gt 0 ; do - case $1 in - --time-stamp | --time* | -t ) - echo "$timestamp" ; exit ;; - --version | -v ) - echo "$version" ; exit ;; - --help | --h* | -h ) - echo "$usage"; exit ;; - -- ) # Stop option processing - shift; break ;; - - ) # Use stdin as input. - break ;; - -* ) - echo "$me: invalid option $1$help" >&2 - exit 1 ;; - * ) - break ;; - esac -done - -if test $# != 0; then - echo "$me: too many arguments$help" >&2 - exit 1 -fi - -trap 'exit 1' 1 2 15 - -# CC_FOR_BUILD -- compiler used by this script. Note that the use of a -# compiler to aid in system detection is discouraged as it requires -# temporary files to be created and, as you can see below, it is a -# headache to deal with in a portable fashion. - -# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still -# use `HOST_CC' if defined, but it is deprecated. - -# Portable tmp directory creation inspired by the Autoconf team. - -set_cc_for_build=' -trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; -trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; -: ${TMPDIR=/tmp} ; - { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || - { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || - { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || - { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; -dummy=$tmp/dummy ; -tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; -case $CC_FOR_BUILD,$HOST_CC,$CC in - ,,) echo "int x;" > $dummy.c ; - for c in cc gcc c89 c99 ; do - if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then - CC_FOR_BUILD="$c"; break ; - fi ; - done ; - if test x"$CC_FOR_BUILD" = x ; then - CC_FOR_BUILD=no_compiler_found ; - fi - ;; - ,,*) CC_FOR_BUILD=$CC ;; - ,*,*) CC_FOR_BUILD=$HOST_CC ;; -esac ; set_cc_for_build= ;' - -# This is needed to find uname on a Pyramid OSx when run in the BSD universe. -# (ghazi@noc.rutgers.edu 1994-08-24) -if (test -f /.attbin/uname) >/dev/null 2>&1 ; then - PATH=$PATH:/.attbin ; export PATH -fi - -UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown -UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown -UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown -UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown - -# Note: order is significant - the case branches are not exclusive. - -case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in - *:NetBSD:*:*) - # NetBSD (nbsd) targets should (where applicable) match one or - # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*, - # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently - # switched to ELF, *-*-netbsd* would select the old - # object file format. This provides both forward - # compatibility and a consistent mechanism for selecting the - # object file format. - # - # Note: NetBSD doesn't particularly care about the vendor - # portion of the name. We always set it to "unknown". - sysctl="sysctl -n hw.machine_arch" - UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \ - /usr/sbin/$sysctl 2>/dev/null || echo unknown)` - case "${UNAME_MACHINE_ARCH}" in - armeb) machine=armeb-unknown ;; - arm*) machine=arm-unknown ;; - sh3el) machine=shl-unknown ;; - sh3eb) machine=sh-unknown ;; - sh5el) machine=sh5le-unknown ;; - *) machine=${UNAME_MACHINE_ARCH}-unknown ;; - esac - # The Operating System including object format, if it has switched - # to ELF recently, or will in the future. - case "${UNAME_MACHINE_ARCH}" in - arm*|i386|m68k|ns32k|sh3*|sparc|vax) - eval $set_cc_for_build - if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ - | grep __ELF__ >/dev/null - then - # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). - # Return netbsd for either. FIX? - os=netbsd - else - os=netbsdelf - fi - ;; - *) - os=netbsd - ;; - esac - # The OS release - # Debian GNU/NetBSD machines have a different userland, and - # thus, need a distinct triplet. However, they do not need - # kernel version information, so it can be replaced with a - # suitable tag, in the style of linux-gnu. - case "${UNAME_VERSION}" in - Debian*) - release='-gnu' - ;; - *) - release=`echo ${UNAME_RELEASE}|sed -e 's/-_.*/\./'` - ;; - esac - # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: - # contains redundant information, the shorter form: - # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. - echo "${machine}-${os}${release}" - exit ;; - *:OpenBSD:*:*) - UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` - echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} - exit ;; - *:ekkoBSD:*:*) - echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} - exit ;; - *:SolidBSD:*:*) - echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} - exit ;; - macppc:MirBSD:*:*) - echo powerpc-unknown-mirbsd${UNAME_RELEASE} - exit ;; - *:MirBSD:*:*) - echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} - exit ;; - alpha:OSF1:*:*) - case $UNAME_RELEASE in - *4.0) - UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` - ;; - *5.*) - UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` - ;; - esac - # According to Compaq, /usr/sbin/psrinfo has been available on - # OSF/1 and Tru64 systems produced since 1995. I hope that - # covers most systems running today. This code pipes the CPU - # types through head -n 1, so we only detect the type of CPU 0. - ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` - case "$ALPHA_CPU_TYPE" in - "EV4 (21064)") - UNAME_MACHINE="alpha" ;; - "EV4.5 (21064)") - UNAME_MACHINE="alpha" ;; - "LCA4 (21066/21068)") - UNAME_MACHINE="alpha" ;; - "EV5 (21164)") - UNAME_MACHINE="alphaev5" ;; - "EV5.6 (21164A)") - UNAME_MACHINE="alphaev56" ;; - "EV5.6 (21164PC)") - UNAME_MACHINE="alphapca56" ;; - "EV5.7 (21164PC)") - UNAME_MACHINE="alphapca57" ;; - "EV6 (21264)") - UNAME_MACHINE="alphaev6" ;; - "EV6.7 (21264A)") - UNAME_MACHINE="alphaev67" ;; - "EV6.8CB (21264C)") - UNAME_MACHINE="alphaev68" ;; - "EV6.8AL (21264B)") - UNAME_MACHINE="alphaev68" ;; - "EV6.8CX (21264D)") - UNAME_MACHINE="alphaev68" ;; - "EV6.9A (21264/EV69A)") - UNAME_MACHINE="alphaev69" ;; - "EV7 (21364)") - UNAME_MACHINE="alphaev7" ;; - "EV7.9 (21364A)") - UNAME_MACHINE="alphaev79" ;; - esac - # A Pn.n version is a patched version. - # A Vn.n version is a released version. - # A Tn.n version is a released field test version. - # A Xn.n version is an unreleased experimental baselevel. - # 1.2 uses "1.2" for uname -r. - echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^PVTX//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` - exit ;; - Alpha\ *:Windows_NT*:*) - # How do we know it's Interix rather than the generic POSIX subsystem? - # Should we change UNAME_MACHINE based on the output of uname instead - # of the specific Alpha model? - echo alpha-pc-interix - exit ;; - 21064:Windows_NT:50:3) - echo alpha-dec-winnt3.5 - exit ;; - Amiga*:UNIX_System_V:4.0:*) - echo m68k-unknown-sysv4 - exit ;; - *:AamigaOoSs:*:*) - echo ${UNAME_MACHINE}-unknown-amigaos - exit ;; - *:MmorphOoSs:*:*) - echo ${UNAME_MACHINE}-unknown-morphos - exit ;; - *:OS/390:*:*) - echo i370-ibm-openedition - exit ;; - *:z/VM:*:*) - echo s390-ibm-zvmoe - exit ;; - *:OS400:*:*) - echo powerpc-ibm-os400 - exit ;; - arm:RISC*:1.012*:*|arm:riscix:1.012*:*) - echo arm-acorn-riscix${UNAME_RELEASE} - exit ;; - arm:riscos:*:*|arm:RISCOS:*:*) - echo arm-unknown-riscos - exit ;; - SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) - echo hppa1.1-hitachi-hiuxmpp - exit ;; - Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) - # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. - if test "`(/bin/universe) 2>/dev/null`" = att ; then - echo pyramid-pyramid-sysv3 - else - echo pyramid-pyramid-bsd - fi - exit ;; - NILE*:*:*:dcosx) - echo pyramid-pyramid-svr4 - exit ;; - DRS?6000:unix:4.0:6*) - echo sparc-icl-nx6 - exit ;; - DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) - case `/usr/bin/uname -p` in - sparc) echo sparc-icl-nx7; exit ;; - esac ;; - sun4H:SunOS:5.*:*) - echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` - exit ;; - sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) - echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` - exit ;; - i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) - echo i386-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` - exit ;; - sun4*:SunOS:6*:*) - # According to config.sub, this is the proper way to canonicalize - # SunOS6. Hard to guess exactly what SunOS6 will be like, but - # it's likely to be more like Solaris than SunOS4. - echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` - exit ;; - sun4*:SunOS:*:*) - case "`/usr/bin/arch -k`" in - Series*|S4*) - UNAME_RELEASE=`uname -v` - ;; - esac - # Japanese Language versions have a version number like `4.1.3-JL'. - echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` - exit ;; - sun3*:SunOS:*:*) - echo m68k-sun-sunos${UNAME_RELEASE} - exit ;; - sun*:*:4.2BSD:*) - UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` - test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 - case "`/bin/arch`" in - sun3) - echo m68k-sun-sunos${UNAME_RELEASE} - ;; - sun4) - echo sparc-sun-sunos${UNAME_RELEASE} - ;; - esac - exit ;; - aushp:SunOS:*:*) - echo sparc-auspex-sunos${UNAME_RELEASE} - exit ;; - # The situation for MiNT is a little confusing. The machine name - # can be virtually everything (everything which is not - # "atarist" or "atariste" at least should have a processor - # > m68000). The system name ranges from "MiNT" over "FreeMiNT" - # to the lowercase version "mint" (or "freemint"). Finally - # the system name "TOS" denotes a system which is actually not - # MiNT. But MiNT is downward compatible to TOS, so this should - # be no problem. - atariste:*MiNT:*:* | atariste:*mint:*:* | atariste:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - atari*:*MiNT:*:* | atari*:*mint:*:* | atariste:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) - echo m68k-milan-mint${UNAME_RELEASE} - exit ;; - hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) - echo m68k-hades-mint${UNAME_RELEASE} - exit ;; - *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) - echo m68k-unknown-mint${UNAME_RELEASE} - exit ;; - m68k:machten:*:*) - echo m68k-apple-machten${UNAME_RELEASE} - exit ;; - powerpc:machten:*:*) - echo powerpc-apple-machten${UNAME_RELEASE} - exit ;; - RISC*:Mach:*:*) - echo mips-dec-mach_bsd4.3 - exit ;; - RISC*:ULTRIX:*:*) - echo mips-dec-ultrix${UNAME_RELEASE} - exit ;; - VAX*:ULTRIX*:*:*) - echo vax-dec-ultrix${UNAME_RELEASE} - exit ;; - 2020:CLIX:*:* | 2430:CLIX:*:*) - echo clipper-intergraph-clix${UNAME_RELEASE} - exit ;; - mips:*:*:UMIPS | mips:*:*:RISCos) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c -#ifdef __cplusplus -#include <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", argv1); exit (0); - #endif - #if defined (SYSTYPE_SVR4) - printf ("mips-mips-riscos%ssvr4\n", argv1); exit (0); - #endif - #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) - printf ("mips-mips-riscos%sbsd\n", argv1); exit (0); - #endif - #endif - exit (-1); - } -EOF - $CC_FOR_BUILD -o $dummy $dummy.c && - dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\(0-9*\).*/\1/p'` && - SYSTEM_NAME=`$dummy $dummyarg` && - { echo "$SYSTEM_NAME"; exit; } - echo mips-mips-riscos${UNAME_RELEASE} - exit ;; - Motorola:PowerMAX_OS:*:*) - echo powerpc-motorola-powermax - exit ;; - Motorola:*:4.3:PL8-*) - echo powerpc-harris-powermax - exit ;; - Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) - echo powerpc-harris-powermax - exit ;; - Night_Hawk:Power_UNIX:*:*) - echo powerpc-harris-powerunix - exit ;; - m88k:CX/UX:7*:*) - echo m88k-harris-cxux7 - exit ;; - m88k:*:4*:R4*) - echo m88k-motorola-sysv4 - exit ;; - m88k:*:3*:R3*) - echo m88k-motorola-sysv3 - exit ;; - AViiON:dgux:*:*) - # DG/UX returns AViiON for all architectures - UNAME_PROCESSOR=`/usr/bin/uname -p` - if $UNAME_PROCESSOR = mc88100 || $UNAME_PROCESSOR = mc88110 - then - if ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx || \ - ${TARGET_BINARY_INTERFACE}x = x - then - echo m88k-dg-dgux${UNAME_RELEASE} - else - echo m88k-dg-dguxbcs${UNAME_RELEASE} - fi - else - echo i586-dg-dgux${UNAME_RELEASE} - fi - exit ;; - M88*:DolphinOS:*:*) # DolphinOS (SVR3) - echo m88k-dolphin-sysv3 - exit ;; - M88*:*:R3*:*) - # Delta 88k system running SVR3 - echo m88k-motorola-sysv3 - exit ;; - XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) - echo m88k-tektronix-sysv3 - exit ;; - Tek430-90-9:UTek:*:*) # Tektronix 4300 system running UTek (BSD) - echo m68k-tektronix-bsd - exit ;; - *:IRIX*:*:*) - echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` - exit ;; - ????????:AIX?:12.1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. - echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id - exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' - i*86:AIX:*:*) - echo i386-ibm-aix - exit ;; - ia64:AIX:*:*) - if -x /usr/bin/oslevel ; then - IBM_REV=`/usr/bin/oslevel` - else - IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} - fi - echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} - exit ;; - *:AIX:2:3) - if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include <sys/systemcfg.h> - - main() - { - if (!__power_pc()) - exit(1); - puts("powerpc-ibm-aix3.2.5"); - exit(0); - } -EOF - if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` - then - echo "$SYSTEM_NAME" - else - echo rs6000-ibm-aix3.2.5 - fi - elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then - echo rs6000-ibm-aix3.2.4 - else - echo rs6000-ibm-aix3.2 - fi - exit ;; - *:AIX:*:456) - IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` - if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then - IBM_ARCH=rs6000 - else - IBM_ARCH=powerpc - fi - if -x /usr/bin/oslevel ; then - IBM_REV=`/usr/bin/oslevel` - else - IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} - fi - echo ${IBM_ARCH}-ibm-aix${IBM_REV} - exit ;; - *:AIX:*:*) - echo rs6000-ibm-aix - exit ;; - ibmrt:4.4BSD:*|romp-ibm:BSD:*) - echo romp-ibm-bsd4.4 - exit ;; - ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and - echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to - exit ;; # report: romp-ibm BSD 4.3 - *:BOSX:*:*) - echo rs6000-bull-bosx - exit ;; - DPX/2?00:B.O.S.:*:*) - echo m68k-bull-sysv3 - exit ;; - 9000/34??:4.3bsd:1.*:*) - echo m68k-hp-bsd - exit ;; - hp300:4.4BSD:*:* | 9000/34??:4.3bsd:2.*:*) - echo m68k-hp-bsd4.4 - exit ;; - 9000/34678??:HP-UX:*:*) - HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/^.*.0B*//'` - case "${UNAME_MACHINE}" in - 9000/31? ) HP_ARCH=m68000 ;; - 9000/34?? ) HP_ARCH=m68k ;; - 9000/6780-90-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 - eval $set_cc_for_build - - # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating - # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler - # generating 64-bit code. GNU and HP use different nomenclature: - # - # $ CC_FOR_BUILD=cc ./config.guess - # => hppa2.0w-hp-hpux11.23 - # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess - # => hppa64-hp-hpux11.23 - - if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | - grep __LP64__ >/dev/null - then - HP_ARCH="hppa2.0w" - else - HP_ARCH="hppa64" - fi - fi - echo ${HP_ARCH}-hp-hpux${HPUX_REV} - exit ;; - ia64:HP-UX:*:*) - HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/^.*.0B*//'` - echo ia64-hp-hpux${HPUX_REV} - exit ;; - 3050*:HI-UX:*:*) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include <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 && SYSTEM_NAME=`$dummy` && - { echo "$SYSTEM_NAME"; exit; } - echo unknown-hitachi-hiuxwe2 - exit ;; - 9000/7??:4.3bsd:*:* | 9000/8?79:4.3bsd:*:* ) - echo hppa1.1-hp-bsd - exit ;; - 9000/8??:4.3bsd:*:*) - echo hppa1.0-hp-bsd - exit ;; - *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) - echo hppa1.0-hp-mpeix - exit ;; - hp7??:OSF1:*:* | hp8?79:OSF1:*:* ) - echo hppa1.1-hp-osf - exit ;; - hp8??:OSF1:*:*) - echo hppa1.0-hp-osf - exit ;; - i*86:OSF1:*:*) - if -x /usr/sbin/sysversion ; then - echo ${UNAME_MACHINE}-unknown-osf1mk - else - echo ${UNAME_MACHINE}-unknown-osf1 - fi - exit ;; - parisc*:Lites*:*:*) - echo hppa1.1-hp-lites - exit ;; - C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) - echo c1-convex-bsd - exit ;; - C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) - if getsysinfo -f scalar_acc - then echo c32-convex-bsd - else echo c2-convex-bsd - fi - exit ;; - C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) - echo c34-convex-bsd - exit ;; - C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) - echo c38-convex-bsd - exit ;; - C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) - echo c4-convex-bsd - exit ;; - CRAY*Y-MP:*:*:*) - echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' - exit ;; - CRAY*A-Z90:*:*:*) - echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ - | sed -e 's/CRAY.*\(A-Z90\)/\1/' \ - -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ - -e 's/\.^.*$/.X/' - exit ;; - CRAY*TS:*:*:*) - echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' - exit ;; - CRAY*T3E:*:*:*) - echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' - exit ;; - CRAY*SV1:*:*:*) - echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' - exit ;; - *:UNICOS/mp:*:*) - echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.^.*$/.X/' - exit ;; - F3001:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) - FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` - FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` - FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` - echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" - exit ;; - 5000:UNIX_System_V:4.*:*) - FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` - FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` - echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" - exit ;; - i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) - echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} - exit ;; - sparc*:BSD/OS:*:*) - echo sparc-unknown-bsdi${UNAME_RELEASE} - exit ;; - *:BSD/OS:*:*) - echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} - exit ;; - *:FreeBSD:*:*) - case ${UNAME_MACHINE} in - pc98) - echo i386-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` ;; - amd64) - echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` ;; - *) - echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` ;; - esac - exit ;; - i*:CYGWIN*:*) - echo ${UNAME_MACHINE}-pc-cygwin - exit ;; - *:MINGW*:*) - echo ${UNAME_MACHINE}-pc-mingw32 - exit ;; - i*:windows32*:*) - # uname -m includes "-pc" on this system. - echo ${UNAME_MACHINE}-mingw32 - exit ;; - i*:PW*:*) - echo ${UNAME_MACHINE}-pc-pw32 - exit ;; - *:Interix*:3456*) - case ${UNAME_MACHINE} in - x86) - echo i586-pc-interix${UNAME_RELEASE} - exit ;; - EM64T | authenticamd) - echo x86_64-unknown-interix${UNAME_RELEASE} - exit ;; - IA64) - echo ia64-unknown-interix${UNAME_RELEASE} - exit ;; - esac ;; - 34586:Windows_95:* | 34586:Windows_98:* | 34586:Windows_NT:*) - echo i${UNAME_MACHINE}-pc-mks - exit ;; - i*:Windows_NT*:* | Pentium*:Windows_NT*:*) - # How do we know it's Interix rather than the generic POSIX subsystem? - # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we - # UNAME_MACHINE based on the output of uname instead of i386? - echo i586-pc-interix - exit ;; - i*:UWIN*:*) - echo ${UNAME_MACHINE}-pc-uwin - exit ;; - amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) - echo x86_64-unknown-cygwin - exit ;; - p*:CYGWIN*:*) - echo powerpcle-unknown-cygwin - exit ;; - prep*:SunOS:5.*:*) - echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/^.*//'` - exit ;; - *:GNU:*:*) - # the GNU system - echo `echo ${UNAME_MACHINE}|sed -e 's,-/.*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` - exit ;; - *:GNU/*:*:*) - # other systems with GNU libc and userland - echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^^/*/,,' | tr 'A-Z' 'a-z'``echo ${UNAME_RELEASE}|sed -e 's/-(.*//'`-gnu - exit ;; - i*86:Minix:*:*) - echo ${UNAME_MACHINE}-pc-minix - exit ;; - arm*:Linux:*:*) - eval $set_cc_for_build - if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ - | grep -q __ARM_EABI__ - then - echo ${UNAME_MACHINE}-unknown-linux-gnu - else - echo ${UNAME_MACHINE}-unknown-linux-gnueabi - fi - exit ;; - avr32*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - cris:Linux:*:*) - echo cris-axis-linux-gnu - exit ;; - crisv32:Linux:*:*) - echo crisv32-axis-linux-gnu - exit ;; - frv:Linux:*:*) - echo frv-unknown-linux-gnu - exit ;; - ia64:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - m32r*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - m68*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - mips:Linux:*:*) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #undef CPU - #undef mips - #undef mipsel - #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) - CPU=mipsel - #else - #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) - CPU=mips - #else - CPU= - #endif - #endif -EOF - eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' - /^CPU/{ - s: ::g - p - }'`" - test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } - ;; - mips64:Linux:*:*) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #undef CPU - #undef mips64 - #undef mips64el - #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) - CPU=mips64el - #else - #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) - CPU=mips64 - #else - CPU= - #endif - #endif -EOF - eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' - /^CPU/{ - s: ::g - p - }'`" - test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } - ;; - or32:Linux:*:*) - echo or32-unknown-linux-gnu - exit ;; - ppc:Linux:*:*) - echo powerpc-unknown-linux-gnu - exit ;; - ppc64:Linux:*:*) - echo powerpc64-unknown-linux-gnu - exit ;; - alpha:Linux:*:*) - case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in - EV5) UNAME_MACHINE=alphaev5 ;; - EV56) UNAME_MACHINE=alphaev56 ;; - PCA56) UNAME_MACHINE=alphapca56 ;; - PCA57) UNAME_MACHINE=alphapca56 ;; - EV6) UNAME_MACHINE=alphaev6 ;; - EV67) UNAME_MACHINE=alphaev67 ;; - EV68*) UNAME_MACHINE=alphaev68 ;; - esac - objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null - if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi - echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} - exit ;; - parisc:Linux:*:* | hppa:Linux:*:*) - # Look for CPU level - case `grep '^cpu^a-z*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in - PA7*) echo hppa1.1-unknown-linux-gnu ;; - PA8*) echo hppa2.0-unknown-linux-gnu ;; - *) echo hppa-unknown-linux-gnu ;; - esac - exit ;; - parisc64:Linux:*:* | hppa64:Linux:*:*) - echo hppa64-unknown-linux-gnu - exit ;; - s390:Linux:*:* | s390x:Linux:*:*) - echo ${UNAME_MACHINE}-ibm-linux - exit ;; - sh64*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - sh*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - sparc:Linux:*:* | sparc64:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - vax:Linux:*:*) - echo ${UNAME_MACHINE}-dec-linux-gnu - exit ;; - x86_64:Linux:*:*) - echo x86_64-unknown-linux-gnu - exit ;; - xtensa*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - i*86:Linux:*:*) - # The BFD linker knows what the default object file format is, so - # first see if it will tell us. cd to the root directory to prevent - # problems with other programs or directories called `ld' in the path. - # Set LC_ALL=C to ensure ld outputs messages in English. - ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \ - | sed -ne '/supported targets:/!d - s/ */ /g - s/.*supported targets: *// - s/ .*// - p'` - case "$ld_supported_targets" in - elf32-i386) - TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu" - ;; - a.out-i386-linux) - echo "${UNAME_MACHINE}-pc-linux-gnuaout" - exit ;; - coff-i386) - echo "${UNAME_MACHINE}-pc-linux-gnucoff" - exit ;; - "") - # Either a pre-BFD a.out linker (linux-gnuoldld) or - # one that does not give us useful --help. - echo "${UNAME_MACHINE}-pc-linux-gnuoldld" - exit ;; - esac - # Determine whether the default compiler is a.out or elf - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include <features.h> - #ifdef __ELF__ - # ifdef __GLIBC__ - # if __GLIBC__ >= 2 - LIBC=gnu - # else - LIBC=gnulibc1 - # endif - # else - LIBC=gnulibc1 - # endif - #else - #if defined(__INTEL_COMPILER) || defined(__PGI) || defined(__SUNPRO_C) || defined(__SUNPRO_CC) - LIBC=gnu - #else - LIBC=gnuaout - #endif - #endif - #ifdef __dietlibc__ - LIBC=dietlibc - #endif -EOF - eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' - /^LIBC/{ - s: ::g - p - }'`" - test x"${LIBC}" != x && { - echo "${UNAME_MACHINE}-pc-linux-${LIBC}" - exit - } - test x"${TENTATIVE}" != x && { echo "${TENTATIVE}"; exit; } - ;; - i*86:DYNIX/ptx:4*:*) - # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. - # earlier versions are messed up and put the nodename in both - # sysname and nodename. - echo i386-sequent-sysv4 - exit ;; - i*86:UNIX_SV:4.2MP:2.*) - # Unixware is an offshoot of SVR4, but it has its own version - # number series starting with 2... - # I am not positive that other SVR4 systems won't match this, - # I just have to hope. -- rms. - # Use sysv4.2uw... so that sysv4* matches it. - echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} - exit ;; - i*86:OS/2:*:*) - # If we were able to find `uname', then EMX Unix compatibility - # is probably installed. - echo ${UNAME_MACHINE}-pc-os2-emx - exit ;; - i*86:XTS-300:*:STOP) - echo ${UNAME_MACHINE}-unknown-stop - exit ;; - i*86:atheos:*:*) - echo ${UNAME_MACHINE}-unknown-atheos - exit ;; - i*86:syllable:*:*) - echo ${UNAME_MACHINE}-pc-syllable - exit ;; - i*86:LynxOS:2.*:* | i*86:LynxOS:3.01*:* | i*86:LynxOS:4.0*:*) - echo i386-unknown-lynxos${UNAME_RELEASE} - exit ;; - i*86:*DOS:*:*) - echo ${UNAME_MACHINE}-pc-msdosdjgpp - exit ;; - i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) - UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` - if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then - echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} - else - echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} - fi - exit ;; - i*86:*:5:678*) - # UnixWare 7.x, OpenUNIX and OpenServer 6. - case `/bin/uname -X | grep "^Machine"` in - *486*) UNAME_MACHINE=i486 ;; - *Pentium) UNAME_MACHINE=i586 ;; - *Pent*|*Celeron) UNAME_MACHINE=i686 ;; - esac - echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} - exit ;; - i*86:*:3.2:*) - if test -f /usr/options/cb.name; then - UNAME_REL=`sed -n 's/.*Version //p' </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 ;; - pc:*:*:*) - # Left here for compatibility: - # uname -m prints for DJGPP always 'pc', but it prints nothing about - # the processor, so we play safe by assuming i386. - echo i386-pc-msdosdjgpp - exit ;; - Intel:Mach:3*:*) - echo i386-pc-mach3 - exit ;; - paragon:*:*:*) - echo i860-intel-osf1 - exit ;; - i860:*:4.*:*) # i860-SVR4 - if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then - echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 - else # Add other i860-SVR4 vendors below as they are discovered. - echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 - fi - exit ;; - mini*:CTIX:SYS*5:*) - # "miniframe" - echo m68010-convergent-sysv - exit ;; - mc68k:UNIX:SYSTEM5:3.51m) - echo m68k-convergent-sysv - exit ;; - M680?0:D-NIX:5.3:*) - echo m68k-diab-dnix - exit ;; - M68*:*:R3V5678*:*) - test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; - 3345??:*:4.0:3.0 | 334??A:*:4.0:3.0 | 334??,*:*:4.0:3.0 | 334??/*:*: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-90-9\).*/\1/p' < /etc/.relid` - /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4.3${OS_REL}; exit; } - /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ - && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; - 334??:*:4.0:* | 334??,*:*:4.0:*) - /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4; exit; } ;; - m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) - echo m68k-unknown-lynxos${UNAME_RELEASE} - exit ;; - mc68030:UNIX_System_V:4.*:*) - echo m68k-atari-sysv4 - exit ;; - TSUNAMI:LynxOS:2.*:*) - echo sparc-unknown-lynxos${UNAME_RELEASE} - exit ;; - rs6000:LynxOS:2.*:*) - echo rs6000-unknown-lynxos${UNAME_RELEASE} - exit ;; - PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.01*:* | PowerPC:LynxOS:4.0*:*) - echo powerpc-unknown-lynxos${UNAME_RELEASE} - exit ;; - SMBES:UNIX_SV:*:*) - echo mips-dde-sysv${UNAME_RELEASE} - exit ;; - RM*:ReliantUNIX-*:*:*) - echo mips-sni-sysv4 - exit ;; - RM*:SINIX-*:*:*) - echo mips-sni-sysv4 - exit ;; - *:SINIX-*:*:*) - if uname -p 2>/dev/null >/dev/null ; then - UNAME_MACHINE=`(uname -p) 2>/dev/null` - echo ${UNAME_MACHINE}-sni-sysv4 - else - echo ns32k-sni-sysv - fi - exit ;; - PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort - # says <Richard.M.Bartel@ccMail.Census.GOV> - echo i586-unisys-sysv4 - exit ;; - *:UNIX_System_V:4*:FTX*) - # From Gerald Hewes <hewes@openmarket.com>. - # How about differentiating between stratus architectures? -djm - echo hppa1.1-stratus-sysv4 - exit ;; - *:*:*:FTX*) - # From seanf@swdc.stratus.com. - echo i860-stratus-sysv4 - exit ;; - i*86:VOS:*:*) - # From Paul.Green@stratus.com. - echo ${UNAME_MACHINE}-stratus-vos - exit ;; - *:VOS:*:*) - # From Paul.Green@stratus.com. - echo hppa1.1-stratus-vos - exit ;; - mc68*:A/UX:*:*) - echo m68k-apple-aux${UNAME_RELEASE} - exit ;; - news*:NEWS-OS:6*:*) - echo mips-sony-newsos6 - exit ;; - R34000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) - if -d /usr/nec ; then - echo mips-nec-sysv${UNAME_RELEASE} - else - echo mips-unknown-sysv${UNAME_RELEASE} - fi - exit ;; - BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. - echo powerpc-be-beos - exit ;; - BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. - echo powerpc-apple-beos - exit ;; - BePC:BeOS:*:*) # BeOS running on Intel PC compatible. - echo i586-pc-beos - exit ;; - SX-4:SUPER-UX:*:*) - echo sx4-nec-superux${UNAME_RELEASE} - exit ;; - SX-5:SUPER-UX:*:*) - echo sx5-nec-superux${UNAME_RELEASE} - exit ;; - SX-6:SUPER-UX:*:*) - echo sx6-nec-superux${UNAME_RELEASE} - exit ;; - SX-7:SUPER-UX:*:*) - echo sx7-nec-superux${UNAME_RELEASE} - exit ;; - SX-8:SUPER-UX:*:*) - echo sx8-nec-superux${UNAME_RELEASE} - exit ;; - SX-8R:SUPER-UX:*:*) - echo sx8r-nec-superux${UNAME_RELEASE} - exit ;; - Power*:Rhapsody:*:*) - echo powerpc-apple-rhapsody${UNAME_RELEASE} - exit ;; - *:Rhapsody:*:*) - echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} - exit ;; - *:Darwin:*:*) - UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown - case $UNAME_PROCESSOR in - unknown) UNAME_PROCESSOR=powerpc ;; - esac - echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} - exit ;; - *:procnto*:*:* | *:QNX:0123456789*:*) - UNAME_PROCESSOR=`uname -p` - if test "$UNAME_PROCESSOR" = "x86"; then - UNAME_PROCESSOR=i386 - UNAME_MACHINE=pc - fi - echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} - exit ;; - *:QNX:*:4*) - echo i386-pc-qnx - exit ;; - NSE-?:NONSTOP_KERNEL:*:*) - echo nse-tandem-nsk${UNAME_RELEASE} - exit ;; - NSR-?:NONSTOP_KERNEL:*:*) - echo nsr-tandem-nsk${UNAME_RELEASE} - exit ;; - *:NonStop-UX:*:*) - echo mips-compaq-nonstopux - exit ;; - BS2000:POSIX*:*:*) - echo bs2000-siemens-sysv - exit ;; - DS/*:UNIX_System_V:*:*) - echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} - exit ;; - *:Plan9:*:*) - # "uname -m" is not consistent, so use $cputype instead. 386 - # is converted to i386 for consistency with other x86 - # operating systems. - if test "$cputype" = "386"; then - UNAME_MACHINE=i386 - else - UNAME_MACHINE="$cputype" - fi - echo ${UNAME_MACHINE}-unknown-plan9 - exit ;; - *:TOPS-10:*:*) - echo pdp10-unknown-tops10 - exit ;; - *:TENEX:*:*) - echo pdp10-unknown-tenex - exit ;; - KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) - echo pdp10-dec-tops20 - exit ;; - XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) - echo pdp10-xkl-tops20 - exit ;; - *:TOPS-20:*:*) - echo pdp10-unknown-tops20 - exit ;; - *:ITS:*:*) - echo pdp10-unknown-its - exit ;; - SEI:*:*:SEIUX) - echo mips-sei-seiux${UNAME_RELEASE} - exit ;; - *:DragonFly:*:*) - echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/-(.*//'` - exit ;; - *:*VMS:*:*) - UNAME_MACHINE=`(uname -p) 2>/dev/null` - case "${UNAME_MACHINE}" in - A*) echo alpha-dec-vms ; exit ;; - I*) echo ia64-dec-vms ; exit ;; - V*) echo vax-dec-vms ; exit ;; - esac ;; - *:XENIX:*:SysV) - echo i386-pc-xenix - exit ;; - i*86:skyos:*:*) - echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' - exit ;; - i*86:rdos:*:*) - echo ${UNAME_MACHINE}-pc-rdos - exit ;; -esac - -#echo '(No uname command or uname output not recognized.)' 1>&2 -#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 - -eval $set_cc_for_build -cat >$dummy.c <<EOF -#ifdef _SEQUENT_ -# include <sys/types.h> -# include <sys/utsname.h> -#endif -main () -{ -#if defined (sony) -#if defined (MIPSEB) - /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, - I don't know.... */ - printf ("mips-sony-bsd\n"); exit (0); -#else -#include <sys/param.h> - printf ("m68k-sony-newsos%s\n", -#ifdef NEWSOS4 - "4" -#else - "" -#endif - ); exit (0); -#endif -#endif - -#if defined (__arm) && defined (__acorn) && defined (__unix) - printf ("arm-acorn-riscix\n"); exit (0); -#endif - -#if defined (hp300) && !defined (hpux) - printf ("m68k-hp-bsd\n"); exit (0); -#endif - -#if defined (NeXT) -#if !defined (__ARCHITECTURE__) -#define __ARCHITECTURE__ "m68k" -#endif - int version; - version=`(hostinfo | sed -n 's/.*NeXT Mach \(0-9*\).*/\1/p') 2>/dev/null`; - if (version < 4) - printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); - else - printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); - exit (0); -#endif - -#if defined (MULTIMAX) || defined (n16) -#if defined (UMAXV) - printf ("ns32k-encore-sysv\n"); exit (0); -#else -#if defined (CMU) - printf ("ns32k-encore-mach\n"); exit (0); -#else - printf ("ns32k-encore-bsd\n"); exit (0); -#endif -#endif -#endif - -#if defined (__386BSD__) - printf ("i386-pc-bsd\n"); exit (0); -#endif - -#if defined (sequent) -#if defined (i386) - printf ("i386-sequent-dynix\n"); exit (0); -#endif -#if defined (ns32000) - printf ("ns32k-sequent-dynix\n"); exit (0); -#endif -#endif - -#if defined (_SEQUENT_) - struct utsname un; - - uname(&un); - - if (strncmp(un.version, "V2", 2) == 0) { - printf ("i386-sequent-ptx2\n"); exit (0); - } - if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ - printf ("i386-sequent-ptx1\n"); exit (0); - } - printf ("i386-sequent-ptx\n"); exit (0); - -#endif - -#if defined (vax) -# if !defined (ultrix) -# include <sys/param.h> -# if defined (BSD) -# if BSD == 43 - printf ("vax-dec-bsd4.3\n"); exit (0); -# else -# if BSD == 199006 - printf ("vax-dec-bsd4.3reno\n"); exit (0); -# else - printf ("vax-dec-bsd\n"); exit (0); -# endif -# endif -# else - printf ("vax-dec-bsd\n"); exit (0); -# endif -# else - printf ("vax-dec-ultrix\n"); exit (0); -# endif -#endif - -#if defined (alliant) && defined (i860) - printf ("i860-alliant-bsd\n"); exit (0); -#endif - - exit (1); -} -EOF - -$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` && - { echo "$SYSTEM_NAME"; exit; } - -# Apollos put the system type in the environment. - -test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; } - -# Convex versions that predate uname can use getsysinfo(1) - -if -x /usr/convex/getsysinfo -then - case `getsysinfo -f cpu_type` in - c1*) - echo c1-convex-bsd - exit ;; - c2*) - if getsysinfo -f scalar_acc - then echo c32-convex-bsd - else echo c2-convex-bsd - fi - exit ;; - c34*) - echo c34-convex-bsd - exit ;; - c38*) - echo c38-convex-bsd - exit ;; - c4*) - echo c4-convex-bsd - exit ;; - esac -fi - -cat >&2 <<EOF -$0: unable to guess system type - -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://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD -and - http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD - -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@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:
View file
linuxsampler-1.0.0.tar.bz2/config.h.in
Deleted
@@ -1,260 +0,0 @@ -/* config.h.in. Generated from configure.in by autoheader. */ - -/* Define to the major version number of your Alsa installation. */ -#undef ALSA_MAJOR - -/* Define to the minor version number of your Alsa installation. */ -#undef ALSA_MINOR - -/* Define to the subminor version number of your Alsa installation. */ -#undef ALSA_SUBMINOR - -/* Define to 1 if you build for x86 architecture. */ -#undef ARCH_X86 - -/* Define to 1 if you want to enable asm optimizations. */ -#undef CONFIG_ASM - -/* Define to 1 if you want to enable GS SysEx check. */ -#undef CONFIG_ASSERT_GS_SYSEX_CHECKSUM - -/* Define console verbosity. */ -#undef CONFIG_DEBUG_LEVEL - -/* Only when instruments DB feature is enabled: default location of the DB - file. */ -#undef CONFIG_DEFAULT_INSTRUMENTS_DB_LOCATION - -/* Define initial max. streams. */ -#undef CONFIG_DEFAULT_MAX_STREAMS - -/* Define initial max. voices. */ -#undef CONFIG_DEFAULT_MAX_VOICES - -/* Define default subfragment size (in sample points). */ -#undef CONFIG_DEFAULT_SUBFRAGMENT_SIZE - -/* Define to 1 if you want to enable development mode. */ -#undef CONFIG_DEVMODE - -/* Define bottom limit of envelopes. */ -#undef CONFIG_EG_BOTTOM - -/* Define min. release time. */ -#undef CONFIG_EG_MIN_RELEASE_TIME - -/* Define max. filter cutoff frequency. */ -#undef CONFIG_FILTER_CUTOFF_MAX - -/* Define min. filter cutoff frequency. */ -#undef CONFIG_FILTER_CUTOFF_MIN - -/* Define to 1 to force filter usage. */ -#undef CONFIG_FORCE_FILTER - -/* Define default global volume attenuation (as floating point factor). */ -#undef CONFIG_GLOBAL_ATTENUATION_DEFAULT - -/* Define to 1 if you want to enable interpolation of volume modulation. */ -#undef CONFIG_INTERPOLATE_VOLUME - -/* Define to 1 if you want global volume sysex message only be applied to the - respective MIDI port. */ -#undef CONFIG_MASTER_VOLUME_SYSEX_BY_PORT - -/* Define max. allowed events per fragment. */ -#undef CONFIG_MAX_EVENTS_PER_FRAGMENT - -/* Define max. allowed pitch. */ -#undef CONFIG_MAX_PITCH - -/* Define to a MIDI controller number to override cutoff control. */ -#undef CONFIG_OVERRIDE_CUTOFF_CTRL - -/* Define to a filter type to always force that filter type. */ -#undef CONFIG_OVERRIDE_FILTER_TYPE - -/* Define to a MIDI controller number to override resonance control. */ -#undef CONFIG_OVERRIDE_RESONANCE_CTRL - -/* Define default portamento time. */ -#undef CONFIG_PORTAMENTO_TIME_DEFAULT - -/* Define max. portamento time. */ -#undef CONFIG_PORTAMENTO_TIME_MAX - -/* Define min. portamento time. */ -#undef CONFIG_PORTAMENTO_TIME_MIN - -/* Define amount of sample points to be cached in RAM. */ -#undef CONFIG_PRELOAD_SAMPLES - -/* Define to 1 if you want to enable processing of All-Notes-Off MIDI - messages. */ -#undef CONFIG_PROCESS_ALL_NOTES_OFF - -/* Define to 1 if you want to enable processing of muted channels. */ -#undef CONFIG_PROCESS_MUTED_CHANNELS - -/* Define to 1 to enable pthread_testcancel() calls. */ -#undef CONFIG_PTHREAD_TESTCANCEL - -/* Define amount of streams to be refilled per cycle. */ -#undef CONFIG_REFILL_STREAMS_PER_RUN - -/* Define to 1 to allow exceptions in the realtime context. */ -#undef CONFIG_RT_EXCEPTIONS - -/* Define signed triangular wave algorithm to be used. */ -#undef CONFIG_SIGNED_TRIANG_ALGO - -/* Define each stream's ring buffer size. */ -#undef CONFIG_STREAM_BUFFER_SIZE - -/* Define max. stream refill size. */ -#undef CONFIG_STREAM_MAX_REFILL_SIZE - -/* Define min. stream refill size. */ -#undef CONFIG_STREAM_MIN_REFILL_SIZE - -/* Define SysEx buffer size. */ -#undef CONFIG_SYSEX_BUFFER_SIZE - -/* Define unsigned triangular wave algorithm to be used. */ -#undef CONFIG_UNSIGNED_TRIANG_ALGO - -/* Define voice stealing algorithm to be used. */ -#undef CONFIG_VOICE_STEAL_ALGO - -/* Define to 1 if you have ALSA installed. */ -#undef HAVE_ALSA - -/* Define to 1 if you have aRts installed. */ -#undef HAVE_ARTS - -/* Define to 1 if you have ASIO installed. */ -#undef HAVE_ASIO - -/* Define to 1 if you have the <AudioUnit/AudioUnit.h> header file. */ -#undef HAVE_AUDIOUNIT_AUDIOUNIT_H - -/* Define to 1 if you have CoreAudio installed. */ -#undef HAVE_COREAUDIO - -/* Define to 1 if you have CoreMIDI installed. */ -#undef HAVE_COREMIDI - -/* Define to 1 if you have the <dlfcn.h> header file. */ -#undef HAVE_DLFCN_H - -/* Define to 1 if you have the <dssi.h> header file. */ -#undef HAVE_DSSI_H - -/* Define to 1 if you have the <features.h> header file. */ -#undef HAVE_FEATURES_H - -/* Define to 1 if you have the <inttypes.h> header file. */ -#undef HAVE_INTTYPES_H - -/* Define to 1 if you have JACK installed. */ -#undef HAVE_JACK - -/* Define to 1 if you have the `jack_client_name_size' function. */ -#undef HAVE_JACK_CLIENT_NAME_SIZE - -/* Define to 1 if you have the `jack_client_open' function. */ -#undef HAVE_JACK_CLIENT_OPEN - -/* Define to 1 if you have JACK with MIDI support installed. */ -#undef HAVE_JACK_MIDI - -/* Define to 1 if you have the `jack_midi_get_event_count' function. */ -#undef HAVE_JACK_MIDI_GET_EVENT_COUNT - -/* Define to 1 if you have the `artsc' library (-lartsc). */ -#undef HAVE_LIBARTSC - -/* Define to 1 if you have the <memory.h> header file. */ -#undef HAVE_MEMORY_H - -/* Define to 1 if you have MidiShare installed. */ -#undef HAVE_MIDISHARE - -/* Define to 1 if you have MME MIDI installed. */ -#undef HAVE_MME_MIDI - -/* Define to 1 if you have the <mmsystem.h> header file. */ -#undef HAVE_MMSYSTEM_H - -/* Define if you have POSIX threads libraries and header files. */ -#undef HAVE_PTHREAD - -/* Define to 1 if you want the instruments DB feature and have SQLITE3 - installed. */ -#undef HAVE_SQLITE3 - -/* Define to 1 if you have the <stdint.h> header file. */ -#undef HAVE_STDINT_H - -/* Define to 1 if you have the <stdlib.h> header file. */ -#undef HAVE_STDLIB_H - -/* Define to 1 if you have the <strings.h> header file. */ -#undef HAVE_STRINGS_H - -/* Define to 1 if you have the <string.h> header file. */ -#undef HAVE_STRING_H - -/* Define to 1 if you have the <sys/stat.h> header file. */ -#undef HAVE_SYS_STAT_H - -/* Define to 1 if you have the <sys/types.h> header file. */ -#undef HAVE_SYS_TYPES_H - -/* Define to 1 if you have the <unistd.h> header file. */ -#undef HAVE_UNISTD_H - -/* Define to 1 if you have the <uuid/uuid.h> header file. */ -#undef HAVE_UUID_UUID_H - -/* Define to 1 if you have the old jack midi functions that need an nframes - argument. */ -#undef JACK_MIDI_FUNCS_NEED_NFRAMES - -/* LSCP spec major version this release complies with. */ -#undef LSCP_RELEASE_MAJOR - -/* LSCP spec minor version this release complies with. */ -#undef LSCP_RELEASE_MINOR - -/* Name of package */ -#undef PACKAGE - -/* Define to the address where bug reports for this package should be sent. */ -#undef PACKAGE_BUGREPORT - -/* Define to the full name of this package. */ -#undef PACKAGE_NAME - -/* Define to the full name and version of this package. */ -#undef PACKAGE_STRING - -/* Define to the one symbol short name of this package. */ -#undef PACKAGE_TARNAME - -/* Define to the version of this package. */ -#undef PACKAGE_VERSION - -/* Define to necessary symbol if this constant uses a non-standard name on - your system. */ -#undef PTHREAD_CREATE_JOINABLE - -/* Define to 1 if you have the ANSI C header files. */ -#undef STDC_HEADERS - -/* Version number of package */ -#undef VERSION - -/* Define to 1 if your processor stores words with the most significant byte - first (like Motorola and SPARC, unlike Intel and VAX). */ -#undef WORDS_BIGENDIAN
View file
linuxsampler-1.0.0.tar.bz2/config.sub
Deleted
@@ -1,1658 +0,0 @@ -#! /bin/sh -# Configuration validation subroutine script. -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, -# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -# Free Software Foundation, Inc. - -timestamp='2008-01-16' - -# 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., 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. - - -# Please send patches to <config-patches@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@gnu.org>." - -version="\ -GNU config.sub ($timestamp) - -Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, -2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. - -This is free software; see the source for copying conditions. There is NO -warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." - -help=" -Try \`$me --help' for more information." - -# Parse command line -while test $# -gt 0 ; do - case $1 in - --time-stamp | --time* | -t ) - echo "$timestamp" ; exit ;; - --version | -v ) - echo "$version" ; exit ;; - --help | --h* | -h ) - echo "$usage"; exit ;; - -- ) # Stop option processing - shift; break ;; - - ) # Use stdin as input. - break ;; - -* ) - echo "$me: invalid option $1$help" - exit 1 ;; - - *local*) - # First pass through any local machine types. - echo $1 - exit ;; - - * ) - break ;; - esac -done - -case $# in - 0) echo "$me: missing argument$help" >&2 - exit 1;; - 1) ;; - *) echo "$me: too many arguments$help" >&2 - exit 1;; -esac - -# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). -# Here we must recognize all the valid KERNEL-OS combinations. -maybe_os=`echo $1 | sed 's/^\(.*\)-\(^-*-^-*\)$/\2/'` -case $maybe_os in - nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \ - uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \ - storm-chaos* | os2-emx* | rtmk-nova*) - os=-$maybe_os - basic_machine=`echo $1 | sed 's/^\(.*\)-\(^-*-^-*\)$/\1/'` - ;; - *) - basic_machine=`echo $1 | sed 's/-^-*$//'` - if $basic_machine != $1 - then os=`echo $1 | sed 's/.*-/-/'` - else os=; fi - ;; -esac - -### Let's recognize common machines as not being operating systems so -### that things like config.sub decstation-3100 work. We also -### recognize some manufacturers as not being operating systems, so we -### can provide default operating systems below. -case $os in - -sun*os*) - # Prevent following clause from handling this invalid input. - ;; - -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ - -att* | -7300* | -3300* | -delta* | -motorola* | -sun234* | \ - -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ - -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ - -c123* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ - -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ - -apple | -axis | -knuth | -cray) - os= - basic_machine=$1 - ;; - -sim | -cisco | -oki | -wec | -winbond) - os= - basic_machine=$1 - ;; - -scout) - ;; - -wrs) - os=-vxworks - basic_machine=$1 - ;; - -chorusos*) - os=-chorusos - basic_machine=$1 - ;; - -chorusrdb) - os=-chorusrdb - basic_machine=$1 - ;; - -hiux*) - os=-hiuxwe2 - ;; - -sco6) - os=-sco5v6 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco5) - os=-sco3.2v5 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco4) - os=-sco3.2v4 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco3.2.4-9*) - os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco3.2v4-9*) - # Don't forget version if it is 3.2v4 or newer. - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco5v6*) - # Don't forget version if it is 3.2v4 or newer. - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco*) - os=-sco3.2v2 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -udk*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -isc) - os=-isc2.2 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -clix*) - basic_machine=clipper-intergraph - ;; - -isc*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -lynx*) - os=-lynxos - ;; - -ptx*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` - ;; - -windowsnt*) - os=`echo $os | sed -e 's/windowsnt/winnt/'` - ;; - -psos*) - os=-psos - ;; - -mint | -mint0-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 | alphaev4-8 | alphaev56 | alphaev678 | alphapca567 \ - | alpha64 | alpha64ev4-8 | alpha64ev56 | alpha64ev678 | alpha64pca567 \ - | am33_2.0 \ - | arc | arm | armble | armelb | armv2345 | armv345lb | avr | avr32 \ - | bfin \ - | c4x | clipper \ - | d10v | d30v | dlx | dsp16xx \ - | fido | fr30 | frv \ - | h8300 | h8500 | hppa | hppa1.01 | hppa2.0 | hppa2.0nw | hppa64 \ - | i370 | i860 | i960 | ia64 \ - | ip2k | iq2000 \ - | m32c | m32r | m32rle | m68000 | m68k | m88k \ - | maxq | mb | microblaze | mcore | mep \ - | mips | mipsbe | mipseb | mipsel | mipsle \ - | mips16 \ - | mips64 | mips64el \ - | mips64vr | mips64vrel \ - | mips64orion | mips64orionel \ - | mips64vr4100 | mips64vr4100el \ - | mips64vr4300 | mips64vr4300el \ - | mips64vr5000 | mips64vr5000el \ - | mips64vr5900 | mips64vr5900el \ - | mipsisa32 | mipsisa32el \ - | mipsisa32r2 | mipsisa32r2el \ - | mipsisa64 | mipsisa64el \ - | mipsisa64r2 | mipsisa64r2el \ - | mipsisa64sb1 | mipsisa64sb1el \ - | mipsisa64sr71k | mipsisa64sr71kel \ - | mipstx39 | mipstx39el \ - | mn10200 | mn10300 \ - | mt \ - | msp430 \ - | nios | nios2 \ - | ns16k | ns32k \ - | or32 \ - | pdp10 | pdp11 | pj | pjl \ - | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \ - | pyramid \ - | score \ - | sh | sh1234 | sh24a | sh23e | sh34eb | sheb | shbe | shle | sh1234le | sh3ele \ - | sh64 | sh64le \ - | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ - | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ - | spu | strongarm \ - | tahoe | thumb | tic4x | tic80 | tron \ - | v850 | v850e \ - | we32k \ - | x86 | xc16x | xscale | xscaleebl | xstormy16 | xtensa \ - | z8k) - basic_machine=$basic_machine-unknown - ;; - m6811 | m68hc11 | m6812 | m68hc12) - # Motorola 68HC11/12. - basic_machine=$basic_machine-unknown - os=-none - ;; - m88110 | m680123460 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) - ;; - ms1) - basic_machine=mt-unknown - ;; - - # We use `pc' rather than `unknown' - # because (1) that's what they normally are, and - # (2) the word "unknown" tends to confuse beginning users. - i*86 | x86_64) - basic_machine=$basic_machine-pc - ;; - # Object if more than one company name word. - *-*-*) - echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 - exit 1 - ;; - # Recognize the basic CPU types with company name. - 580-* \ - | a29k-* \ - | alpha-* | alphaev4-8-* | alphaev56-* | alphaev678-* \ - | alpha64-* | alpha64ev4-8-* | alpha64ev56-* | alpha64ev678-* \ - | alphapca567-* | alpha64pca567-* | arc-* \ - | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ - | avr-* | avr32-* \ - | bfin-* | bs2000-* \ - | c123* | c30-* | cjt90-* | c4x-* | c54x-* | c55x-* | c6x-* \ - | clipper-* | craynv-* | cydra-* \ - | d10v-* | d30v-* | dlx-* \ - | elxsi-* \ - | f3001-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ - | h8300-* | h8500-* \ - | hppa-* | hppa1.01-* | hppa2.0-* | hppa2.0nw-* | hppa64-* \ - | i*86-* | i860-* | i960-* | ia64-* \ - | ip2k-* | iq2000-* \ - | m32c-* | m32r-* | m32rle-* \ - | m68000-* | m6800123460-* | m68360-* | m683?2-* | m68k-* \ - | m88110-* | m88k-* | maxq-* | mcore-* \ - | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ - | mips16-* \ - | mips64-* | mips64el-* \ - | mips64vr-* | mips64vrel-* \ - | mips64orion-* | mips64orionel-* \ - | mips64vr4100-* | mips64vr4100el-* \ - | mips64vr4300-* | mips64vr4300el-* \ - | mips64vr5000-* | mips64vr5000el-* \ - | mips64vr5900-* | mips64vr5900el-* \ - | mipsisa32-* | mipsisa32el-* \ - | mipsisa32r2-* | mipsisa32r2el-* \ - | mipsisa64-* | mipsisa64el-* \ - | mipsisa64r2-* | mipsisa64r2el-* \ - | mipsisa64sb1-* | mipsisa64sb1el-* \ - | mipsisa64sr71k-* | mipsisa64sr71kel-* \ - | mipstx39-* | mipstx39el-* \ - | mmix-* \ - | mt-* \ - | msp430-* \ - | nios-* | nios2-* \ - | none-* | np1-* | ns16k-* | ns32k-* \ - | orion-* \ - | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ - | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \ - | pyramid-* \ - | romp-* | rs6000-* \ - | sh-* | sh1234-* | sh24a-* | sh23e-* | sh34eb-* | sheb-* | shbe-* \ - | shle-* | sh1234le-* | sh3ele-* | sh64-* | sh64le-* \ - | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ - | sparclite-* \ - | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | strongarm-* | sv1-* | sx?-* \ - | tahoe-* | thumb-* \ - | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ - | tron-* \ - | v850-* | v850e-* | vax-* \ - | we32k-* \ - | x86-* | x86_64-* | xc16x-* | xps100-* | xscale-* | xscaleebl-* \ - | xstormy16-* | xtensa*-* \ - | ymp-* \ - | z8k-*) - ;; - # Recognize the basic CPU types without company name, with glob match. - xtensa*) - basic_machine=$basic_machine-unknown - ;; - # 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 - ;; - blackfin) - basic_machine=bfin-unknown - os=-linux - ;; - blackfin-*) - basic_machine=bfin-`echo $basic_machine | sed 's/^^-*-//'` - os=-linux - ;; - 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 - ;; - cr16) - basic_machine=cr16-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 - ;; - hp3k90-90-9 | hp90-90-9) - basic_machine=hppa1.0-hp - ;; - hp9k20-90-9 | hp9k310-9) - basic_machine=m68000-hp - ;; - hp9k32-90-9) - basic_machine=m68k-hp - ;; - hp9k60-90-9 | hp60-90-9) - basic_machine=hppa1.0-hp - ;; - hp9k70-790-9 | hp70-790-9) - basic_machine=hppa1.1-hp - ;; - hp9k780-9 | hp780-9) - # FIXME: really hppa2.0-hp - basic_machine=hppa1.1-hp - ;; - hp9k8671 | hp8671 | hp9k8024 | hp8024 | hp9k8789 | hp8789 | hp9k893 | hp893) - # FIXME: really hppa2.0-hp - basic_machine=hppa1.1-hp - ;; - hp9k80-913679 | hp80-913679) - basic_machine=hppa1.1-hp - ;; - hp9k80-90-9 | hp80-90-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 - ;; - m68knommu) - basic_machine=m68k-unknown - os=-linux - ;; - m68knommu-*) - basic_machine=m68k-`echo $basic_machine | sed 's/^^-*-//'` - os=-linux - ;; - 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 - ;; - mingw32ce) - basic_machine=arm-unknown - os=-mingw32ce - ;; - miniframe) - basic_machine=m68000-convergent - ;; - *mint | -mint0-9* | *MiNT | *MiNT0-9*) - basic_machine=m68k-atari - os=-mint - ;; - mips3*-*) - basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` - ;; - mips3*) - basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown - ;; - monitor) - basic_machine=m68k-rom68k - os=-coff - ;; - morphos) - basic_machine=powerpc-unknown - os=-morphos - ;; - msdos) - basic_machine=i386-pc - os=-msdos - ;; - ms1-*) - basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` - ;; - mvs) - basic_machine=i370-ibm - os=-mvs - ;; - ncr3000) - basic_machine=i486-ncr - os=-sysv4 - ;; - netbsd386) - basic_machine=i386-unknown - os=-netbsd - ;; - netwinder) - basic_machine=armv4l-rebel - os=-linux - ;; - news | news700 | news800 | news900) - basic_machine=m68k-sony - os=-newsos - ;; - news1000) - basic_machine=m68030-sony - os=-newsos - ;; - news-3600 | risc-news) - basic_machine=mips-sony - os=-newsos - ;; - necv70) - basic_machine=v70-nec - os=-sysv - ;; - next | m*-next ) - basic_machine=m68k-next - case $os in - -nextstep* ) - ;; - -ns2*) - os=-nextstep2 - ;; - *) - os=-nextstep3 - ;; - esac - ;; - nh3000) - basic_machine=m68k-harris - os=-cxux - ;; - nh45000) - basic_machine=m88k-harris - os=-cxux - ;; - nindy960) - basic_machine=i960-intel - os=-nindy - ;; - mon960) - basic_machine=i960-intel - os=-mon960 - ;; - nonstopux) - basic_machine=mips-compaq - os=-nonstopux - ;; - np1) - basic_machine=np1-gould - ;; - nsr-tandem) - basic_machine=nsr-tandem - ;; - op50n-* | op60c-*) - basic_machine=hppa1.1-oki - os=-proelf - ;; - openrisc | openrisc-*) - basic_machine=or32-unknown - ;; - os400) - basic_machine=powerpc-ibm - os=-os400 - ;; - OSE68000 | ose68000) - basic_machine=m68000-ericsson - os=-ose - ;; - os68k) - basic_machine=m68k-none - os=-os68k - ;; - pa-hitachi) - basic_machine=hppa1.1-hitachi - os=-hiuxwe2 - ;; - paragon) - basic_machine=i860-intel - os=-osf - ;; - parisc) - basic_machine=hppa-unknown - os=-linux - ;; - parisc-*) - basic_machine=hppa-`echo $basic_machine | sed 's/^^-*-//'` - os=-linux - ;; - pbd) - basic_machine=sparc-tti - ;; - pbb) - basic_machine=m68k-tti - ;; - pc532 | pc532-*) - basic_machine=ns32k-pc532 - ;; - pc98) - basic_machine=i386-pc - ;; - pc98-*) - basic_machine=i386-`echo $basic_machine | sed 's/^^-*-//'` - ;; - pentium | p5 | k5 | k6 | nexgen | viac3) - basic_machine=i586-pc - ;; - pentiumpro | p6 | 6x86 | athlon | athlon_*) - basic_machine=i686-pc - ;; - pentiumii | pentium2 | pentiumiii | pentium3) - basic_machine=i686-pc - ;; - pentium4) - basic_machine=i786-pc - ;; - pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) - basic_machine=i586-`echo $basic_machine | sed 's/^^-*-//'` - ;; - pentiumpro-* | p6-* | 6x86-* | athlon-*) - basic_machine=i686-`echo $basic_machine | sed 's/^^-*-//'` - ;; - pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) - basic_machine=i686-`echo $basic_machine | sed 's/^^-*-//'` - ;; - pentium4-*) - basic_machine=i786-`echo $basic_machine | sed 's/^^-*-//'` - ;; - pn) - basic_machine=pn-gould - ;; - power) basic_machine=power-ibm - ;; - ppc) basic_machine=powerpc-unknown - ;; - ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^^-*-//'` - ;; - ppcle | powerpclittle | ppc-le | powerpc-little) - basic_machine=powerpcle-unknown - ;; - ppcle-* | powerpclittle-*) - basic_machine=powerpcle-`echo $basic_machine | sed 's/^^-*-//'` - ;; - ppc64) basic_machine=powerpc64-unknown - ;; - ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^^-*-//'` - ;; - ppc64le | powerpc64little | ppc64-le | powerpc64-little) - basic_machine=powerpc64le-unknown - ;; - ppc64le-* | powerpc64little-*) - basic_machine=powerpc64le-`echo $basic_machine | sed 's/^^-*-//'` - ;; - ps2) - basic_machine=i386-ibm - ;; - pw32) - basic_machine=i586-unknown - os=-pw32 - ;; - rdos) - basic_machine=i386-pc - os=-rdos - ;; - rom68k) - basic_machine=m68k-rom68k - os=-coff - ;; - rm4600) - basic_machine=mips-siemens - ;; - rtpc | rtpc-*) - basic_machine=romp-ibm - ;; - s390 | s390-*) - basic_machine=s390-ibm - ;; - s390x | s390x-*) - basic_machine=s390x-ibm - ;; - sa29200) - basic_machine=a29k-amd - os=-udi - ;; - sb1) - basic_machine=mipsisa64sb1-unknown - ;; - sb1el) - basic_machine=mipsisa64sb1el-unknown - ;; - sde) - basic_machine=mipsisa32-sde - os=-elf - ;; - sei) - basic_machine=mips-sei - os=-seiux - ;; - sequent) - basic_machine=i386-sequent - ;; - sh) - basic_machine=sh-hitachi - os=-hms - ;; - sh5el) - basic_machine=sh5le-unknown - ;; - sh64) - basic_machine=sh64-unknown - ;; - sparclite-wrs | simso-wrs) - basic_machine=sparclite-wrs - os=-vxworks - ;; - sps7) - basic_machine=m68k-bull - os=-sysv2 - ;; - spur) - basic_machine=spur-unknown - ;; - st2000) - basic_machine=m68k-tandem - ;; - stratus) - basic_machine=i860-stratus - os=-sysv4 - ;; - sun2) - basic_machine=m68000-sun - ;; - sun2os3) - basic_machine=m68000-sun - os=-sunos3 - ;; - sun2os4) - basic_machine=m68000-sun - os=-sunos4 - ;; - sun3os3) - basic_machine=m68k-sun - os=-sunos3 - ;; - sun3os4) - basic_machine=m68k-sun - os=-sunos4 - ;; - sun4os3) - basic_machine=sparc-sun - os=-sunos3 - ;; - sun4os4) - basic_machine=sparc-sun - os=-sunos4 - ;; - sun4sol2) - basic_machine=sparc-sun - os=-solaris2 - ;; - sun3 | sun3-*) - basic_machine=m68k-sun - ;; - sun4) - basic_machine=sparc-sun - ;; - sun386 | sun386i | roadrunner) - basic_machine=i386-sun - ;; - sv1) - basic_machine=sv1-cray - os=-unicos - ;; - symmetry) - basic_machine=i386-sequent - os=-dynix - ;; - t3e) - basic_machine=alphaev5-cray - os=-unicos - ;; - t90) - basic_machine=t90-cray - os=-unicos - ;; - tic54x | c54x*) - basic_machine=tic54x-unknown - os=-coff - ;; - tic55x | c55x*) - basic_machine=tic55x-unknown - os=-coff - ;; - tic6x | c6x*) - basic_machine=tic6x-unknown - os=-coff - ;; - tile*) - basic_machine=tile-unknown - os=-linux-gnu - ;; - 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 - ;; - sh1234 | sh24a | sh34eb | sh1234le | sh23ele) - basic_machine=sh-unknown - ;; - sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) - basic_machine=sparc-sun - ;; - cydra) - basic_machine=cydra-cydrome - ;; - orion) - basic_machine=orion-highlevel - ;; - orion105) - basic_machine=clipper-highlevel - ;; - mac | mpw | mac-mpw) - basic_machine=m68k-apple - ;; - pmac | pmac-mpw) - basic_machine=powerpc-apple - ;; - *-unknown) - # Make sure to match an already-canonicalized machine name. - ;; - *) - echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 - exit 1 - ;; -esac - -# Here we canonicalize certain aliases for manufacturers. -case $basic_machine in - *-digital*) - basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` - ;; - *-commodore*) - basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` - ;; - *) - ;; -esac - -# Decode manufacturer-specific aliases for certain operating systems. - -if x"$os" != x"" -then -case $os in - # First match some system type aliases - # that might get confused with valid system types. - # -solaris* is a basic system type, with this one exception. - -solaris1 | -solaris1.*) - os=`echo $os | sed -e 's|solaris1|sunos4|'` - ;; - -solaris) - os=-solaris2 - ;; - -svr4*) - os=-sysv4 - ;; - -unixware*) - os=-sysv4.2uw - ;; - -gnu/linux*) - os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` - ;; - # First accept the basic system types. - # The portable systems comes first. - # Each alternative MUST END IN A *, to match a version number. - # -sysv* is not here because it comes later, after sysvr4. - -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ - | -*vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos34*\ - | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \ - | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ - | -aos* \ - | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ - | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ - | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ - | -openbsd* | -solidbsd* \ - | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ - | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ - | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ - | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ - | -chorusos* | -chorusrdb* \ - | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ - | -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \ - | -uxpv* | -beos* | -mpeix* | -udk* \ - | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ - | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ - | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ - | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ - | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ - | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ - | -skyos* | -haiku* | -rdos* | -toppers* | -drops*) - # Remember, each alternative MUST END IN *, to match a version number. - ;; - -qnx*) - case $basic_machine in - x86-* | i*86-*) - ;; - *) - os=-nto$os - ;; - esac - ;; - -nto-qnx*) - ;; - -nto*) - os=`echo $os | sed -e 's|nto|nto-qnx|'` - ;; - -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ - | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ - | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) - ;; - -mac*) - os=`echo $os | sed -e 's|mac|macos|'` - ;; - -linux-dietlibc) - os=-linux-dietlibc - ;; - -linux*) - os=`echo $os | sed -e 's|linux|linux-gnu|'` - ;; - -sunos5*) - os=`echo $os | sed -e 's|sunos5|solaris2|'` - ;; - -sunos6*) - os=`echo $os | sed -e 's|sunos6|solaris3|'` - ;; - -opened*) - os=-openedition - ;; - -os400*) - os=-os400 - ;; - -wince*) - os=-wince - ;; - -osfrose*) - os=-osfrose - ;; - -osf*) - os=-osf - ;; - -utek*) - os=-bsd - ;; - -dynix*) - os=-bsd - ;; - -acis*) - os=-aos - ;; - -atheos*) - os=-atheos - ;; - -syllable*) - os=-syllable - ;; - -386bsd) - os=-bsd - ;; - -ctix* | -uts*) - os=-sysv - ;; - -nova*) - os=-rtmk-nova - ;; - -ns2 ) - os=-nextstep2 - ;; - -nsk*) - os=-nsk - ;; - # Preserve the version number of sinix5. - -sinix5.*) - os=`echo $os | sed -e 's|sinix|sysv|'` - ;; - -sinix*) - os=-sysv4 - ;; - -tpf*) - os=-tpf - ;; - -triton*) - os=-sysv3 - ;; - -oss*) - os=-sysv3 - ;; - -svr4) - os=-sysv4 - ;; - -svr3) - os=-sysv3 - ;; - -sysvr4) - os=-sysv4 - ;; - # This must come after -sysvr4. - -sysv*) - ;; - -ose*) - os=-ose - ;; - -es1800*) - os=-ose - ;; - -xenix) - os=-xenix - ;; - -*mint | -mint0-9* | -*MiNT | -MiNT0-9*) - os=-mint - ;; - -aros*) - os=-aros - ;; - -kaos*) - os=-kaos - ;; - -zvmoe) - os=-zvmoe - ;; - -none) - ;; - *) - # Get rid of the `-' at the beginning of $os. - os=`echo $os | sed 's/^-*-//'` - echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 - exit 1 - ;; -esac -else - -# Here we handle the default operating systems that come with various machines. -# The value should be what the vendor currently ships out the door with their -# machine or put another way, the most popular os provided with the machine. - -# Note that if you're going to try to match "-MANUFACTURER" here (say, -# "-sun"), then you have to tell the case statement up towards the top -# that MANUFACTURER isn't an operating system. Otherwise, code above -# will signal an error saying that MANUFACTURER isn't an operating -# system, and we'll never get to this point. - -case $basic_machine in - score-*) - os=-elf - ;; - spu-*) - os=-elf - ;; - *-acorn) - os=-riscix1.2 - ;; - arm*-rebel) - os=-linux - ;; - arm*-semi) - os=-aout - ;; - c4x-* | tic4x-*) - os=-coff - ;; - # This must come before the *-dec entry. - pdp10-*) - os=-tops20 - ;; - pdp11-*) - os=-none - ;; - *-dec | vax-*) - os=-ultrix4.2 - ;; - m68*-apollo) - os=-domain - ;; - i386-sun) - os=-sunos4.0.2 - ;; - m68000-sun) - os=-sunos3 - # This also exists in the configure program, but was not the - # default. - # os=-sunos4 - ;; - m68*-cisco) - os=-aout - ;; - mep-*) - os=-elf - ;; - mips*-cisco) - os=-elf - ;; - mips*-*) - os=-elf - ;; - or32-*) - os=-coff - ;; - *-tti) # must be before sparc entry or we get the wrong os. - os=-sysv3 - ;; - sparc-* | *-sun) - os=-sunos4.1.1 - ;; - *-be) - os=-beos - ;; - *-haiku) - os=-haiku - ;; - *-ibm) - os=-aix - ;; - *-knuth) - os=-mmixware - ;; - *-wec) - os=-proelf - ;; - *-winbond) - os=-proelf - ;; - *-oki) - os=-proelf - ;; - *-hp) - os=-hpux - ;; - *-hitachi) - os=-hiux - ;; - i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) - os=-sysv - ;; - *-cbm) - os=-amigaos - ;; - *-dg) - os=-dgux - ;; - *-dolphin) - os=-sysv3 - ;; - m68k-ccur) - os=-rtu - ;; - m88k-omron*) - os=-luna - ;; - *-next ) - os=-nextstep - ;; - *-sequent) - os=-ptx - ;; - *-crds) - os=-unos - ;; - *-ns) - os=-genix - ;; - i370-*) - os=-mvs - ;; - *-next) - os=-nextstep3 - ;; - *-gould) - os=-sysv - ;; - *-highlevel) - os=-bsd - ;; - *-encore) - os=-bsd - ;; - *-sgi) - os=-irix - ;; - *-siemens) - os=-sysv4 - ;; - *-masscomp) - os=-rtu - ;; - f3001-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 | -mint0-9* | -*MiNT | -MiNT0-9*) - vendor=atari - ;; - -vos*) - vendor=stratus - ;; - esac - basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` - ;; -esac - -echo $basic_machine$os -exit - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "timestamp='" -# time-stamp-format: "%:y-%02m-%02d" -# time-stamp-end: "'" -# End:
View file
linuxsampler-1.0.0.tar.bz2/configure
Deleted
@@ -1,27657 +0,0 @@ -#! /bin/sh -# Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.61. -# -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, -# 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. -# This configure script is free software; the Free Software Foundation -# gives unlimited permission to copy, distribute and modify it. -## --------------------- ## -## M4sh Initialization. ## -## --------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in - *posix*) set -o posix ;; -esac - -fi - - - - -# PATH needs CR -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - -# The user is always right. -if test "${PATH_SEPARATOR+set}" != set; then - echo "#! /bin/sh" >conf$$.sh - echo "exit 0" >>conf$$.sh - chmod +x conf$$.sh - if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then - PATH_SEPARATOR=';' - else - PATH_SEPARATOR=: - fi - rm -f conf$$.sh -fi - -# Support unset when possible. -if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then - as_unset=unset -else - as_unset=false -fi - - -# IFS -# We need space, tab and new line, in precisely that order. Quoting is -# there to prevent editors from complaining about space-tab. -# (If _AS_PATH_WALK were called with IFS unset, it would disable word -# splitting by setting IFS to empty value.) -as_nl=' -' -IFS=" "" $as_nl" - -# Find who we are. Look in the path if we contain no directory separator. -case $0 in - *\\/* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break -done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - { (exit 1); exit 1; } -fi - -# Work around bugs in pre-3.0 UWIN ksh. -for as_var in ENV MAIL MAILPATH -do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var -done -PS1='$ ' -PS2='> ' -PS4='+ ' - -# NLS nuisances. -for as_var in \ - LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ - LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ - LC_TELEPHONE LC_TIME -do - if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then - eval $as_var=C; export $as_var - else - ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var - fi -done - -# Required to use basename. -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - - -# Name of the executable. -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\(^/^/*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -echo X/"$0" | - sed '/^.*\/\(^/^/*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# CDPATH. -$as_unset CDPATH - - -if test "x$CONFIG_SHELL" = x; then - if (eval ":") 2>/dev/null; then - as_have_required=yes -else - as_have_required=no -fi - - if test $as_have_required = yes && (eval ": -(as_func_return () { - (exit \$1) -} -as_func_success () { - as_func_return 0 -} -as_func_failure () { - as_func_return 1 -} -as_func_ret_success () { - return 0 -} -as_func_ret_failure () { - return 1 -} - -exitcode=0 -if as_func_success; then - : -else - exitcode=1 - echo as_func_success failed. -fi - -if as_func_failure; then - exitcode=1 - echo as_func_failure succeeded. -fi - -if as_func_ret_success; then - : -else - exitcode=1 - echo as_func_ret_success failed. -fi - -if as_func_ret_failure; then - exitcode=1 - echo as_func_ret_failure succeeded. -fi - -if ( set x; as_func_ret_success y && test x = \"\$1\" ); then - : -else - exitcode=1 - echo positional parameters were not saved. -fi - -test \$exitcode = 0) || { (exit 1); exit 1; } - -( - as_lineno_1=\$LINENO - as_lineno_2=\$LINENO - test \"x\$as_lineno_1\" != \"x\$as_lineno_2\" && - test \"x\`expr \$as_lineno_1 + 1\`\" = \"x\$as_lineno_2\") || { (exit 1); exit 1; } -") 2> /dev/null; then - : -else - as_candidate_shells= - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - case $as_dir in - /*) - for as_base in sh bash ksh sh5; do - as_candidate_shells="$as_candidate_shells $as_dir/$as_base" - done;; - esac -done -IFS=$as_save_IFS - - - for as_shell in $as_candidate_shells $SHELL; do - # Try only shells that exist, to save several forks. - if { test -f "$as_shell" || test -f "$as_shell.exe"; } && - { ("$as_shell") 2> /dev/null <<\_ASEOF -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in - *posix*) set -o posix ;; -esac - -fi - - -: -_ASEOF -}; then - CONFIG_SHELL=$as_shell - as_have_required=yes - if { "$as_shell" 2> /dev/null <<\_ASEOF -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in - *posix*) set -o posix ;; -esac - -fi - - -: -(as_func_return () { - (exit $1) -} -as_func_success () { - as_func_return 0 -} -as_func_failure () { - as_func_return 1 -} -as_func_ret_success () { - return 0 -} -as_func_ret_failure () { - return 1 -} - -exitcode=0 -if as_func_success; then - : -else - exitcode=1 - echo as_func_success failed. -fi - -if as_func_failure; then - exitcode=1 - echo as_func_failure succeeded. -fi - -if as_func_ret_success; then - : -else - exitcode=1 - echo as_func_ret_success failed. -fi - -if as_func_ret_failure; then - exitcode=1 - echo as_func_ret_failure succeeded. -fi - -if ( set x; as_func_ret_success y && test x = "$1" ); then - : -else - exitcode=1 - echo positional parameters were not saved. -fi - -test $exitcode = 0) || { (exit 1); exit 1; } - -( - as_lineno_1=$LINENO - as_lineno_2=$LINENO - test "x$as_lineno_1" != "x$as_lineno_2" && - test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2") || { (exit 1); exit 1; } - -_ASEOF -}; then - break -fi - -fi - - done - - if test "x$CONFIG_SHELL" != x; then - for as_var in BASH_ENV ENV - do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var - done - export CONFIG_SHELL - exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} -fi - - - if test $as_have_required = no; then - echo This script requires a shell more modern than all the - echo shells that I found on your system. Please install a - echo modern shell, or manually run the script under such a - echo shell if you do have one. - { (exit 1); exit 1; } -fi - - -fi - -fi - - - -(eval "as_func_return () { - (exit \$1) -} -as_func_success () { - as_func_return 0 -} -as_func_failure () { - as_func_return 1 -} -as_func_ret_success () { - return 0 -} -as_func_ret_failure () { - return 1 -} - -exitcode=0 -if as_func_success; then - : -else - exitcode=1 - echo as_func_success failed. -fi - -if as_func_failure; then - exitcode=1 - echo as_func_failure succeeded. -fi - -if as_func_ret_success; then - : -else - exitcode=1 - echo as_func_ret_success failed. -fi - -if as_func_ret_failure; then - exitcode=1 - echo as_func_ret_failure succeeded. -fi - -if ( set x; as_func_ret_success y && test x = \"\$1\" ); then - : -else - exitcode=1 - echo positional parameters were not saved. -fi - -test \$exitcode = 0") || { - echo No shell found that supports shell functions. - echo Please tell autoconf@gnu.org about your system, - echo including any error possibly output before this - echo message -} - - - - as_lineno_1=$LINENO - as_lineno_2=$LINENO - test "x$as_lineno_1" != "x$as_lineno_2" && - test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2" || { - - # Create $as_me.lineno as a copy of $as_myself, but with $LINENO - # uniformly replaced by the line number. The first 'sed' inserts a - # line-number line after each line using $LINENO; the second 'sed' - # does the real work. The second script uses 'N' to pair each - # line-number line with the line containing $LINENO, and appends - # trailing '-' during substitution so that $LINENO is not a special - # case at line end. - # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the - # scripts with optimization help from Paolo Bonzini. Blame Lee - # E. McMahon (1931-1989) for sed's syntax. :-) - sed -n ' - p - /$LINENO/= - ' <$as_myself | - sed ' - s/$LINENO.*/&-/ - t lineno - b - :lineno - N - :loop - s/$LINENO\(^'$as_cr_alnum'_.*\n\)\(.*\)/\2\1\2/ - t loop - s/-\n.*// - ' >$as_me.lineno && - chmod +x "$as_me.lineno" || - { echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2 - { (exit 1); exit 1; }; } - - # Don't try to exec as it changes $0, causing all sort of problems - # (the dirname of $0 is not the place where we might find the - # original and so on. Autoconf is especially sensitive to this). - . "./$as_me.lineno" - # Exit status is that of the last command. - exit -} - - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in --n*) - case `echo 'x\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - *) ECHO_C='\c';; - esac;; -*) - ECHO_N='-n';; -esac - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir -fi -echo >conf$$.file -if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -p'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -p' -elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln -else - as_ln_s='cp -p' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - -if mkdir -p . 2>/dev/null; then - as_mkdir_p=: -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - -if test -x / >/dev/null 2>&1; then - as_test_x='test -x' -else - if ls -dL / >/dev/null 2>&1; then - as_ls_L_option=L - else - as_ls_L_option= - fi - as_test_x=' - eval sh -c '\'' - if test -d "$1"; then - test -d "$1/."; - else - case $1 in - -*)set "./$1";; - esac; - case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in - ???sx*):;;*)false;;esac;fi - '\'' sh - ' -fi -as_executable_p=$as_test_x - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%^_$as_cr_alnum%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%^_$as_cr_alnum%_%g'" - - - - -# 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 - - - - -tagnames=${tagnames+${tagnames},}CXX - -tagnames=${tagnames+${tagnames},}F77 - -exec 7<&0 </dev/null 6>&1 - -# Name of the host. -# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, -# so uname gets run too. -ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` - -# -# Initializations. -# -ac_default_prefix=/usr/local -ac_clean_files= -ac_config_libobj_dir=. -LIBOBJS= -cross_compiling=no -subdirs= -MFLAGS= -MAKEFLAGS= -SHELL=${CONFIG_SHELL-/bin/sh} - -# Identity of this package. -PACKAGE_NAME= -PACKAGE_TARNAME= -PACKAGE_VERSION= -PACKAGE_STRING= -PACKAGE_BUGREPORT= - -ac_unique_file="configure.in" -# Factoring default headers for most tests. -ac_includes_default="\ -#include <stdio.h> -#ifdef HAVE_SYS_TYPES_H -# include <sys/types.h> -#endif -#ifdef HAVE_SYS_STAT_H -# include <sys/stat.h> -#endif -#ifdef STDC_HEADERS -# include <stdlib.h> -# include <stddef.h> -#else -# ifdef HAVE_STDLIB_H -# include <stdlib.h> -# endif -#endif -#ifdef HAVE_STRING_H -# if !defined STDC_HEADERS && defined HAVE_MEMORY_H -# include <memory.h> -# endif -# include <string.h> -#endif -#ifdef HAVE_STRINGS_H -# include <strings.h> -#endif -#ifdef HAVE_INTTYPES_H -# include <inttypes.h> -#endif -#ifdef HAVE_STDINT_H -# include <stdint.h> -#endif -#ifdef HAVE_UNISTD_H -# include <unistd.h> -#endif" - -ac_subst_vars='SHELL -PATH_SEPARATOR -PACKAGE_NAME -PACKAGE_TARNAME -PACKAGE_VERSION -PACKAGE_STRING -PACKAGE_BUGREPORT -exec_prefix -prefix -program_transform_name -bindir -sbindir -libexecdir -datarootdir -datadir -sysconfdir -sharedstatedir -localstatedir -includedir -oldincludedir -docdir -infodir -htmldir -dvidir -pdfdir -psdir -libdir -localedir -mandir -DEFS -ECHO_C -ECHO_N -ECHO_T -LIBS -build_alias -host_alias -target_alias -CXX -CXXFLAGS -LDFLAGS -CPPFLAGS -ac_ct_CXX -EXEEXT -OBJEXT -build -build_cpu -build_vendor -build_os -host -host_cpu -host_vendor -host_os -CC -CFLAGS -ac_ct_CC -SED -GREP -EGREP -LN_S -ECHO -AR -RANLIB -STRIP -DSYMUTIL -NMEDIT -DLLTOOL -AS -OBJDUMP -CPP -CXXCPP -F77 -FFLAGS -ac_ct_F77 -LIBTOOL -SHLIB_VERSION_ARG -SHARED_VERSION_INFO -PKG_CONFIG -CROSS_COMPILING_TRUE -CROSS_COMPILING_FALSE -CXX_CPU_SWITCH -HAVE_WINDOWS_TRUE -HAVE_WINDOWS_FALSE -acx_pthread_config -PTHREAD_CC -PTHREAD_LIBS -PTHREAD_CFLAGS -HAVE_ALSA_TRUE -HAVE_ALSA_FALSE -JACK_CFLAGS -JACK_LIBS -HAVE_JACK_TRUE -HAVE_JACK_FALSE -HAVE_JACK_MIDI_TRUE -HAVE_JACK_MIDI_FALSE -ARTS_CONFIG -ARTS_CFLAGS -ARTS_LIBS -HAVE_ARTS_TRUE -HAVE_ARTS_FALSE -config_asiosdk_dir -ASIOSDK_BASEDIR -HAVE_ASIO_TRUE -HAVE_ASIO_FALSE -HAVE_MIDISHARE_TRUE -HAVE_MIDISHARE_FALSE -HAVE_COREMIDI_TRUE -HAVE_COREMIDI_FALSE -HAVE_COREAUDIO_TRUE -HAVE_COREAUDIO_FALSE -HAVE_MME_MIDI_TRUE -HAVE_MME_MIDI_FALSE -HAVE_DSSI_TRUE -HAVE_DSSI_FALSE -LV2_CFLAGS -LV2_LIBS -HAVE_LV2_TRUE -HAVE_LV2_FALSE -VSTSDK_DIR -HAVE_VST_TRUE -HAVE_VST_FALSE -HAVE_AU_TRUE -HAVE_AU_FALSE -HAVE_AUFLAGS_TRUE -HAVE_AUFLAGS_FALSE -GIG_CFLAGS -GIG_LIBS -SQLITE3_CFLAGS -SQLITE3_LIBS -HAVE_SQLITE3_TRUE -HAVE_SQLITE3_FALSE -config_plugin_dir -config_default_instruments_db_file -INSTALL_PROGRAM -INSTALL_SCRIPT -INSTALL_DATA -CYGPATH_W -PACKAGE -VERSION -ACLOCAL -AUTOCONF -AUTOMAKE -AUTOHEADER -MAKEINFO -AMTAR -install_sh -INSTALL_STRIP_PROGRAM -mkdir_p -AWK -SET_MAKE -am__leading_dot -DEPDIR -am__include -am__quote -AMDEP_TRUE -AMDEP_FALSE -AMDEPBACKSLASH -CCDEPMODE -am__fastdepCC_TRUE -am__fastdepCC_FALSE -CXXDEPMODE -am__fastdepCXX_TRUE -am__fastdepCXX_FALSE -LIBOBJS -LTLIBOBJS' -ac_subst_files='' - ac_precious_vars='build_alias -host_alias -target_alias -CXX -CXXFLAGS -LDFLAGS -LIBS -CPPFLAGS -CCC -CC -CFLAGS -CPP -CXXCPP -F77 -FFLAGS -PKG_CONFIG -JACK_CFLAGS -JACK_LIBS -LV2_CFLAGS -LV2_LIBS -GIG_CFLAGS -GIG_LIBS -SQLITE3_CFLAGS -SQLITE3_LIBS' - - -# Initialize some variables set by options. -ac_init_help= -ac_init_version=false -# The variables have the same names as the options, with -# dashes changed to underlines. -cache_file=/dev/null -exec_prefix=NONE -no_create= -no_recursion= -prefix=NONE -program_prefix=NONE -program_suffix=NONE -program_transform_name=s,x,x, -silent= -site= -srcdir= -verbose= -x_includes=NONE -x_libraries=NONE - -# Installation directory options. -# These are left unexpanded so users can "make install exec_prefix=/foo" -# and all the variables that are supposed to be based on exec_prefix -# by default will actually change. -# Use braces instead of parens because sh, perl, etc. also accept them. -# (The list follows the same order as the GNU Coding Standards.) -bindir='${exec_prefix}/bin' -sbindir='${exec_prefix}/sbin' -libexecdir='${exec_prefix}/libexec' -datarootdir='${prefix}/share' -datadir='${datarootdir}' -sysconfdir='${prefix}/etc' -sharedstatedir='${prefix}/com' -localstatedir='${prefix}/var' -includedir='${prefix}/include' -oldincludedir='/usr/include' -docdir='${datarootdir}/doc/${PACKAGE}' -infodir='${datarootdir}/info' -htmldir='${docdir}' -dvidir='${docdir}' -pdfdir='${docdir}' -psdir='${docdir}' -libdir='${exec_prefix}/lib' -localedir='${datarootdir}/locale' -mandir='${datarootdir}/man' - -ac_prev= -ac_dashdash= -for ac_option -do - # If the previous option needs an argument, assign it. - if test -n "$ac_prev"; then - eval $ac_prev=\$ac_option - ac_prev= - continue - fi - - case $ac_option in - *=*) ac_optarg=`expr "X$ac_option" : '^=*=\(.*\)'` ;; - *) ac_optarg=yes ;; - esac - - # Accept the important Cygnus configure options, so we can diagnose typos. - - case $ac_dashdash$ac_option in - --) - ac_dashdash=yes ;; - - -bindir | --bindir | --bindi | --bind | --bin | --bi) - ac_prev=bindir ;; - -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) - bindir=$ac_optarg ;; - - -build | --build | --buil | --bui | --bu) - ac_prev=build_alias ;; - -build=* | --build=* | --buil=* | --bui=* | --bu=*) - build_alias=$ac_optarg ;; - - -cache-file | --cache-file | --cache-fil | --cache-fi \ - | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) - ac_prev=cache_file ;; - -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ - | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) - cache_file=$ac_optarg ;; - - --config-cache | -C) - cache_file=config.cache ;; - - -datadir | --datadir | --datadi | --datad) - ac_prev=datadir ;; - -datadir=* | --datadir=* | --datadi=* | --datad=*) - datadir=$ac_optarg ;; - - -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ - | --dataroo | --dataro | --datar) - ac_prev=datarootdir ;; - -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ - | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) - datarootdir=$ac_optarg ;; - - -disable-* | --disable-*) - ac_feature=`expr "x$ac_option" : 'x-*disable-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_feature" : ".*^-._$as_cr_alnum" >/dev/null && - { echo "$as_me: error: invalid feature name: $ac_feature" >&2 - { (exit 1); exit 1; }; } - ac_feature=`echo $ac_feature | sed 's/-./_/g'` - eval enable_$ac_feature=no ;; - - -docdir | --docdir | --docdi | --doc | --do) - ac_prev=docdir ;; - -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) - docdir=$ac_optarg ;; - - -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) - ac_prev=dvidir ;; - -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) - dvidir=$ac_optarg ;; - - -enable-* | --enable-*) - ac_feature=`expr "x$ac_option" : 'x-*enable-\(^=*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_feature" : ".*^-._$as_cr_alnum" >/dev/null && - { echo "$as_me: error: invalid feature name: $ac_feature" >&2 - { (exit 1); exit 1; }; } - ac_feature=`echo $ac_feature | sed 's/-./_/g'` - eval enable_$ac_feature=\$ac_optarg ;; - - -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ - | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ - | --exec | --exe | --ex) - ac_prev=exec_prefix ;; - -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ - | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ - | --exec=* | --exe=* | --ex=*) - exec_prefix=$ac_optarg ;; - - -gas | --gas | --ga | --g) - # Obsolete; use --with-gas. - with_gas=yes ;; - - -help | --help | --hel | --he | -h) - ac_init_help=long ;; - -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) - ac_init_help=recursive ;; - -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) - ac_init_help=short ;; - - -host | --host | --hos | --ho) - ac_prev=host_alias ;; - -host=* | --host=* | --hos=* | --ho=*) - host_alias=$ac_optarg ;; - - -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) - ac_prev=htmldir ;; - -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ - | --ht=*) - htmldir=$ac_optarg ;; - - -includedir | --includedir | --includedi | --included | --include \ - | --includ | --inclu | --incl | --inc) - ac_prev=includedir ;; - -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ - | --includ=* | --inclu=* | --incl=* | --inc=*) - includedir=$ac_optarg ;; - - -infodir | --infodir | --infodi | --infod | --info | --inf) - ac_prev=infodir ;; - -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) - infodir=$ac_optarg ;; - - -libdir | --libdir | --libdi | --libd) - ac_prev=libdir ;; - -libdir=* | --libdir=* | --libdi=* | --libd=*) - libdir=$ac_optarg ;; - - -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ - | --libexe | --libex | --libe) - ac_prev=libexecdir ;; - -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ - | --libexe=* | --libex=* | --libe=*) - libexecdir=$ac_optarg ;; - - -localedir | --localedir | --localedi | --localed | --locale) - ac_prev=localedir ;; - -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) - localedir=$ac_optarg ;; - - -localstatedir | --localstatedir | --localstatedi | --localstated \ - | --localstate | --localstat | --localsta | --localst | --locals) - ac_prev=localstatedir ;; - -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ - | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) - localstatedir=$ac_optarg ;; - - -mandir | --mandir | --mandi | --mand | --man | --ma | --m) - ac_prev=mandir ;; - -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) - mandir=$ac_optarg ;; - - -nfp | --nfp | --nf) - # Obsolete; use --without-fp. - with_fp=no ;; - - -no-create | --no-create | --no-creat | --no-crea | --no-cre \ - | --no-cr | --no-c | -n) - no_create=yes ;; - - -no-recursion | --no-recursion | --no-recursio | --no-recursi \ - | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) - no_recursion=yes ;; - - -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ - | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ - | --oldin | --oldi | --old | --ol | --o) - ac_prev=oldincludedir ;; - -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ - | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ - | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) - oldincludedir=$ac_optarg ;; - - -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) - ac_prev=prefix ;; - -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) - prefix=$ac_optarg ;; - - -program-prefix | --program-prefix | --program-prefi | --program-pref \ - | --program-pre | --program-pr | --program-p) - ac_prev=program_prefix ;; - -program-prefix=* | --program-prefix=* | --program-prefi=* \ - | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) - program_prefix=$ac_optarg ;; - - -program-suffix | --program-suffix | --program-suffi | --program-suff \ - | --program-suf | --program-su | --program-s) - ac_prev=program_suffix ;; - -program-suffix=* | --program-suffix=* | --program-suffi=* \ - | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) - program_suffix=$ac_optarg ;; - - -program-transform-name | --program-transform-name \ - | --program-transform-nam | --program-transform-na \ - | --program-transform-n | --program-transform- \ - | --program-transform | --program-transfor \ - | --program-transfo | --program-transf \ - | --program-trans | --program-tran \ - | --progr-tra | --program-tr | --program-t) - ac_prev=program_transform_name ;; - -program-transform-name=* | --program-transform-name=* \ - | --program-transform-nam=* | --program-transform-na=* \ - | --program-transform-n=* | --program-transform-=* \ - | --program-transform=* | --program-transfor=* \ - | --program-transfo=* | --program-transf=* \ - | --program-trans=* | --program-tran=* \ - | --progr-tra=* | --program-tr=* | --program-t=*) - program_transform_name=$ac_optarg ;; - - -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) - ac_prev=pdfdir ;; - -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) - pdfdir=$ac_optarg ;; - - -psdir | --psdir | --psdi | --psd | --ps) - ac_prev=psdir ;; - -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) - psdir=$ac_optarg ;; - - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - silent=yes ;; - - -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) - ac_prev=sbindir ;; - -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ - | --sbi=* | --sb=*) - sbindir=$ac_optarg ;; - - -sharedstatedir | --sharedstatedir | --sharedstatedi \ - | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ - | --sharedst | --shareds | --shared | --share | --shar \ - | --sha | --sh) - ac_prev=sharedstatedir ;; - -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ - | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ - | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ - | --sha=* | --sh=*) - sharedstatedir=$ac_optarg ;; - - -site | --site | --sit) - ac_prev=site ;; - -site=* | --site=* | --sit=*) - site=$ac_optarg ;; - - -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) - ac_prev=srcdir ;; - -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) - srcdir=$ac_optarg ;; - - -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ - | --syscon | --sysco | --sysc | --sys | --sy) - ac_prev=sysconfdir ;; - -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ - | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) - sysconfdir=$ac_optarg ;; - - -target | --target | --targe | --targ | --tar | --ta | --t) - ac_prev=target_alias ;; - -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) - target_alias=$ac_optarg ;; - - -v | -verbose | --verbose | --verbos | --verbo | --verb) - verbose=yes ;; - - -version | --version | --versio | --versi | --vers | -V) - ac_init_version=: ;; - - -with-* | --with-*) - ac_package=`expr "x$ac_option" : 'x-*with-\(^=*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_package" : ".*^-._$as_cr_alnum" >/dev/null && - { echo "$as_me: error: invalid package name: $ac_package" >&2 - { (exit 1); exit 1; }; } - ac_package=`echo $ac_package | sed 's/-./_/g'` - eval with_$ac_package=\$ac_optarg ;; - - -without-* | --without-*) - ac_package=`expr "x$ac_option" : 'x-*without-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_package" : ".*^-._$as_cr_alnum" >/dev/null && - { echo "$as_me: error: invalid package name: $ac_package" >&2 - { (exit 1); exit 1; }; } - ac_package=`echo $ac_package | sed 's/-./_/g'` - eval with_$ac_package=no ;; - - --x) - # Obsolete; use --with-x. - with_x=yes ;; - - -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ - | --x-incl | --x-inc | --x-in | --x-i) - ac_prev=x_includes ;; - -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ - | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) - x_includes=$ac_optarg ;; - - -x-libraries | --x-libraries | --x-librarie | --x-librari \ - | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) - ac_prev=x_libraries ;; - -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ - | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) - x_libraries=$ac_optarg ;; - - -*) { echo "$as_me: error: unrecognized option: $ac_option -Try \`$0 --help' for more information." >&2 - { (exit 1); exit 1; }; } - ;; - - *=*) - ac_envvar=`expr "x$ac_option" : 'x\(^=*\)='` - # Reject names that are not valid shell variable names. - expr "x$ac_envvar" : ".*^_$as_cr_alnum" >/dev/null && - { echo "$as_me: error: invalid variable name: $ac_envvar" >&2 - { (exit 1); exit 1; }; } - eval $ac_envvar=\$ac_optarg - export $ac_envvar ;; - - *) - # FIXME: should be removed in autoconf 3.0. - echo "$as_me: WARNING: you should use --build, --host, --target" >&2 - expr "x$ac_option" : ".*^-._$as_cr_alnum" >/dev/null && - echo "$as_me: WARNING: invalid host type: $ac_option" >&2 - : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} - ;; - - esac -done - -if test -n "$ac_prev"; then - ac_option=--`echo $ac_prev | sed 's/_/-/g'` - { echo "$as_me: error: missing argument to $ac_option" >&2 - { (exit 1); exit 1; }; } -fi - -# Be sure to have absolute directory names. -for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ - datadir sysconfdir sharedstatedir localstatedir includedir \ - oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ - libdir localedir mandir -do - eval ac_val=\$$ac_var - case $ac_val in - \\/$* | ?:\\/* ) continue;; - NONE | '' ) case $ac_var in *prefix ) continue;; esac;; - esac - { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 - { (exit 1); exit 1; }; } -done - -# There might be people who depend on the old broken behavior: `$host' -# used to hold the argument of --host etc. -# FIXME: To remove some day. -build=$build_alias -host=$host_alias -target=$target_alias - -# FIXME: To remove some day. -if test "x$host_alias" != x; then - if test "x$build_alias" = x; then - cross_compiling=maybe - echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. - If a cross compiler is detected then cross compile mode will be used." >&2 - elif test "x$build_alias" != "x$host_alias"; then - cross_compiling=yes - fi -fi - -ac_tool_prefix= -test -n "$host_alias" && ac_tool_prefix=$host_alias- - -test "$silent" = yes && exec 6>/dev/null - - -ac_pwd=`pwd` && test -n "$ac_pwd" && -ac_ls_di=`ls -di .` && -ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || - { echo "$as_me: error: Working directory cannot be determined" >&2 - { (exit 1); exit 1; }; } -test "X$ac_ls_di" = "X$ac_pwd_ls_di" || - { echo "$as_me: error: pwd does not report name of working directory" >&2 - { (exit 1); exit 1; }; } - - -# Find the source files, if location was not specified. -if test -z "$srcdir"; then - ac_srcdir_defaulted=yes - # Try the directory containing this script, then the parent directory. - ac_confdir=`$as_dirname -- "$0" || -$as_expr X"$0" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$0" : 'X\(//\)^/' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -echo X"$0" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - srcdir=$ac_confdir - if test ! -r "$srcdir/$ac_unique_file"; then - srcdir=.. - fi -else - ac_srcdir_defaulted=no -fi -if test ! -r "$srcdir/$ac_unique_file"; then - test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." - { echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2 - { (exit 1); exit 1; }; } -fi -ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" -ac_abs_confdir=`( - cd "$srcdir" && test -r "./$ac_unique_file" || { echo "$as_me: error: $ac_msg" >&2 - { (exit 1); exit 1; }; } - pwd)` -# When building in place, set srcdir=. -if test "$ac_abs_confdir" = "$ac_pwd"; then - srcdir=. -fi -# Remove unnecessary trailing slashes from srcdir. -# Double slashes in file names in object file debugging info -# mess up M-x gdb in Emacs. -case $srcdir in -*/) srcdir=`expr "X$srcdir" : 'X\(.*^/\)' \| "X$srcdir" : 'X\(.*\)'`;; -esac -for ac_var in $ac_precious_vars; do - eval ac_env_${ac_var}_set=\${${ac_var}+set} - eval ac_env_${ac_var}_value=\$${ac_var} - eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} - eval ac_cv_env_${ac_var}_value=\$${ac_var} -done - -# -# Report the --help message. -# -if test "$ac_init_help" = "long"; then - # Omit some internal or obsolete options to make the list less imposing. - # This message is too long to be a string in the A/UX 3.1 sh. - cat <<_ACEOF -\`configure' configures this package to adapt to many kinds of systems. - -Usage: $0 OPTION... VAR=VALUE... - -To assign environment variables (e.g., CC, CFLAGS...), specify them as -VAR=VALUE. See below for descriptions of some of the useful variables. - -Defaults for the options are specified in brackets. - -Configuration: - -h, --help display this help and exit - --help=short display options specific to this package - --help=recursive display the short help of all the included packages - -V, --version display version information and exit - -q, --quiet, --silent do not print \`checking...' messages - --cache-file=FILE cache test results in FILE disabled - -C, --config-cache alias for \`--cache-file=config.cache' - -n, --no-create do not create output files - --srcdir=DIR find the sources in DIR configure dir or \`..' - -Installation directories: - --prefix=PREFIX install architecture-independent files in PREFIX - $ac_default_prefix - --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX - PREFIX - -By default, \`make install' will install all the files in -\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify -an installation prefix other than \`$ac_default_prefix' using \`--prefix', -for instance \`--prefix=\$HOME'. - -For better control, use the options below. - -Fine tuning of the installation directories: - --bindir=DIR user executables EPREFIX/bin - --sbindir=DIR system admin executables EPREFIX/sbin - --libexecdir=DIR program executables EPREFIX/libexec - --sysconfdir=DIR read-only single-machine data PREFIX/etc - --sharedstatedir=DIR modifiable architecture-independent data PREFIX/com - --localstatedir=DIR modifiable single-machine data PREFIX/var - --libdir=DIR object code libraries EPREFIX/lib - --includedir=DIR C header files PREFIX/include - --oldincludedir=DIR C header files for non-gcc /usr/include - --datarootdir=DIR read-only arch.-independent data root PREFIX/share - --datadir=DIR read-only architecture-independent data DATAROOTDIR - --infodir=DIR info documentation DATAROOTDIR/info - --localedir=DIR locale-dependent data DATAROOTDIR/locale - --mandir=DIR man documentation DATAROOTDIR/man - --docdir=DIR documentation root DATAROOTDIR/doc/PACKAGE - --htmldir=DIR html documentation DOCDIR - --dvidir=DIR dvi documentation DOCDIR - --pdfdir=DIR pdf documentation DOCDIR - --psdir=DIR ps documentation DOCDIR -_ACEOF - - cat <<\_ACEOF - -Program names: - --program-prefix=PREFIX prepend PREFIX to installed program names - --program-suffix=SUFFIX append SUFFIX to installed program names - --program-transform-name=PROGRAM run sed PROGRAM on installed program names - -System types: - --build=BUILD configure for building on BUILD guessed - --host=HOST cross-compile to build programs to run on HOST BUILD -_ACEOF -fi - -if test -n "$ac_init_help"; then - - cat <<\_ACEOF - -Optional Features: - --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) - --enable-FEATURE=ARG include FEATURE ARG=yes - --enable-shared=PKGS build shared libraries default=yes - --enable-static=PKGS build static libraries default=yes - --enable-fast-install=PKGS - optimize for fast installation default=yes - --disable-libtool-lock avoid locking (might break parallel builds) - --disable-nptl-bug-check - Disable check for a bug in certain NPTL-enabled - glibc versions that caused crashs. - --disable-alsa-driver - Disable support for the Advanced Linux Sound - Architecture (ALSA). - --disable-jack-driver - Disable support for the Jack Audio Connection Kit - (JACK). - --disable-arts-driver - Disable support for the Analogue Realtime System - (aRts). - --disable-artstest do not try to compile and run a test ARTS program - --enable-asiosdk-dir - Directory where the ASIO SDK is located, this automatically - enables the compilation of the ASIO audio output driver. - --disable-asio-driver - Disable support for the Windows ASIO driver. - --disable-midishare-driver - Disable support for the MidiShare system. - --disable-coremidi-driver - Disable support for the Apple CoreMIDI system. - --disable-coreaudio-driver - Disable support for the Apple CoreAudio system. - --disable-mmemidi-driver - Disable support for the Windows MME MIDI system. - --enable-vstsdk-dir - Directory where the VST SDK is located. - This automatically enables the compilation - of the VST plugin. - --disable-instruments-db - Disable compilation of the sampler's instruments - database feature. You need to have SQLite 3.3 - or younger installed for this feature. - --disable-asm - Enable hand-crafted assembly optimizations - (default=on). LinuxSampler provides CPU specific - assembly optimizations. This is currently limited - to just enter a fast (denormal) FPU mode on x86 - platforms. There are currently no synthesis core - assembly optimizations anymore since LS 0.4.0 - --enable-dev-mode - Enable development mode (default=off). In that mode - we do some extra sanity checks here and there. - This helps to spot possible problems, but reduces - efficiency a bit - --enable-debug-level - Specify verbosity of console messages (default=1). - The higher the value, the higher will be verbosity. - A value of 0 means no console output at all. - There's not really an upper limit but the usual - level of all messages is currently somewhere less - than 10. - --enable-rt-exceptions - Enable exceptions in the realtime thread - (default=no). If this is enabled, exceptions will - be thrown on critical errors in the realtime - context as well. Otherwise if disabled - segmentation faults will be forced by the - application on critical errors. - --enable-pthread-testcancel - Enable pthread_testcancel() calls and avoid asynchronous - cancel of pthreads (default=no). - --enable-preload-samples - Due to seeking and latency issues with hard drives - we have to cache a small part of samples' head in - RAM (default=32768). The higher this value the - more memory will be occupied for each sample, but - the safer this will be in regards of possible - droputs. A 'good' value depends on the running - system and usage dependant factors. - --enable-max-pitch - Specify the maximum allowed pitch value in octaves - (default=4). To lower memory usage you might want - set a smaller value. - --enable-max-events - Specify the maximum allowed amount of events to be - processed per fragment (default=1024). - --enable-eg-bottom - Bottom limit of envelope generators - (default=0.001). Certain kinds of curve types like - exponential curves converge against 0 but never - reach 0. So we have to define a certain low value - after which we should consider all smaller values - to be 'almost zero'. The smaller this value, the - longer will voices survive in EG's release stage - and thus waste voices. If this value is too high - will cause click sounds though. - --enable-eg-min-release-time - Specify the lowest allowed release time in seconds - (default=0.0025). This value will also be used to - ramp down voices on voice stealing. This value - should always be less than the period time of the - used audio driver, as in case of voice stealing - the killed voice needs to be completely ramped - down in the same fragment. - --enable-refill-streams - Number of streams that should be refilled in each - disk thread cycle (default=4). - --enable-stream-min-refill - Minimum refill size for disk streams (default=1024). - The disk thread will go to sleep for a while if no - stream had to be refilled more than this value in - a disk thread cycle. - --enable-stream-max-refill - Maximum refill size for disk streams - (default=65536). The disk thread will refill - each stream only by a size of this value per - disk thread cycle. - --enable-stream-size - Size of each stream's ring buffer in sample points - (default=262144). - --enable-max-streams - Initial maximum amount of disk streams - (default=90). This value can be changed at - runtime. It should always be higher than the - maximum amount of voices. - --enable-max-voices - Initial maximum amount of voices (default=64). - This value can be changed at runtime. It should - always be lower than the maximum amount of disk - streams. - --enable-subfragment-size - Every audio fragment will be splitted into - subfragments. Where each subfragment renders - audio with constant synthesis parameters. This is - done for efficiency reasons. This parameter - defines the default size of a subfragment in - sample points. A large value means less CPU time - whereas a low value means better audio quality - (default=32). - --enable-global-attenuation-default - To prevent clipping all samples will be lowered - in amplitude by this given default factor (can - be overridden at runtime). - (default=0.35) - --enable-voice-steal-algo - Voice stealing algorithm to be used. Currently - available options: - none: - Disable voice stealing completely. - oldestvoiceonkey (default): - Try to kill a voice on the same key first, - if no success, proceed with the oldest key. - oldestkey: - Try to kill a voice from the oldest active - key. - --enable-sysex-buffer-size - System Exclusive Message buffer size in kB - (default=2048). - --enable-force-filter - If enabled will force filter to be used even if - no usage was define in instrument patch files. - (default=no). - --enable-filter-cutoff-min - Minimum filter cutoff frequency in Hz - (default=100.0). - --enable-filter-cutoff-max - Maximum filter cutoff frequency in Hz - (default=10000.0). - --enable-override-cutoff-ctrl - Override filter cutoff MIDI controller (default=no). - Note: you have to define the MIDI controller number - here, it's not a boolean parameter type! If this - option is used, controller number given by - instrument patch will be ignored and instead this - supplied value will be used. - --enable-override-resonance-ctrl - Override filter resonance MIDI controller - (default=no). Note: you have to define the MIDI - controller number here, it's not a boolean - parameter type! If this option is used, controller - number given by instrument patch will be ignored - and instead this supplied value will be used. - --enable-override-filter-type - Override filter type (default=no). Options: - hp: for highpass - bp: for bandpass - br: for bandreject - lp: for lowpass - lpt: for lowpass turbo - --enable-gs-checksum - Enable Roland General Synth SysEx checksum check - (default=no). If this is enabled, all GS SysEx - messages which do not provide a correct checksum - will be ignored. This is disabled by default as - not all devices honor GS checksums. - --enable-portamento-time-min - Minimum Portamento time in seconds - (default=0.1). - --enable-portamento-time-max - Maximum Portamento time in seconds - (default=32). - --enable-portamento-time-default - Default Portamento time in seconds - (default=1). - --enable-signed-triang-algo - Signed triangular wave algorithm to be used (e.g. for LFOs). - Currently available options: - intmath: - Uses integer math without any branch will then be - converted to floating point value for each sample point. - This int->float conversion might hurt on some systems. - intmathabs: - Similar to intmath but uses abs() function. - Depending on compiler and platrofm this could - perform better than integer math as it avoids - an extra integer multiply instruction. - diharmonic: - The triangular wave will be approximated by adding two - sinusoidials. This solution might especially hurt on - systems with weak floating point unit. - benchmark (default): - This is not an algorithm. Use this option if the - appropriate algorithm should be automatically - chosen by the configure script by performing a - benchmark between the algorithms mentioned above. - This will NOT work for cross compilation! - --enable-unsigned-triang-algo - Unsigned triangular wave algorithm to be used (e.g. for LFOs). - Currently available options: - intmath: - Uses integer math without any branch will then be - converted to floating point value for each sample point. - This int->float conversion might hurt on some systems. - intmathabs: - Similar to intmath but uses abs() function. - Depending on compiler and platrofm this could - perform better than integer math as it avoids - an extra integer multiply instruction. - diharmonic: - The triangular wave will be approximated by adding two - sinusoidials. This solution might especially hurt on - systems with weak floating point unit. - benchmark (default): - This is not an algorithm. Use this option if the - appropriate algorithm should be automatically - chosen by the configure script by performing a - benchmark between the algorithms mentioned above. - This will NOT work for cross compilation! - --enable-process-muted-channels - Enable processing of muted channels (default=no). - In that mode all MIDI events in the muted channels - will be processed. This will provide information - about the active voices in the muted channels and - will not discard notes, triggered in mute mode, - when the channel is unmuted. But also will reduce - the efficiency. - --disable-process-all-notes-off - Disable interpretation of All-Notes-Off MIDI - messages (default=on). By default LS will release - all voices whenever it receives an All-Notes-Off - MIDI message. You can disable this behavior, so - that LS simply ignores such messages. - --disable-interpolate-volume - Disable interpolation of volume modulation - (default=on). With this enabled, the volume changes - generated by for example the envelope generator - will be smoother, minimizing the risk for audio - clicks. Disable it to reduce CPU usage. - --enable-master-volume-sysex-by-port - Whether global volume sysex message should be - applied globally to the whole sampler or only to - the sampler channels connected to the same MIDI - input port on which the sysex message arrived on. - By default global volume sysex messages apply - globally to the whole sampler, since many MIDI - devices behave that way. - --enable-plugin-dir - Directory where the sampler shall look for potential plugins, - that is 3rd party shared libraries that should be loaded by - the sampler on startup. By default the sampler will search - for plugins in the subdirectory "plugins" below its own - library directory. - (i.e. /usr/local/lib/linuxsampler/plugins) - --enable-default-instruments-db-location - Only when instruments DB feature is enabled: file name - which shall be taken as default location of the - instruments DB file. This location can still be - overridden at runtime with a command line switch. - (default: /var/lib/linuxsampler/instruments.db) - --disable-dependency-tracking speeds up one-time build - --enable-dependency-tracking do not reject slow dependency extractors - -Optional Packages: - --with-PACKAGE=ARG use PACKAGE ARG=yes - --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) - --with-gnu-ld assume the C compiler uses GNU ld default=no - --with-pic try to use only PIC/non-PIC objects default=use - both - --with-tags=TAGS include additional configurations automatic - --with-arts-prefix=DIR prefix where ARTS is installed (optional) - -Some influential environment variables: - CXX C++ compiler command - CXXFLAGS C++ compiler flags - LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a - nonstandard directory <lib dir> - LIBS libraries to pass to the linker, e.g. -l<library> - CPPFLAGS C/C++/Objective C preprocessor flags, e.g. -I<include dir> if - you have headers in a nonstandard directory <include dir> - CC C compiler command - CFLAGS C compiler flags - CPP C preprocessor - CXXCPP C++ preprocessor - F77 Fortran 77 compiler command - FFLAGS Fortran 77 compiler flags - PKG_CONFIG path to pkg-config utility - JACK_CFLAGS C compiler flags for JACK, overriding pkg-config - JACK_LIBS linker flags for JACK, overriding pkg-config - LV2_CFLAGS C compiler flags for LV2, overriding pkg-config - LV2_LIBS linker flags for LV2, overriding pkg-config - GIG_CFLAGS C compiler flags for GIG, overriding pkg-config - GIG_LIBS linker flags for GIG, overriding pkg-config - SQLITE3_CFLAGS - C compiler flags for SQLITE3, overriding pkg-config - SQLITE3_LIBS - linker flags for SQLITE3, overriding pkg-config - -Use these variables to override the choices made by `configure' or to help -it to find libraries and programs with nonstandard names/locations. - -_ACEOF -ac_status=$? -fi - -if test "$ac_init_help" = "recursive"; then - # If there are subdirs, report their specific --help. - for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue - test -d "$ac_dir" || continue - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.\\/,,'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`echo "$ac_dir_suffix" | sed 's,/^\\/*,/..,g;s,/,,'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - \\/* | ?:\\/* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - cd "$ac_dir" || { ac_status=$?; continue; } - # Check for guested configure. - if test -f "$ac_srcdir/configure.gnu"; then - echo && - $SHELL "$ac_srcdir/configure.gnu" --help=recursive - elif test -f "$ac_srcdir/configure"; then - echo && - $SHELL "$ac_srcdir/configure" --help=recursive - else - echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 - fi || ac_status=$? - cd "$ac_pwd" || { ac_status=$?; break; } - done -fi - -test -n "$ac_init_help" && exit $ac_status -if $ac_init_version; then - cat <<\_ACEOF -configure -generated by GNU Autoconf 2.61 - -Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, -2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. -This configure script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it. -_ACEOF - exit -fi -cat >config.log <<_ACEOF -This file contains any messages produced by compilers while -running configure, to aid debugging if configure makes a mistake. - -It was created by $as_me, which was -generated by GNU Autoconf 2.61. Invocation command line was - - $ $0 $@ - -_ACEOF -exec 5>>config.log -{ -cat <<_ASUNAME -## --------- ## -## Platform. ## -## --------- ## - -hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` -uname -m = `(uname -m) 2>/dev/null || echo unknown` -uname -r = `(uname -r) 2>/dev/null || echo unknown` -uname -s = `(uname -s) 2>/dev/null || echo unknown` -uname -v = `(uname -v) 2>/dev/null || echo unknown` - -/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` -/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` - -/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` -/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` -/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` -/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` -/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` -/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` -/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` - -_ASUNAME - -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - echo "PATH: $as_dir" -done -IFS=$as_save_IFS - -} >&5 - -cat >&5 <<_ACEOF - - -## ----------- ## -## Core tests. ## -## ----------- ## - -_ACEOF - - -# Keep a trace of the command line. -# Strip out --no-create and --no-recursion so they do not pile up. -# Strip out --silent because we don't want to record it for future runs. -# Also quote any args containing shell meta-characters. -# Make two passes to allow for proper duplicate-argument suppression. -ac_configure_args= -ac_configure_args0= -ac_configure_args1= -ac_must_keep_next=false -for ac_pass in 1 2 -do - for ac_arg - do - case $ac_arg in - -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - continue ;; - *\'*) - ac_arg=`echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - case $ac_pass in - 1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;; - 2) - ac_configure_args1="$ac_configure_args1 '$ac_arg'" - if test $ac_must_keep_next = true; then - ac_must_keep_next=false # Got value, back to normal. - else - case $ac_arg in - *=* | --config-cache | -C | -disable-* | --disable-* \ - | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ - | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ - | -with-* | --with-* | -without-* | --without-* | --x) - case "$ac_configure_args0 " in - "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; - esac - ;; - -* ) ac_must_keep_next=true ;; - esac - fi - ac_configure_args="$ac_configure_args '$ac_arg'" - ;; - esac - done -done -$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; } -$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; } - -# When interrupted or exit'd, cleanup temporary files, and complete -# config.log. We remove comments because anyway the quotes in there -# would cause problems or look ugly. -# WARNING: Use '\'' to represent an apostrophe within the trap. -# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. -trap 'exit_status=$? - # Save into config.log some information that might help in debugging. - { - echo - - cat <<\_ASBOX -## ---------------- ## -## Cache variables. ## -## ---------------- ## -_ASBOX - echo - # The following way of writing the cache mishandles newlines in values, -( - for ac_var in `(set) 2>&1 | sed -n '\''s/^\(a-zA-Z_a-zA-Z0-9_*\)=.*/\1/p'\''`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { echo "$as_me:$LINENO: WARNING: Cache variable $ac_var contains a newline." >&5 -echo "$as_me: WARNING: Cache variable $ac_var contains a newline." >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - *) $as_unset $ac_var ;; - esac ;; - esac - done - (set) 2>&1 | - case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - sed -n \ - "s/'\''/'\''\\\\'\'''\''/g; - s/^\\(_$as_cr_alnum*_cv__$as_cr_alnum*\\)=\\(.*\\)/\\1='\''\\2'\''/p" - ;; #( - *) - sed -n "/^_$as_cr_alnum*_cv__$as_cr_alnum*=/p" - ;; - esac | - sort -) - echo - - cat <<\_ASBOX -## ----------------- ## -## Output variables. ## -## ----------------- ## -_ASBOX - echo - for ac_var in $ac_subst_vars - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - echo "$ac_var='\''$ac_val'\''" - done | sort - echo - - if test -n "$ac_subst_files"; then - cat <<\_ASBOX -## ------------------- ## -## File substitutions. ## -## ------------------- ## -_ASBOX - echo - for ac_var in $ac_subst_files - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - echo "$ac_var='\''$ac_val'\''" - done | sort - echo - fi - - if test -s confdefs.h; then - cat <<\_ASBOX -## ----------- ## -## confdefs.h. ## -## ----------- ## -_ASBOX - echo - cat confdefs.h - echo - fi - test "$ac_signal" != 0 && - echo "$as_me: caught signal $ac_signal" - echo "$as_me: exit $exit_status" - } >&5 - rm -f core *.core core.conftest.* && - rm -f -r conftest* confdefs* conf$$* $ac_clean_files && - exit $exit_status -' 0 -for ac_signal in 1 2 13 15; do - trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal -done -ac_signal=0 - -# confdefs.h avoids OS command line length limits that DEFS can exceed. -rm -f -r conftest* confdefs.h - -# Predefined preprocessor variables. - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_NAME "$PACKAGE_NAME" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_TARNAME "$PACKAGE_TARNAME" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_VERSION "$PACKAGE_VERSION" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_STRING "$PACKAGE_STRING" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" -_ACEOF - - -# Let the site file select an alternate cache file if it wants to. -# Prefer explicitly selected file to automatically selected ones. -if test -n "$CONFIG_SITE"; then - set x "$CONFIG_SITE" -elif test "x$prefix" != xNONE; then - set x "$prefix/share/config.site" "$prefix/etc/config.site" -else - set x "$ac_default_prefix/share/config.site" \ - "$ac_default_prefix/etc/config.site" -fi -shift -for ac_site_file -do - if test -r "$ac_site_file"; then - { echo "$as_me:$LINENO: loading site script $ac_site_file" >&5 -echo "$as_me: loading site script $ac_site_file" >&6;} - sed 's/^/| /' "$ac_site_file" >&5 - . "$ac_site_file" - fi -done - -if test -r "$cache_file"; then - # Some versions of bash will fail to source /dev/null (special - # files actually), so we avoid doing that. - if test -f "$cache_file"; then - { echo "$as_me:$LINENO: loading cache $cache_file" >&5 -echo "$as_me: loading cache $cache_file" >&6;} - case $cache_file in - \\/* | ?:\\/* ) . "$cache_file";; - *) . "./$cache_file";; - esac - fi -else - { echo "$as_me:$LINENO: creating cache $cache_file" >&5 -echo "$as_me: creating cache $cache_file" >&6;} - >$cache_file -fi - -# Check that the precious variables saved in the cache have kept the same -# value. -ac_cache_corrupted=false -for ac_var in $ac_precious_vars; do - eval ac_old_set=\$ac_cv_env_${ac_var}_set - eval ac_new_set=\$ac_env_${ac_var}_set - eval ac_old_val=\$ac_cv_env_${ac_var}_value - eval ac_new_val=\$ac_env_${ac_var}_value - case $ac_old_set,$ac_new_set in - set,) - { echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 -echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,set) - { echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5 -echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,);; - *) - if test "x$ac_old_val" != "x$ac_new_val"; then - { echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5 -echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} - { echo "$as_me:$LINENO: former value: $ac_old_val" >&5 -echo "$as_me: former value: $ac_old_val" >&2;} - { echo "$as_me:$LINENO: current value: $ac_new_val" >&5 -echo "$as_me: current value: $ac_new_val" >&2;} - ac_cache_corrupted=: - fi;; - esac - # Pass precious variables to config.status. - if test "$ac_new_set" = set; then - case $ac_new_val in - *\'*) ac_arg=$ac_var=`echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; - *) ac_arg=$ac_var=$ac_new_val ;; - esac - case " $ac_configure_args " in - *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. - *) ac_configure_args="$ac_configure_args '$ac_arg'" ;; - esac - fi -done -if $ac_cache_corrupted; then - { echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5 -echo "$as_me: error: changes in the environment can compromise the build" >&2;} - { { echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5 -echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;} - { (exit 1); exit 1; }; } -fi - - - - - - - - - - - - - - - - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -#------------------------------------------------------------------------------------ -# LinuxSampler's / liblinuxsampler's "official" release version: - -LINUXSAMPLER_RELEASE_MAJOR=1 -LINUXSAMPLER_RELEASE_MINOR=0 -LINUXSAMPLER_RELEASE_BUILD=0 - -#------------------------------------------------------------------------------------ -# The following is the libtool / shared library version. This doesn't have to -# do anything with the release version. It MUST conform to the following rules: -# -# 1. Start with version information of `0:0:0' for each libtool library. -# 2. Update the version information only immediately before a public release of -# your software. More frequent updates are unnecessary, and only guarantee -# that the current interface number gets larger faster. -# 3. If the library source code has changed at all since the last update, then -# increment revision (`c:r:a' becomes `c:r+1:a'). -# 4. If any interfaces have been added, removed, or changed since the last update, -# increment current, and set revision to 0. -# 5. If any interfaces have been added since the last public release, then increment -# age. -# 6. If any interfaces have been removed since the last public release, then set age -# to 0. - -LIBLINUXSAMPLER_LT_CURRENT=3 -LIBLINUXSAMPLER_LT_REVISION=0 -LIBLINUXSAMPLER_LT_AGE=0 -SHARED_VERSION_INFO="$LIBLINUXSAMPLER_LT_CURRENT:$LIBLINUXSAMPLER_LT_REVISION:$LIBLINUXSAMPLER_LT_AGE" - -#------------------------------------------------------------------------------------ -# the LSCP specification version this LinuSampler release complies with: - -LSCP_RELEASE_MAJOR=1 -LSCP_RELEASE_MINOR=4 - - -cat >>confdefs.h <<_ACEOF -#define LSCP_RELEASE_MAJOR ${LSCP_RELEASE_MAJOR} -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define LSCP_RELEASE_MINOR ${LSCP_RELEASE_MINOR} -_ACEOF - - -ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu -if test -z "$CXX"; then - if test -n "$CCC"; then - CXX=$CCC - else - if test -n "$ac_tool_prefix"; then - for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_CXX+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$CXX"; then - ac_cv_prog_CXX="$CXX" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -CXX=$ac_cv_prog_CXX -if test -n "$CXX"; then - { echo "$as_me:$LINENO: result: $CXX" >&5 -echo "${ECHO_T}$CXX" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$CXX" && break - done -fi -if test -z "$CXX"; then - ac_ct_CXX=$CXX - for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_CXX"; then - ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CXX="$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_CXX=$ac_cv_prog_ac_ct_CXX -if test -n "$ac_ct_CXX"; then - { echo "$as_me:$LINENO: result: $ac_ct_CXX" >&5 -echo "${ECHO_T}$ac_ct_CXX" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$ac_ct_CXX" && break -done - - if test "x$ac_ct_CXX" = x; then - CXX="g++" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - CXX=$ac_ct_CXX - fi -fi - - fi -fi -# Provide some information about the compiler. -echo "$as_me:$LINENO: checking for C++ compiler version" >&5 -ac_compiler=`set X $ac_compile; echo $2` -{ (ac_try="$ac_compiler --version >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler --version >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -v >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -v >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -V >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -V >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files a.out a.exe b.out" -# Try to create an executable without -o first, disregard a.out. -# It will help us diagnose broken compilers, and finding out an intuition -# of exeext. -{ echo "$as_me:$LINENO: checking for C++ compiler default output file name" >&5 -echo $ECHO_N "checking for C++ compiler default output file name... $ECHO_C" >&6; } -ac_link_default=`echo "$ac_link" | sed 's/ -o *conftest^ *//'` -# -# List of possible output files, starting from the most likely. -# The algorithm is not robust to junk in `.', hence go to wildcards (a.*) -# only as a last resort. b.out is created by i960 compilers. -ac_files='a_out.exe a.exe conftest.exe a.out conftest a.* conftest.* b.out' -# -# The IRIX 6 linker writes into existing files which may not be -# executable, retaining their permissions. Remove them first so a -# subsequent execution test works. -ac_rmfiles= -for ac_file in $ac_files -do - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.o | *.obj ) ;; - * ) ac_rmfiles="$ac_rmfiles $ac_file";; - esac -done -rm -f $ac_rmfiles - -if { (ac_try="$ac_link_default" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link_default") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. -# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' -# in a Makefile. We should not override ac_cv_exeext if it was cached, -# so that the user can short-circuit this test for compilers unknown to -# Autoconf. -for ac_file in $ac_files '' -do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.o | *.obj ) - ;; - ab.out ) - # We found the default executable, but exeext='' is most - # certainly right. - break;; - *.* ) - if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; - then :; else - ac_cv_exeext=`expr "$ac_file" : '^.*\(\..*\)'` - fi - # We set ac_cv_exeext here because the later test for it is not - # safe: cross compilers may not add the suffix if given an `-o' - # argument, so we may need to know it at that point already. - # Even if this section looks crufty: it has the advantage of - # actually working. - break;; - * ) - break;; - esac -done -test "$ac_cv_exeext" = no && ac_cv_exeext= - -else - ac_file='' -fi - -{ echo "$as_me:$LINENO: result: $ac_file" >&5 -echo "${ECHO_T}$ac_file" >&6; } -if test -z "$ac_file"; then - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { echo "$as_me:$LINENO: error: C++ compiler cannot create executables -See \`config.log' for more details." >&5 -echo "$as_me: error: C++ compiler cannot create executables -See \`config.log' for more details." >&2;} - { (exit 77); exit 77; }; } -fi - -ac_exeext=$ac_cv_exeext - -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ echo "$as_me:$LINENO: checking whether the C++ compiler works" >&5 -echo $ECHO_N "checking whether the C++ compiler works... $ECHO_C" >&6; } -# FIXME: These cross compiler hacks should be removed for Autoconf 3.0 -# If not cross compiling, check that we can run a simple program. -if test "$cross_compiling" != yes; then - if { ac_try='./$ac_file' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - cross_compiling=no - else - if test "$cross_compiling" = maybe; then - cross_compiling=yes - else - { { echo "$as_me:$LINENO: error: cannot run C++ compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details." >&5 -echo "$as_me: error: cannot run C++ compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } - fi - fi -fi -{ echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - -rm -f a.out a.exe conftest$ac_cv_exeext b.out -ac_clean_files=$ac_clean_files_save -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ echo "$as_me:$LINENO: checking whether we are cross compiling" >&5 -echo $ECHO_N "checking whether we are cross compiling... $ECHO_C" >&6; } -{ echo "$as_me:$LINENO: result: $cross_compiling" >&5 -echo "${ECHO_T}$cross_compiling" >&6; } - -{ echo "$as_me:$LINENO: checking for suffix of executables" >&5 -echo $ECHO_N "checking for suffix of executables... $ECHO_C" >&6; } -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - # If both `conftest.exe' and `conftest' are `present' (well, observable) -# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -# work properly (i.e., refer to `conftest.exe'), while it won't with -# `rm'. -for ac_file in conftest.exe conftest conftest.*; do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.o | *.obj ) ;; - *.* ) ac_cv_exeext=`expr "$ac_file" : '^.*\(\..*\)'` - break;; - * ) break;; - esac -done -else - { { echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details." >&5 -echo "$as_me: error: cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } -fi - -rm -f conftest$ac_cv_exeext -{ echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5 -echo "${ECHO_T}$ac_cv_exeext" >&6; } - -rm -f conftest.$ac_ext -EXEEXT=$ac_cv_exeext -ac_exeext=$EXEEXT -{ echo "$as_me:$LINENO: checking for suffix of object files" >&5 -echo $ECHO_N "checking for suffix of object files... $ECHO_C" >&6; } -if test "${ac_cv_objext+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.o conftest.obj -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - for ac_file in conftest.o conftest.obj conftest.*; do - test -f "$ac_file" || continue; - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf ) ;; - *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` - break;; - esac -done -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile -See \`config.log' for more details." >&5 -echo "$as_me: error: cannot compute suffix of object files: cannot compile -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } -fi - -rm -f conftest.$ac_cv_objext conftest.$ac_ext -fi -{ echo "$as_me:$LINENO: result: $ac_cv_objext" >&5 -echo "${ECHO_T}$ac_cv_objext" >&6; } -OBJEXT=$ac_cv_objext -ac_objext=$OBJEXT -{ echo "$as_me:$LINENO: checking whether we are using the GNU C++ compiler" >&5 -echo $ECHO_N "checking whether we are using the GNU C++ compiler... $ECHO_C" >&6; } -if test "${ac_cv_cxx_compiler_gnu+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_compiler_gnu=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_compiler_gnu=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_cxx_compiler_gnu=$ac_compiler_gnu - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_cxx_compiler_gnu" >&5 -echo "${ECHO_T}$ac_cv_cxx_compiler_gnu" >&6; } -GXX=`test $ac_compiler_gnu = yes && echo yes` -ac_test_CXXFLAGS=${CXXFLAGS+set} -ac_save_CXXFLAGS=$CXXFLAGS -{ echo "$as_me:$LINENO: checking whether $CXX accepts -g" >&5 -echo $ECHO_N "checking whether $CXX accepts -g... $ECHO_C" >&6; } -if test "${ac_cv_prog_cxx_g+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_save_cxx_werror_flag=$ac_cxx_werror_flag - ac_cxx_werror_flag=yes - ac_cv_prog_cxx_g=no - CXXFLAGS="-g" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_cxx_g=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - CXXFLAGS="" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cxx_werror_flag=$ac_save_cxx_werror_flag - CXXFLAGS="-g" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_cxx_g=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_cxx_werror_flag=$ac_save_cxx_werror_flag -fi -{ echo "$as_me:$LINENO: result: $ac_cv_prog_cxx_g" >&5 -echo "${ECHO_T}$ac_cv_prog_cxx_g" >&6; } -if test "$ac_test_CXXFLAGS" = set; then - CXXFLAGS=$ac_save_CXXFLAGS -elif test $ac_cv_prog_cxx_g = yes; then - if test "$GXX" = yes; then - CXXFLAGS="-g -O2" - else - CXXFLAGS="-g" - fi -else - if test "$GXX" = yes; then - CXXFLAGS="-O2" - else - CXXFLAGS= - fi -fi -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -# Check whether --enable-shared was given. -if test "${enable_shared+set}" = set; then - enableval=$enable_shared; p=${PACKAGE-default} - case $enableval in - yes) enable_shared=yes ;; - no) enable_shared=no ;; - *) - enable_shared=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_shared=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac -else - enable_shared=yes -fi - - -# Check whether --enable-static was given. -if test "${enable_static+set}" = set; then - enableval=$enable_static; p=${PACKAGE-default} - case $enableval in - yes) enable_static=yes ;; - no) enable_static=no ;; - *) - enable_static=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_static=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac -else - enable_static=yes -fi - - -# Check whether --enable-fast-install was given. -if test "${enable_fast_install+set}" = set; then - enableval=$enable_fast_install; p=${PACKAGE-default} - case $enableval in - yes) enable_fast_install=yes ;; - no) enable_fast_install=no ;; - *) - enable_fast_install=no - # Look at the argument we got. We use all the common list separators. - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for pkg in $enableval; do - IFS="$lt_save_ifs" - if test "X$pkg" = "X$p"; then - enable_fast_install=yes - fi - done - IFS="$lt_save_ifs" - ;; - esac -else - enable_fast_install=yes -fi - - -ac_aux_dir= -for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do - if test -f "$ac_dir/install-sh"; then - ac_aux_dir=$ac_dir - ac_install_sh="$ac_aux_dir/install-sh -c" - break - elif test -f "$ac_dir/install.sh"; then - ac_aux_dir=$ac_dir - ac_install_sh="$ac_aux_dir/install.sh -c" - break - elif test -f "$ac_dir/shtool"; then - ac_aux_dir=$ac_dir - ac_install_sh="$ac_aux_dir/shtool install -c" - break - fi -done -if test -z "$ac_aux_dir"; then - { { echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" >&5 -echo "$as_me: error: cannot find install-sh or install.sh in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" >&2;} - { (exit 1); exit 1; }; } -fi - -# These three variables are undocumented and unsupported, -# and are intended to be withdrawn in a future Autoconf release. -# They can cause serious problems if a builder's source tree is in a directory -# whose full name contains unusual characters. -ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. -ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. -ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. - - -# Make sure we can run config.sub. -$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || - { { echo "$as_me:$LINENO: error: cannot run $SHELL $ac_aux_dir/config.sub" >&5 -echo "$as_me: error: cannot run $SHELL $ac_aux_dir/config.sub" >&2;} - { (exit 1); exit 1; }; } - -{ echo "$as_me:$LINENO: checking build system type" >&5 -echo $ECHO_N "checking build system type... $ECHO_C" >&6; } -if test "${ac_cv_build+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_build_alias=$build_alias -test "x$ac_build_alias" = x && - ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` -test "x$ac_build_alias" = x && - { { echo "$as_me:$LINENO: error: cannot guess build type; you must specify one" >&5 -echo "$as_me: error: cannot guess build type; you must specify one" >&2;} - { (exit 1); exit 1; }; } -ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || - { { echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&5 -echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&2;} - { (exit 1); exit 1; }; } - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_build" >&5 -echo "${ECHO_T}$ac_cv_build" >&6; } -case $ac_cv_build in -*-*-*) ;; -*) { { echo "$as_me:$LINENO: error: invalid value of canonical build" >&5 -echo "$as_me: error: invalid value of canonical build" >&2;} - { (exit 1); exit 1; }; };; -esac -build=$ac_cv_build -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_build -shift -build_cpu=$1 -build_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -build_os=$* -IFS=$ac_save_IFS -case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac - - -{ echo "$as_me:$LINENO: checking host system type" >&5 -echo $ECHO_N "checking host system type... $ECHO_C" >&6; } -if test "${ac_cv_host+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test "x$host_alias" = x; then - ac_cv_host=$ac_cv_build -else - ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || - { { echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&5 -echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&2;} - { (exit 1); exit 1; }; } -fi - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_host" >&5 -echo "${ECHO_T}$ac_cv_host" >&6; } -case $ac_cv_host in -*-*-*) ;; -*) { { echo "$as_me:$LINENO: error: invalid value of canonical host" >&5 -echo "$as_me: error: invalid value of canonical host" >&2;} - { (exit 1); exit 1; }; };; -esac -host=$ac_cv_host -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_host -shift -host_cpu=$1 -host_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -host_os=$* -IFS=$ac_save_IFS -case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. -set dummy ${ac_tool_prefix}gcc; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}gcc" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { echo "$as_me:$LINENO: result: $CC" >&5 -echo "${ECHO_T}$CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_CC"; then - ac_ct_CC=$CC - # Extract the first word of "gcc", so it can be a program name with args. -set dummy gcc; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="gcc" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 -echo "${ECHO_T}$ac_ct_CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -else - CC="$ac_cv_prog_CC" -fi - -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. -set dummy ${ac_tool_prefix}cc; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}cc" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { echo "$as_me:$LINENO: result: $CC" >&5 -echo "${ECHO_T}$CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - fi -fi -if test -z "$CC"; then - # Extract the first word of "cc", so it can be a program name with args. -set dummy cc; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else - ac_prog_rejected=no -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then - ac_prog_rejected=yes - continue - fi - ac_cv_prog_CC="cc" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -if test $ac_prog_rejected = yes; then - # We found a bogon in the path, so make sure we never use it. - set dummy $ac_cv_prog_CC - shift - if test $# != 0; then - # We chose a different compiler from the bogus one. - # However, it has the same basename, so the bogon will be chosen - # first if we set CC to just the basename; use the full file name. - shift - ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" - fi -fi -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { echo "$as_me:$LINENO: result: $CC" >&5 -echo "${ECHO_T}$CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - for ac_prog in cl.exe - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="$ac_tool_prefix$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { echo "$as_me:$LINENO: result: $CC" >&5 -echo "${ECHO_T}$CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$CC" && break - done -fi -if test -z "$CC"; then - ac_ct_CC=$CC - for ac_prog in cl.exe -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 -echo "${ECHO_T}$ac_ct_CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$ac_ct_CC" && break -done - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -fi - -fi - - -test -z "$CC" && { { echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH -See \`config.log' for more details." >&5 -echo "$as_me: error: no acceptable C compiler found in \$PATH -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } - -# Provide some information about the compiler. -echo "$as_me:$LINENO: checking for C compiler version" >&5 -ac_compiler=`set X $ac_compile; echo $2` -{ (ac_try="$ac_compiler --version >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler --version >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -v >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -v >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -V >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -V >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - -{ echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5 -echo $ECHO_N "checking whether we are using the GNU C compiler... $ECHO_C" >&6; } -if test "${ac_cv_c_compiler_gnu+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_compiler_gnu=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_compiler_gnu=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_c_compiler_gnu=$ac_compiler_gnu - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5 -echo "${ECHO_T}$ac_cv_c_compiler_gnu" >&6; } -GCC=`test $ac_compiler_gnu = yes && echo yes` -ac_test_CFLAGS=${CFLAGS+set} -ac_save_CFLAGS=$CFLAGS -{ echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5 -echo $ECHO_N "checking whether $CC accepts -g... $ECHO_C" >&6; } -if test "${ac_cv_prog_cc_g+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_save_c_werror_flag=$ac_c_werror_flag - ac_c_werror_flag=yes - ac_cv_prog_cc_g=no - CFLAGS="-g" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_cc_g=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - CFLAGS="" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_c_werror_flag=$ac_save_c_werror_flag - CFLAGS="-g" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_cc_g=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_c_werror_flag=$ac_save_c_werror_flag -fi -{ echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5 -echo "${ECHO_T}$ac_cv_prog_cc_g" >&6; } -if test "$ac_test_CFLAGS" = set; then - CFLAGS=$ac_save_CFLAGS -elif test $ac_cv_prog_cc_g = yes; then - if test "$GCC" = yes; then - CFLAGS="-g -O2" - else - CFLAGS="-g" - fi -else - if test "$GCC" = yes; then - CFLAGS="-O2" - else - CFLAGS= - fi -fi -{ echo "$as_me:$LINENO: checking for $CC option to accept ISO C89" >&5 -echo $ECHO_N "checking for $CC option to accept ISO C89... $ECHO_C" >&6; } -if test "${ac_cv_prog_cc_c89+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_prog_cc_c89=no -ac_save_CC=$CC -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <stdarg.h> -#include <stdio.h> -#include <sys/types.h> -#include <sys/stat.h> -/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ -struct buf { int x; }; -FILE * (*rcsopen) (struct buf *, struct stat *, int); -static char *e (p, i) - char **p; - int i; -{ - return pi; -} -static char *f (char * (*g) (char **, int), char **p, ...) -{ - char *s; - va_list v; - va_start (v,p); - s = g (p, va_arg (v,int)); - va_end (v); - return s; -} - -/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has - function prototypes and stuff, but not '\xHH' hex character constants. - These don't provoke an error unfortunately, instead are silently treated - as 'x'. The following induces an error, until -std is added to get - proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an - array size at least. It's necessary to write '\x00'==0 to get something - that's true only with -std. */ -int osf4_cc_array '\x00' == 0 ? 1 : -1; - -/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters - inside strings and character constants. */ -#define FOO(x) 'x' -int xlc6_cc_arrayFOO(a) == 'x' ? 1 : -1; - -int test (int i, double x); -struct s1 {int (*f) (int a);}; -struct s2 {int (*f) (double a);}; -int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); -int argc; -char **argv; -int -main () -{ -return f (e, argv, 0) != argv0 || f (e, argv, 1) != argv1; - ; - return 0; -} -_ACEOF -for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ - -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" -do - CC="$ac_save_CC $ac_arg" - rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_cc_c89=$ac_arg -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext - test "x$ac_cv_prog_cc_c89" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC - -fi -# AC_CACHE_VAL -case "x$ac_cv_prog_cc_c89" in - x) - { echo "$as_me:$LINENO: result: none needed" >&5 -echo "${ECHO_T}none needed" >&6; } ;; - xno) - { echo "$as_me:$LINENO: result: unsupported" >&5 -echo "${ECHO_T}unsupported" >&6; } ;; - *) - CC="$CC $ac_cv_prog_cc_c89" - { echo "$as_me:$LINENO: result: $ac_cv_prog_cc_c89" >&5 -echo "${ECHO_T}$ac_cv_prog_cc_c89" >&6; } ;; -esac - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -{ echo "$as_me:$LINENO: checking for a sed that does not truncate output" >&5 -echo $ECHO_N "checking for a sed that does not truncate output... $ECHO_C" >&6; } -if test "${lt_cv_path_SED+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # Loop through the user's path and test for sed and gsed. -# Then use that list of sed's as ones to test for truncation. -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for lt_ac_prog in sed gsed; do - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$lt_ac_prog$ac_exec_ext" && $as_test_x "$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 -IFS=$as_save_IFS -lt_ac_max=0 -lt_ac_count=0 -# Add /usr/xpg4/bin/sed as it is typically found on Solaris -# along with /bin/sed that truncates output. -for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do - test ! -f $lt_ac_sed && continue - cat /dev/null > conftest.in - lt_ac_count=0 - echo $ECHO_N "0123456789$ECHO_C" >conftest.in - # Check for GNU sed and select it if it is found. - if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then - lt_cv_path_SED=$lt_ac_sed - break - fi - while true; do - cat conftest.in conftest.in >conftest.tmp - mv conftest.tmp conftest.in - cp conftest.in conftest.nl - echo >>conftest.nl - $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break - cmp -s conftest.out conftest.nl || break - # 10000 chars as input seems more than enough - test $lt_ac_count -gt 10 && break - lt_ac_count=`expr $lt_ac_count + 1` - if test $lt_ac_count -gt $lt_ac_max; then - lt_ac_max=$lt_ac_count - lt_cv_path_SED=$lt_ac_sed - fi - done -done - -fi - -SED=$lt_cv_path_SED - -{ echo "$as_me:$LINENO: result: $SED" >&5 -echo "${ECHO_T}$SED" >&6; } - -{ echo "$as_me:$LINENO: checking for grep that handles long lines and -e" >&5 -echo $ECHO_N "checking for grep that handles long lines and -e... $ECHO_C" >&6; } -if test "${ac_cv_path_GREP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # Extract the first word of "grep ggrep" to use in msg output -if test -z "$GREP"; then -set dummy grep ggrep; ac_prog_name=$2 -if test "${ac_cv_path_GREP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_path_GREP_found=false -# Loop through the user's path and test for each of PROGNAME-LIST -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_prog in grep ggrep; do - for ac_exec_ext in '' $ac_executable_extensions; do - ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" - { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue - # Check for GNU ac_path_GREP and select it if it is found. - # Check for GNU $ac_path_GREP -case `"$ac_path_GREP" --version 2>&1` in -*GNU*) - ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; -*) - ac_count=0 - echo $ECHO_N "0123456789$ECHO_C" >"conftest.in" - while : - do - cat "conftest.in" "conftest.in" >"conftest.tmp" - mv "conftest.tmp" "conftest.in" - cp "conftest.in" "conftest.nl" - echo 'GREP' >> "conftest.nl" - "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break - diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break - ac_count=`expr $ac_count + 1` - if test $ac_count -gt ${ac_path_GREP_max-0}; then - # Best one so far, save it but keep looking for a better one - ac_cv_path_GREP="$ac_path_GREP" - ac_path_GREP_max=$ac_count - fi - # 10*(2^10) chars as input seems more than enough - test $ac_count -gt 10 && break - done - rm -f conftest.in conftest.tmp conftest.nl conftest.out;; -esac - - - $ac_path_GREP_found && break 3 - done -done - -done -IFS=$as_save_IFS - - -fi - -GREP="$ac_cv_path_GREP" -if test -z "$GREP"; then - { { echo "$as_me:$LINENO: error: no acceptable $ac_prog_name could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5 -echo "$as_me: error: no acceptable $ac_prog_name could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;} - { (exit 1); exit 1; }; } -fi - -else - ac_cv_path_GREP=$GREP -fi - - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_path_GREP" >&5 -echo "${ECHO_T}$ac_cv_path_GREP" >&6; } - GREP="$ac_cv_path_GREP" - - -{ echo "$as_me:$LINENO: checking for egrep" >&5 -echo $ECHO_N "checking for egrep... $ECHO_C" >&6; } -if test "${ac_cv_path_EGREP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 - then ac_cv_path_EGREP="$GREP -E" - else - # Extract the first word of "egrep" to use in msg output -if test -z "$EGREP"; then -set dummy egrep; ac_prog_name=$2 -if test "${ac_cv_path_EGREP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_path_EGREP_found=false -# Loop through the user's path and test for each of PROGNAME-LIST -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_prog in egrep; do - for ac_exec_ext in '' $ac_executable_extensions; do - ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" - { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue - # Check for GNU ac_path_EGREP and select it if it is found. - # Check for GNU $ac_path_EGREP -case `"$ac_path_EGREP" --version 2>&1` in -*GNU*) - ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; -*) - ac_count=0 - echo $ECHO_N "0123456789$ECHO_C" >"conftest.in" - while : - do - cat "conftest.in" "conftest.in" >"conftest.tmp" - mv "conftest.tmp" "conftest.in" - cp "conftest.in" "conftest.nl" - echo 'EGREP' >> "conftest.nl" - "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break - diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break - ac_count=`expr $ac_count + 1` - if test $ac_count -gt ${ac_path_EGREP_max-0}; then - # Best one so far, save it but keep looking for a better one - ac_cv_path_EGREP="$ac_path_EGREP" - ac_path_EGREP_max=$ac_count - fi - # 10*(2^10) chars as input seems more than enough - test $ac_count -gt 10 && break - done - rm -f conftest.in conftest.tmp conftest.nl conftest.out;; -esac - - - $ac_path_EGREP_found && break 3 - done -done - -done -IFS=$as_save_IFS - - -fi - -EGREP="$ac_cv_path_EGREP" -if test -z "$EGREP"; then - { { echo "$as_me:$LINENO: error: no acceptable $ac_prog_name could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5 -echo "$as_me: error: no acceptable $ac_prog_name could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;} - { (exit 1); exit 1; }; } -fi - -else - ac_cv_path_EGREP=$EGREP -fi - - - fi -fi -{ echo "$as_me:$LINENO: result: $ac_cv_path_EGREP" >&5 -echo "${ECHO_T}$ac_cv_path_EGREP" >&6; } - EGREP="$ac_cv_path_EGREP" - - - -# Check whether --with-gnu-ld was given. -if test "${with_gnu_ld+set}" = set; then - withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes -else - with_gnu_ld=no -fi - -ac_prog=ld -if test "$GCC" = yes; then - # Check if gcc -print-prog-name=ld gives a path. - { echo "$as_me:$LINENO: checking for ld used by $CC" >&5 -echo $ECHO_N "checking for ld used by $CC... $ECHO_C" >&6; } - case $host in - *-*-mingw*) - # gcc leaves a trailing carriage return which upsets mingw - ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; - *) - ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; - esac - case $ac_prog in - # Accept absolute paths. - \\/* | ?:\\/*) - re_direlt='/^/^/*/\.\./' - # Canonicalize the pathname of ld - ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` - while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do - ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` - done - test -z "$LD" && LD="$ac_prog" - ;; - "") - # If it fails, then pretend we aren't using GCC. - ac_prog=ld - ;; - *) - # If it is relative, then search for the first ld in PATH. - with_gnu_ld=unknown - ;; - esac -elif test "$with_gnu_ld" = yes; then - { echo "$as_me:$LINENO: checking for GNU ld" >&5 -echo $ECHO_N "checking for GNU ld... $ECHO_C" >&6; } -else - { echo "$as_me:$LINENO: checking for non-GNU ld" >&5 -echo $ECHO_N "checking for non-GNU ld... $ECHO_C" >&6; } -fi -if test "${lt_cv_path_LD+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -z "$LD"; then - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - for ac_dir in $PATH; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then - lt_cv_path_LD="$ac_dir/$ac_prog" - # Check to see if the program is GNU ld. I'd rather use --version, - # but apparently some variants of GNU ld only accept -v. - # Break only if it was the GNU/non-GNU ld that we prefer. - case `"$lt_cv_path_LD" -v 2>&1 </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 -fi - -LD="$lt_cv_path_LD" -if test -n "$LD"; then - { echo "$as_me:$LINENO: result: $LD" >&5 -echo "${ECHO_T}$LD" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi -test -z "$LD" && { { echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 -echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} - { (exit 1); exit 1; }; } -{ echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 -echo $ECHO_N "checking if the linker ($LD) is GNU ld... $ECHO_C" >&6; } -if test "${lt_cv_prog_gnu_ld+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # I'd rather use --version here, but apparently some GNU lds only accept -v. -case `$LD -v 2>&1 </dev/null` in -*GNU* | *'with BFD'*) - lt_cv_prog_gnu_ld=yes - ;; -*) - lt_cv_prog_gnu_ld=no - ;; -esac -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_gnu_ld" >&5 -echo "${ECHO_T}$lt_cv_prog_gnu_ld" >&6; } -with_gnu_ld=$lt_cv_prog_gnu_ld - - -{ echo "$as_me:$LINENO: checking for $LD option to reload object files" >&5 -echo $ECHO_N "checking for $LD option to reload object files... $ECHO_C" >&6; } -if test "${lt_cv_ld_reload_flag+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_ld_reload_flag='-r' -fi -{ echo "$as_me:$LINENO: result: $lt_cv_ld_reload_flag" >&5 -echo "${ECHO_T}$lt_cv_ld_reload_flag" >&6; } -reload_flag=$lt_cv_ld_reload_flag -case $reload_flag in -"" | " "*) ;; -*) reload_flag=" $reload_flag" ;; -esac -reload_cmds='$LD$reload_flag -o $output$reload_objs' -case $host_os in - darwin*) - if test "$GCC" = yes; then - reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs' - else - reload_cmds='$LD$reload_flag -o $output$reload_objs' - fi - ;; -esac - -{ echo "$as_me:$LINENO: checking for BSD-compatible nm" >&5 -echo $ECHO_N "checking for BSD-compatible nm... $ECHO_C" >&6; } -if test "${lt_cv_path_NM+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$NM"; then - # Let the user override the test. - lt_cv_path_NM="$NM" -else - lt_nm_to_check="${ac_tool_prefix}nm" - if test -n "$ac_tool_prefix" && test "$build" = "$host"; then - lt_nm_to_check="$lt_nm_to_check nm" - fi - for lt_tmp_nm in $lt_nm_to_check; do - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - tmp_nm="$ac_dir/$lt_tmp_nm" - if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then - # 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" - done - test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm -fi -fi -{ echo "$as_me:$LINENO: result: $lt_cv_path_NM" >&5 -echo "${ECHO_T}$lt_cv_path_NM" >&6; } -NM="$lt_cv_path_NM" - -{ echo "$as_me:$LINENO: checking whether ln -s works" >&5 -echo $ECHO_N "checking whether ln -s works... $ECHO_C" >&6; } -LN_S=$as_ln_s -if test "$LN_S" = "ln -s"; then - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } -else - { echo "$as_me:$LINENO: result: no, using $LN_S" >&5 -echo "${ECHO_T}no, using $LN_S" >&6; } -fi - -{ echo "$as_me:$LINENO: checking how to recognize dependent libraries" >&5 -echo $ECHO_N "checking how to recognize dependent libraries... $ECHO_C" >&6; } -if test "${lt_cv_deplibs_check_method+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_file_magic_cmd='$MAGIC_CMD' -lt_cv_file_magic_test_file= -lt_cv_deplibs_check_method='unknown' -# Need to set the preceding variable on all platforms that support -# interlibrary dependencies. -# 'none' -- dependencies not supported. -# `unknown' -- same as none, but documents that we really don't know. -# 'pass_all' -- all dependencies passed with no checks. -# 'test_compile' -- check by making test program. -# 'file_magic regex' -- check by looking for files in library path -# which responds to the $file_magic_cmd with a given extended regex. -# If you have `file' or equivalent on your system and you're not sure -# whether `pass_all' will *always* work, you probably want this one. - -case $host_os in -aix4-9*) - lt_cv_deplibs_check_method=pass_all - ;; - -beos*) - lt_cv_deplibs_check_method=pass_all - ;; - -bsdi45*) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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', - # unless we find 'file', for example because we are cross-compiling. - if ( file / ) >/dev/null 2>&1; then - lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' - lt_cv_file_magic_cmd='func_win32_libid' - else - lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' - lt_cv_file_magic_cmd='$OBJDUMP -f' - fi - ;; - -darwin* | rhapsody*) - lt_cv_deplibs_check_method=pass_all - ;; - -freebsd* | 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)/i3-986 (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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|ELF-0-90-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 (s0-90-90-9|PA-RISC0-9.0-9) shared library' - lt_cv_file_magic_test_file=/usr/lib/libc.sl - ;; - esac - ;; - -interix3-9*) - # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so|\.a)$' - ;; - -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* | k*bsd*-gnu) - lt_cv_deplibs_check_method=pass_all - ;; - -netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so\.0-9+\.0-9+|_pic\.a)$' - else - lt_cv_deplibs_check_method='match_pattern /lib^/+(\.so|_pic\.a)$' - fi - ;; - -newos6*) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (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 - ;; - -rdos*) - lt_cv_deplibs_check_method=pass_all - ;; - -solaris*) - lt_cv_deplibs_check_method=pass_all - ;; - -sysv4 | sysv4.3*) - case $host_vendor in - motorola) - lt_cv_deplibs_check_method='file_magic ELF 0-90-9*-bit MLSB (shared object|dynamic lib) M0-90-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-90-9*-bit LMSB (shared object|dynamic lib )' - ;; - sni) - lt_cv_file_magic_cmd='/bin/file' - lt_cv_deplibs_check_method="file_magic ELF 0-90-9*-bit LMSB dynamic lib" - lt_cv_file_magic_test_file=/lib/libc.so - ;; - siemens) - lt_cv_deplibs_check_method=pass_all - ;; - pc) - lt_cv_deplibs_check_method=pass_all - ;; - esac - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - lt_cv_deplibs_check_method=pass_all - ;; -esac - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_deplibs_check_method" >&5 -echo "${ECHO_T}$lt_cv_deplibs_check_method" >&6; } -file_magic_cmd=$lt_cv_file_magic_cmd -deplibs_check_method=$lt_cv_deplibs_check_method -test -z "$deplibs_check_method" && deplibs_check_method=unknown - - - - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# Check whether --enable-libtool-lock was given. -if test "${enable_libtool_lock+set}" = set; then - enableval=$enable_libtool_lock; -fi - -test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes - -# Some flags need to be propagated to the compiler or linker for good -# libtool support. -case $host in -ia64-*-hpux*) - # Find out which ABI we are using. - echo 'int i;' > conftest.$ac_ext - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - case `/usr/bin/file conftest.$ac_objext` in - *ELF-32*) - HPUX_IA64_MODE="32" - ;; - *ELF-64*) - HPUX_IA64_MODE="64" - ;; - esac - fi - rm -rf conftest* - ;; -*-*-irix6*) - # Find out which ABI we are using. - echo '#line 4453 "configure"' > conftest.$ac_ext - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - if test "$lt_cv_prog_gnu_ld" = yes; then - case `/usr/bin/file conftest.$ac_objext` in - *32-bit*) - LD="${LD-ld} -melf32bsmip" - ;; - *N32*) - LD="${LD-ld} -melf32bmipn32" - ;; - *64-bit*) - LD="${LD-ld} -melf64bmip" - ;; - esac - else - case `/usr/bin/file conftest.$ac_objext` in - *32-bit*) - LD="${LD-ld} -32" - ;; - *N32*) - LD="${LD-ld} -n32" - ;; - *64-bit*) - LD="${LD-ld} -64" - ;; - esac - fi - fi - rm -rf conftest* - ;; - -x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \ -s390*-*linux*|sparc*-*linux*) - # Find out which ABI we are using. - echo 'int i;' > conftest.$ac_ext - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - case `/usr/bin/file conftest.o` in - *32-bit*) - case $host in - x86_64-*kfreebsd*-gnu) - LD="${LD-ld} -m elf_i386_fbsd" - ;; - 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-*kfreebsd*-gnu) - LD="${LD-ld} -m elf_x86_64_fbsd" - ;; - x86_64-*linux*) - LD="${LD-ld} -m elf_x86_64" - ;; - ppc*-*linux*|powerpc*-*linux*) - LD="${LD-ld} -m elf64ppc" - ;; - s390*-*linux*) - LD="${LD-ld} -m elf64_s390" - ;; - sparc*-*linux*) - LD="${LD-ld} -m elf64_sparc" - ;; - esac - ;; - esac - fi - rm -rf conftest* - ;; - -*-*-sco3.2v5*) - # On SCO OpenServer 5, we need -belf to get full-featured binaries. - SAVE_CFLAGS="$CFLAGS" - CFLAGS="$CFLAGS -belf" - { echo "$as_me:$LINENO: checking whether the C compiler needs -belf" >&5 -echo $ECHO_N "checking whether the C compiler needs -belf... $ECHO_C" >&6; } -if test "${lt_cv_cc_needs_belf+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - lt_cv_cc_needs_belf=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - lt_cv_cc_needs_belf=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_cc_needs_belf" >&5 -echo "${ECHO_T}$lt_cv_cc_needs_belf" >&6; } - if test x"$lt_cv_cc_needs_belf" != x"yes"; then - # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf - CFLAGS="$SAVE_CFLAGS" - fi - ;; -sparc*-*solaris*) - # Find out which ABI we are using. - echo 'int i;' > conftest.$ac_ext - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - case `/usr/bin/file conftest.o` in - *64-bit*) - case $lt_cv_prog_gnu_ld in - yes*) LD="${LD-ld} -m elf64_sparc" ;; - *) - if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then - LD="${LD-ld} -64" - fi - ;; - esac - ;; - esac - fi - rm -rf conftest* - ;; - -*-*-cygwin* | *-*-mingw* | *-*-pw32*) - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. -set dummy ${ac_tool_prefix}dlltool; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_DLLTOOL+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$DLLTOOL"; then - ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -DLLTOOL=$ac_cv_prog_DLLTOOL -if test -n "$DLLTOOL"; then - { echo "$as_me:$LINENO: result: $DLLTOOL" >&5 -echo "${ECHO_T}$DLLTOOL" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_DLLTOOL"; then - ac_ct_DLLTOOL=$DLLTOOL - # Extract the first word of "dlltool", so it can be a program name with args. -set dummy dlltool; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_DLLTOOL+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_DLLTOOL"; then - ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_DLLTOOL="dlltool" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL -if test -n "$ac_ct_DLLTOOL"; then - { echo "$as_me:$LINENO: result: $ac_ct_DLLTOOL" >&5 -echo "${ECHO_T}$ac_ct_DLLTOOL" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_DLLTOOL" = x; then - DLLTOOL="false" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - DLLTOOL=$ac_ct_DLLTOOL - fi -else - DLLTOOL="$ac_cv_prog_DLLTOOL" -fi - - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args. -set dummy ${ac_tool_prefix}as; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_AS+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$AS"; then - ac_cv_prog_AS="$AS" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_AS="${ac_tool_prefix}as" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -AS=$ac_cv_prog_AS -if test -n "$AS"; then - { echo "$as_me:$LINENO: result: $AS" >&5 -echo "${ECHO_T}$AS" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_AS"; then - ac_ct_AS=$AS - # Extract the first word of "as", so it can be a program name with args. -set dummy as; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_AS+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_AS"; then - ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_AS="as" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_AS=$ac_cv_prog_ac_ct_AS -if test -n "$ac_ct_AS"; then - { echo "$as_me:$LINENO: result: $ac_ct_AS" >&5 -echo "${ECHO_T}$ac_ct_AS" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_AS" = x; then - AS="false" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - AS=$ac_ct_AS - fi -else - AS="$ac_cv_prog_AS" -fi - - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. -set dummy ${ac_tool_prefix}objdump; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_OBJDUMP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$OBJDUMP"; then - ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -OBJDUMP=$ac_cv_prog_OBJDUMP -if test -n "$OBJDUMP"; then - { echo "$as_me:$LINENO: result: $OBJDUMP" >&5 -echo "${ECHO_T}$OBJDUMP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_OBJDUMP"; then - ac_ct_OBJDUMP=$OBJDUMP - # Extract the first word of "objdump", so it can be a program name with args. -set dummy objdump; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_OBJDUMP"; then - ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_OBJDUMP="objdump" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP -if test -n "$ac_ct_OBJDUMP"; then - { echo "$as_me:$LINENO: result: $ac_ct_OBJDUMP" >&5 -echo "${ECHO_T}$ac_ct_OBJDUMP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_OBJDUMP" = x; then - OBJDUMP="false" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - OBJDUMP=$ac_ct_OBJDUMP - fi -else - OBJDUMP="$ac_cv_prog_OBJDUMP" -fi - - ;; - -esac - -need_locks="$enable_libtool_lock" - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -{ echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5 -echo $ECHO_N "checking how to run the C preprocessor... $ECHO_C" >&6; } -# On Suns, sometimes $CPP names a directory. -if test -n "$CPP" && test -d "$CPP"; then - CPP= -fi -if test -z "$CPP"; then - if test "${ac_cv_prog_CPP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # Double quotes because CPP needs to be expanded - for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" - do - ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - # <limits.h> exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - Syntax error -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Broken: fails on valid input. -continue -fi - -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <ac_nonexistent.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - # Broken: success on invalid input. -continue -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Passes both tests. -ac_preproc_ok=: -break -fi - -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then - break -fi - - done - ac_cv_prog_CPP=$CPP - -fi - CPP=$ac_cv_prog_CPP -else - ac_cv_prog_CPP=$CPP -fi -{ echo "$as_me:$LINENO: result: $CPP" >&5 -echo "${ECHO_T}$CPP" >&6; } -ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - # <limits.h> exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - Syntax error -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Broken: fails on valid input. -continue -fi - -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <ac_nonexistent.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - # Broken: success on invalid input. -continue -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Passes both tests. -ac_preproc_ok=: -break -fi - -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then - : -else - { { echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details." >&5 -echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -{ echo "$as_me:$LINENO: checking for ANSI C header files" >&5 -echo $ECHO_N "checking for ANSI C header files... $ECHO_C" >&6; } -if test "${ac_cv_header_stdc+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <stdlib.h> -#include <stdarg.h> -#include <string.h> -#include <float.h> - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_header_stdc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_header_stdc=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -if test $ac_cv_header_stdc = yes; then - # SunOS 4.x string.h does not declare mem*, contrary to ANSI. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <string.h> - -_ACEOF -if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | - $EGREP "memchr" >/dev/null 2>&1; then - : -else - ac_cv_header_stdc=no -fi -rm -f conftest* - -fi - -if test $ac_cv_header_stdc = yes; then - # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <stdlib.h> - -_ACEOF -if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | - $EGREP "free" >/dev/null 2>&1; then - : -else - ac_cv_header_stdc=no -fi -rm -f conftest* - -fi - -if test $ac_cv_header_stdc = yes; then - # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. - if test "$cross_compiling" = yes; then - : -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <ctype.h> -#include <stdlib.h> -#if ((' ' & 0x0FF) == 0x020) -# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') -# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) -#else -# define ISLOWER(c) \ - (('a' <= (c) && (c) <= 'i') \ - || ('j' <= (c) && (c) <= 'r') \ - || ('s' <= (c) && (c) <= 'z')) -# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) -#endif - -#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) -int -main () -{ - int i; - for (i = 0; i < 256; i++) - if (XOR (islower (i), ISLOWER (i)) - || toupper (i) != TOUPPER (i)) - return 2; - return 0; -} -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - : -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -ac_cv_header_stdc=no -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - -fi -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5 -echo "${ECHO_T}$ac_cv_header_stdc" >&6; } -if test $ac_cv_header_stdc = yes; then - -cat >>confdefs.h <<\_ACEOF -#define STDC_HEADERS 1 -_ACEOF - -fi - -# On IRIX 5.3, sys/types and inttypes.h are conflicting. - - - - - - - - - -for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ - inttypes.h stdint.h unistd.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default - -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - eval "$as_ac_Header=yes" -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - eval "$as_ac_Header=no" -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - - - -for ac_header in dlfcn.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - - - -if test -n "$CXX" && ( test "X$CXX" != "Xno" && - ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || - (test "X$CXX" != "Xg++"))) ; then - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu -{ echo "$as_me:$LINENO: checking how to run the C++ preprocessor" >&5 -echo $ECHO_N "checking how to run the C++ preprocessor... $ECHO_C" >&6; } -if test -z "$CXXCPP"; then - if test "${ac_cv_prog_CXXCPP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # Double quotes because CXXCPP needs to be expanded - for CXXCPP in "$CXX -E" "/lib/cpp" - do - ac_preproc_ok=false -for ac_cxx_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - # <limits.h> exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - Syntax error -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || - test ! -s conftest.err - }; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Broken: fails on valid input. -continue -fi - -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <ac_nonexistent.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || - test ! -s conftest.err - }; then - # Broken: success on invalid input. -continue -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Passes both tests. -ac_preproc_ok=: -break -fi - -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then - break -fi - - done - ac_cv_prog_CXXCPP=$CXXCPP - -fi - CXXCPP=$ac_cv_prog_CXXCPP -else - ac_cv_prog_CXXCPP=$CXXCPP -fi -{ echo "$as_me:$LINENO: result: $CXXCPP" >&5 -echo "${ECHO_T}$CXXCPP" >&6; } -ac_preproc_ok=false -for ac_cxx_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - # <limits.h> exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - Syntax error -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || - test ! -s conftest.err - }; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Broken: fails on valid input. -continue -fi - -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <ac_nonexistent.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || - test ! -s conftest.err - }; then - # Broken: success on invalid input. -continue -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # Passes both tests. -ac_preproc_ok=: -break -fi - -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then - : -else - { { echo "$as_me:$LINENO: error: C++ preprocessor \"$CXXCPP\" fails sanity check -See \`config.log' for more details." >&5 -echo "$as_me: error: C++ preprocessor \"$CXXCPP\" fails sanity check -See \`config.log' for more details." >&2;} - { (exit 1); exit 1; }; } -fi - -ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - -fi - - -ac_ext=f -ac_compile='$F77 -c $FFLAGS conftest.$ac_ext >&5' -ac_link='$F77 -o conftest$ac_exeext $FFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_f77_compiler_gnu -if test -n "$ac_tool_prefix"; then - for ac_prog in g77 xlf f77 frt pgf77 cf77 fort77 fl32 af77 xlf90 f90 pgf90 pghpf epcf90 gfortran g95 xlf95 f95 fort ifort ifc efc pgf95 lf95 ftn - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_F77+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$F77"; then - ac_cv_prog_F77="$F77" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_F77="$ac_tool_prefix$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -F77=$ac_cv_prog_F77 -if test -n "$F77"; then - { echo "$as_me:$LINENO: result: $F77" >&5 -echo "${ECHO_T}$F77" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$F77" && break - done -fi -if test -z "$F77"; then - ac_ct_F77=$F77 - for ac_prog in g77 xlf f77 frt pgf77 cf77 fort77 fl32 af77 xlf90 f90 pgf90 pghpf epcf90 gfortran g95 xlf95 f95 fort ifort ifc efc pgf95 lf95 ftn -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_F77+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_F77"; then - ac_cv_prog_ac_ct_F77="$ac_ct_F77" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_F77="$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_F77=$ac_cv_prog_ac_ct_F77 -if test -n "$ac_ct_F77"; then - { echo "$as_me:$LINENO: result: $ac_ct_F77" >&5 -echo "${ECHO_T}$ac_ct_F77" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$ac_ct_F77" && break -done - - if test "x$ac_ct_F77" = x; then - F77="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - F77=$ac_ct_F77 - fi -fi - - -# Provide some information about the compiler. -echo "$as_me:$LINENO: checking for Fortran 77 compiler version" >&5 -ac_compiler=`set X $ac_compile; echo $2` -{ (ac_try="$ac_compiler --version >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler --version >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -v >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -v >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -{ (ac_try="$ac_compiler -V >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compiler -V >&5") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } -rm -f a.out - -# If we don't use `.F' as extension, the preprocessor is not run on the -# input file. (Note that this only needs to work for GNU compilers.) -ac_save_ext=$ac_ext -ac_ext=F -{ echo "$as_me:$LINENO: checking whether we are using the GNU Fortran 77 compiler" >&5 -echo $ECHO_N "checking whether we are using the GNU Fortran 77 compiler... $ECHO_C" >&6; } -if test "${ac_cv_f77_compiler_gnu+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF - program main -#ifndef __GNUC__ - choke me -#endif - - end -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_f77_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_compiler_gnu=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_compiler_gnu=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_f77_compiler_gnu=$ac_compiler_gnu - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_f77_compiler_gnu" >&5 -echo "${ECHO_T}$ac_cv_f77_compiler_gnu" >&6; } -ac_ext=$ac_save_ext -ac_test_FFLAGS=${FFLAGS+set} -ac_save_FFLAGS=$FFLAGS -FFLAGS= -{ echo "$as_me:$LINENO: checking whether $F77 accepts -g" >&5 -echo $ECHO_N "checking whether $F77 accepts -g... $ECHO_C" >&6; } -if test "${ac_cv_prog_f77_g+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - FFLAGS=-g -cat >conftest.$ac_ext <<_ACEOF - program main - - end -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_f77_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_prog_f77_g=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_prog_f77_g=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_prog_f77_g" >&5 -echo "${ECHO_T}$ac_cv_prog_f77_g" >&6; } -if test "$ac_test_FFLAGS" = set; then - FFLAGS=$ac_save_FFLAGS -elif test $ac_cv_prog_f77_g = yes; then - if test "x$ac_cv_f77_compiler_gnu" = xyes; then - FFLAGS="-g -O2" - else - FFLAGS="-g" - fi -else - if test "x$ac_cv_f77_compiler_gnu" = xyes; then - FFLAGS="-O2" - else - FFLAGS= - fi -fi - -G77=`test $ac_compiler_gnu = yes && echo yes` -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers! -# find the maximum length of command line arguments -{ echo "$as_me:$LINENO: checking the maximum length of command line arguments" >&5 -echo $ECHO_N "checking the maximum length of command line arguments... $ECHO_C" >&6; } -if test "${lt_cv_sys_max_cmd_len+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - i=0 - teststring="ABCD" - - case $build_os in - msdosdjgpp*) - # On DJGPP, this test can blow up pretty badly due to problems in libc - # (any single argument exceeding 2000 bytes causes a buffer overrun - # during glob expansion). Even if it were fixed, the result of this - # check would be larger than it should be. - lt_cv_sys_max_cmd_len=12288; # 12K is about right - ;; - - gnu*) - # Under GNU Hurd, this test is not required because there is - # no limit to the length of command line arguments. - # Libtool will interpret -1 as no limit whatsoever - lt_cv_sys_max_cmd_len=-1; - ;; - - cygwin* | mingw*) - # On Win9x/ME, this test blows up -- it succeeds, but takes - # about 5 minutes as the teststring grows exponentially. - # Worse, since 9x/ME are not pre-emptively multitasking, - # you end up with a "frozen" computer, even though with patience - # the test eventually succeeds (with a max line length of 256k). - # Instead, let's just punt: use the minimum linelength reported by - # all of the supported platforms: 8192 (on NT/2K/XP). - lt_cv_sys_max_cmd_len=8192; - ;; - - amigaos*) - # On AmigaOS with pdksh, this test takes hours, literally. - # So we just punt and use a minimum line length of 8192. - lt_cv_sys_max_cmd_len=8192; - ;; - - netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) - # This has been around since 386BSD, at least. Likely further. - if test -x /sbin/sysctl; then - lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` - elif test -x /usr/sbin/sysctl; then - lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` - else - lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs - fi - # And add a safety zone - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` - ;; - - interix*) - # We know the value 262144 and hardcode it with a safety zone (like BSD) - lt_cv_sys_max_cmd_len=196608 - ;; - - 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 - ;; - sco3.2v5*) - lt_cv_sys_max_cmd_len=102400 - ;; - sysv5* | sco5v6* | sysv4.2uw2*) - kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` - if test -n "$kargmax"; then - lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.* //'` - else - lt_cv_sys_max_cmd_len=32768 - fi - ;; - *) - lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` - if test -n "$lt_cv_sys_max_cmd_len"; then - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` - lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` - else - 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` - fi - ;; - esac - -fi - -if test -n $lt_cv_sys_max_cmd_len ; then - { echo "$as_me:$LINENO: result: $lt_cv_sys_max_cmd_len" >&5 -echo "${ECHO_T}$lt_cv_sys_max_cmd_len" >&6; } -else - { echo "$as_me:$LINENO: result: none" >&5 -echo "${ECHO_T}none" >&6; } -fi - - - - - -# Check for command to grab the raw symbol name followed by C symbol from nm. -{ echo "$as_me:$LINENO: checking command to parse $NM output from $compiler object" >&5 -echo $ECHO_N "checking command to parse $NM output from $compiler object... $ECHO_C" >&6; } -if test "${lt_cv_sys_global_symbol_pipe+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - -# These are sane defaults that work on at least a few old systems. -# They come from Ultrix. What could be older than Ultrix?!! ;) - -# Character class describing NM global symbol codes. -symcode='BCDEGRST' - -# Regexp to match symbols that can be accessed directly from C. -sympat='\(_A-Za-z_A-Za-z0-9*\)' - -# Transform an extracted symbol line into a proper C declaration -lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern int \1;/p'" - -# Transform an extracted symbol line into symbol name and symbol address -lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \(^ *\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode \(^ *\) \(^ *\)$/ {\"\2\", (lt_ptr) \&\2},/p'" - -# Define system-specific variables. -case $host_os in -aix*) - symcode='BCDT' - ;; -cygwin* | mingw* | pw32*) - symcode='ABCDGISTW' - ;; -hpux*) # Its linker distinguishes data from code symbols - if test "$host_cpu" = ia64; then - symcode='ABCDEGRST' - fi - lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" - lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \(^ *\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \(^ *\) \(^ *\)$/ {\"\2\", (lt_ptr) \&\2},/p'" - ;; -linux* | k*bsd*-gnu) - 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*) - symcode='BDRT' - ;; -sco3.2v5*) - symcode='DT' - ;; -sysv4.2uw2*) - symcode='DT' - ;; -sysv5* | sco5v6* | unixware* | OpenUNIX*) - symcode='ABDT' - ;; -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 { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - # Now try to grab the symbols. - nlist=conftest.nm - if { (eval echo "$as_me:$LINENO: \"$NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist\"") >&5 - (eval $NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && test -s "$nlist"; then - # Try sorting and uniquifying the output. - if sort "$nlist" | uniq > "$nlist"T; then - mv -f "$nlist"T "$nlist" - else - rm -f "$nlist"T - fi - - # Make sure that we snagged all the symbols we need. - if grep ' nm_test_var$' "$nlist" >/dev/null; then - if grep ' nm_test_func$' "$nlist" >/dev/null; then - cat <<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_prog_compiler_no_builtin_flag" - if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 - (eval $ac_link) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && test -s conftest${ac_exeext}; then - pipe_works=yes - fi - LIBS="$lt_save_LIBS" - CFLAGS="$lt_save_CFLAGS" - else - echo "cannot find nm_test_func in $nlist" >&5 - fi - else - echo "cannot find nm_test_var in $nlist" >&5 - fi - else - echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 - fi - else - echo "$progname: failed program was:" >&5 - cat conftest.$ac_ext >&5 - fi - rm -rf conftest* conftst* - - # Do not use the global_symbol_pipe unless it works. - if test "$pipe_works" = yes; then - break - else - lt_cv_sys_global_symbol_pipe= - fi -done - -fi - -if test -z "$lt_cv_sys_global_symbol_pipe"; then - lt_cv_sys_global_symbol_to_cdecl= -fi -if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then - { echo "$as_me:$LINENO: result: failed" >&5 -echo "${ECHO_T}failed" >&6; } -else - { echo "$as_me:$LINENO: result: ok" >&5 -echo "${ECHO_T}ok" >&6; } -fi - -{ echo "$as_me:$LINENO: checking for objdir" >&5 -echo $ECHO_N "checking for objdir... $ECHO_C" >&6; } -if test "${lt_cv_objdir+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - rm -f .libs 2>/dev/null -mkdir .libs 2>/dev/null -if test -d .libs; then - lt_cv_objdir=.libs -else - # MS-DOS does not allow filenames that begin with a dot. - lt_cv_objdir=_libs -fi -rmdir .libs 2>/dev/null -fi -{ echo "$as_me:$LINENO: result: $lt_cv_objdir" >&5 -echo "${ECHO_T}$lt_cv_objdir" >&6; } -objdir=$lt_cv_objdir - - - - - -case $host_os in -aix3*) - # AIX sometimes has problems with the GCC collect2 program. For some - # reason, if we set the COLLECT_NAMES environment variable, the problems - # vanish in a puff of smoke. - if test "X${COLLECT_NAMES+set}" != Xset; then - COLLECT_NAMES= - export COLLECT_NAMES - fi - ;; -esac - -# Sed substitution that helps us do robust quoting. It backslashifies -# metacharacters that are still active within double-quoted strings. -Xsed='sed -e 1s/^X//' -sed_quote_subst='s/\(\\"\\`$\\\\\)/\\\1/g' - -# Same as above, but do not quote variable references. -double_quote_subst='s/\(\\"\\`\\\\\)/\\\1/g' - -# Sed substitution to delay expansion of an escaped shell variable in a -# double_quote_subst'ed string. -delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' - -# Sed substitution to avoid accidental globbing in evaled expressions -no_glob_subst='s/\*/\\\*/g' - -# Constants: -rm="rm -f" - -# Global variables: -default_ofile=libtool -can_build_shared=yes - -# All known linkers require a `.a' archive for static linking (except MSVC, -# which needs '.lib'). -libext=a -ltmain="$ac_aux_dir/ltmain.sh" -ofile="$default_ofile" -with_gnu_ld="$lt_cv_prog_gnu_ld" - -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args. -set dummy ${ac_tool_prefix}ar; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_AR+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$AR"; then - ac_cv_prog_AR="$AR" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_AR="${ac_tool_prefix}ar" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -AR=$ac_cv_prog_AR -if test -n "$AR"; then - { echo "$as_me:$LINENO: result: $AR" >&5 -echo "${ECHO_T}$AR" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_AR"; then - ac_ct_AR=$AR - # Extract the first word of "ar", so it can be a program name with args. -set dummy ar; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_AR+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_AR"; then - ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_AR="ar" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_AR=$ac_cv_prog_ac_ct_AR -if test -n "$ac_ct_AR"; then - { echo "$as_me:$LINENO: result: $ac_ct_AR" >&5 -echo "${ECHO_T}$ac_ct_AR" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_AR" = x; then - AR="false" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - AR=$ac_ct_AR - fi -else - AR="$ac_cv_prog_AR" -fi - -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. -set dummy ${ac_tool_prefix}ranlib; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_RANLIB+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$RANLIB"; then - ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -RANLIB=$ac_cv_prog_RANLIB -if test -n "$RANLIB"; then - { echo "$as_me:$LINENO: result: $RANLIB" >&5 -echo "${ECHO_T}$RANLIB" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_RANLIB"; then - ac_ct_RANLIB=$RANLIB - # Extract the first word of "ranlib", so it can be a program name with args. -set dummy ranlib; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_RANLIB"; then - ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_RANLIB="ranlib" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB -if test -n "$ac_ct_RANLIB"; then - { echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5 -echo "${ECHO_T}$ac_ct_RANLIB" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_RANLIB" = x; then - RANLIB=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - RANLIB=$ac_ct_RANLIB - fi -else - RANLIB="$ac_cv_prog_RANLIB" -fi - -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. -set dummy ${ac_tool_prefix}strip; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_STRIP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$STRIP"; then - ac_cv_prog_STRIP="$STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_STRIP="${ac_tool_prefix}strip" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -STRIP=$ac_cv_prog_STRIP -if test -n "$STRIP"; then - { echo "$as_me:$LINENO: result: $STRIP" >&5 -echo "${ECHO_T}$STRIP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_STRIP"; then - ac_ct_STRIP=$STRIP - # Extract the first word of "strip", so it can be a program name with args. -set dummy strip; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_STRIP"; then - ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_STRIP="strip" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP -if test -n "$ac_ct_STRIP"; then - { echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 -echo "${ECHO_T}$ac_ct_STRIP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_STRIP" = x; then - STRIP=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - STRIP=$ac_ct_STRIP - fi -else - STRIP="$ac_cv_prog_STRIP" -fi - - -old_CC="$CC" -old_CFLAGS="$CFLAGS" - -# Set sane defaults for various variables -test -z "$AR" && AR=ar -test -z "$AR_FLAGS" && AR_FLAGS=cru -test -z "$AS" && AS=as -test -z "$CC" && CC=cc -test -z "$LTCC" && LTCC=$CC -test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS -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_postinstall_cmds='chmod 644 $oldlib' -old_postuninstall_cmds= - -if test -n "$RANLIB"; then - case $host_os in - openbsd*) - old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib" - ;; - *) - old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib" - ;; - esac - old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" -fi - -for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - -# Only perform the check for file, if the check method requires it -case $deplibs_check_method in -file_magic*) - if test "$file_magic_cmd" = '$MAGIC_CMD'; then - { echo "$as_me:$LINENO: checking for ${ac_tool_prefix}file" >&5 -echo $ECHO_N "checking for ${ac_tool_prefix}file... $ECHO_C" >&6; } -if test "${lt_cv_path_MAGIC_CMD+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $MAGIC_CMD in -\\/* | ?:\\/*) - lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. - ;; -*) - lt_save_MAGIC_CMD="$MAGIC_CMD" - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" - for ac_dir in $ac_dummy; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - if test -f $ac_dir/${ac_tool_prefix}file; then - lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file" - if test -n "$file_magic_test_file"; then - case $deplibs_check_method in - "file_magic "*) - file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` - MAGIC_CMD="$lt_cv_path_MAGIC_CMD" - if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | - $EGREP "$file_magic_regex" > /dev/null; then - : - else - cat <<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@gnu.org - -EOF - fi ;; - esac - fi - break - fi - done - IFS="$lt_save_ifs" - MAGIC_CMD="$lt_save_MAGIC_CMD" - ;; -esac -fi - -MAGIC_CMD="$lt_cv_path_MAGIC_CMD" -if test -n "$MAGIC_CMD"; then - { echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 -echo "${ECHO_T}$MAGIC_CMD" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - -if test -z "$lt_cv_path_MAGIC_CMD"; then - if test -n "$ac_tool_prefix"; then - { echo "$as_me:$LINENO: checking for file" >&5 -echo $ECHO_N "checking for file... $ECHO_C" >&6; } -if test "${lt_cv_path_MAGIC_CMD+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $MAGIC_CMD in -\\/* | ?:\\/*) - lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. - ;; -*) - lt_save_MAGIC_CMD="$MAGIC_CMD" - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" - for ac_dir in $ac_dummy; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - if test -f $ac_dir/file; then - lt_cv_path_MAGIC_CMD="$ac_dir/file" - if test -n "$file_magic_test_file"; then - case $deplibs_check_method in - "file_magic "*) - file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` - MAGIC_CMD="$lt_cv_path_MAGIC_CMD" - if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | - $EGREP "$file_magic_regex" > /dev/null; then - : - else - cat <<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@gnu.org - -EOF - fi ;; - esac - fi - break - fi - done - IFS="$lt_save_ifs" - MAGIC_CMD="$lt_save_MAGIC_CMD" - ;; -esac -fi - -MAGIC_CMD="$lt_cv_path_MAGIC_CMD" -if test -n "$MAGIC_CMD"; then - { echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 -echo "${ECHO_T}$MAGIC_CMD" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - else - MAGIC_CMD=: - fi -fi - - fi - ;; -esac - - - case $host_os in - rhapsody* | darwin*) - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. -set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_DSYMUTIL+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$DSYMUTIL"; then - ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -DSYMUTIL=$ac_cv_prog_DSYMUTIL -if test -n "$DSYMUTIL"; then - { echo "$as_me:$LINENO: result: $DSYMUTIL" >&5 -echo "${ECHO_T}$DSYMUTIL" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_DSYMUTIL"; then - ac_ct_DSYMUTIL=$DSYMUTIL - # Extract the first word of "dsymutil", so it can be a program name with args. -set dummy dsymutil; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_DSYMUTIL+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_DSYMUTIL"; then - ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL -if test -n "$ac_ct_DSYMUTIL"; then - { echo "$as_me:$LINENO: result: $ac_ct_DSYMUTIL" >&5 -echo "${ECHO_T}$ac_ct_DSYMUTIL" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_DSYMUTIL" = x; then - DSYMUTIL=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - DSYMUTIL=$ac_ct_DSYMUTIL - fi -else - DSYMUTIL="$ac_cv_prog_DSYMUTIL" -fi - - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. -set dummy ${ac_tool_prefix}nmedit; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_NMEDIT+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$NMEDIT"; then - ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -NMEDIT=$ac_cv_prog_NMEDIT -if test -n "$NMEDIT"; then - { echo "$as_me:$LINENO: result: $NMEDIT" >&5 -echo "${ECHO_T}$NMEDIT" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_NMEDIT"; then - ac_ct_NMEDIT=$NMEDIT - # Extract the first word of "nmedit", so it can be a program name with args. -set dummy nmedit; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_NMEDIT+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_NMEDIT"; then - ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_NMEDIT="nmedit" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT -if test -n "$ac_ct_NMEDIT"; then - { echo "$as_me:$LINENO: result: $ac_ct_NMEDIT" >&5 -echo "${ECHO_T}$ac_ct_NMEDIT" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_NMEDIT" = x; then - NMEDIT=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - NMEDIT=$ac_ct_NMEDIT - fi -else - NMEDIT="$ac_cv_prog_NMEDIT" -fi - - - { echo "$as_me:$LINENO: checking for -single_module linker flag" >&5 -echo $ECHO_N "checking for -single_module linker flag... $ECHO_C" >&6; } -if test "${lt_cv_apple_cc_single_mod+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_apple_cc_single_mod=no - if test -z "${LT_MULTI_MODULE}"; then - # By default we will add the -single_module flag. You can override - # by either setting the environment variable LT_MULTI_MODULE - # non-empty at configure time, or by adding -multi_module to the - # link flags. - echo "int foo(void){return 1;}" > conftest.c - $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ - -dynamiclib ${wl}-single_module conftest.c - if test -f libconftest.dylib; then - lt_cv_apple_cc_single_mod=yes - rm -rf libconftest.dylib* - fi - rm conftest.c - fi -fi -{ echo "$as_me:$LINENO: result: $lt_cv_apple_cc_single_mod" >&5 -echo "${ECHO_T}$lt_cv_apple_cc_single_mod" >&6; } - { echo "$as_me:$LINENO: checking for -exported_symbols_list linker flag" >&5 -echo $ECHO_N "checking for -exported_symbols_list linker flag... $ECHO_C" >&6; } -if test "${lt_cv_ld_exported_symbols_list+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_ld_exported_symbols_list=no - save_LDFLAGS=$LDFLAGS - echo "_main" > conftest.sym - LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - lt_cv_ld_exported_symbols_list=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - lt_cv_ld_exported_symbols_list=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - LDFLAGS="$save_LDFLAGS" - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_ld_exported_symbols_list" >&5 -echo "${ECHO_T}$lt_cv_ld_exported_symbols_list" >&6; } - case $host_os in - rhapsody* | darwin1.0123) - _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;; - darwin1.*) - _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; - darwin*) - # if running on 10.5 or later, the deployment target defaults - # to the OS version, if on x86, and 10.4, the deployment - # target defaults to 10.4. Don't you love it? - case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in - 10.0,*86*-darwin8*|10.0,*-darwin91*) - _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; - 10.012*) - _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;; - 10.*) - _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;; - esac - ;; - esac - if test "$lt_cv_apple_cc_single_mod" = "yes"; then - _lt_dar_single_mod='$single_module' - fi - if test "$lt_cv_ld_exported_symbols_list" = "yes"; then - _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym' - else - _lt_dar_export_syms="~$NMEDIT -s \$output_objdir/\${libname}-symbols.expsym \${lib}" - fi - if test "$DSYMUTIL" != ":"; then - _lt_dsymutil="~$DSYMUTIL \$lib || :" - else - _lt_dsymutil= - fi - ;; - esac - - -enable_dlopen=no -enable_win32_dll=yes - -# Check whether --enable-libtool-lock was given. -if test "${enable_libtool_lock+set}" = set; then - enableval=$enable_libtool_lock; -fi - -test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes - - -# Check whether --with-pic was given. -if test "${with_pic+set}" = set; then - withval=$with_pic; pic_mode="$withval" -else - pic_mode=default -fi - -test -z "$pic_mode" && pic_mode=default - -# Use C for the default configuration in the libtool script -tagname= -lt_save_CC="$CC" -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -# Source file extension for C test sources. -ac_ext=c - -# Object file extension for compiled C test sources. -objext=o -objext=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code="int some_variable = 0;" - -# Code to be used in simple link tests -lt_simple_link_test_code='int main(){return(0);}' - - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# save warnings/boilerplate of simple test code -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_compiler_boilerplate=`cat conftest.err` -$rm conftest* - -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* - - - -lt_prog_compiler_no_builtin_flag= - -if test "$GCC" = yes; then - lt_prog_compiler_no_builtin_flag=' -fno-builtin' - - -{ echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 -echo $ECHO_N "checking if $compiler supports -fno-rtti -fno-exceptions... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_rtti_exceptions=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="-fno-rtti -fno-exceptions" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:7323: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:7327: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_rtti_exceptions=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_rtti_exceptions" >&6; } - -if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then - lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" -else - : -fi - -fi - -lt_prog_compiler_wl= -lt_prog_compiler_pic= -lt_prog_compiler_static= - -{ echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 -echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6; } - - if test "$GCC" = yes; then - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_static='-static' - - case $host_os in - aix*) - # All AIX code is PIC. - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static='-Bstatic' - fi - ;; - - amigaos*) - # FIXME: we need at least 68020 code to build shared libraries, but - # adding the `-m68020' flag to GCC prevents building anything better, - # like `-m68040'. - lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' - ;; - - beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - lt_prog_compiler_pic='-DDLL_EXPORT' - ;; - - darwin* | rhapsody*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - lt_prog_compiler_pic='-fno-common' - ;; - - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - - msdosdjgpp*) - # Just because we use GCC doesn't mean we suddenly get shared libraries - # on systems that don't support them. - lt_prog_compiler_can_build_shared=no - enable_shared=no - ;; - - sysv4*MP*) - if test -d /usr/nec; then - lt_prog_compiler_pic=-Kconform_pic - fi - ;; - - hpux*) - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic='-fPIC' - ;; - esac - ;; - - *) - lt_prog_compiler_pic='-fPIC' - ;; - esac - else - # PORTME Check for flag to pass linker flags through the system compiler. - case $host_os in - aix*) - lt_prog_compiler_wl='-Wl,' - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static='-Bstatic' - else - lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' - fi - ;; - darwin*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - case $cc_basename in - xlc*) - lt_prog_compiler_pic='-qnocommon' - lt_prog_compiler_wl='-Wl,' - ;; - esac - ;; - - mingw* | cygwin* | pw32* | os2*) - # This hack is so that the source file can tell whether it is being - # built for inclusion in a dll (and should export symbols for example). - lt_prog_compiler_pic='-DDLL_EXPORT' - ;; - - hpux9* | hpux10* | hpux11*) - lt_prog_compiler_wl='-Wl,' - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic='+Z' - ;; - esac - # Is there a better lt_prog_compiler_static that works with the bundled CC? - lt_prog_compiler_static='${wl}-a ${wl}archive' - ;; - - irix5* | irix6* | nonstopux*) - lt_prog_compiler_wl='-Wl,' - # PIC (with -KPIC) is the default. - lt_prog_compiler_static='-non_shared' - ;; - - newsos6) - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - ;; - - linux* | k*bsd*-gnu) - case $cc_basename in - icc* | ecc*) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-static' - ;; - pgcc* | pgf77* | pgf90* | pgf95*) - # Portland Group compilers (*not* the Pentium gcc compiler, - # which looks to be a dead project) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_pic='-fpic' - lt_prog_compiler_static='-Bstatic' - ;; - ccc*) - lt_prog_compiler_wl='-Wl,' - # All Alpha code is PIC. - lt_prog_compiler_static='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C 5.9 - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - lt_prog_compiler_wl='-Wl,' - ;; - *Sun\ F*) - # Sun Fortran 8.3 passes all unrecognized flags to the linker - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - lt_prog_compiler_wl='' - ;; - esac - ;; - esac - ;; - - osf3* | osf4* | osf5*) - lt_prog_compiler_wl='-Wl,' - # All OSF/1 code is PIC. - lt_prog_compiler_static='-non_shared' - ;; - - rdos*) - lt_prog_compiler_static='-non_shared' - ;; - - solaris*) - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - case $cc_basename in - f77* | f90* | f95*) - lt_prog_compiler_wl='-Qoption ld ';; - *) - lt_prog_compiler_wl='-Wl,';; - esac - ;; - - sunos4*) - lt_prog_compiler_wl='-Qoption ld ' - lt_prog_compiler_pic='-PIC' - lt_prog_compiler_static='-Bstatic' - ;; - - sysv4 | sysv4.2uw2* | sysv4.3*) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - ;; - - sysv4*MP*) - if test -d /usr/nec ;then - lt_prog_compiler_pic='-Kconform_pic' - lt_prog_compiler_static='-Bstatic' - fi - ;; - - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_pic='-KPIC' - lt_prog_compiler_static='-Bstatic' - ;; - - unicos*) - lt_prog_compiler_wl='-Wl,' - lt_prog_compiler_can_build_shared=no - ;; - - uts4*) - lt_prog_compiler_pic='-pic' - lt_prog_compiler_static='-Bstatic' - ;; - - *) - lt_prog_compiler_can_build_shared=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $lt_prog_compiler_pic" >&5 -echo "${ECHO_T}$lt_prog_compiler_pic" >&6; } - -# -# Check to make sure the PIC flag actually works. -# -if test -n "$lt_prog_compiler_pic"; then - -{ echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 -echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_pic_works+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_pic_works=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="$lt_prog_compiler_pic -DPIC" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:7613: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:7617: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_pic_works=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_pic_works" >&6; } - -if test x"$lt_cv_prog_compiler_pic_works" = xyes; then - case $lt_prog_compiler_pic in - "" | " "*) ;; - *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; - esac -else - lt_prog_compiler_pic= - lt_prog_compiler_can_build_shared=no -fi - -fi -case $host_os in - # For platforms which do not support PIC, -DPIC is meaningless: - *djgpp*) - lt_prog_compiler_pic= - ;; - *) - lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" - ;; -esac - -# -# Check to make sure the static flag actually works. -# -wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" -{ echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 -echo $ECHO_N "checking if $compiler static flag $lt_tmp_static_flag works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_static_works+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_static_works=no - save_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS $lt_tmp_static_flag" - echo "$lt_simple_link_test_code" > conftest.$ac_ext - if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then - # The linker can only warn and ignore the option if not recognized - # So say no if there are warnings - if test -s conftest.err; then - # Append any errors to the config.log. - cat conftest.err 1>&5 - $echo "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_static_works=yes - fi - else - lt_cv_prog_compiler_static_works=yes - fi - fi - $rm -r conftest* - LDFLAGS="$save_LDFLAGS" - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_static_works" >&6; } - -if test x"$lt_cv_prog_compiler_static_works" = xyes; then - : -else - lt_prog_compiler_static= -fi - - -{ echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 -echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_c_o+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_c_o=no - $rm -r conftest 2>/dev/null - mkdir conftest - cd conftest - mkdir out - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - lt_compiler_flag="-o out/conftest2.$ac_objext" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:7717: $lt_compile\"" >&5) - (eval "$lt_compile" 2>out/conftest.err) - ac_status=$? - cat out/conftest.err >&5 - echo "$as_me:7721: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s out/conftest2.$ac_objext - then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp - $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 - if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then - lt_cv_prog_compiler_c_o=yes - fi - fi - chmod u+w . 2>&5 - $rm conftest* - # SGI C++ compiler will create directory out/ii_files/ for - # template instantiation - test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files - $rm out/* && rmdir out - cd .. - rmdir conftest - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_c_o" >&6; } - - -hard_links="nottested" -if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then - # do not overwrite the value of need_locks provided by the user - { echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 -echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6; } - hard_links=yes - $rm conftest* - ln conftest.a conftest.b 2>/dev/null && hard_links=no - touch conftest.a - ln conftest.a conftest.b 2>&5 || hard_links=no - ln conftest.a conftest.b 2>/dev/null && hard_links=no - { echo "$as_me:$LINENO: result: $hard_links" >&5 -echo "${ECHO_T}$hard_links" >&6; } - if test "$hard_links" = no; then - { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 -echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} - need_locks=warn - fi -else - need_locks=no -fi - -{ echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 -echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6; } - - runpath_var= - allow_undefined_flag= - enable_shared_with_static_runtimes=no - archive_cmds= - archive_expsym_cmds= - old_archive_From_new_cmds= - old_archive_from_expsyms_cmds= - export_dynamic_flag_spec= - whole_archive_flag_spec= - thread_safe_flag_spec= - hardcode_libdir_flag_spec= - hardcode_libdir_flag_spec_ld= - hardcode_libdir_separator= - hardcode_direct=no - hardcode_minus_L=no - hardcode_shlibpath_var=unsupported - link_all_deplibs=unknown - hardcode_automatic=no - module_cmds= - module_expsym_cmds= - always_export_symbols=no - export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - # include_expsyms should be a list of space-separated symbols to be *always* - # included in the symbol list - include_expsyms= - # exclude_expsyms can be an extended regexp of symbols to exclude - # it will be wrapped by ` (' and `)$', so one must not match beginning or - # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', - # as well as any symbol that contains `d'. - exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__FID_.*' - # 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. - # Exclude shared library initialization/finalization symbols. - extract_expsyms_cmds= - # Just being paranoid about ensuring that cc_basename is set. - for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - case $host_os in - cygwin* | mingw* | pw32*) - # FIXME: the MSVC++ port hasn't been tested in a loooong time - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - if test "$GCC" != yes; then - with_gnu_ld=no - fi - ;; - interix*) - # we just hope/assume this is gcc and not c89 (= MSVC++) - with_gnu_ld=yes - ;; - openbsd*) - with_gnu_ld=no - ;; - esac - - ld_shlibs=yes - if test "$with_gnu_ld" = yes; then - # If archive_cmds runs LD, not CC, wlarc should be empty - wlarc='${wl}' - - # Set some defaults for GNU ld with shared library support. These - # are reset later if shared libraries are not supported. Putting them - # here allows them to be overridden if necessary. - runpath_var=LD_RUN_PATH - hardcode_libdir_flag_spec='${wl}--rpath ${wl}$libdir' - export_dynamic_flag_spec='${wl}--export-dynamic' - # ancient GNU ld didn't support --whole-archive et. al. - if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then - whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' - else - whole_archive_flag_spec= - fi - supports_anon_versioning=no - case `$LD -v 2>/dev/null` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10.*) ;; # catch versions < 2.11 - *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... - *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... - *\ 2.11.*) ;; # other 2.11 versions - *) supports_anon_versioning=yes ;; - esac - - # See if GNU ld supports shared libraries. - case $host_os in - aix3-9*) - # On AIX/PPC, the GNU linker is very broken - if test "$host_cpu" != ia64; then - ld_shlibs=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*) - archive_cmds='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec='-L$libdir' - hardcode_minus_L=yes - - # Samuel A. Falvo II <kc5tja@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. - ld_shlibs=no - ;; - - beos*) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - allow_undefined_flag=unsupported - # Joseph Beckenbach <jrb3@best.com> says some releases of gcc - # support --undefined. This deserves some investigation. FIXME - archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - else - ld_shlibs=no - fi - ;; - - cygwin* | mingw* | pw32*) - # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, - # as there is no search path for DLLs. - hardcode_libdir_flag_spec='-L$libdir' - allow_undefined_flag=unsupported - always_export_symbols=no - enable_shared_with_static_runtimes=yes - export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^BCDGRS /s/.* \(^ *\)/\1 DATA/'\'' -e '\''/^AITW /s/.* //'\'' | sort | uniq > $export_symbols' - - if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then - cp $export_symbols $output_objdir/$soname.def; - else - echo EXPORTS > $output_objdir/$soname.def; - cat $export_symbols >> $output_objdir/$soname.def; - fi~ - $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - ld_shlibs=no - fi - ;; - - interix3-9*) - hardcode_direct=no - hardcode_shlibpath_var=no - hardcode_libdir_flag_spec='${wl}-rpath,$libdir' - export_dynamic_flag_spec='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - - gnu* | linux* | k*bsd*-gnu) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - tmp_addflag= - case $cc_basename,$host_cpu in - pgcc*) # Portland Group C compiler - whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag' - ;; - pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers - whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag -Mnomain' ;; - ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 - tmp_addflag=' -i_dynamic' ;; - efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 - tmp_addflag=' -i_dynamic -nofor_main' ;; - ifc* | ifort*) # Intel Fortran compiler - tmp_addflag=' -nofor_main' ;; - esac - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) # Sun C 5.9 - whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_sharedflag='-G' ;; - *Sun\ F*) # Sun Fortran 8.3 - tmp_sharedflag='-G' ;; - *) - tmp_sharedflag='-shared' ;; - esac - archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - - if test $supports_anon_versioning = yes; then - archive_expsym_cmds='$echo "{ global:" > $output_objdir/$libname.ver~ - cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ - $echo "local: *; };" >> $output_objdir/$libname.ver~ - $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' - fi - link_all_deplibs=no - else - ld_shlibs=no - fi - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' - wlarc= - else - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - fi - ;; - - solaris*) - if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then - ld_shlibs=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 - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs=no - fi - ;; - - sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) - case `$LD -v 2>&1` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10-5.*) - ld_shlibs=no - cat <<_LT_EOF 1>&2 - -*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not -*** reliably create shared libraries on SCO systems. Therefore, libtool -*** is disabling shared libraries support. We urge you to upgrade GNU -*** binutils to release 2.16.91.0.3 or newer. Another option is to modify -*** your PATH or compiler configuration so that the native linker is -*** used, and then restart. - -_LT_EOF - ;; - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib' - archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname,-retain-symbols-file,$export_symbols -o $lib' - else - ld_shlibs=no - fi - ;; - esac - ;; - - sunos4*) - archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' - wlarc= - hardcode_direct=yes - hardcode_shlibpath_var=no - ;; - - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs=no - fi - ;; - esac - - if test "$ld_shlibs" = no; then - runpath_var= - hardcode_libdir_flag_spec= - export_dynamic_flag_spec= - whole_archive_flag_spec= - fi - else - # PORTME fill in a description of your system's linker (not GNU ld) - case $host_os in - aix3*) - allow_undefined_flag=unsupported - always_export_symbols=yes - archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' - # Note: this linker hardcodes the directories in LIBPATH if there - # are no directories specified by -L. - hardcode_minus_L=yes - if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then - # Neither direct hardcoding nor static linking is supported with a - # broken collect2. - hardcode_direct=unsupported - fi - ;; - - aix4-9*) - if test "$host_cpu" = ia64; then - # On IA64, the linker does run time linking by default, so we don't - # have to do anything special. - aix_use_runtimelinking=no - exp_sym_flag='-Bexport' - no_entry_flag="" - else - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to AIX nm, but means don't demangle with GNU nm - if $NM -V 2>&1 | grep 'GNU' > /dev/null; then - export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - else - export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - fi - aix_use_runtimelinking=no - - # Test if we are trying to use run time linking or normal - # AIX style linking. If -brtl is somewhere in LDFLAGS, we - # need to do runtime linking. - case $host_os in aix4.23|aix4.23.*|aix5-9*) - for ld_flag in $LDFLAGS; do - if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then - aix_use_runtimelinking=yes - break - fi - done - ;; - esac - - exp_sym_flag='-bexport' - no_entry_flag='-bnoentry' - fi - - # When large executables or shared objects are built, AIX ld can - # have problems creating the table of contents. If linking a library - # or program results in "error TOC overflow" add -mminimal-toc to - # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not - # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. - - archive_cmds='' - hardcode_direct=yes - hardcode_libdir_separator=':' - link_all_deplibs=yes - - if test "$GCC" = yes; then - case $host_os in aix4.012|aix4.012.*) - # We only want to do this on AIX 4.2 and lower, the check - # below for broken collect2 doesn't work under 4.3+ - collect2name=`${CC} -print-prog-name=collect2` - if test -f "$collect2name" && \ - strings "$collect2name" | grep resolve_lib_name >/dev/null - then - # We have reworked collect2 - : - else - # We have old collect2 - hardcode_direct=unsupported - # It fails to find uninstalled libraries when the uninstalled - # path is not listed in the libpath. Setting hardcode_minus_L - # to unsupported forces relinking - hardcode_minus_L=yes - hardcode_libdir_flag_spec='-L$libdir' - hardcode_libdir_separator= - fi - ;; - esac - shared_flag='-shared' - if test "$aix_use_runtimelinking" = yes; then - shared_flag="$shared_flag "'${wl}-G' - fi - else - # not using gcc - if test "$host_cpu" = ia64; then - # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release - # chokes on -Wl,-G. The following line is correct: - shared_flag='-G' - else - if test "$aix_use_runtimelinking" = yes; then - shared_flag='${wl}-G' - else - shared_flag='${wl}-bM:SRE' - fi - fi - fi - - # It seems that -bexpall does not export symbols beginning with - # underscore (_), so it is better to generate a list of symbols to export. - always_export_symbols=yes - if test "$aix_use_runtimelinking" = yes; then - # Warning - without using the other runtime loading flags (-brtl), - # -berok will link without error, but may produce a broken library. - allow_undefined_flag='-berok' - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" - archive_expsym_cmds="\$CC"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" - else - if test "$host_cpu" = ia64; then - hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' - allow_undefined_flag="-z nodefs" - archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" - # Warning - without using the other run time loading flags, - # -berok will link without error, but may produce a broken library. - no_undefined_flag=' ${wl}-bernotok' - allow_undefined_flag=' ${wl}-berok' - # Exported symbols can be pulled into shared objects from archives - whole_archive_flag_spec='$convenience' - archive_cmds_need_lc=yes - # This is similar to how AIX traditionally builds its shared libraries. - archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' - fi - fi - ;; - - amigaos*) - archive_cmds='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec='-L$libdir' - hardcode_minus_L=yes - # see comment about different semantics on the GNU ld section - ld_shlibs=no - ;; - - bsdi45*) - export_dynamic_flag_spec=-rdynamic - ;; - - cygwin* | mingw* | pw32*) - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - # hardcode_libdir_flag_spec is actually meaningless, as there is - # no search path for DLLs. - hardcode_libdir_flag_spec=' ' - allow_undefined_flag=unsupported - # Tell ltmain to make .lib files, not .a files. - libext=lib - # Tell ltmain to make .dll files, not .so files. - shrext_cmds=".dll" - # FIXME: Setting linknames here is a bad hack. - archive_cmds='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' - # The linker will automatically build a .lib file if we build a DLL. - old_archive_From_new_cmds='true' - # FIXME: Should let the user specify the lib program. - old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' - fix_srcfile_path='`cygpath -w "$srcfile"`' - enable_shared_with_static_runtimes=yes - ;; - - darwin* | rhapsody*) - case $host_os in - rhapsody* | darwin1.012) - allow_undefined_flag='${wl}-undefined ${wl}suppress' - ;; - *) # Darwin 1.3 on - if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then - allow_undefined_flag='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - else - case ${MACOSX_DEPLOYMENT_TARGET} in - 10.012) - allow_undefined_flag='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - ;; - 10.*) - allow_undefined_flag='${wl}-undefined ${wl}dynamic_lookup' - ;; - esac - fi - ;; - esac - archive_cmds_need_lc=no - hardcode_direct=no - hardcode_automatic=yes - hardcode_shlibpath_var=unsupported - whole_archive_flag_spec='' - link_all_deplibs=yes - if test "$GCC" = yes ; then - output_verbose_link_cmd='echo' - archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" - module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - else - case $cc_basename in - xlc*) - output_verbose_link_cmd='echo' - archive_cmds='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $xlcverstring' - module_cmds='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - archive_expsym_cmds='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - module_expsym_cmds='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - ;; - *) - ld_shlibs=no - ;; - esac - fi - ;; - - dgux*) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec='-L$libdir' - hardcode_shlibpath_var=no - ;; - - freebsd1*) - ld_shlibs=no - ;; - - # FreeBSD 2.2.012 allows us to include c++rt0.o to get C++ constructor - # support. Future versions do this automatically, but an explicit c++rt0.o - # does not break anything, and helps significantly (at the cost of a little - # extra space). - freebsd2.2*) - archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' - hardcode_libdir_flag_spec='-R$libdir' - hardcode_direct=yes - hardcode_shlibpath_var=no - ;; - - # Unfortunately, older versions of FreeBSD 2 do not have this feature. - freebsd2*) - archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct=yes - hardcode_minus_L=yes - hardcode_shlibpath_var=no - ;; - - # FreeBSD 3 and greater uses gcc -shared to do shared libraries. - freebsd* | dragonfly*) - archive_cmds='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec='-R$libdir' - hardcode_direct=yes - hardcode_shlibpath_var=no - ;; - - hpux9*) - if test "$GCC" = yes; then - archive_cmds='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - else - archive_cmds='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - fi - hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' - hardcode_libdir_separator=: - hardcode_direct=yes - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L=yes - export_dynamic_flag_spec='${wl}-E' - ;; - - hpux10*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' - hardcode_libdir_separator=: - - hardcode_direct=yes - export_dynamic_flag_spec='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L=yes - fi - ;; - - hpux11*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - case $host_cpu in - hppa*64*) - archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds='$CC -shared ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - else - case $host_cpu in - hppa*64*) - archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' - hardcode_libdir_separator=: - - case $host_cpu in - hppa*64*|ia64*) - hardcode_libdir_flag_spec_ld='+b $libdir' - hardcode_direct=no - hardcode_shlibpath_var=no - ;; - *) - hardcode_direct=yes - export_dynamic_flag_spec='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L=yes - ;; - esac - fi - ;; - - irix5* | irix6* | nonstopux*) - if test "$GCC" = yes; then - archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec_ld='-rpath $libdir' - fi - hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator=: - link_all_deplibs=yes - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out - else - archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF - fi - hardcode_libdir_flag_spec='-R$libdir' - hardcode_direct=yes - hardcode_shlibpath_var=no - ;; - - newsos6) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct=yes - hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator=: - hardcode_shlibpath_var=no - ;; - - openbsd*) - if test -f /usr/libexec/ld.so; then - hardcode_direct=yes - hardcode_shlibpath_var=no - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' - hardcode_libdir_flag_spec='${wl}-rpath,$libdir' - export_dynamic_flag_spec='${wl}-E' - else - case $host_os in - openbsd01.* | openbsd2.0-7 | openbsd2.0-7.*) - archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec='-R$libdir' - ;; - *) - archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec='${wl}-rpath,$libdir' - ;; - esac - fi - else - ld_shlibs=no - fi - ;; - - os2*) - hardcode_libdir_flag_spec='-L$libdir' - hardcode_minus_L=yes - allow_undefined_flag=unsupported - archive_cmds='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' - old_archive_From_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' - ;; - - osf3*) - if test "$GCC" = yes; then - allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - allow_undefined_flag=' -expect_unresolved \*' - archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - fi - hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator=: - ;; - - osf4* | osf5*) # as osf3* with the addition of -msym flag - if test "$GCC" = yes; then - allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' - else - allow_undefined_flag=' -expect_unresolved \*' - archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ - $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' - - # Both c and cxx compiler support -rpath directly - hardcode_libdir_flag_spec='-rpath $libdir' - fi - hardcode_libdir_separator=: - ;; - - solaris*) - no_undefined_flag=' -z text' - if test "$GCC" = yes; then - wlarc='${wl}' - archive_cmds='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' - else - wlarc='' - archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' - archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' - fi - hardcode_libdir_flag_spec='-R$libdir' - hardcode_shlibpath_var=no - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - # The compiler driver will combine and reorder linker options, - # but understands `-z linker_flag'. GCC discards it without `$wl', - # but is careful enough not to reorder. - # Supported since Solaris 2.6 (maybe 2.5.1?) - if test "$GCC" = yes; then - whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - else - whole_archive_flag_spec='-z allextract$convenience -z defaultextract' - fi - ;; - esac - link_all_deplibs=yes - ;; - - sunos4*) - if test "x$host_vendor" = xsequent; then - # Use $CC to link under sequent, because it throws in some extra .o - # files that make .init and .fini sections work. - archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' - fi - hardcode_libdir_flag_spec='-L$libdir' - hardcode_direct=yes - hardcode_minus_L=yes - hardcode_shlibpath_var=no - ;; - - sysv4) - case $host_vendor in - sni) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct=yes # is this really true??? - ;; - siemens) - ## LD is ld it makes a PLAMLIB - ## CC just makes a GrossModule. - archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' - reload_cmds='$CC -r -o $output$reload_objs' - hardcode_direct=no - ;; - motorola) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct=no #Motorola manual says yes, but my tests say they lie - ;; - esac - runpath_var='LD_RUN_PATH' - hardcode_shlibpath_var=no - ;; - - sysv4.3*) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var=no - export_dynamic_flag_spec='-Bexport' - ;; - - sysv4*MP*) - if test -d /usr/nec; then - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var=no - runpath_var=LD_RUN_PATH - hardcode_runpath_var=yes - ld_shlibs=yes - fi - ;; - - sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - no_undefined_flag='${wl}-z,text' - archive_cmds_need_lc=no - hardcode_shlibpath_var=no - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - no_undefined_flag='${wl}-z,text' - allow_undefined_flag='${wl}-z,nodefs' - archive_cmds_need_lc=no - hardcode_shlibpath_var=no - hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - hardcode_libdir_separator=':' - link_all_deplibs=yes - export_dynamic_flag_spec='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - uts4*) - archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec='-L$libdir' - hardcode_shlibpath_var=no - ;; - - *) - ld_shlibs=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $ld_shlibs" >&5 -echo "${ECHO_T}$ld_shlibs" >&6; } -test "$ld_shlibs" = no && can_build_shared=no - -# -# Do we need to explicitly link libc? -# -case "x$archive_cmds_need_lc" in -x|xyes) - # Assume -lc should be added - archive_cmds_need_lc=yes - - if test "$enable_shared" = yes && test "$GCC" = yes; then - case $archive_cmds in - *'~'*) - # FIXME: we may have to deal with multi-command sequences. - ;; - '$CC '*) - # Test whether the compiler implicitly links with -lc since on some - # systems, -lgcc has to come before -lc. If gcc already passes -lc - # to ld, don't add -lc before -lgcc. - { echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 -echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6; } - $rm conftest* - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } 2>conftest.err; then - soname=conftest - lib=conftest - libobjs=conftest.$ac_objext - deplibs= - wl=$lt_prog_compiler_wl - pic_flag=$lt_prog_compiler_pic - compiler_flags=-v - linker_flags=-v - verstring= - output_objdir=. - libname=conftest - lt_save_allow_undefined_flag=$allow_undefined_flag - allow_undefined_flag= - if { (eval echo "$as_me:$LINENO: \"$archive_cmds 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 - (eval $archive_cmds 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - then - archive_cmds_need_lc=no - else - archive_cmds_need_lc=yes - fi - allow_undefined_flag=$lt_save_allow_undefined_flag - else - cat conftest.err 1>&5 - fi - $rm conftest* - { echo "$as_me:$LINENO: result: $archive_cmds_need_lc" >&5 -echo "${ECHO_T}$archive_cmds_need_lc" >&6; } - ;; - esac - fi - ;; -esac - -{ echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 -echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6; } -library_names_spec= -libname_spec='lib$name' -soname_spec= -shrext_cmds=".so" -postinstall_cmds= -postuninstall_cmds= -finish_cmds= -finish_eval= -shlibpath_var= -shlibpath_overrides_runpath=unknown -version_type=none -dynamic_linker="$host_os ld.so" -sys_lib_dlsearch_path_spec="/lib /usr/lib" - -if test "$GCC" = yes; then - case $host_os in - darwin*) lt_awk_arg="/^libraries:/,/LR/" ;; - *) lt_awk_arg="/^libraries:/" ;; - esac - lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$lt_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. - lt_search_path_spec=`echo "$lt_search_path_spec" | $SED -e 's/;/ /g'` - else - lt_search_path_spec=`echo "$lt_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - # Ok, now we have the path, separated by spaces, we can step through it - # and add multilib dir if necessary. - lt_tmp_lt_search_path_spec= - lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` - for lt_sys_path in $lt_search_path_spec; do - if test -d "$lt_sys_path/$lt_multi_os_dir"; then - lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir" - else - test -d "$lt_sys_path" && \ - lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" - fi - done - lt_search_path_spec=`echo $lt_tmp_lt_search_path_spec | awk ' -BEGIN {RS=" "; FS="/|\n";} { - lt_foo=""; - lt_count=0; - for (lt_i = NF; lt_i > 0; lt_i--) { - if ($lt_i != "" && $lt_i != ".") { - if ($lt_i == "..") { - lt_count++; - } else { - if (lt_count == 0) { - lt_foo="/" $lt_i lt_foo; - } else { - lt_count--; - } - } - } - } - if (lt_foo != "") { lt_freqlt_foo++; } - if (lt_freqlt_foo == 1) { print lt_foo; } -}'` - sys_lib_search_path_spec=`echo $lt_search_path_spec` -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-9*) - 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 - ;; - -bsdi45*) - version_type=linux - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' - shlibpath_var=LD_LIBRARY_PATH - sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" - sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" - # the default ld.so.conf also contains /usr/contrib/lib and - # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow - # libtool to hard-code these into programs - ;; - -cygwin* | mingw* | pw32*) - version_type=windows - shrext_cmds=".dll" - need_version=no - need_lib_prefix=no - - case $GCC,$host_os in - yes,cygwin* | yes,mingw* | yes,pw32*) - library_names_spec='$libname.dll.a' - # DLL is installed to $(libdir)/../bin by postinstall_cmds - postinstall_cmds='base_file=`basename \${file}`~ - dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ - dldir=$destdir/`dirname \$dlpath`~ - test -d \$dldir || mkdir -p \$dldir~ - $install_prog $dir/$dlname \$dldir/$dlname~ - chmod a+x \$dldir/$dlname' - postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ - dlpath=$dir/\$dldll~ - $rm \$dlpath' - shlibpath_overrides_runpath=yes - - case $host_os in - cygwin*) - # Cygwin DLLs use 'cyg' prefix rather than 'lib' - soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" - ;; - mingw*) - # MinGW DLLs use traditional 'lib' prefix - soname_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$sys_lib_search_path_spec" | grep ';c-zC-Z:/' >/dev/null; then - # It is most probably a Windows format PATH printed by - # mingw gcc, but we are running on Cygwin. Gcc prints its search - # path with ; separators, and with drive letters. We can handle the - # drive letters (cygwin fileutils understands them), so leave them, - # especially as we might pass files found there to a mingw objdump, - # which wouldn't understand a cygwinified path. Ahh. - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` - else - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - ;; - pw32*) - # pw32 DLLs use 'pw' prefix rather than 'lib' - library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - ;; - esac - ;; - - *) - library_names_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext} $libname.lib' - ;; - esac - dynamic_linker='Win32 ld.exe' - # FIXME: first we should search . and the directory the executable is in - shlibpath_var=PATH - ;; - -darwin* | rhapsody*) - dynamic_linker="$host_os dyld" - version_type=darwin - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' - soname_spec='${libname}${release}${major}$shared_ext' - shlibpath_overrides_runpath=yes - shlibpath_var=DYLD_LIBRARY_PATH - shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' - - sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" - 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 - ;; - -freebsd* | dragonfly*) - # DragonFly does not have aout. When/if they implement a new - # versioning mechanism, adjust this. - if test -x /usr/bin/objformat; then - objformat=`/usr/bin/objformat` - else - case $host_os in - freebsd123*) objformat=aout ;; - *) objformat=elf ;; - esac - fi - version_type=freebsd-$objformat - case $version_type in - freebsd-elf*) - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - need_version=no - need_lib_prefix=no - ;; - freebsd-*) - library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' - need_version=yes - ;; - esac - shlibpath_var=LD_LIBRARY_PATH - case $host_os in - freebsd2*) - shlibpath_overrides_runpath=yes - ;; - freebsd3.01* | freebsdelf3.01*) - shlibpath_overrides_runpath=yes - hardcode_into_libs=yes - ;; - freebsd3.2-9* | freebsdelf3.2-9* | \ - freebsd4.0-5 | freebsdelf4.0-5 | freebsd4.1.1 | freebsdelf4.1.1) - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - *) # from 4.6 on, and DragonFly - shlibpath_overrides_runpath=yes - 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' - ;; - -interix3-9*) - 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' - dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - -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* | k*bsd*-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' - 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>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^ *hwcap /d;s/:, / /g;s/=^=*$//;s/=^= * / /g;/^$/d' | tr '\n' ' '` - sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" - fi - - # We used to test for /lib/ld.so.1 and disable shared libraries on - # powerpc, because MkLinux only supported shared libraries with the - # GNU dynamic linker. Since this was broken with cross compilers, - # most powerpc-linux boxes support dynamic linking these days and - # people can always --disable-shared, the test was removed, and we - # assume the GNU/Linux dynamic linker is in use. - dynamic_linker='GNU/Linux ld.so' - ;; - -netbsdelf*-gnu) - version_type=linux - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - dynamic_linker='NetBSD ld.elf_so' - ;; - -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 - sys_lib_dlsearch_path_spec="/usr/lib" - need_lib_prefix=no - # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. - case $host_os in - openbsd3.3 | openbsd3.3.*) need_version=yes ;; - *) need_version=no ;; - esac - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' - finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' - shlibpath_var=LD_LIBRARY_PATH - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - case $host_os in - openbsd2.89 | openbsd2.89.*) - shlibpath_overrides_runpath=no - ;; - *) - shlibpath_overrides_runpath=yes - ;; - esac - 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" - ;; - -rdos*) - dynamic_linker=no - ;; - -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.3*) - 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 - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - version_type=freebsd-elf - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - hardcode_into_libs=yes - if test "$with_gnu_ld" = yes; then - sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' - shlibpath_overrides_runpath=no - else - sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' - shlibpath_overrides_runpath=yes - case $host_os in - sco3.2v5*) - sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" - ;; - esac - fi - sys_lib_dlsearch_path_spec='/usr/lib' - ;; - -uts4*) - version_type=linux - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - ;; - -*) - dynamic_linker=no - ;; -esac -{ echo "$as_me:$LINENO: result: $dynamic_linker" >&5 -echo "${ECHO_T}$dynamic_linker" >&6; } -test "$dynamic_linker" = no && can_build_shared=no - -if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_search_path_spec="$sys_lib_search_path_spec" -fi - -sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" -if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec" -fi - -sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" - -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 - -{ echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 -echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6; } -hardcode_action= -if test -n "$hardcode_libdir_flag_spec" || \ - test -n "$runpath_var" || \ - test "X$hardcode_automatic" = "Xyes" ; then - - # We can hardcode non-existant directories. - if test "$hardcode_direct" != no && - # If the only mechanism to avoid hardcoding is shlibpath_var, we - # have to relink, otherwise we might link with an installed library - # when we should be linking with a yet-to-be-installed one - ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, )" != no && - test "$hardcode_minus_L" != no; then - # Linking always hardcodes the temporary library directory. - hardcode_action=relink - else - # We can link without hardcoding, and we can hardcode nonexisting dirs. - hardcode_action=immediate - fi -else - # We cannot hardcode anything, or else we can only hardcode existing - # directories. - hardcode_action=unsupported -fi -{ echo "$as_me:$LINENO: result: $hardcode_action" >&5 -echo "${ECHO_T}$hardcode_action" >&6; } - -if test "$hardcode_action" = relink; then - # Fast installation is not supported - enable_fast_install=no -elif test "$shlibpath_overrides_runpath" = yes || - test "$enable_shared" = no; then - # Fast installation is not necessary - enable_fast_install=needless -fi - -striplib= -old_striplib= -{ echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 -echo $ECHO_N "checking whether stripping libraries is possible... $ECHO_C" >&6; } -if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then - test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" - test -z "$striplib" && striplib="$STRIP --strip-unneeded" - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } -else -# FIXME - insert some real tests, host_os isn't really good enough - case $host_os in - darwin*) - if test -n "$STRIP" ; then - striplib="$STRIP -x" - old_striplib="$STRIP -S" - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - ;; - *) - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - ;; - esac -fi - -if test "x$enable_dlopen" != xyes; then - enable_dlopen=unknown - enable_dlopen_self=unknown - enable_dlopen_self_static=unknown -else - lt_cv_dlopen=no - lt_cv_dlopen_libs= - - case $host_os in - beos*) - lt_cv_dlopen="load_add_on" - lt_cv_dlopen_libs= - lt_cv_dlopen_self=yes - ;; - - mingw* | pw32*) - lt_cv_dlopen="LoadLibrary" - lt_cv_dlopen_libs= - ;; - - cygwin*) - lt_cv_dlopen="dlopen" - lt_cv_dlopen_libs= - ;; - - darwin*) - # if libdl is installed we need to link against it - { echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 -echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6; } -if test "${ac_cv_lib_dl_dlopen+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-ldl $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char dlopen (); -int -main () -{ -return dlopen (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_dl_dlopen=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_dl_dlopen=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 -echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6; } -if test $ac_cv_lib_dl_dlopen = yes; then - lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" -else - - lt_cv_dlopen="dyld" - lt_cv_dlopen_libs= - lt_cv_dlopen_self=yes - -fi - - ;; - - *) - { echo "$as_me:$LINENO: checking for shl_load" >&5 -echo $ECHO_N "checking for shl_load... $ECHO_C" >&6; } -if test "${ac_cv_func_shl_load+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -/* Define shl_load to an innocuous variant, in case <limits.h> declares shl_load. - For example, HP-UX 11i <limits.h> declares gettimeofday. */ -#define shl_load innocuous_shl_load - -/* System header to define __stub macros and hopefully few prototypes, - which can conflict with char shl_load (); below. - Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - <limits.h> exists even on freestanding compilers. */ - -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - -#undef shl_load - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char shl_load (); -/* The GNU C library defines this for functions which it implements - to always fail with ENOSYS. Some functions are actually named - something starting with __ and the normal name is an alias. */ -#if defined __stub_shl_load || defined __stub___shl_load -choke me -#endif - -int -main () -{ -return shl_load (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_func_shl_load=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_func_shl_load=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -fi -{ echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5 -echo "${ECHO_T}$ac_cv_func_shl_load" >&6; } -if test $ac_cv_func_shl_load = yes; then - lt_cv_dlopen="shl_load" -else - { echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5 -echo $ECHO_N "checking for shl_load in -ldld... $ECHO_C" >&6; } -if test "${ac_cv_lib_dld_shl_load+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-ldld $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char shl_load (); -int -main () -{ -return shl_load (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_dld_shl_load=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_dld_shl_load=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5 -echo "${ECHO_T}$ac_cv_lib_dld_shl_load" >&6; } -if test $ac_cv_lib_dld_shl_load = yes; then - lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld" -else - { echo "$as_me:$LINENO: checking for dlopen" >&5 -echo $ECHO_N "checking for dlopen... $ECHO_C" >&6; } -if test "${ac_cv_func_dlopen+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -/* Define dlopen to an innocuous variant, in case <limits.h> declares dlopen. - For example, HP-UX 11i <limits.h> declares gettimeofday. */ -#define dlopen innocuous_dlopen - -/* System header to define __stub macros and hopefully few prototypes, - which can conflict with char dlopen (); below. - Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - <limits.h> exists even on freestanding compilers. */ - -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - -#undef dlopen - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char dlopen (); -/* The GNU C library defines this for functions which it implements - to always fail with ENOSYS. Some functions are actually named - something starting with __ and the normal name is an alias. */ -#if defined __stub_dlopen || defined __stub___dlopen -choke me -#endif - -int -main () -{ -return dlopen (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_func_dlopen=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_func_dlopen=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -fi -{ echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5 -echo "${ECHO_T}$ac_cv_func_dlopen" >&6; } -if test $ac_cv_func_dlopen = yes; then - lt_cv_dlopen="dlopen" -else - { echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 -echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6; } -if test "${ac_cv_lib_dl_dlopen+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-ldl $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char dlopen (); -int -main () -{ -return dlopen (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_dl_dlopen=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_dl_dlopen=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 -echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6; } -if test $ac_cv_lib_dl_dlopen = yes; then - lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" -else - { echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5 -echo $ECHO_N "checking for dlopen in -lsvld... $ECHO_C" >&6; } -if test "${ac_cv_lib_svld_dlopen+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-lsvld $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char dlopen (); -int -main () -{ -return dlopen (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_svld_dlopen=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_svld_dlopen=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5 -echo "${ECHO_T}$ac_cv_lib_svld_dlopen" >&6; } -if test $ac_cv_lib_svld_dlopen = yes; then - lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" -else - { echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5 -echo $ECHO_N "checking for dld_link in -ldld... $ECHO_C" >&6; } -if test "${ac_cv_lib_dld_dld_link+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-ldld $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char dld_link (); -int -main () -{ -return dld_link (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_dld_dld_link=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_dld_dld_link=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5 -echo "${ECHO_T}$ac_cv_lib_dld_dld_link" >&6; } -if test $ac_cv_lib_dld_dld_link = yes; then - lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld" -fi - - -fi - - -fi - - -fi - - -fi - - -fi - - ;; - esac - - if test "x$lt_cv_dlopen" != xno; then - enable_dlopen=yes - else - enable_dlopen=no - fi - - case $lt_cv_dlopen in - dlopen) - save_CPPFLAGS="$CPPFLAGS" - test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" - - save_LDFLAGS="$LDFLAGS" - wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" - - save_LIBS="$LIBS" - LIBS="$lt_cv_dlopen_libs $LIBS" - - { echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5 -echo $ECHO_N "checking whether a program can dlopen itself... $ECHO_C" >&6; } -if test "${lt_cv_dlopen_self+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test "$cross_compiling" = yes; then : - lt_cv_dlopen_self=cross -else - lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 - lt_status=$lt_dlunknown - cat > conftest.$ac_ext <<EOF -#line 10094 "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); */ - } - else - puts (dlerror ()); - - exit (status); -} -EOF - if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 - (eval $ac_link) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then - (./conftest; exit; ) >&5 2>/dev/null - lt_status=$? - case x$lt_status in - x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; - x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; - x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; - esac - else : - # compilation failed - lt_cv_dlopen_self=no - fi -fi -rm -fr conftest* - - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5 -echo "${ECHO_T}$lt_cv_dlopen_self" >&6; } - - if test "x$lt_cv_dlopen_self" = xyes; then - wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" - { echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5 -echo $ECHO_N "checking whether a statically linked program can dlopen itself... $ECHO_C" >&6; } -if test "${lt_cv_dlopen_self_static+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test "$cross_compiling" = yes; then : - lt_cv_dlopen_self_static=cross -else - lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 - lt_status=$lt_dlunknown - cat > conftest.$ac_ext <<EOF -#line 10194 "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); */ - } - else - puts (dlerror ()); - - exit (status); -} -EOF - if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 - (eval $ac_link) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then - (./conftest; exit; ) >&5 2>/dev/null - lt_status=$? - case x$lt_status in - x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; - x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; - x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; - esac - else : - # compilation failed - lt_cv_dlopen_self_static=no - fi -fi -rm -fr conftest* - - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5 -echo "${ECHO_T}$lt_cv_dlopen_self_static" >&6; } - fi - - CPPFLAGS="$save_CPPFLAGS" - LDFLAGS="$save_LDFLAGS" - LIBS="$save_LIBS" - ;; - esac - - case $lt_cv_dlopen_self in - yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; - *) enable_dlopen_self=unknown ;; - esac - - case $lt_cv_dlopen_self_static in - yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; - *) enable_dlopen_self_static=unknown ;; - esac -fi - - -# Report which library types will actually be built -{ echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5 -echo $ECHO_N "checking if libtool supports shared libraries... $ECHO_C" >&6; } -{ echo "$as_me:$LINENO: result: $can_build_shared" >&5 -echo "${ECHO_T}$can_build_shared" >&6; } - -{ echo "$as_me:$LINENO: checking whether to build shared libraries" >&5 -echo $ECHO_N "checking whether to build shared libraries... $ECHO_C" >&6; } -test "$can_build_shared" = "no" && enable_shared=no - -# On AIX, shared libraries and static libraries use the same namespace, and -# are all built from PIC. -case $host_os in -aix3*) - test "$enable_shared" = yes && enable_static=no - if test -n "$RANLIB"; then - archive_cmds="$archive_cmds~\$RANLIB \$lib" - postinstall_cmds='$RANLIB $lib' - fi - ;; - -aix4-9*) - if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then - test "$enable_shared" = yes && enable_static=no - fi - ;; -esac -{ echo "$as_me:$LINENO: result: $enable_shared" >&5 -echo "${ECHO_T}$enable_shared" >&6; } - -{ echo "$as_me:$LINENO: checking whether to build static libraries" >&5 -echo $ECHO_N "checking whether to build static libraries... $ECHO_C" >&6; } -# Make sure either enable_shared or enable_static is yes. -test "$enable_shared" = yes || enable_static=yes -{ echo "$as_me:$LINENO: result: $enable_static" >&5 -echo "${ECHO_T}$enable_static" >&6; } - -# The else clause should only fire when bootstrapping the -# libtool distribution, otherwise you forgot to ship ltmain.sh -# with your package, and you will get complaints that there are -# no rules to generate ltmain.sh. -if test -f "$ltmain"; then - # See if we are running on zsh, and set the options which allow our commands through - # without removal of \ escapes. - if test -n "${ZSH_VERSION+set}" ; then - setopt NO_GLOB_SUBST - fi - # Now quote all the things that may contain metacharacters while being - # careful not to overquote the AC_SUBSTed values. We take copies of the - # variables and quote the copies for generation of the libtool script. - for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC LTCFLAGS NM \ - SED SHELL STRIP \ - libname_spec library_names_spec soname_spec extract_expsyms_cmds \ - old_striplib striplib file_magic_cmd finish_cmds finish_eval \ - deplibs_check_method reload_flag reload_cmds need_locks \ - lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ - lt_cv_sys_global_symbol_to_c_name_address \ - sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ - old_postinstall_cmds old_postuninstall_cmds \ - compiler \ - CC \ - LD \ - lt_prog_compiler_wl \ - lt_prog_compiler_pic \ - lt_prog_compiler_static \ - lt_prog_compiler_no_builtin_flag \ - export_dynamic_flag_spec \ - thread_safe_flag_spec \ - whole_archive_flag_spec \ - enable_shared_with_static_runtimes \ - old_archive_cmds \ - old_archive_from_new_cmds \ - predep_objects \ - postdep_objects \ - predeps \ - postdeps \ - compiler_lib_search_path \ - compiler_lib_search_dirs \ - archive_cmds \ - archive_expsym_cmds \ - postinstall_cmds \ - postuninstall_cmds \ - old_archive_from_expsyms_cmds \ - allow_undefined_flag \ - no_undefined_flag \ - export_symbols_cmds \ - hardcode_libdir_flag_spec \ - hardcode_libdir_flag_spec_ld \ - hardcode_libdir_separator \ - hardcode_automatic \ - module_cmds \ - module_expsym_cmds \ - lt_cv_prog_compiler_c_o \ - fix_srcfile_path \ - exclude_expsyms \ - include_expsyms; do - - case $var in - old_archive_cmds | \ - old_archive_from_new_cmds | \ - archive_cmds | \ - archive_expsym_cmds | \ - module_cmds | \ - module_expsym_cmds | \ - old_archive_from_expsyms_cmds | \ - export_symbols_cmds | \ - extract_expsyms_cmds | reload_cmds | finish_cmds | \ - postinstall_cmds | postuninstall_cmds | \ - old_postinstall_cmds | old_postuninstall_cmds | \ - sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) - # Double-quote double-evaled strings. - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" - ;; - *) - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" - ;; - esac - done - - case $lt_echo in - *'\$0 --fallback-echo"') - lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` - ;; - esac - -cfgfile="${ofile}T" - trap "$rm \"$cfgfile\"; exit 1" 1 2 15 - $rm -f "$cfgfile" - { echo "$as_me:$LINENO: creating $ofile" >&5 -echo "$as_me: creating $ofile" >&6;} - - cat <<__EOF__ >> "$cfgfile" -#! $SHELL - -# `$echo "$cfgfile" | sed 's%^.*/%%'` - Provide generalized library-building support services. -# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) -# NOTE: Changes made to this file will be lost: look at ltmain.sh. -# -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 -# Free Software Foundation, Inc. -# -# This file is part of GNU Libtool: -# Originally by Gordon Matzigkeit <gord@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 - -# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: - -# Shell to use when invoking shell scripts. -SHELL=$lt_SHELL - -# Whether or not to build shared libraries. -build_libtool_libs=$enable_shared - -# Whether or not to build static libraries. -build_old_libs=$enable_static - -# Whether or not to add -lc for building shared libraries. -build_libtool_need_lc=$archive_cmds_need_lc - -# Whether or not to disallow shared libs when runtime libs are static -allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes - -# Whether or not to optimize for fast installation. -fast_install=$enable_fast_install - -# The host system. -host_alias=$host_alias -host=$host -host_os=$host_os - -# The build system. -build_alias=$build_alias -build=$build -build_os=$build_os - -# An echo program that does not interpret backslashes. -echo=$lt_echo - -# The archiver. -AR=$lt_AR -AR_FLAGS=$lt_AR_FLAGS - -# A C compiler. -LTCC=$lt_LTCC - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# A language-specific compiler. -CC=$lt_compiler - -# Is the compiler the GNU C compiler? -with_gcc=$GCC - -# An ERE matcher. -EGREP=$lt_EGREP - -# The linker used to build libraries. -LD=$lt_LD - -# Whether we need hard or soft links. -LN_S=$lt_LN_S - -# A BSD-compatible nm program. -NM=$lt_NM - -# A symbol stripping program -STRIP=$lt_STRIP - -# Used to examine libraries when file_magic_cmd begins "file" -MAGIC_CMD=$MAGIC_CMD - -# Used on cygwin: DLL creation program. -DLLTOOL="$DLLTOOL" - -# Used on cygwin: object dumper. -OBJDUMP="$OBJDUMP" - -# Used on cygwin: assembler. -AS="$AS" - -# The name of the directory that contains temporary libtool files. -objdir=$objdir - -# How to create reloadable object files. -reload_flag=$lt_reload_flag -reload_cmds=$lt_reload_cmds - -# How to pass a linker flag through the compiler. -wl=$lt_lt_prog_compiler_wl - -# Object file suffix (normally "o"). -objext="$ac_objext" - -# Old archive suffix (normally "a"). -libext="$libext" - -# Shared library suffix (normally ".so"). -shrext_cmds='$shrext_cmds' - -# Executable file suffix (normally ""). -exeext="$exeext" - -# Additional compiler flags for building library objects. -pic_flag=$lt_lt_prog_compiler_pic -pic_mode=$pic_mode - -# What is the maximum length of a command? -max_cmd_len=$lt_cv_sys_max_cmd_len - -# Does compiler simultaneously support -c and -o options? -compiler_c_o=$lt_lt_cv_prog_compiler_c_o - -# Must we lock files when doing compilation? -need_locks=$lt_need_locks - -# Do we need the lib prefix for modules? -need_lib_prefix=$need_lib_prefix - -# Do we need a version for libraries? -need_version=$need_version - -# Whether dlopen is supported. -dlopen_support=$enable_dlopen - -# Whether dlopen of programs is supported. -dlopen_self=$enable_dlopen_self - -# Whether dlopen of statically linked programs is supported. -dlopen_self_static=$enable_dlopen_self_static - -# Compiler flag to prevent dynamic linking. -link_static_flag=$lt_lt_prog_compiler_static - -# Compiler flag to turn off builtin functions. -no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag - -# Compiler flag to allow reflexive dlopens. -export_dynamic_flag_spec=$lt_export_dynamic_flag_spec - -# Compiler flag to generate shared objects directly from archives. -whole_archive_flag_spec=$lt_whole_archive_flag_spec - -# Compiler flag to generate thread-safe objects. -thread_safe_flag_spec=$lt_thread_safe_flag_spec - -# Library versioning type. -version_type=$version_type - -# Format of library name prefix. -libname_spec=$lt_libname_spec - -# List of archive names. First name is the real one, the rest are links. -# The last name is the one that the linker finds with -lNAME. -library_names_spec=$lt_library_names_spec - -# The coded name of the library, if different from the real name. -soname_spec=$lt_soname_spec - -# Commands used to build and install an old-style archive. -RANLIB=$lt_RANLIB -old_archive_cmds=$lt_old_archive_cmds -old_postinstall_cmds=$lt_old_postinstall_cmds -old_postuninstall_cmds=$lt_old_postuninstall_cmds - -# Create an old-style archive from a shared archive. -old_archive_from_new_cmds=$lt_old_archive_from_new_cmds - -# Create a temporary old-style archive to link instead of a shared archive. -old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds - -# Commands used to build and install a shared archive. -archive_cmds=$lt_archive_cmds -archive_expsym_cmds=$lt_archive_expsym_cmds -postinstall_cmds=$lt_postinstall_cmds -postuninstall_cmds=$lt_postuninstall_cmds - -# Commands used to build a loadable module (assumed same as above if empty) -module_cmds=$lt_module_cmds -module_expsym_cmds=$lt_module_expsym_cmds - -# Commands to strip libraries. -old_striplib=$lt_old_striplib -striplib=$lt_striplib - -# Dependencies to place before the objects being linked to create a -# shared library. -predep_objects=$lt_predep_objects - -# Dependencies to place after the objects being linked to create a -# shared library. -postdep_objects=$lt_postdep_objects - -# Dependencies to place before the objects being linked to create a -# shared library. -predeps=$lt_predeps - -# Dependencies to place after the objects being linked to create a -# shared library. -postdeps=$lt_postdeps - -# The directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt_compiler_lib_search_dirs - -# The library search path used internally by the compiler when linking -# a shared library. -compiler_lib_search_path=$lt_compiler_lib_search_path - -# Method to check whether dependent libraries are shared objects. -deplibs_check_method=$lt_deplibs_check_method - -# Command to use when deplibs_check_method == file_magic. -file_magic_cmd=$lt_file_magic_cmd - -# Flag that allows shared libraries with undefined symbols to be built. -allow_undefined_flag=$lt_allow_undefined_flag - -# Flag that forces no undefined symbols. -no_undefined_flag=$lt_no_undefined_flag - -# Commands used to finish a libtool library installation in a directory. -finish_cmds=$lt_finish_cmds - -# Same as above, but a single script fragment to be evaled but not shown. -finish_eval=$lt_finish_eval - -# Take the output of nm and produce a listing of raw symbols and C names. -global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe - -# Transform the output of nm in a proper C declaration -global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl - -# Transform the output of nm in a C name address pair -global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address - -# This is the shared library runtime path variable. -runpath_var=$runpath_var - -# This is the shared library path variable. -shlibpath_var=$shlibpath_var - -# Is shlibpath searched before the hard-coded library search path? -shlibpath_overrides_runpath=$shlibpath_overrides_runpath - -# How to hardcode a shared library path into an executable. -hardcode_action=$hardcode_action - -# Whether we should hardcode library paths into libraries. -hardcode_into_libs=$hardcode_into_libs - -# Flag to hardcode \$libdir into a binary during linking. -# This must work even if \$libdir does not exist. -hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec - -# If ld is used when linking, flag to hardcode \$libdir into -# a binary during linking. This must work even if \$libdir does -# not exist. -hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld - -# Whether we need a single -rpath flag with a separated argument. -hardcode_libdir_separator=$lt_hardcode_libdir_separator - -# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the -# resulting binary. -hardcode_direct=$hardcode_direct - -# Set to yes if using the -LDIR flag during linking hardcodes DIR into the -# resulting binary. -hardcode_minus_L=$hardcode_minus_L - -# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into -# the resulting binary. -hardcode_shlibpath_var=$hardcode_shlibpath_var - -# Set to yes if building a shared library automatically hardcodes DIR into the library -# and all subsequent libraries and executables linked against it. -hardcode_automatic=$hardcode_automatic - -# Variables whose values should be saved in libtool wrapper scripts and -# restored at relink time. -variables_saved_for_relink="$variables_saved_for_relink" - -# Whether libtool must link a program against all its dependency libraries. -link_all_deplibs=$link_all_deplibs - -# Compile-time system search path for libraries -sys_lib_search_path_spec=$lt_sys_lib_search_path_spec - -# Run-time system search path for libraries -sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec - -# Fix the shell variable \$srcfile for the compiler. -fix_srcfile_path=$lt_fix_srcfile_path - -# Set to yes if exported symbols are required. -always_export_symbols=$always_export_symbols - -# The commands to list exported symbols. -export_symbols_cmds=$lt_export_symbols_cmds - -# The commands to extract the exported symbol list from a shared archive. -extract_expsyms_cmds=$lt_extract_expsyms_cmds - -# Symbols that should not be listed in the preloaded symbols. -exclude_expsyms=$lt_exclude_expsyms - -# Symbols that must always be exported. -include_expsyms=$lt_include_expsyms - -# ### END LIBTOOL CONFIG - -__EOF__ - - - case $host_os in - aix3*) - cat <<\EOF >> "$cfgfile" - -# AIX sometimes has problems with the GCC collect2 program. For some -# reason, if we set the COLLECT_NAMES environment variable, the problems -# vanish in a puff of smoke. -if test "X${COLLECT_NAMES+set}" != Xset; then - COLLECT_NAMES= - export COLLECT_NAMES -fi -EOF - ;; - esac - - # We use sed instead of cat because bash on DJGPP gets confused if - # if finds mixed CR/LF and LF-only lines. Since sed operates in - # text mode, it properly converts lines to CR/LF. This bash problem - # is reportedly fixed, but why not run on old versions too? - sed '$q' "$ltmain" >> "$cfgfile" || (rm -f "$cfgfile"; exit 1) - - mv -f "$cfgfile" "$ofile" || \ - (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") - chmod +x "$ofile" - -else - # If there is no Makefile yet, we rely on a make rule to execute - # `config.status --recheck' to rerun these tests and create the - # libtool script then. - ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` - if test -f "$ltmain_in"; then - test -f Makefile && make "$ltmain" - fi -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -CC="$lt_save_CC" - - -# Check whether --with-tags was given. -if test "${with_tags+set}" = set; then - withval=$with_tags; tagnames="$withval" -fi - - -if test -f "$ltmain" && test -n "$tagnames"; then - if test ! -f "${ofile}"; then - { echo "$as_me:$LINENO: WARNING: output file \`$ofile' does not exist" >&5 -echo "$as_me: WARNING: output file \`$ofile' does not exist" >&2;} - fi - - if test -z "$LTCC"; then - eval "`$SHELL ${ofile} --config | grep '^LTCC='`" - if test -z "$LTCC"; then - { echo "$as_me:$LINENO: WARNING: output file \`$ofile' does not look like a libtool script" >&5 -echo "$as_me: WARNING: output file \`$ofile' does not look like a libtool script" >&2;} - else - { echo "$as_me:$LINENO: WARNING: using \`LTCC=$LTCC', extracted from \`$ofile'" >&5 -echo "$as_me: WARNING: using \`LTCC=$LTCC', extracted from \`$ofile'" >&2;} - fi - fi - if test -z "$LTCFLAGS"; then - eval "`$SHELL ${ofile} --config | grep '^LTCFLAGS='`" - fi - - # Extract list of available tagged configurations in $ofile. - # Note that this assumes the entire list is on one line. - available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'` - - lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," - for tagname in $tagnames; do - IFS="$lt_save_ifs" - # Check whether tagname contains only valid characters - case `$echo "X$tagname" | $Xsed -e 's:-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/::g'` in - "") ;; - *) { { echo "$as_me:$LINENO: error: invalid tag name: $tagname" >&5 -echo "$as_me: error: invalid tag name: $tagname" >&2;} - { (exit 1); exit 1; }; } - ;; - esac - - if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null - then - { { echo "$as_me:$LINENO: error: tag name \"$tagname\" already exists" >&5 -echo "$as_me: error: tag name \"$tagname\" already exists" >&2;} - { (exit 1); exit 1; }; } - fi - - # Update the list of available tags. - if test -n "$tagname"; then - echo appending configuration tag \"$tagname\" to $ofile - - case $tagname in - CXX) - if test -n "$CXX" && ( test "X$CXX" != "Xno" && - ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || - (test "X$CXX" != "Xg++"))) ; then - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - - - -archive_cmds_need_lc_CXX=no -allow_undefined_flag_CXX= -always_export_symbols_CXX=no -archive_expsym_cmds_CXX= -export_dynamic_flag_spec_CXX= -hardcode_direct_CXX=no -hardcode_libdir_flag_spec_CXX= -hardcode_libdir_flag_spec_ld_CXX= -hardcode_libdir_separator_CXX= -hardcode_minus_L_CXX=no -hardcode_shlibpath_var_CXX=unsupported -hardcode_automatic_CXX=no -module_cmds_CXX= -module_expsym_cmds_CXX= -link_all_deplibs_CXX=unknown -old_archive_cmds_CXX=$old_archive_cmds -no_undefined_flag_CXX= -whole_archive_flag_spec_CXX= -enable_shared_with_static_runtimes_CXX=no - -# Dependencies to place before and after the object being linked: -predep_objects_CXX= -postdep_objects_CXX= -predeps_CXX= -postdeps_CXX= -compiler_lib_search_path_CXX= -compiler_lib_search_dirs_CXX= - -# Source file extension for C++ test sources. -ac_ext=cpp - -# Object file extension for compiled C++ test sources. -objext=o -objext_CXX=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code="int some_variable = 0;" - -# Code to be used in simple link tests -lt_simple_link_test_code='int main(int, char *) { return(0); }' - -# ltmain only uses $CC for tagged configurations so make sure $CC is set. - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# save warnings/boilerplate of simple test code -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_compiler_boilerplate=`cat conftest.err` -$rm conftest* - -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* - - -# Allow CC to be a program name with arguments. -lt_save_CC=$CC -lt_save_LD=$LD -lt_save_GCC=$GCC -GCC=$GXX -lt_save_with_gnu_ld=$with_gnu_ld -lt_save_path_LD=$lt_cv_path_LD -if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then - lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx -else - $as_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 - $as_unset lt_cv_path_LD -fi -test -z "${LDCXX+set}" || LD=$LDCXX -CC=${CXX-"c++"} -compiler=$CC -compiler_CXX=$CC -for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - -# We don't want -fno-exception wen compiling C++ code, so set the -# no_builtin_flag separately -if test "$GXX" = yes; then - lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' -else - lt_prog_compiler_no_builtin_flag_CXX= -fi - -if test "$GXX" = yes; then - # Set up default GNU C++ configuration - - -# Check whether --with-gnu-ld was given. -if test "${with_gnu_ld+set}" = set; then - withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes -else - with_gnu_ld=no -fi - -ac_prog=ld -if test "$GCC" = yes; then - # Check if gcc -print-prog-name=ld gives a path. - { echo "$as_me:$LINENO: checking for ld used by $CC" >&5 -echo $ECHO_N "checking for ld used by $CC... $ECHO_C" >&6; } - case $host in - *-*-mingw*) - # gcc leaves a trailing carriage return which upsets mingw - ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; - *) - ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; - esac - case $ac_prog in - # Accept absolute paths. - \\/* | ?:\\/*) - re_direlt='/^/^/*/\.\./' - # Canonicalize the pathname of ld - ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` - while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do - ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` - done - test -z "$LD" && LD="$ac_prog" - ;; - "") - # If it fails, then pretend we aren't using GCC. - ac_prog=ld - ;; - *) - # If it is relative, then search for the first ld in PATH. - with_gnu_ld=unknown - ;; - esac -elif test "$with_gnu_ld" = yes; then - { echo "$as_me:$LINENO: checking for GNU ld" >&5 -echo $ECHO_N "checking for GNU ld... $ECHO_C" >&6; } -else - { echo "$as_me:$LINENO: checking for non-GNU ld" >&5 -echo $ECHO_N "checking for non-GNU ld... $ECHO_C" >&6; } -fi -if test "${lt_cv_path_LD+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -z "$LD"; then - lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR - for ac_dir in $PATH; do - IFS="$lt_save_ifs" - test -z "$ac_dir" && ac_dir=. - if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then - lt_cv_path_LD="$ac_dir/$ac_prog" - # Check to see if the program is GNU ld. I'd rather use --version, - # but apparently some variants of GNU ld only accept -v. - # Break only if it was the GNU/non-GNU ld that we prefer. - case `"$lt_cv_path_LD" -v 2>&1 </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 -fi - -LD="$lt_cv_path_LD" -if test -n "$LD"; then - { echo "$as_me:$LINENO: result: $LD" >&5 -echo "${ECHO_T}$LD" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi -test -z "$LD" && { { echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 -echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} - { (exit 1); exit 1; }; } -{ echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 -echo $ECHO_N "checking if the linker ($LD) is GNU ld... $ECHO_C" >&6; } -if test "${lt_cv_prog_gnu_ld+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # I'd rather use --version here, but apparently some GNU lds only accept -v. -case `$LD -v 2>&1 </dev/null` in -*GNU* | *'with BFD'*) - lt_cv_prog_gnu_ld=yes - ;; -*) - lt_cv_prog_gnu_ld=no - ;; -esac -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_gnu_ld" >&5 -echo "${ECHO_T}$lt_cv_prog_gnu_ld" >&6; } -with_gnu_ld=$lt_cv_prog_gnu_ld - - - - # Check if GNU C++ uses GNU ld as the underlying linker, since the - # archiving commands below assume that GNU ld is being used. - if test "$with_gnu_ld" = yes; then - archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - - hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' - export_dynamic_flag_spec_CXX='${wl}--export-dynamic' - - # If archive_cmds runs LD, not CC, wlarc should be empty - # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to - # investigate it a little bit more. (MM) - wlarc='${wl}' - - # ancient GNU ld didn't support --whole-archive et. al. - if eval "`$CC -print-prog-name=ld` --help 2>&1" | \ - grep 'no-whole-archive' > /dev/null; then - whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' - else - whole_archive_flag_spec_CXX= - fi - else - with_gnu_ld=no - wlarc= - - # A generic and very simple default shared library creation - # command for GNU C++ for the case where it uses the native - # linker, instead of GNU ld. If possible, this setting should - # overridden to take advantage of the native linker features on - # the platform it is being used on. - archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' - fi - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' - -else - GXX=no - with_gnu_ld=no - wlarc= -fi - -# PORTME: fill in a description of your system's C++ link characteristics -{ echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 -echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6; } -ld_shlibs_CXX=yes -case $host_os in - aix3*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - aix4-9*) - 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-9*) - for ld_flag in $LDFLAGS; do - case $ld_flag in - *-brtl*) - aix_use_runtimelinking=yes - break - ;; - esac - done - ;; - esac - - exp_sym_flag='-bexport' - no_entry_flag='-bnoentry' - fi - - # When large executables or shared objects are built, AIX ld can - # have problems creating the table of contents. If linking a library - # or program results in "error TOC overflow" add -mminimal-toc to - # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not - # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. - - archive_cmds_CXX='' - hardcode_direct_CXX=yes - hardcode_libdir_separator_CXX=':' - link_all_deplibs_CXX=yes - - if test "$GXX" = yes; then - case $host_os in aix4.012|aix4.012.*) - # We only want to do this on AIX 4.2 and lower, the check - # below for broken collect2 doesn't work under 4.3+ - collect2name=`${CC} -print-prog-name=collect2` - if test -f "$collect2name" && \ - strings "$collect2name" | grep resolve_lib_name >/dev/null - then - # We have reworked collect2 - : - else - # We have old collect2 - hardcode_direct_CXX=unsupported - # It fails to find uninstalled libraries when the uninstalled - # path is not listed in the libpath. Setting hardcode_minus_L - # to unsupported forces relinking - hardcode_minus_L_CXX=yes - hardcode_libdir_flag_spec_CXX='-L$libdir' - hardcode_libdir_separator_CXX= - fi - ;; - esac - shared_flag='-shared' - if test "$aix_use_runtimelinking" = yes; then - shared_flag="$shared_flag "'${wl}-G' - fi - else - # not using gcc - if test "$host_cpu" = ia64; then - # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release - # chokes on -Wl,-G. The following line is correct: - shared_flag='-G' - else - if test "$aix_use_runtimelinking" = yes; then - shared_flag='${wl}-G' - else - shared_flag='${wl}-bM:SRE' - fi - fi - fi - - # It seems that -bexpall does not export symbols beginning with - # underscore (_), so it is better to generate a list of symbols to export. - always_export_symbols_CXX=yes - if test "$aix_use_runtimelinking" = yes; then - # Warning - without using the other runtime loading flags (-brtl), - # -berok will link without error, but may produce a broken library. - allow_undefined_flag_CXX='-berok' - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" - - archive_expsym_cmds_CXX="\$CC"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" - else - if test "$host_cpu" = ia64; then - hardcode_libdir_flag_spec_CXX='${wl}-R $libdir:/usr/lib:/lib' - allow_undefined_flag_CXX="-z nodefs" - archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" - # Warning - without using the other run time loading flags, - # -berok will link without error, but may produce a broken library. - no_undefined_flag_CXX=' ${wl}-bernotok' - allow_undefined_flag_CXX=' ${wl}-berok' - # Exported symbols can be pulled into shared objects from archives - whole_archive_flag_spec_CXX='$convenience' - archive_cmds_need_lc_CXX=yes - # This is similar to how AIX traditionally builds its shared libraries. - archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' - fi - fi - ;; - - beos*) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - allow_undefined_flag_CXX=unsupported - # Joseph Beckenbach <jrb3@best.com> says some releases of gcc - # support --undefined. This deserves some investigation. FIXME - archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - else - ld_shlibs_CXX=no - fi - ;; - - chorus*) - case $cc_basename in - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - esac - ;; - - cygwin* | mingw* | pw32*) - # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, - # as there is no search path for DLLs. - hardcode_libdir_flag_spec_CXX='-L$libdir' - allow_undefined_flag_CXX=unsupported - always_export_symbols_CXX=no - enable_shared_with_static_runtimes_CXX=yes - - if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then - archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then - cp $export_symbols $output_objdir/$soname.def; - else - echo EXPORTS > $output_objdir/$soname.def; - cat $export_symbols >> $output_objdir/$soname.def; - fi~ - $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - ld_shlibs_CXX=no - fi - ;; - darwin* | rhapsody*) - archive_cmds_need_lc_CXX=no - hardcode_direct_CXX=no - hardcode_automatic_CXX=yes - hardcode_shlibpath_var_CXX=unsupported - whole_archive_flag_spec_CXX='' - link_all_deplibs_CXX=yes - allow_undefined_flag_CXX="$_lt_dar_allow_undefined" - if test "$GXX" = yes ; then - output_verbose_link_cmd='echo' - archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" - module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - module_expsym_cmds_CXX="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - if test "$lt_cv_apple_cc_single_mod" != "yes"; then - archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}" - archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}" - fi - else - case $cc_basename in - xlc*) - output_verbose_link_cmd='echo' - archive_cmds_CXX='$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $xlcverstring' - module_cmds_CXX='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - archive_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - module_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - ;; - *) - ld_shlibs_CXX=no - ;; - esac - fi - ;; - - dgux*) - case $cc_basename in - ec++*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - ghcx*) - # Green Hills C++ Compiler - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - esac - ;; - freebsd12*) - # C++ shared libraries reported to be fairly broken before switch to ELF - ld_shlibs_CXX=no - ;; - freebsd-elf*) - archive_cmds_need_lc_CXX=no - ;; - freebsd* | dragonfly*) - # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF - # conventions - ld_shlibs_CXX=yes - ;; - gnu*) - ;; - hpux9*) - hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_CXX=: - export_dynamic_flag_spec_CXX='${wl}-E' - hardcode_direct_CXX=yes - hardcode_minus_L_CXX=yes # Not in the search PATH, - # but as the default - # location of the library. - - case $cc_basename in - CC*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - aCC*) - archive_cmds_CXX='$rm $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - if test "$GXX" = yes; then - archive_cmds_CXX='$rm $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - else - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - fi - ;; - esac - ;; - hpux10*|hpux11*) - if test $with_gnu_ld = no; then - hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_CXX=: - - case $host_cpu in - hppa*64*|ia64*) ;; - *) - export_dynamic_flag_spec_CXX='${wl}-E' - ;; - esac - fi - case $host_cpu in - hppa*64*|ia64*) - hardcode_direct_CXX=no - hardcode_shlibpath_var_CXX=no - ;; - *) - hardcode_direct_CXX=yes - hardcode_minus_L_CXX=yes # Not in the search PATH, - # but as the default - # location of the library. - ;; - esac - - case $cc_basename in - CC*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - aCC*) - case $host_cpu in - hppa*64*) - archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - ia64*) - archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - *) - archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - esac - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - if test "$GXX" = yes; then - if test $with_gnu_ld = no; then - case $host_cpu in - hppa*64*) - archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - ia64*) - archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - *) - archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - ;; - esac - fi - else - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - fi - ;; - esac - ;; - interix3-9*) - hardcode_direct_CXX=no - hardcode_shlibpath_var_CXX=no - hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' - export_dynamic_flag_spec_CXX='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - archive_expsym_cmds_CXX='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - irix5* | irix6*) - case $cc_basename in - CC*) - # SGI C++ - archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - - # Archives containing C++ object files must be created using - # "CC -ar", where "CC" is the IRIX C++ compiler. This is - # necessary to make sure instantiated templates are included - # in the archive. - old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' - ;; - *) - if test "$GXX" = yes; then - if test "$with_gnu_ld" = no; then - archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` -o $lib' - fi - fi - link_all_deplibs_CXX=yes - ;; - esac - hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_CXX=: - ;; - linux* | k*bsd*-gnu) - case $cc_basename in - KCC*) - # Kuck and Associates, Inc. (KAI) C++ Compiler - - # KCC will only create a shared library if the output file - # ends with ".so" (or ".sl" for HP-UX), so rename the library - # to its proper name (with version) after linking. - archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\(^()0-9A-Za-z{}\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' - archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\(^()0-9A-Za-z{}\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | grep "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - - hardcode_libdir_flag_spec_CXX='${wl}--rpath,$libdir' - export_dynamic_flag_spec_CXX='${wl}--export-dynamic' - - # Archives containing C++ object files must be created using - # "CC -Bstatic", where "CC" is the KAI C++ compiler. - old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' - ;; - icpc*) - # Intel C++ - with_gnu_ld=yes - # version 8.0 and above of icpc choke on multiply defined symbols - # if we add $predep_objects and $postdep_objects, however 7.1 and - # earlier do not add the objects themselves. - case `$CC -V 2>&1` in - *"Version 7."*) - archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - ;; - *) # Version 8.0 or newer - tmp_idyn= - case $host_cpu in - ia64*) tmp_idyn=' -i_dynamic';; - esac - archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - ;; - esac - archive_cmds_need_lc_CXX=no - hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' - export_dynamic_flag_spec_CXX='${wl}--export-dynamic' - whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive' - ;; - pgCC* | pgcpp*) - # Portland Group C++ compiler - archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' - archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' - - hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' - export_dynamic_flag_spec_CXX='${wl}--export-dynamic' - whole_archive_flag_spec_CXX='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - ;; - cxx*) - # Compaq C++ - archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' - - runpath_var=LD_RUN_PATH - hardcode_libdir_flag_spec_CXX='-rpath $libdir' - hardcode_libdir_separator_CXX=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - no_undefined_flag_CXX=' -zdefs' - archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - archive_expsym_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols' - hardcode_libdir_flag_spec_CXX='-R$libdir' - whole_archive_flag_spec_CXX='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - - # Not sure whether something based on - # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 - # would be better. - output_verbose_link_cmd='echo' - - # Archives containing C++ object files must be created using - # "CC -xar", where "CC" is the Sun C++ compiler. This is - # necessary to make sure instantiated templates are included - # in the archive. - old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' - ;; - esac - ;; - esac - ;; - lynxos*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - m88k*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - mvs*) - case $cc_basename in - cxx*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - esac - ;; - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' - wlarc= - hardcode_libdir_flag_spec_CXX='-R$libdir' - hardcode_direct_CXX=yes - hardcode_shlibpath_var_CXX=no - fi - # Workaround some broken pre-1.5 toolchains - output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' - ;; - openbsd2*) - # C++ shared libraries are fairly broken - ld_shlibs_CXX=no - ;; - openbsd*) - if test -f /usr/libexec/ld.so; then - hardcode_direct_CXX=yes - hardcode_shlibpath_var_CXX=no - archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' - hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' - export_dynamic_flag_spec_CXX='${wl}-E' - whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' - fi - output_verbose_link_cmd='echo' - else - ld_shlibs_CXX=no - fi - ;; - osf3*) - case $cc_basename in - KCC*) - # Kuck and Associates, Inc. (KAI) C++ Compiler - - # KCC will only create a shared library if the output file - # ends with ".so" (or ".sl" for HP-UX), so rename the library - # to its proper name (with version) after linking. - archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\(^()0-9A-Za-z{}\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' - - hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' - hardcode_libdir_separator_CXX=: - - # Archives containing C++ object files must be created using - # "CC -Bstatic", where "CC" is the KAI C++ compiler. - old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' - - ;; - RCC*) - # Rational C++ 2.4.1 - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - cxx*) - allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && echo ${wl}-set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - - hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_CXX=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - if test "$GXX" = yes && test "$with_gnu_ld" = no; then - allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - - hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_CXX=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' - - else - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - fi - ;; - esac - ;; - osf4* | osf5*) - case $cc_basename in - KCC*) - # Kuck and Associates, Inc. (KAI) C++ Compiler - - # KCC will only create a shared library if the output file - # ends with ".so" (or ".sl" for HP-UX), so rename the library - # to its proper name (with version) after linking. - archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\(^()0-9A-Za-z{}\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' - - hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' - hardcode_libdir_separator_CXX=: - - # Archives containing C++ object files must be created using - # the KAI C++ compiler. - old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' - ;; - RCC*) - # Rational C++ 2.4.1 - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - cxx*) - allow_undefined_flag_CXX=' -expect_unresolved \*' - archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ - echo "-hidden">> $lib.exp~ - $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname -Wl,-input -Wl,$lib.exp `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~ - $rm $lib.exp' - - hardcode_libdir_flag_spec_CXX='-rpath $libdir' - hardcode_libdir_separator_CXX=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - # - # There doesn't appear to be a way to prevent this compiler from - # explicitly linking system object files so we need to strip them - # from the output so that they don't get included in the library - # dependencies. - output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' - ;; - *) - if test "$GXX" = yes && test "$with_gnu_ld" = no; then - allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - - hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_CXX=: - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' - - else - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - fi - ;; - esac - ;; - psos*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - sunos4*) - case $cc_basename in - CC*) - # Sun C++ 4.x - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - lcc*) - # Lucid - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - esac - ;; - solaris*) - case $cc_basename in - CC*) - # Sun C++ 4.2, 5.x and Centerline C++ - archive_cmds_need_lc_CXX=yes - no_undefined_flag_CXX=' -zdefs' - archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' - archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - hardcode_libdir_flag_spec_CXX='-R$libdir' - hardcode_shlibpath_var_CXX=no - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - # The compiler driver will combine and reorder linker options, - # but understands `-z linker_flag'. - # Supported since Solaris 2.6 (maybe 2.5.1?) - whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract' - ;; - esac - link_all_deplibs_CXX=yes - - output_verbose_link_cmd='echo' - - # Archives containing C++ object files must be created using - # "CC -xar", where "CC" is the Sun C++ compiler. This is - # necessary to make sure instantiated templates are included - # in the archive. - old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' - ;; - gcx*) - # Green Hills C++ Compiler - archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - - # The C++ compiler must be used to create the archive. - old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' - ;; - *) - # GNU C++ compiler with Solaris linker - if test "$GXX" = yes && test "$with_gnu_ld" = no; then - no_undefined_flag_CXX=' ${wl}-z ${wl}defs' - if $CC --version | grep -v '^2\.7' > /dev/null; then - archive_cmds_CXX='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" - else - # g++ 2.7 appears to require `-G' NOT `-shared' on this - # platform. - archive_cmds_CXX='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' - archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' - - # Commands to make compiler produce verbose output that lists - # what "hidden" libraries, object files and flags are used when - # linking a shared library. - output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" - fi - - hardcode_libdir_flag_spec_CXX='${wl}-R $wl$libdir' - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - whole_archive_flag_spec_CXX='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - ;; - esac - fi - ;; - esac - ;; - sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - no_undefined_flag_CXX='${wl}-z,text' - archive_cmds_need_lc_CXX=no - hardcode_shlibpath_var_CXX=no - runpath_var='LD_RUN_PATH' - - case $cc_basename in - CC*) - archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - ;; - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - # For security reasons, it is highly recommended that you always - # use absolute paths for naming shared libraries, and exclude the - # DT_RUNPATH tag from executables and libraries. But doing so - # requires that you compile everything twice, which is a pain. - # So that behaviour is only enabled if SCOABSPATH is set to a - # non-empty value in the environment. Most likely only useful for - # creating official distributions of packages. - # This is a hack until libtool officially supports absolute path - # names for shared libraries. - no_undefined_flag_CXX='${wl}-z,text' - allow_undefined_flag_CXX='${wl}-z,nodefs' - archive_cmds_need_lc_CXX=no - hardcode_shlibpath_var_CXX=no - hardcode_libdir_flag_spec_CXX='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - hardcode_libdir_separator_CXX=':' - link_all_deplibs_CXX=yes - export_dynamic_flag_spec_CXX='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - case $cc_basename in - CC*) - archive_cmds_CXX='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_CXX='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - ;; - tandem*) - case $cc_basename in - NCC*) - # NonStop-UX NCC 3.20 - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - esac - ;; - vxworks*) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; - *) - # FIXME: insert proper C++ library support - ld_shlibs_CXX=no - ;; -esac -{ echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 -echo "${ECHO_T}$ld_shlibs_CXX" >&6; } -test "$ld_shlibs_CXX" = no && can_build_shared=no - -GCC_CXX="$GXX" -LD_CXX="$LD" - -cat > conftest.$ac_ext <<EOF -class Foo -{ -public: - Foo (void) { a = 0; } -private: - int a; -}; -EOF - -if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - # Parse the compiler output and extract the necessary - # objects, libraries and library flags. - - # Sentinel used to keep track of whether or not we are before - # the conftest object file. - pre_test_object_deps_done=no - - # The `*' in the case matches for architectures that use `case' in - # $output_verbose_cmd can trigger glob expansion during the loop - # eval without this substitution. - output_verbose_link_cmd=`$echo "X$output_verbose_link_cmd" | $Xsed -e "$no_glob_subst"` - - for p in `eval $output_verbose_link_cmd`; do - case $p in - - -L* | -R* | -l*) - # Some compilers place space between "-{L,R}" and the path. - # Remove the space. - if test $p = "-L" \ - || test $p = "-R"; then - prev=$p - continue - else - prev= - fi - - if test "$pre_test_object_deps_done" = no; then - case $p in - -L* | -R*) - # Internal compiler library paths should come after those - # provided the user. The postdeps already come after the - # user supplied libs so there is no need to process them. - if test -z "$compiler_lib_search_path_CXX"; then - compiler_lib_search_path_CXX="${prev}${p}" - else - compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} ${prev}${p}" - fi - ;; - # The "-l" case would never come before the object being - # linked, so don't bother handling this case. - esac - else - if test -z "$postdeps_CXX"; then - postdeps_CXX="${prev}${p}" - else - postdeps_CXX="${postdeps_CXX} ${prev}${p}" - fi - fi - ;; - - *.$objext) - # This assumes that the test object file only shows up - # once in the compiler output. - if test "$p" = "conftest.$objext"; then - pre_test_object_deps_done=yes - continue - fi - - if test "$pre_test_object_deps_done" = no; then - if test -z "$predep_objects_CXX"; then - predep_objects_CXX="$p" - else - predep_objects_CXX="$predep_objects_CXX $p" - fi - else - if test -z "$postdep_objects_CXX"; then - postdep_objects_CXX="$p" - else - postdep_objects_CXX="$postdep_objects_CXX $p" - fi - fi - ;; - - *) ;; # Ignore the rest. - - esac - done - - # Clean up. - rm -f a.out a.exe -else - echo "libtool.m4: error: problem compiling CXX test program" -fi - -$rm -f confest.$objext - -compiler_lib_search_dirs_CXX= -if test -n "$compiler_lib_search_path_CXX"; then - compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | ${SED} -e 's! -L! !g' -e 's!^ !!'` -fi - -# PORTME: override above test on systems where it is broken -case $host_os in -interix3-9*) - # Interix 3.5 installs completely hosed .la files for C++, so rather than - # hack all around it, let's just trust "g++" to DTRT. - predep_objects_CXX= - postdep_objects_CXX= - postdeps_CXX= - ;; - -linux*) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - # - # The more standards-conforming stlport4 library is - # incompatible with the Cstd library. Avoid specifying - # it if it's in CXXFLAGS. Ignore libCrun as - # -library=stlport4 depends on it. - case " $CXX $CXXFLAGS " in - *" -library=stlport4 "*) - solaris_use_stlport4=yes - ;; - esac - if test "$solaris_use_stlport4" != yes; then - postdeps_CXX='-library=Cstd -library=Crun' - fi - ;; - esac - ;; - -solaris*) - case $cc_basename in - CC*) - # The more standards-conforming stlport4 library is - # incompatible with the Cstd library. Avoid specifying - # it if it's in CXXFLAGS. Ignore libCrun as - # -library=stlport4 depends on it. - case " $CXX $CXXFLAGS " in - *" -library=stlport4 "*) - solaris_use_stlport4=yes - ;; - esac - - # Adding this requires a known-good setup of shared libraries for - # Sun compiler versions before 5.6, else PIC objects from an old - # archive will be linked into the output, leading to subtle bugs. - if test "$solaris_use_stlport4" != yes; then - postdeps_CXX='-library=Cstd -library=Crun' - fi - ;; - esac - ;; -esac - -case " $postdeps_CXX " in -*" -lc "*) archive_cmds_need_lc_CXX=no ;; -esac - -lt_prog_compiler_wl_CXX= -lt_prog_compiler_pic_CXX= -lt_prog_compiler_static_CXX= - -{ echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 -echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6; } - - # C++ specific cases for pic, static, wl, etc. - if test "$GXX" = yes; then - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_static_CXX='-static' - - case $host_os in - aix*) - # All AIX code is PIC. - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_CXX='-Bstatic' - fi - ;; - amigaos*) - # FIXME: we need at least 68020 code to build shared libraries, but - # adding the `-m68020' flag to GCC prevents building anything better, - # like `-m68040'. - lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' - ;; - beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - lt_prog_compiler_pic_CXX='-DDLL_EXPORT' - ;; - darwin* | rhapsody*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - lt_prog_compiler_pic_CXX='-fno-common' - ;; - *djgpp*) - # DJGPP does not support shared libraries at all - lt_prog_compiler_pic_CXX= - ;; - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - sysv4*MP*) - if test -d /usr/nec; then - lt_prog_compiler_pic_CXX=-Kconform_pic - fi - ;; - hpux*) - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - ;; - *) - lt_prog_compiler_pic_CXX='-fPIC' - ;; - esac - ;; - *) - lt_prog_compiler_pic_CXX='-fPIC' - ;; - esac - else - case $host_os in - aix4-9*) - # All AIX code is PIC. - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_CXX='-Bstatic' - else - lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' - fi - ;; - chorus*) - case $cc_basename in - cxch68*) - # Green Hills C++ Compiler - # _LT_AC_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" - ;; - esac - ;; - darwin*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - case $cc_basename in - xlc*) - lt_prog_compiler_pic_CXX='-qnocommon' - lt_prog_compiler_wl_CXX='-Wl,' - ;; - esac - ;; - dgux*) - case $cc_basename in - ec++*) - lt_prog_compiler_pic_CXX='-KPIC' - ;; - ghcx*) - # Green Hills C++ Compiler - lt_prog_compiler_pic_CXX='-pic' - ;; - *) - ;; - esac - ;; - freebsd* | dragonfly*) - # FreeBSD uses GNU C++ - ;; - hpux9* | hpux10* | hpux11*) - case $cc_basename in - CC*) - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' - if test "$host_cpu" != ia64; then - lt_prog_compiler_pic_CXX='+Z' - fi - ;; - aCC*) - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_static_CXX='${wl}-a ${wl}archive' - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic_CXX='+Z' - ;; - esac - ;; - *) - ;; - esac - ;; - interix*) - # This is c89, which is MS Visual C++ (no shared libs) - # Anyone wants to do a port? - ;; - irix5* | irix6* | nonstopux*) - case $cc_basename in - CC*) - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_static_CXX='-non_shared' - # CC pic flag -KPIC is the default. - ;; - *) - ;; - esac - ;; - linux* | k*bsd*-gnu) - case $cc_basename in - KCC*) - # KAI C++ Compiler - lt_prog_compiler_wl_CXX='--backend -Wl,' - lt_prog_compiler_pic_CXX='-fPIC' - ;; - icpc* | ecpc*) - # Intel C++ - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_pic_CXX='-KPIC' - lt_prog_compiler_static_CXX='-static' - ;; - pgCC* | pgcpp*) - # Portland Group C++ compiler. - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_pic_CXX='-fpic' - lt_prog_compiler_static_CXX='-Bstatic' - ;; - cxx*) - # Compaq C++ - # Make sure the PIC flag is empty. It appears that all Alpha - # Linux and Compaq Tru64 Unix objects are PIC. - lt_prog_compiler_pic_CXX= - lt_prog_compiler_static_CXX='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C++ 5.9 - lt_prog_compiler_pic_CXX='-KPIC' - lt_prog_compiler_static_CXX='-Bstatic' - lt_prog_compiler_wl_CXX='-Qoption ld ' - ;; - esac - ;; - esac - ;; - lynxos*) - ;; - m88k*) - ;; - mvs*) - case $cc_basename in - cxx*) - lt_prog_compiler_pic_CXX='-W c,exportall' - ;; - *) - ;; - esac - ;; - netbsd* | netbsdelf*-gnu) - ;; - osf3* | osf4* | osf5*) - case $cc_basename in - KCC*) - lt_prog_compiler_wl_CXX='--backend -Wl,' - ;; - RCC*) - # Rational C++ 2.4.1 - lt_prog_compiler_pic_CXX='-pic' - ;; - cxx*) - # Digital/Compaq C++ - lt_prog_compiler_wl_CXX='-Wl,' - # Make sure the PIC flag is empty. It appears that all Alpha - # Linux and Compaq Tru64 Unix objects are PIC. - lt_prog_compiler_pic_CXX= - lt_prog_compiler_static_CXX='-non_shared' - ;; - *) - ;; - esac - ;; - psos*) - ;; - solaris*) - case $cc_basename in - CC*) - # Sun C++ 4.2, 5.x and Centerline C++ - lt_prog_compiler_pic_CXX='-KPIC' - lt_prog_compiler_static_CXX='-Bstatic' - lt_prog_compiler_wl_CXX='-Qoption ld ' - ;; - gcx*) - # Green Hills C++ Compiler - lt_prog_compiler_pic_CXX='-PIC' - ;; - *) - ;; - esac - ;; - sunos4*) - case $cc_basename in - CC*) - # Sun C++ 4.x - lt_prog_compiler_pic_CXX='-pic' - lt_prog_compiler_static_CXX='-Bstatic' - ;; - lcc*) - # Lucid - lt_prog_compiler_pic_CXX='-pic' - ;; - *) - ;; - esac - ;; - tandem*) - case $cc_basename in - NCC*) - # NonStop-UX NCC 3.20 - lt_prog_compiler_pic_CXX='-KPIC' - ;; - *) - ;; - esac - ;; - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - case $cc_basename in - CC*) - lt_prog_compiler_wl_CXX='-Wl,' - lt_prog_compiler_pic_CXX='-KPIC' - lt_prog_compiler_static_CXX='-Bstatic' - ;; - esac - ;; - vxworks*) - ;; - *) - lt_prog_compiler_can_build_shared_CXX=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_CXX" >&5 -echo "${ECHO_T}$lt_prog_compiler_pic_CXX" >&6; } - -# -# Check to make sure the PIC flag actually works. -# -if test -n "$lt_prog_compiler_pic_CXX"; then - -{ echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 -echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_pic_works_CXX+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_pic_works_CXX=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:12595: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:12599: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_pic_works_CXX=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works_CXX" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_pic_works_CXX" >&6; } - -if test x"$lt_cv_prog_compiler_pic_works_CXX" = xyes; then - case $lt_prog_compiler_pic_CXX in - "" | " "*) ;; - *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; - esac -else - lt_prog_compiler_pic_CXX= - lt_prog_compiler_can_build_shared_CXX=no -fi - -fi -case $host_os in - # For platforms which do not support PIC, -DPIC is meaningless: - *djgpp*) - lt_prog_compiler_pic_CXX= - ;; - *) - lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" - ;; -esac - -# -# Check to make sure the static flag actually works. -# -wl=$lt_prog_compiler_wl_CXX eval lt_tmp_static_flag=\"$lt_prog_compiler_static_CXX\" -{ echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 -echo $ECHO_N "checking if $compiler static flag $lt_tmp_static_flag works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_static_works_CXX+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_static_works_CXX=no - save_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS $lt_tmp_static_flag" - echo "$lt_simple_link_test_code" > conftest.$ac_ext - if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then - # The linker can only warn and ignore the option if not recognized - # So say no if there are warnings - if test -s conftest.err; then - # Append any errors to the config.log. - cat conftest.err 1>&5 - $echo "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_static_works_CXX=yes - fi - else - lt_cv_prog_compiler_static_works_CXX=yes - fi - fi - $rm -r conftest* - LDFLAGS="$save_LDFLAGS" - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works_CXX" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_static_works_CXX" >&6; } - -if test x"$lt_cv_prog_compiler_static_works_CXX" = xyes; then - : -else - lt_prog_compiler_static_CXX= -fi - - -{ echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 -echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_c_o_CXX+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_c_o_CXX=no - $rm -r conftest 2>/dev/null - mkdir conftest - cd conftest - mkdir out - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - lt_compiler_flag="-o out/conftest2.$ac_objext" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:12699: $lt_compile\"" >&5) - (eval "$lt_compile" 2>out/conftest.err) - ac_status=$? - cat out/conftest.err >&5 - echo "$as_me:12703: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s out/conftest2.$ac_objext - then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp - $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 - if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then - lt_cv_prog_compiler_c_o_CXX=yes - fi - fi - chmod u+w . 2>&5 - $rm conftest* - # SGI C++ compiler will create directory out/ii_files/ for - # template instantiation - test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files - $rm out/* && rmdir out - cd .. - rmdir conftest - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_CXX" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_c_o_CXX" >&6; } - - -hard_links="nottested" -if test "$lt_cv_prog_compiler_c_o_CXX" = no && test "$need_locks" != no; then - # do not overwrite the value of need_locks provided by the user - { echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 -echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6; } - hard_links=yes - $rm conftest* - ln conftest.a conftest.b 2>/dev/null && hard_links=no - touch conftest.a - ln conftest.a conftest.b 2>&5 || hard_links=no - ln conftest.a conftest.b 2>/dev/null && hard_links=no - { echo "$as_me:$LINENO: result: $hard_links" >&5 -echo "${ECHO_T}$hard_links" >&6; } - if test "$hard_links" = no; then - { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 -echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} - need_locks=warn - fi -else - need_locks=no -fi - -{ echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 -echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6; } - - export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - case $host_os in - aix4-9*) - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to AIX nm, but means don't demangle with GNU nm - if $NM -V 2>&1 | grep 'GNU' > /dev/null; then - export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - else - export_symbols_cmds_CXX='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - fi - ;; - pw32*) - export_symbols_cmds_CXX="$ltdll_cmds" - ;; - cygwin* | mingw*) - export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^BCDGRS /s/.* \(^ *\)/\1 DATA/;/^.* __nm__/s/^.* __nm__\(^ *\) ^ */\1 DATA/;/^I /d;/^AITW /s/.* //'\'' | sort | uniq > $export_symbols' - ;; - linux* | k*bsd*-gnu) - link_all_deplibs_CXX=no - ;; - *) - export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - ;; - esac - exclude_expsyms_CXX='_GLOBAL_OFFSET_TABLE_|_GLOBAL__FID_.*' - -{ echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 -echo "${ECHO_T}$ld_shlibs_CXX" >&6; } -test "$ld_shlibs_CXX" = no && can_build_shared=no - -# -# Do we need to explicitly link libc? -# -case "x$archive_cmds_need_lc_CXX" in -x|xyes) - # Assume -lc should be added - archive_cmds_need_lc_CXX=yes - - if test "$enable_shared" = yes && test "$GCC" = yes; then - case $archive_cmds_CXX in - *'~'*) - # FIXME: we may have to deal with multi-command sequences. - ;; - '$CC '*) - # Test whether the compiler implicitly links with -lc since on some - # systems, -lgcc has to come before -lc. If gcc already passes -lc - # to ld, don't add -lc before -lgcc. - { echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 -echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6; } - $rm conftest* - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } 2>conftest.err; then - soname=conftest - lib=conftest - libobjs=conftest.$ac_objext - deplibs= - wl=$lt_prog_compiler_wl_CXX - pic_flag=$lt_prog_compiler_pic_CXX - compiler_flags=-v - linker_flags=-v - verstring= - output_objdir=. - libname=conftest - lt_save_allow_undefined_flag=$allow_undefined_flag_CXX - allow_undefined_flag_CXX= - if { (eval echo "$as_me:$LINENO: \"$archive_cmds_CXX 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 - (eval $archive_cmds_CXX 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - then - archive_cmds_need_lc_CXX=no - else - archive_cmds_need_lc_CXX=yes - fi - allow_undefined_flag_CXX=$lt_save_allow_undefined_flag - else - cat conftest.err 1>&5 - fi - $rm conftest* - { echo "$as_me:$LINENO: result: $archive_cmds_need_lc_CXX" >&5 -echo "${ECHO_T}$archive_cmds_need_lc_CXX" >&6; } - ;; - esac - fi - ;; -esac - -{ echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 -echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6; } -library_names_spec= -libname_spec='lib$name' -soname_spec= -shrext_cmds=".so" -postinstall_cmds= -postuninstall_cmds= -finish_cmds= -finish_eval= -shlibpath_var= -shlibpath_overrides_runpath=unknown -version_type=none -dynamic_linker="$host_os ld.so" -sys_lib_dlsearch_path_spec="/lib /usr/lib" - -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-9*) - 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 - ;; - -bsdi45*) - version_type=linux - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' - shlibpath_var=LD_LIBRARY_PATH - sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" - sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" - # the default ld.so.conf also contains /usr/contrib/lib and - # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow - # libtool to hard-code these into programs - ;; - -cygwin* | mingw* | pw32*) - version_type=windows - shrext_cmds=".dll" - need_version=no - need_lib_prefix=no - - case $GCC,$host_os in - yes,cygwin* | yes,mingw* | yes,pw32*) - library_names_spec='$libname.dll.a' - # DLL is installed to $(libdir)/../bin by postinstall_cmds - postinstall_cmds='base_file=`basename \${file}`~ - dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ - dldir=$destdir/`dirname \$dlpath`~ - test -d \$dldir || mkdir -p \$dldir~ - $install_prog $dir/$dlname \$dldir/$dlname~ - chmod a+x \$dldir/$dlname' - postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ - dlpath=$dir/\$dldll~ - $rm \$dlpath' - shlibpath_overrides_runpath=yes - - case $host_os in - cygwin*) - # Cygwin DLLs use 'cyg' prefix rather than 'lib' - soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" - ;; - mingw*) - # MinGW DLLs use traditional 'lib' prefix - soname_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$sys_lib_search_path_spec" | grep ';c-zC-Z:/' >/dev/null; then - # It is most probably a Windows format PATH printed by - # mingw gcc, but we are running on Cygwin. Gcc prints its search - # path with ; separators, and with drive letters. We can handle the - # drive letters (cygwin fileutils understands them), so leave them, - # especially as we might pass files found there to a mingw objdump, - # which wouldn't understand a cygwinified path. Ahh. - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` - else - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - ;; - pw32*) - # pw32 DLLs use 'pw' prefix rather than 'lib' - library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - ;; - esac - ;; - - *) - library_names_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext} $libname.lib' - ;; - esac - dynamic_linker='Win32 ld.exe' - # FIXME: first we should search . and the directory the executable is in - shlibpath_var=PATH - ;; - -darwin* | rhapsody*) - dynamic_linker="$host_os dyld" - version_type=darwin - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' - soname_spec='${libname}${release}${major}$shared_ext' - shlibpath_overrides_runpath=yes - shlibpath_var=DYLD_LIBRARY_PATH - shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' - - 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 - ;; - -freebsd* | dragonfly*) - # DragonFly does not have aout. When/if they implement a new - # versioning mechanism, adjust this. - if test -x /usr/bin/objformat; then - objformat=`/usr/bin/objformat` - else - case $host_os in - freebsd123*) objformat=aout ;; - *) objformat=elf ;; - esac - fi - version_type=freebsd-$objformat - case $version_type in - freebsd-elf*) - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - need_version=no - need_lib_prefix=no - ;; - freebsd-*) - library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' - need_version=yes - ;; - esac - shlibpath_var=LD_LIBRARY_PATH - case $host_os in - freebsd2*) - shlibpath_overrides_runpath=yes - ;; - freebsd3.01* | freebsdelf3.01*) - shlibpath_overrides_runpath=yes - hardcode_into_libs=yes - ;; - freebsd3.2-9* | freebsdelf3.2-9* | \ - freebsd4.0-5 | freebsdelf4.0-5 | freebsd4.1.1 | freebsdelf4.1.1) - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - *) # from 4.6 on, and DragonFly - shlibpath_overrides_runpath=yes - 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' - ;; - -interix3-9*) - 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' - dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - -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* | k*bsd*-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' - 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>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^ *hwcap /d;s/:, / /g;s/=^=*$//;s/=^= * / /g;/^$/d' | tr '\n' ' '` - sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" - fi - - # We used to test for /lib/ld.so.1 and disable shared libraries on - # powerpc, because MkLinux only supported shared libraries with the - # GNU dynamic linker. Since this was broken with cross compilers, - # most powerpc-linux boxes support dynamic linking these days and - # people can always --disable-shared, the test was removed, and we - # assume the GNU/Linux dynamic linker is in use. - dynamic_linker='GNU/Linux ld.so' - ;; - -netbsdelf*-gnu) - version_type=linux - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - dynamic_linker='NetBSD ld.elf_so' - ;; - -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 - sys_lib_dlsearch_path_spec="/usr/lib" - need_lib_prefix=no - # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. - case $host_os in - openbsd3.3 | openbsd3.3.*) need_version=yes ;; - *) need_version=no ;; - esac - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' - finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' - shlibpath_var=LD_LIBRARY_PATH - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - case $host_os in - openbsd2.89 | openbsd2.89.*) - shlibpath_overrides_runpath=no - ;; - *) - shlibpath_overrides_runpath=yes - ;; - esac - 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" - ;; - -rdos*) - dynamic_linker=no - ;; - -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.3*) - 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 - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - version_type=freebsd-elf - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - hardcode_into_libs=yes - if test "$with_gnu_ld" = yes; then - sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' - shlibpath_overrides_runpath=no - else - sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' - shlibpath_overrides_runpath=yes - case $host_os in - sco3.2v5*) - sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" - ;; - esac - fi - sys_lib_dlsearch_path_spec='/usr/lib' - ;; - -uts4*) - version_type=linux - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - ;; - -*) - dynamic_linker=no - ;; -esac -{ echo "$as_me:$LINENO: result: $dynamic_linker" >&5 -echo "${ECHO_T}$dynamic_linker" >&6; } -test "$dynamic_linker" = no && can_build_shared=no - -if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_search_path_spec="$sys_lib_search_path_spec" -fi - -sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" -if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec" -fi - -sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" - -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 - -{ echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 -echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6; } -hardcode_action_CXX= -if test -n "$hardcode_libdir_flag_spec_CXX" || \ - test -n "$runpath_var_CXX" || \ - test "X$hardcode_automatic_CXX" = "Xyes" ; then - - # We can hardcode non-existant directories. - if test "$hardcode_direct_CXX" != no && - # If the only mechanism to avoid hardcoding is shlibpath_var, we - # have to relink, otherwise we might link with an installed library - # when we should be linking with a yet-to-be-installed one - ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, CXX)" != no && - test "$hardcode_minus_L_CXX" != no; then - # Linking always hardcodes the temporary library directory. - hardcode_action_CXX=relink - else - # We can link without hardcoding, and we can hardcode nonexisting dirs. - hardcode_action_CXX=immediate - fi -else - # We cannot hardcode anything, or else we can only hardcode existing - # directories. - hardcode_action_CXX=unsupported -fi -{ echo "$as_me:$LINENO: result: $hardcode_action_CXX" >&5 -echo "${ECHO_T}$hardcode_action_CXX" >&6; } - -if test "$hardcode_action_CXX" = relink; then - # Fast installation is not supported - enable_fast_install=no -elif test "$shlibpath_overrides_runpath" = yes || - test "$enable_shared" = no; then - # Fast installation is not necessary - enable_fast_install=needless -fi - - -# 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 LTCFLAGS NM \ - SED SHELL STRIP \ - libname_spec library_names_spec soname_spec extract_expsyms_cmds \ - old_striplib striplib file_magic_cmd finish_cmds finish_eval \ - deplibs_check_method reload_flag reload_cmds need_locks \ - lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ - lt_cv_sys_global_symbol_to_c_name_address \ - sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ - old_postinstall_cmds old_postuninstall_cmds \ - compiler_CXX \ - CC_CXX \ - LD_CXX \ - lt_prog_compiler_wl_CXX \ - lt_prog_compiler_pic_CXX \ - lt_prog_compiler_static_CXX \ - lt_prog_compiler_no_builtin_flag_CXX \ - export_dynamic_flag_spec_CXX \ - thread_safe_flag_spec_CXX \ - whole_archive_flag_spec_CXX \ - enable_shared_with_static_runtimes_CXX \ - old_archive_cmds_CXX \ - old_archive_from_new_cmds_CXX \ - predep_objects_CXX \ - postdep_objects_CXX \ - predeps_CXX \ - postdeps_CXX \ - compiler_lib_search_path_CXX \ - compiler_lib_search_dirs_CXX \ - archive_cmds_CXX \ - archive_expsym_cmds_CXX \ - postinstall_cmds_CXX \ - postuninstall_cmds_CXX \ - old_archive_from_expsyms_cmds_CXX \ - allow_undefined_flag_CXX \ - no_undefined_flag_CXX \ - export_symbols_cmds_CXX \ - hardcode_libdir_flag_spec_CXX \ - hardcode_libdir_flag_spec_ld_CXX \ - hardcode_libdir_separator_CXX \ - hardcode_automatic_CXX \ - module_cmds_CXX \ - module_expsym_cmds_CXX \ - lt_cv_prog_compiler_c_o_CXX \ - fix_srcfile_path_CXX \ - exclude_expsyms_CXX \ - include_expsyms_CXX; do - - case $var in - old_archive_cmds_CXX | \ - old_archive_from_new_cmds_CXX | \ - archive_cmds_CXX | \ - archive_expsym_cmds_CXX | \ - module_cmds_CXX | \ - module_expsym_cmds_CXX | \ - old_archive_from_expsyms_cmds_CXX | \ - export_symbols_cmds_CXX | \ - extract_expsyms_cmds | reload_cmds | finish_cmds | \ - postinstall_cmds | postuninstall_cmds | \ - old_postinstall_cmds | old_postuninstall_cmds | \ - sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) - # Double-quote double-evaled strings. - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" - ;; - *) - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" - ;; - esac - done - - case $lt_echo in - *'\$0 --fallback-echo"') - lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` - ;; - esac - -cfgfile="$ofile" - - cat <<__EOF__ >> "$cfgfile" -# ### BEGIN LIBTOOL TAG CONFIG: $tagname - -# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: - -# Shell to use when invoking shell scripts. -SHELL=$lt_SHELL - -# Whether or not to build shared libraries. -build_libtool_libs=$enable_shared - -# Whether or not to build static libraries. -build_old_libs=$enable_static - -# Whether or not to add -lc for building shared libraries. -build_libtool_need_lc=$archive_cmds_need_lc_CXX - -# Whether or not to disallow shared libs when runtime libs are static -allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_CXX - -# Whether or not to optimize for fast installation. -fast_install=$enable_fast_install - -# The host system. -host_alias=$host_alias -host=$host -host_os=$host_os - -# The build system. -build_alias=$build_alias -build=$build -build_os=$build_os - -# An echo program that does not interpret backslashes. -echo=$lt_echo - -# The archiver. -AR=$lt_AR -AR_FLAGS=$lt_AR_FLAGS - -# A C compiler. -LTCC=$lt_LTCC - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# A language-specific compiler. -CC=$lt_compiler_CXX - -# Is the compiler the GNU C compiler? -with_gcc=$GCC_CXX - -# An ERE matcher. -EGREP=$lt_EGREP - -# The linker used to build libraries. -LD=$lt_LD_CXX - -# Whether we need hard or soft links. -LN_S=$lt_LN_S - -# A BSD-compatible nm program. -NM=$lt_NM - -# A symbol stripping program -STRIP=$lt_STRIP - -# Used to examine libraries when file_magic_cmd begins "file" -MAGIC_CMD=$MAGIC_CMD - -# Used on cygwin: DLL creation program. -DLLTOOL="$DLLTOOL" - -# Used on cygwin: object dumper. -OBJDUMP="$OBJDUMP" - -# Used on cygwin: assembler. -AS="$AS" - -# The name of the directory that contains temporary libtool files. -objdir=$objdir - -# How to create reloadable object files. -reload_flag=$lt_reload_flag -reload_cmds=$lt_reload_cmds - -# How to pass a linker flag through the compiler. -wl=$lt_lt_prog_compiler_wl_CXX - -# Object file suffix (normally "o"). -objext="$ac_objext" - -# Old archive suffix (normally "a"). -libext="$libext" - -# Shared library suffix (normally ".so"). -shrext_cmds='$shrext_cmds' - -# Executable file suffix (normally ""). -exeext="$exeext" - -# Additional compiler flags for building library objects. -pic_flag=$lt_lt_prog_compiler_pic_CXX -pic_mode=$pic_mode - -# What is the maximum length of a command? -max_cmd_len=$lt_cv_sys_max_cmd_len - -# Does compiler simultaneously support -c and -o options? -compiler_c_o=$lt_lt_cv_prog_compiler_c_o_CXX - -# Must we lock files when doing compilation? -need_locks=$lt_need_locks - -# Do we need the lib prefix for modules? -need_lib_prefix=$need_lib_prefix - -# Do we need a version for libraries? -need_version=$need_version - -# Whether dlopen is supported. -dlopen_support=$enable_dlopen - -# Whether dlopen of programs is supported. -dlopen_self=$enable_dlopen_self - -# Whether dlopen of statically linked programs is supported. -dlopen_self_static=$enable_dlopen_self_static - -# Compiler flag to prevent dynamic linking. -link_static_flag=$lt_lt_prog_compiler_static_CXX - -# Compiler flag to turn off builtin functions. -no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_CXX - -# Compiler flag to allow reflexive dlopens. -export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_CXX - -# Compiler flag to generate shared objects directly from archives. -whole_archive_flag_spec=$lt_whole_archive_flag_spec_CXX - -# Compiler flag to generate thread-safe objects. -thread_safe_flag_spec=$lt_thread_safe_flag_spec_CXX - -# Library versioning type. -version_type=$version_type - -# Format of library name prefix. -libname_spec=$lt_libname_spec - -# List of archive names. First name is the real one, the rest are links. -# The last name is the one that the linker finds with -lNAME. -library_names_spec=$lt_library_names_spec - -# The coded name of the library, if different from the real name. -soname_spec=$lt_soname_spec - -# Commands used to build and install an old-style archive. -RANLIB=$lt_RANLIB -old_archive_cmds=$lt_old_archive_cmds_CXX -old_postinstall_cmds=$lt_old_postinstall_cmds -old_postuninstall_cmds=$lt_old_postuninstall_cmds - -# Create an old-style archive from a shared archive. -old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_CXX - -# Create a temporary old-style archive to link instead of a shared archive. -old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_CXX - -# Commands used to build and install a shared archive. -archive_cmds=$lt_archive_cmds_CXX -archive_expsym_cmds=$lt_archive_expsym_cmds_CXX -postinstall_cmds=$lt_postinstall_cmds -postuninstall_cmds=$lt_postuninstall_cmds - -# Commands used to build a loadable module (assumed same as above if empty) -module_cmds=$lt_module_cmds_CXX -module_expsym_cmds=$lt_module_expsym_cmds_CXX - -# Commands to strip libraries. -old_striplib=$lt_old_striplib -striplib=$lt_striplib - -# Dependencies to place before the objects being linked to create a -# shared library. -predep_objects=$lt_predep_objects_CXX - -# Dependencies to place after the objects being linked to create a -# shared library. -postdep_objects=$lt_postdep_objects_CXX - -# Dependencies to place before the objects being linked to create a -# shared library. -predeps=$lt_predeps_CXX - -# Dependencies to place after the objects being linked to create a -# shared library. -postdeps=$lt_postdeps_CXX - -# The directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_CXX - -# The library search path used internally by the compiler when linking -# a shared library. -compiler_lib_search_path=$lt_compiler_lib_search_path_CXX - -# Method to check whether dependent libraries are shared objects. -deplibs_check_method=$lt_deplibs_check_method - -# Command to use when deplibs_check_method == file_magic. -file_magic_cmd=$lt_file_magic_cmd - -# Flag that allows shared libraries with undefined symbols to be built. -allow_undefined_flag=$lt_allow_undefined_flag_CXX - -# Flag that forces no undefined symbols. -no_undefined_flag=$lt_no_undefined_flag_CXX - -# Commands used to finish a libtool library installation in a directory. -finish_cmds=$lt_finish_cmds - -# Same as above, but a single script fragment to be evaled but not shown. -finish_eval=$lt_finish_eval - -# Take the output of nm and produce a listing of raw symbols and C names. -global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe - -# Transform the output of nm in a proper C declaration -global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl - -# Transform the output of nm in a C name address pair -global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address - -# This is the shared library runtime path variable. -runpath_var=$runpath_var - -# This is the shared library path variable. -shlibpath_var=$shlibpath_var - -# Is shlibpath searched before the hard-coded library search path? -shlibpath_overrides_runpath=$shlibpath_overrides_runpath - -# How to hardcode a shared library path into an executable. -hardcode_action=$hardcode_action_CXX - -# Whether we should hardcode library paths into libraries. -hardcode_into_libs=$hardcode_into_libs - -# Flag to hardcode \$libdir into a binary during linking. -# This must work even if \$libdir does not exist. -hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX - -# If ld is used when linking, flag to hardcode \$libdir into -# a binary during linking. This must work even if \$libdir does -# not exist. -hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_CXX - -# Whether we need a single -rpath flag with a separated argument. -hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX - -# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the -# resulting binary. -hardcode_direct=$hardcode_direct_CXX - -# Set to yes if using the -LDIR flag during linking hardcodes DIR into the -# resulting binary. -hardcode_minus_L=$hardcode_minus_L_CXX - -# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into -# the resulting binary. -hardcode_shlibpath_var=$hardcode_shlibpath_var_CXX - -# Set to yes if building a shared library automatically hardcodes DIR into the library -# and all subsequent libraries and executables linked against it. -hardcode_automatic=$hardcode_automatic_CXX - -# Variables whose values should be saved in libtool wrapper scripts and -# restored at relink time. -variables_saved_for_relink="$variables_saved_for_relink" - -# Whether libtool must link a program against all its dependency libraries. -link_all_deplibs=$link_all_deplibs_CXX - -# Compile-time system search path for libraries -sys_lib_search_path_spec=$lt_sys_lib_search_path_spec - -# Run-time system search path for libraries -sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec - -# Fix the shell variable \$srcfile for the compiler. -fix_srcfile_path=$lt_fix_srcfile_path - -# Set to yes if exported symbols are required. -always_export_symbols=$always_export_symbols_CXX - -# The commands to list exported symbols. -export_symbols_cmds=$lt_export_symbols_cmds_CXX - -# The commands to extract the exported symbol list from a shared archive. -extract_expsyms_cmds=$lt_extract_expsyms_cmds - -# Symbols that should not be listed in the preloaded symbols. -exclude_expsyms=$lt_exclude_expsyms_CXX - -# Symbols that must always be exported. -include_expsyms=$lt_include_expsyms_CXX - -# ### END LIBTOOL TAG CONFIG: $tagname - -__EOF__ - - -else - # If there is no Makefile yet, we rely on a make rule to execute - # `config.status --recheck' to rerun these tests and create the - # libtool script then. - ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` - if test -f "$ltmain_in"; then - test -f Makefile && make "$ltmain" - fi -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -CC=$lt_save_CC -LDCXX=$LD -LD=$lt_save_LD -GCC=$lt_save_GCC -with_gnu_ldcxx=$with_gnu_ld -with_gnu_ld=$lt_save_with_gnu_ld -lt_cv_path_LDCXX=$lt_cv_path_LD -lt_cv_path_LD=$lt_save_path_LD -lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld -lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld - - else - tagname="" - fi - ;; - - F77) - if test -n "$F77" && test "X$F77" != "Xno"; then - -ac_ext=f -ac_compile='$F77 -c $FFLAGS conftest.$ac_ext >&5' -ac_link='$F77 -o conftest$ac_exeext $FFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_f77_compiler_gnu - - -archive_cmds_need_lc_F77=no -allow_undefined_flag_F77= -always_export_symbols_F77=no -archive_expsym_cmds_F77= -export_dynamic_flag_spec_F77= -hardcode_direct_F77=no -hardcode_libdir_flag_spec_F77= -hardcode_libdir_flag_spec_ld_F77= -hardcode_libdir_separator_F77= -hardcode_minus_L_F77=no -hardcode_automatic_F77=no -module_cmds_F77= -module_expsym_cmds_F77= -link_all_deplibs_F77=unknown -old_archive_cmds_F77=$old_archive_cmds -no_undefined_flag_F77= -whole_archive_flag_spec_F77= -enable_shared_with_static_runtimes_F77=no - -# Source file extension for f77 test sources. -ac_ext=f - -# Object file extension for compiled f77 test sources. -objext=o -objext_F77=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code="\ - subroutine t - return - end -" - -# Code to be used in simple link tests -lt_simple_link_test_code="\ - program t - end -" - -# ltmain only uses $CC for tagged configurations so make sure $CC is set. - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# save warnings/boilerplate of simple test code -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_compiler_boilerplate=`cat conftest.err` -$rm conftest* - -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* - - -# Allow CC to be a program name with arguments. -lt_save_CC="$CC" -CC=${F77-"f77"} -compiler=$CC -compiler_F77=$CC -for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - -{ echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5 -echo $ECHO_N "checking if libtool supports shared libraries... $ECHO_C" >&6; } -{ echo "$as_me:$LINENO: result: $can_build_shared" >&5 -echo "${ECHO_T}$can_build_shared" >&6; } - -{ echo "$as_me:$LINENO: checking whether to build shared libraries" >&5 -echo $ECHO_N "checking whether to build shared libraries... $ECHO_C" >&6; } -test "$can_build_shared" = "no" && enable_shared=no - -# On AIX, shared libraries and static libraries use the same namespace, and -# are all built from PIC. -case $host_os in -aix3*) - test "$enable_shared" = yes && enable_static=no - if test -n "$RANLIB"; then - archive_cmds="$archive_cmds~\$RANLIB \$lib" - postinstall_cmds='$RANLIB $lib' - fi - ;; -aix4-9*) - if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then - test "$enable_shared" = yes && enable_static=no - fi - ;; -esac -{ echo "$as_me:$LINENO: result: $enable_shared" >&5 -echo "${ECHO_T}$enable_shared" >&6; } - -{ echo "$as_me:$LINENO: checking whether to build static libraries" >&5 -echo $ECHO_N "checking whether to build static libraries... $ECHO_C" >&6; } -# Make sure either enable_shared or enable_static is yes. -test "$enable_shared" = yes || enable_static=yes -{ echo "$as_me:$LINENO: result: $enable_static" >&5 -echo "${ECHO_T}$enable_static" >&6; } - -GCC_F77="$G77" -LD_F77="$LD" - -lt_prog_compiler_wl_F77= -lt_prog_compiler_pic_F77= -lt_prog_compiler_static_F77= - -{ echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 -echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6; } - - if test "$GCC" = yes; then - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_static_F77='-static' - - case $host_os in - aix*) - # All AIX code is PIC. - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_F77='-Bstatic' - fi - ;; - - amigaos*) - # FIXME: we need at least 68020 code to build shared libraries, but - # adding the `-m68020' flag to GCC prevents building anything better, - # like `-m68040'. - lt_prog_compiler_pic_F77='-m68020 -resident32 -malways-restore-a4' - ;; - - beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - lt_prog_compiler_pic_F77='-DDLL_EXPORT' - ;; - - darwin* | rhapsody*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - lt_prog_compiler_pic_F77='-fno-common' - ;; - - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - - msdosdjgpp*) - # Just because we use GCC doesn't mean we suddenly get shared libraries - # on systems that don't support them. - lt_prog_compiler_can_build_shared_F77=no - enable_shared=no - ;; - - sysv4*MP*) - if test -d /usr/nec; then - lt_prog_compiler_pic_F77=-Kconform_pic - fi - ;; - - hpux*) - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic_F77='-fPIC' - ;; - esac - ;; - - *) - lt_prog_compiler_pic_F77='-fPIC' - ;; - esac - else - # PORTME Check for flag to pass linker flags through the system compiler. - case $host_os in - aix*) - lt_prog_compiler_wl_F77='-Wl,' - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_F77='-Bstatic' - else - lt_prog_compiler_static_F77='-bnso -bI:/lib/syscalls.exp' - fi - ;; - darwin*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - case $cc_basename in - xlc*) - lt_prog_compiler_pic_F77='-qnocommon' - lt_prog_compiler_wl_F77='-Wl,' - ;; - esac - ;; - - mingw* | cygwin* | pw32* | os2*) - # This hack is so that the source file can tell whether it is being - # built for inclusion in a dll (and should export symbols for example). - lt_prog_compiler_pic_F77='-DDLL_EXPORT' - ;; - - hpux9* | hpux10* | hpux11*) - lt_prog_compiler_wl_F77='-Wl,' - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic_F77='+Z' - ;; - esac - # Is there a better lt_prog_compiler_static that works with the bundled CC? - lt_prog_compiler_static_F77='${wl}-a ${wl}archive' - ;; - - irix5* | irix6* | nonstopux*) - lt_prog_compiler_wl_F77='-Wl,' - # PIC (with -KPIC) is the default. - lt_prog_compiler_static_F77='-non_shared' - ;; - - newsos6) - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - ;; - - linux* | k*bsd*-gnu) - case $cc_basename in - icc* | ecc*) - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-static' - ;; - pgcc* | pgf77* | pgf90* | pgf95*) - # Portland Group compilers (*not* the Pentium gcc compiler, - # which looks to be a dead project) - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_pic_F77='-fpic' - lt_prog_compiler_static_F77='-Bstatic' - ;; - ccc*) - lt_prog_compiler_wl_F77='-Wl,' - # All Alpha code is PIC. - lt_prog_compiler_static_F77='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C 5.9 - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - lt_prog_compiler_wl_F77='-Wl,' - ;; - *Sun\ F*) - # Sun Fortran 8.3 passes all unrecognized flags to the linker - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - lt_prog_compiler_wl_F77='' - ;; - esac - ;; - esac - ;; - - osf3* | osf4* | osf5*) - lt_prog_compiler_wl_F77='-Wl,' - # All OSF/1 code is PIC. - lt_prog_compiler_static_F77='-non_shared' - ;; - - rdos*) - lt_prog_compiler_static_F77='-non_shared' - ;; - - solaris*) - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - case $cc_basename in - f77* | f90* | f95*) - lt_prog_compiler_wl_F77='-Qoption ld ';; - *) - lt_prog_compiler_wl_F77='-Wl,';; - esac - ;; - - sunos4*) - lt_prog_compiler_wl_F77='-Qoption ld ' - lt_prog_compiler_pic_F77='-PIC' - lt_prog_compiler_static_F77='-Bstatic' - ;; - - sysv4 | sysv4.2uw2* | sysv4.3*) - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - ;; - - sysv4*MP*) - if test -d /usr/nec ;then - lt_prog_compiler_pic_F77='-Kconform_pic' - lt_prog_compiler_static_F77='-Bstatic' - fi - ;; - - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_pic_F77='-KPIC' - lt_prog_compiler_static_F77='-Bstatic' - ;; - - unicos*) - lt_prog_compiler_wl_F77='-Wl,' - lt_prog_compiler_can_build_shared_F77=no - ;; - - uts4*) - lt_prog_compiler_pic_F77='-pic' - lt_prog_compiler_static_F77='-Bstatic' - ;; - - *) - lt_prog_compiler_can_build_shared_F77=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_F77" >&5 -echo "${ECHO_T}$lt_prog_compiler_pic_F77" >&6; } - -# -# Check to make sure the PIC flag actually works. -# -if test -n "$lt_prog_compiler_pic_F77"; then - -{ echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_F77 works" >&5 -echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_F77 works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_pic_works_F77+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_pic_works_F77=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="$lt_prog_compiler_pic_F77" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:14297: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:14301: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_pic_works_F77=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works_F77" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_pic_works_F77" >&6; } - -if test x"$lt_cv_prog_compiler_pic_works_F77" = xyes; then - case $lt_prog_compiler_pic_F77 in - "" | " "*) ;; - *) lt_prog_compiler_pic_F77=" $lt_prog_compiler_pic_F77" ;; - esac -else - lt_prog_compiler_pic_F77= - lt_prog_compiler_can_build_shared_F77=no -fi - -fi -case $host_os in - # For platforms which do not support PIC, -DPIC is meaningless: - *djgpp*) - lt_prog_compiler_pic_F77= - ;; - *) - lt_prog_compiler_pic_F77="$lt_prog_compiler_pic_F77" - ;; -esac - -# -# Check to make sure the static flag actually works. -# -wl=$lt_prog_compiler_wl_F77 eval lt_tmp_static_flag=\"$lt_prog_compiler_static_F77\" -{ echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 -echo $ECHO_N "checking if $compiler static flag $lt_tmp_static_flag works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_static_works_F77+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_static_works_F77=no - save_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS $lt_tmp_static_flag" - echo "$lt_simple_link_test_code" > conftest.$ac_ext - if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then - # The linker can only warn and ignore the option if not recognized - # So say no if there are warnings - if test -s conftest.err; then - # Append any errors to the config.log. - cat conftest.err 1>&5 - $echo "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_static_works_F77=yes - fi - else - lt_cv_prog_compiler_static_works_F77=yes - fi - fi - $rm -r conftest* - LDFLAGS="$save_LDFLAGS" - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works_F77" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_static_works_F77" >&6; } - -if test x"$lt_cv_prog_compiler_static_works_F77" = xyes; then - : -else - lt_prog_compiler_static_F77= -fi - - -{ echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 -echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_c_o_F77+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_c_o_F77=no - $rm -r conftest 2>/dev/null - mkdir conftest - cd conftest - mkdir out - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - lt_compiler_flag="-o out/conftest2.$ac_objext" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:14401: $lt_compile\"" >&5) - (eval "$lt_compile" 2>out/conftest.err) - ac_status=$? - cat out/conftest.err >&5 - echo "$as_me:14405: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s out/conftest2.$ac_objext - then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp - $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 - if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then - lt_cv_prog_compiler_c_o_F77=yes - fi - fi - chmod u+w . 2>&5 - $rm conftest* - # SGI C++ compiler will create directory out/ii_files/ for - # template instantiation - test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files - $rm out/* && rmdir out - cd .. - rmdir conftest - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_F77" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_c_o_F77" >&6; } - - -hard_links="nottested" -if test "$lt_cv_prog_compiler_c_o_F77" = no && test "$need_locks" != no; then - # do not overwrite the value of need_locks provided by the user - { echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 -echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6; } - hard_links=yes - $rm conftest* - ln conftest.a conftest.b 2>/dev/null && hard_links=no - touch conftest.a - ln conftest.a conftest.b 2>&5 || hard_links=no - ln conftest.a conftest.b 2>/dev/null && hard_links=no - { echo "$as_me:$LINENO: result: $hard_links" >&5 -echo "${ECHO_T}$hard_links" >&6; } - if test "$hard_links" = no; then - { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 -echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} - need_locks=warn - fi -else - need_locks=no -fi - -{ echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 -echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6; } - - runpath_var= - allow_undefined_flag_F77= - enable_shared_with_static_runtimes_F77=no - archive_cmds_F77= - archive_expsym_cmds_F77= - old_archive_From_new_cmds_F77= - old_archive_from_expsyms_cmds_F77= - export_dynamic_flag_spec_F77= - whole_archive_flag_spec_F77= - thread_safe_flag_spec_F77= - hardcode_libdir_flag_spec_F77= - hardcode_libdir_flag_spec_ld_F77= - hardcode_libdir_separator_F77= - hardcode_direct_F77=no - hardcode_minus_L_F77=no - hardcode_shlibpath_var_F77=unsupported - link_all_deplibs_F77=unknown - hardcode_automatic_F77=no - module_cmds_F77= - module_expsym_cmds_F77= - always_export_symbols_F77=no - export_symbols_cmds_F77='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - # include_expsyms should be a list of space-separated symbols to be *always* - # included in the symbol list - include_expsyms_F77= - # exclude_expsyms can be an extended regexp of symbols to exclude - # it will be wrapped by ` (' and `)$', so one must not match beginning or - # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', - # as well as any symbol that contains `d'. - exclude_expsyms_F77='_GLOBAL_OFFSET_TABLE_|_GLOBAL__FID_.*' - # 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. - # Exclude shared library initialization/finalization symbols. - extract_expsyms_cmds= - # Just being paranoid about ensuring that cc_basename is set. - for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - case $host_os in - cygwin* | mingw* | pw32*) - # FIXME: the MSVC++ port hasn't been tested in a loooong time - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - if test "$GCC" != yes; then - with_gnu_ld=no - fi - ;; - interix*) - # we just hope/assume this is gcc and not c89 (= MSVC++) - with_gnu_ld=yes - ;; - openbsd*) - with_gnu_ld=no - ;; - esac - - ld_shlibs_F77=yes - if test "$with_gnu_ld" = yes; then - # If archive_cmds runs LD, not CC, wlarc should be empty - wlarc='${wl}' - - # Set some defaults for GNU ld with shared library support. These - # are reset later if shared libraries are not supported. Putting them - # here allows them to be overridden if necessary. - runpath_var=LD_RUN_PATH - hardcode_libdir_flag_spec_F77='${wl}--rpath ${wl}$libdir' - export_dynamic_flag_spec_F77='${wl}--export-dynamic' - # ancient GNU ld didn't support --whole-archive et. al. - if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then - whole_archive_flag_spec_F77="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' - else - whole_archive_flag_spec_F77= - fi - supports_anon_versioning=no - case `$LD -v 2>/dev/null` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10.*) ;; # catch versions < 2.11 - *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... - *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... - *\ 2.11.*) ;; # other 2.11 versions - *) supports_anon_versioning=yes ;; - esac - - # See if GNU ld supports shared libraries. - case $host_os in - aix3-9*) - # On AIX/PPC, the GNU linker is very broken - if test "$host_cpu" != ia64; then - ld_shlibs_F77=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*) - archive_cmds_F77='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_minus_L_F77=yes - - # Samuel A. Falvo II <kc5tja@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. - ld_shlibs_F77=no - ;; - - beos*) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - allow_undefined_flag_F77=unsupported - # Joseph Beckenbach <jrb3@best.com> says some releases of gcc - # support --undefined. This deserves some investigation. FIXME - archive_cmds_F77='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - else - ld_shlibs_F77=no - fi - ;; - - cygwin* | mingw* | pw32*) - # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, F77) is actually meaningless, - # as there is no search path for DLLs. - hardcode_libdir_flag_spec_F77='-L$libdir' - allow_undefined_flag_F77=unsupported - always_export_symbols_F77=no - enable_shared_with_static_runtimes_F77=yes - export_symbols_cmds_F77='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^BCDGRS /s/.* \(^ *\)/\1 DATA/'\'' -e '\''/^AITW /s/.* //'\'' | sort | uniq > $export_symbols' - - if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - archive_expsym_cmds_F77='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then - cp $export_symbols $output_objdir/$soname.def; - else - echo EXPORTS > $output_objdir/$soname.def; - cat $export_symbols >> $output_objdir/$soname.def; - fi~ - $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - ld_shlibs_F77=no - fi - ;; - - interix3-9*) - hardcode_direct_F77=no - hardcode_shlibpath_var_F77=no - hardcode_libdir_flag_spec_F77='${wl}-rpath,$libdir' - export_dynamic_flag_spec_F77='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - archive_cmds_F77='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - archive_expsym_cmds_F77='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - - gnu* | linux* | k*bsd*-gnu) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - tmp_addflag= - case $cc_basename,$host_cpu in - pgcc*) # Portland Group C compiler - whole_archive_flag_spec_F77='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag' - ;; - pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers - whole_archive_flag_spec_F77='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag -Mnomain' ;; - ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 - tmp_addflag=' -i_dynamic' ;; - efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 - tmp_addflag=' -i_dynamic -nofor_main' ;; - ifc* | ifort*) # Intel Fortran compiler - tmp_addflag=' -nofor_main' ;; - esac - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) # Sun C 5.9 - whole_archive_flag_spec_F77='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_sharedflag='-G' ;; - *Sun\ F*) # Sun Fortran 8.3 - tmp_sharedflag='-G' ;; - *) - tmp_sharedflag='-shared' ;; - esac - archive_cmds_F77='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - - if test $supports_anon_versioning = yes; then - archive_expsym_cmds_F77='$echo "{ global:" > $output_objdir/$libname.ver~ - cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ - $echo "local: *; };" >> $output_objdir/$libname.ver~ - $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' - fi - link_all_deplibs_F77=no - else - ld_shlibs_F77=no - fi - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds_F77='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' - wlarc= - else - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - fi - ;; - - solaris*) - if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then - ld_shlibs_F77=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 - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs_F77=no - fi - ;; - - sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) - case `$LD -v 2>&1` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10-5.*) - ld_shlibs_F77=no - cat <<_LT_EOF 1>&2 - -*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not -*** reliably create shared libraries on SCO systems. Therefore, libtool -*** is disabling shared libraries support. We urge you to upgrade GNU -*** binutils to release 2.16.91.0.3 or newer. Another option is to modify -*** your PATH or compiler configuration so that the native linker is -*** used, and then restart. - -_LT_EOF - ;; - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - hardcode_libdir_flag_spec_F77='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib' - archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname,-retain-symbols-file,$export_symbols -o $lib' - else - ld_shlibs_F77=no - fi - ;; - esac - ;; - - sunos4*) - archive_cmds_F77='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' - wlarc= - hardcode_direct_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs_F77=no - fi - ;; - esac - - if test "$ld_shlibs_F77" = no; then - runpath_var= - hardcode_libdir_flag_spec_F77= - export_dynamic_flag_spec_F77= - whole_archive_flag_spec_F77= - fi - else - # PORTME fill in a description of your system's linker (not GNU ld) - case $host_os in - aix3*) - allow_undefined_flag_F77=unsupported - always_export_symbols_F77=yes - archive_expsym_cmds_F77='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' - # Note: this linker hardcodes the directories in LIBPATH if there - # are no directories specified by -L. - hardcode_minus_L_F77=yes - if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then - # Neither direct hardcoding nor static linking is supported with a - # broken collect2. - hardcode_direct_F77=unsupported - fi - ;; - - aix4-9*) - if test "$host_cpu" = ia64; then - # On IA64, the linker does run time linking by default, so we don't - # have to do anything special. - aix_use_runtimelinking=no - exp_sym_flag='-Bexport' - no_entry_flag="" - else - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to AIX nm, but means don't demangle with GNU nm - if $NM -V 2>&1 | grep 'GNU' > /dev/null; then - export_symbols_cmds_F77='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - else - export_symbols_cmds_F77='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - fi - aix_use_runtimelinking=no - - # Test if we are trying to use run time linking or normal - # AIX style linking. If -brtl is somewhere in LDFLAGS, we - # need to do runtime linking. - case $host_os in aix4.23|aix4.23.*|aix5-9*) - for ld_flag in $LDFLAGS; do - if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then - aix_use_runtimelinking=yes - break - fi - done - ;; - esac - - exp_sym_flag='-bexport' - no_entry_flag='-bnoentry' - fi - - # When large executables or shared objects are built, AIX ld can - # have problems creating the table of contents. If linking a library - # or program results in "error TOC overflow" add -mminimal-toc to - # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not - # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. - - archive_cmds_F77='' - hardcode_direct_F77=yes - hardcode_libdir_separator_F77=':' - link_all_deplibs_F77=yes - - if test "$GCC" = yes; then - case $host_os in aix4.012|aix4.012.*) - # We only want to do this on AIX 4.2 and lower, the check - # below for broken collect2 doesn't work under 4.3+ - collect2name=`${CC} -print-prog-name=collect2` - if test -f "$collect2name" && \ - strings "$collect2name" | grep resolve_lib_name >/dev/null - then - # We have reworked collect2 - : - else - # We have old collect2 - hardcode_direct_F77=unsupported - # It fails to find uninstalled libraries when the uninstalled - # path is not listed in the libpath. Setting hardcode_minus_L - # to unsupported forces relinking - hardcode_minus_L_F77=yes - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_libdir_separator_F77= - fi - ;; - esac - shared_flag='-shared' - if test "$aix_use_runtimelinking" = yes; then - shared_flag="$shared_flag "'${wl}-G' - fi - else - # not using gcc - if test "$host_cpu" = ia64; then - # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release - # chokes on -Wl,-G. The following line is correct: - shared_flag='-G' - else - if test "$aix_use_runtimelinking" = yes; then - shared_flag='${wl}-G' - else - shared_flag='${wl}-bM:SRE' - fi - fi - fi - - # It seems that -bexpall does not export symbols beginning with - # underscore (_), so it is better to generate a list of symbols to export. - always_export_symbols_F77=yes - if test "$aix_use_runtimelinking" = yes; then - # Warning - without using the other runtime loading flags (-brtl), - # -berok will link without error, but may produce a broken library. - allow_undefined_flag_F77='-berok' - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF - program main - - end -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_f77_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_F77='${wl}-blibpath:$libdir:'"$aix_libpath" - archive_expsym_cmds_F77="\$CC"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" - else - if test "$host_cpu" = ia64; then - hardcode_libdir_flag_spec_F77='${wl}-R $libdir:/usr/lib:/lib' - allow_undefined_flag_F77="-z nodefs" - archive_expsym_cmds_F77="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF - program main - - end -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_f77_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_F77='${wl}-blibpath:$libdir:'"$aix_libpath" - # Warning - without using the other run time loading flags, - # -berok will link without error, but may produce a broken library. - no_undefined_flag_F77=' ${wl}-bernotok' - allow_undefined_flag_F77=' ${wl}-berok' - # Exported symbols can be pulled into shared objects from archives - whole_archive_flag_spec_F77='$convenience' - archive_cmds_need_lc_F77=yes - # This is similar to how AIX traditionally builds its shared libraries. - archive_expsym_cmds_F77="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' - fi - fi - ;; - - amigaos*) - archive_cmds_F77='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_minus_L_F77=yes - # see comment about different semantics on the GNU ld section - ld_shlibs_F77=no - ;; - - bsdi45*) - export_dynamic_flag_spec_F77=-rdynamic - ;; - - cygwin* | mingw* | pw32*) - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - # hardcode_libdir_flag_spec is actually meaningless, as there is - # no search path for DLLs. - hardcode_libdir_flag_spec_F77=' ' - allow_undefined_flag_F77=unsupported - # Tell ltmain to make .lib files, not .a files. - libext=lib - # Tell ltmain to make .dll files, not .so files. - shrext_cmds=".dll" - # FIXME: Setting linknames here is a bad hack. - archive_cmds_F77='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' - # The linker will automatically build a .lib file if we build a DLL. - old_archive_From_new_cmds_F77='true' - # FIXME: Should let the user specify the lib program. - old_archive_cmds_F77='lib -OUT:$oldlib$oldobjs$old_deplibs' - fix_srcfile_path_F77='`cygpath -w "$srcfile"`' - enable_shared_with_static_runtimes_F77=yes - ;; - - darwin* | rhapsody*) - case $host_os in - rhapsody* | darwin1.012) - allow_undefined_flag_F77='${wl}-undefined ${wl}suppress' - ;; - *) # Darwin 1.3 on - if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then - allow_undefined_flag_F77='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - else - case ${MACOSX_DEPLOYMENT_TARGET} in - 10.012) - allow_undefined_flag_F77='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - ;; - 10.*) - allow_undefined_flag_F77='${wl}-undefined ${wl}dynamic_lookup' - ;; - esac - fi - ;; - esac - archive_cmds_need_lc_F77=no - hardcode_direct_F77=no - hardcode_automatic_F77=yes - hardcode_shlibpath_var_F77=unsupported - whole_archive_flag_spec_F77='' - link_all_deplibs_F77=yes - if test "$GCC" = yes ; then - output_verbose_link_cmd='echo' - archive_cmds_F77="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" - module_cmds_F77="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - archive_expsym_cmds_F77="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - module_expsym_cmds_F77="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - else - case $cc_basename in - xlc*) - output_verbose_link_cmd='echo' - archive_cmds_F77='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $xlcverstring' - module_cmds_F77='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - archive_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - module_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - ;; - *) - ld_shlibs_F77=no - ;; - esac - fi - ;; - - dgux*) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_shlibpath_var_F77=no - ;; - - freebsd1*) - ld_shlibs_F77=no - ;; - - # FreeBSD 2.2.012 allows us to include c++rt0.o to get C++ constructor - # support. Future versions do this automatically, but an explicit c++rt0.o - # does not break anything, and helps significantly (at the cost of a little - # extra space). - freebsd2.2*) - archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' - hardcode_libdir_flag_spec_F77='-R$libdir' - hardcode_direct_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - # Unfortunately, older versions of FreeBSD 2 do not have this feature. - freebsd2*) - archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_F77=yes - hardcode_minus_L_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - # FreeBSD 3 and greater uses gcc -shared to do shared libraries. - freebsd* | dragonfly*) - archive_cmds_F77='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec_F77='-R$libdir' - hardcode_direct_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - hpux9*) - if test "$GCC" = yes; then - archive_cmds_F77='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - else - archive_cmds_F77='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - fi - hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_F77=: - hardcode_direct_F77=yes - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_F77=yes - export_dynamic_flag_spec_F77='${wl}-E' - ;; - - hpux10*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - archive_cmds_F77='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_F77='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_F77=: - - hardcode_direct_F77=yes - export_dynamic_flag_spec_F77='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_F77=yes - fi - ;; - - hpux11*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - case $host_cpu in - hppa*64*) - archive_cmds_F77='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds_F77='$CC -shared ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_F77='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - else - case $host_cpu in - hppa*64*) - archive_cmds_F77='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds_F77='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_F77='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_F77=: - - case $host_cpu in - hppa*64*|ia64*) - hardcode_libdir_flag_spec_ld_F77='+b $libdir' - hardcode_direct_F77=no - hardcode_shlibpath_var_F77=no - ;; - *) - hardcode_direct_F77=yes - export_dynamic_flag_spec_F77='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_F77=yes - ;; - esac - fi - ;; - - irix5* | irix6* | nonstopux*) - if test "$GCC" = yes; then - archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - archive_cmds_F77='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec_ld_F77='-rpath $libdir' - fi - hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_F77=: - link_all_deplibs_F77=yes - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out - else - archive_cmds_F77='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF - fi - hardcode_libdir_flag_spec_F77='-R$libdir' - hardcode_direct_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - newsos6) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_F77=yes - hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_F77=: - hardcode_shlibpath_var_F77=no - ;; - - openbsd*) - if test -f /usr/libexec/ld.so; then - hardcode_direct_F77=yes - hardcode_shlibpath_var_F77=no - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - archive_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' - hardcode_libdir_flag_spec_F77='${wl}-rpath,$libdir' - export_dynamic_flag_spec_F77='${wl}-E' - else - case $host_os in - openbsd01.* | openbsd2.0-7 | openbsd2.0-7.*) - archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_F77='-R$libdir' - ;; - *) - archive_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec_F77='${wl}-rpath,$libdir' - ;; - esac - fi - else - ld_shlibs_F77=no - fi - ;; - - os2*) - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_minus_L_F77=yes - allow_undefined_flag_F77=unsupported - archive_cmds_F77='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' - old_archive_From_new_cmds_F77='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' - ;; - - osf3*) - if test "$GCC" = yes; then - allow_undefined_flag_F77=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_F77='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - allow_undefined_flag_F77=' -expect_unresolved \*' - archive_cmds_F77='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - fi - hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_F77=: - ;; - - osf4* | osf5*) # as osf3* with the addition of -msym flag - if test "$GCC" = yes; then - allow_undefined_flag_F77=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_F77='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' - else - allow_undefined_flag_F77=' -expect_unresolved \*' - archive_cmds_F77='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - archive_expsym_cmds_F77='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ - $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' - - # Both c and cxx compiler support -rpath directly - hardcode_libdir_flag_spec_F77='-rpath $libdir' - fi - hardcode_libdir_separator_F77=: - ;; - - solaris*) - no_undefined_flag_F77=' -z text' - if test "$GCC" = yes; then - wlarc='${wl}' - archive_cmds_F77='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' - else - wlarc='' - archive_cmds_F77='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' - archive_expsym_cmds_F77='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' - fi - hardcode_libdir_flag_spec_F77='-R$libdir' - hardcode_shlibpath_var_F77=no - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - # The compiler driver will combine and reorder linker options, - # but understands `-z linker_flag'. GCC discards it without `$wl', - # but is careful enough not to reorder. - # Supported since Solaris 2.6 (maybe 2.5.1?) - if test "$GCC" = yes; then - whole_archive_flag_spec_F77='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - else - whole_archive_flag_spec_F77='-z allextract$convenience -z defaultextract' - fi - ;; - esac - link_all_deplibs_F77=yes - ;; - - sunos4*) - if test "x$host_vendor" = xsequent; then - # Use $CC to link under sequent, because it throws in some extra .o - # files that make .init and .fini sections work. - archive_cmds_F77='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_F77='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' - fi - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_direct_F77=yes - hardcode_minus_L_F77=yes - hardcode_shlibpath_var_F77=no - ;; - - sysv4) - case $host_vendor in - sni) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_F77=yes # is this really true??? - ;; - siemens) - ## LD is ld it makes a PLAMLIB - ## CC just makes a GrossModule. - archive_cmds_F77='$LD -G -o $lib $libobjs $deplibs $linker_flags' - reload_cmds_F77='$CC -r -o $output$reload_objs' - hardcode_direct_F77=no - ;; - motorola) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_F77=no #Motorola manual says yes, but my tests say they lie - ;; - esac - runpath_var='LD_RUN_PATH' - hardcode_shlibpath_var_F77=no - ;; - - sysv4.3*) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var_F77=no - export_dynamic_flag_spec_F77='-Bexport' - ;; - - sysv4*MP*) - if test -d /usr/nec; then - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var_F77=no - runpath_var=LD_RUN_PATH - hardcode_runpath_var=yes - ld_shlibs_F77=yes - fi - ;; - - sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - no_undefined_flag_F77='${wl}-z,text' - archive_cmds_need_lc_F77=no - hardcode_shlibpath_var_F77=no - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds_F77='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_F77='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - no_undefined_flag_F77='${wl}-z,text' - allow_undefined_flag_F77='${wl}-z,nodefs' - archive_cmds_need_lc_F77=no - hardcode_shlibpath_var_F77=no - hardcode_libdir_flag_spec_F77='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - hardcode_libdir_separator_F77=':' - link_all_deplibs_F77=yes - export_dynamic_flag_spec_F77='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds_F77='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_F77='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_F77='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - uts4*) - archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_F77='-L$libdir' - hardcode_shlibpath_var_F77=no - ;; - - *) - ld_shlibs_F77=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $ld_shlibs_F77" >&5 -echo "${ECHO_T}$ld_shlibs_F77" >&6; } -test "$ld_shlibs_F77" = no && can_build_shared=no - -# -# Do we need to explicitly link libc? -# -case "x$archive_cmds_need_lc_F77" in -x|xyes) - # Assume -lc should be added - archive_cmds_need_lc_F77=yes - - if test "$enable_shared" = yes && test "$GCC" = yes; then - case $archive_cmds_F77 in - *'~'*) - # FIXME: we may have to deal with multi-command sequences. - ;; - '$CC '*) - # Test whether the compiler implicitly links with -lc since on some - # systems, -lgcc has to come before -lc. If gcc already passes -lc - # to ld, don't add -lc before -lgcc. - { echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 -echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6; } - $rm conftest* - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } 2>conftest.err; then - soname=conftest - lib=conftest - libobjs=conftest.$ac_objext - deplibs= - wl=$lt_prog_compiler_wl_F77 - pic_flag=$lt_prog_compiler_pic_F77 - compiler_flags=-v - linker_flags=-v - verstring= - output_objdir=. - libname=conftest - lt_save_allow_undefined_flag=$allow_undefined_flag_F77 - allow_undefined_flag_F77= - if { (eval echo "$as_me:$LINENO: \"$archive_cmds_F77 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 - (eval $archive_cmds_F77 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - then - archive_cmds_need_lc_F77=no - else - archive_cmds_need_lc_F77=yes - fi - allow_undefined_flag_F77=$lt_save_allow_undefined_flag - else - cat conftest.err 1>&5 - fi - $rm conftest* - { echo "$as_me:$LINENO: result: $archive_cmds_need_lc_F77" >&5 -echo "${ECHO_T}$archive_cmds_need_lc_F77" >&6; } - ;; - esac - fi - ;; -esac - -{ echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 -echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6; } -library_names_spec= -libname_spec='lib$name' -soname_spec= -shrext_cmds=".so" -postinstall_cmds= -postuninstall_cmds= -finish_cmds= -finish_eval= -shlibpath_var= -shlibpath_overrides_runpath=unknown -version_type=none -dynamic_linker="$host_os ld.so" -sys_lib_dlsearch_path_spec="/lib /usr/lib" - -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-9*) - 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 - ;; - -bsdi45*) - version_type=linux - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' - shlibpath_var=LD_LIBRARY_PATH - sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" - sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" - # the default ld.so.conf also contains /usr/contrib/lib and - # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow - # libtool to hard-code these into programs - ;; - -cygwin* | mingw* | pw32*) - version_type=windows - shrext_cmds=".dll" - need_version=no - need_lib_prefix=no - - case $GCC,$host_os in - yes,cygwin* | yes,mingw* | yes,pw32*) - library_names_spec='$libname.dll.a' - # DLL is installed to $(libdir)/../bin by postinstall_cmds - postinstall_cmds='base_file=`basename \${file}`~ - dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ - dldir=$destdir/`dirname \$dlpath`~ - test -d \$dldir || mkdir -p \$dldir~ - $install_prog $dir/$dlname \$dldir/$dlname~ - chmod a+x \$dldir/$dlname' - postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ - dlpath=$dir/\$dldll~ - $rm \$dlpath' - shlibpath_overrides_runpath=yes - - case $host_os in - cygwin*) - # Cygwin DLLs use 'cyg' prefix rather than 'lib' - soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" - ;; - mingw*) - # MinGW DLLs use traditional 'lib' prefix - soname_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$sys_lib_search_path_spec" | grep ';c-zC-Z:/' >/dev/null; then - # It is most probably a Windows format PATH printed by - # mingw gcc, but we are running on Cygwin. Gcc prints its search - # path with ; separators, and with drive letters. We can handle the - # drive letters (cygwin fileutils understands them), so leave them, - # especially as we might pass files found there to a mingw objdump, - # which wouldn't understand a cygwinified path. Ahh. - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` - else - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - ;; - pw32*) - # pw32 DLLs use 'pw' prefix rather than 'lib' - library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - ;; - esac - ;; - - *) - library_names_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext} $libname.lib' - ;; - esac - dynamic_linker='Win32 ld.exe' - # FIXME: first we should search . and the directory the executable is in - shlibpath_var=PATH - ;; - -darwin* | rhapsody*) - dynamic_linker="$host_os dyld" - version_type=darwin - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' - soname_spec='${libname}${release}${major}$shared_ext' - shlibpath_overrides_runpath=yes - shlibpath_var=DYLD_LIBRARY_PATH - shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' - - 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 - ;; - -freebsd* | dragonfly*) - # DragonFly does not have aout. When/if they implement a new - # versioning mechanism, adjust this. - if test -x /usr/bin/objformat; then - objformat=`/usr/bin/objformat` - else - case $host_os in - freebsd123*) objformat=aout ;; - *) objformat=elf ;; - esac - fi - version_type=freebsd-$objformat - case $version_type in - freebsd-elf*) - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - need_version=no - need_lib_prefix=no - ;; - freebsd-*) - library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' - need_version=yes - ;; - esac - shlibpath_var=LD_LIBRARY_PATH - case $host_os in - freebsd2*) - shlibpath_overrides_runpath=yes - ;; - freebsd3.01* | freebsdelf3.01*) - shlibpath_overrides_runpath=yes - hardcode_into_libs=yes - ;; - freebsd3.2-9* | freebsdelf3.2-9* | \ - freebsd4.0-5 | freebsdelf4.0-5 | freebsd4.1.1 | freebsdelf4.1.1) - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - *) # from 4.6 on, and DragonFly - shlibpath_overrides_runpath=yes - 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' - ;; - -interix3-9*) - 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' - dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - -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* | k*bsd*-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' - 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>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^ *hwcap /d;s/:, / /g;s/=^=*$//;s/=^= * / /g;/^$/d' | tr '\n' ' '` - sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" - fi - - # We used to test for /lib/ld.so.1 and disable shared libraries on - # powerpc, because MkLinux only supported shared libraries with the - # GNU dynamic linker. Since this was broken with cross compilers, - # most powerpc-linux boxes support dynamic linking these days and - # people can always --disable-shared, the test was removed, and we - # assume the GNU/Linux dynamic linker is in use. - dynamic_linker='GNU/Linux ld.so' - ;; - -netbsdelf*-gnu) - version_type=linux - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - dynamic_linker='NetBSD ld.elf_so' - ;; - -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 - sys_lib_dlsearch_path_spec="/usr/lib" - need_lib_prefix=no - # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. - case $host_os in - openbsd3.3 | openbsd3.3.*) need_version=yes ;; - *) need_version=no ;; - esac - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' - finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' - shlibpath_var=LD_LIBRARY_PATH - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - case $host_os in - openbsd2.89 | openbsd2.89.*) - shlibpath_overrides_runpath=no - ;; - *) - shlibpath_overrides_runpath=yes - ;; - esac - 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" - ;; - -rdos*) - dynamic_linker=no - ;; - -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.3*) - 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 - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - version_type=freebsd-elf - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - hardcode_into_libs=yes - if test "$with_gnu_ld" = yes; then - sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' - shlibpath_overrides_runpath=no - else - sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' - shlibpath_overrides_runpath=yes - case $host_os in - sco3.2v5*) - sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" - ;; - esac - fi - sys_lib_dlsearch_path_spec='/usr/lib' - ;; - -uts4*) - version_type=linux - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - ;; - -*) - dynamic_linker=no - ;; -esac -{ echo "$as_me:$LINENO: result: $dynamic_linker" >&5 -echo "${ECHO_T}$dynamic_linker" >&6; } -test "$dynamic_linker" = no && can_build_shared=no - -if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_search_path_spec="$sys_lib_search_path_spec" -fi - -sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" -if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec" -fi - -sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" - -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 - -{ echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 -echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6; } -hardcode_action_F77= -if test -n "$hardcode_libdir_flag_spec_F77" || \ - test -n "$runpath_var_F77" || \ - test "X$hardcode_automatic_F77" = "Xyes" ; then - - # We can hardcode non-existant directories. - if test "$hardcode_direct_F77" != no && - # If the only mechanism to avoid hardcoding is shlibpath_var, we - # have to relink, otherwise we might link with an installed library - # when we should be linking with a yet-to-be-installed one - ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, F77)" != no && - test "$hardcode_minus_L_F77" != no; then - # Linking always hardcodes the temporary library directory. - hardcode_action_F77=relink - else - # We can link without hardcoding, and we can hardcode nonexisting dirs. - hardcode_action_F77=immediate - fi -else - # We cannot hardcode anything, or else we can only hardcode existing - # directories. - hardcode_action_F77=unsupported -fi -{ echo "$as_me:$LINENO: result: $hardcode_action_F77" >&5 -echo "${ECHO_T}$hardcode_action_F77" >&6; } - -if test "$hardcode_action_F77" = relink; then - # Fast installation is not supported - enable_fast_install=no -elif test "$shlibpath_overrides_runpath" = yes || - test "$enable_shared" = no; then - # Fast installation is not necessary - enable_fast_install=needless -fi - - -# 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 LTCFLAGS NM \ - SED SHELL STRIP \ - libname_spec library_names_spec soname_spec extract_expsyms_cmds \ - old_striplib striplib file_magic_cmd finish_cmds finish_eval \ - deplibs_check_method reload_flag reload_cmds need_locks \ - lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ - lt_cv_sys_global_symbol_to_c_name_address \ - sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ - old_postinstall_cmds old_postuninstall_cmds \ - compiler_F77 \ - CC_F77 \ - LD_F77 \ - lt_prog_compiler_wl_F77 \ - lt_prog_compiler_pic_F77 \ - lt_prog_compiler_static_F77 \ - lt_prog_compiler_no_builtin_flag_F77 \ - export_dynamic_flag_spec_F77 \ - thread_safe_flag_spec_F77 \ - whole_archive_flag_spec_F77 \ - enable_shared_with_static_runtimes_F77 \ - old_archive_cmds_F77 \ - old_archive_from_new_cmds_F77 \ - predep_objects_F77 \ - postdep_objects_F77 \ - predeps_F77 \ - postdeps_F77 \ - compiler_lib_search_path_F77 \ - compiler_lib_search_dirs_F77 \ - archive_cmds_F77 \ - archive_expsym_cmds_F77 \ - postinstall_cmds_F77 \ - postuninstall_cmds_F77 \ - old_archive_from_expsyms_cmds_F77 \ - allow_undefined_flag_F77 \ - no_undefined_flag_F77 \ - export_symbols_cmds_F77 \ - hardcode_libdir_flag_spec_F77 \ - hardcode_libdir_flag_spec_ld_F77 \ - hardcode_libdir_separator_F77 \ - hardcode_automatic_F77 \ - module_cmds_F77 \ - module_expsym_cmds_F77 \ - lt_cv_prog_compiler_c_o_F77 \ - fix_srcfile_path_F77 \ - exclude_expsyms_F77 \ - include_expsyms_F77; do - - case $var in - old_archive_cmds_F77 | \ - old_archive_from_new_cmds_F77 | \ - archive_cmds_F77 | \ - archive_expsym_cmds_F77 | \ - module_cmds_F77 | \ - module_expsym_cmds_F77 | \ - old_archive_from_expsyms_cmds_F77 | \ - export_symbols_cmds_F77 | \ - extract_expsyms_cmds | reload_cmds | finish_cmds | \ - postinstall_cmds | postuninstall_cmds | \ - old_postinstall_cmds | old_postuninstall_cmds | \ - sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) - # Double-quote double-evaled strings. - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" - ;; - *) - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" - ;; - esac - done - - case $lt_echo in - *'\$0 --fallback-echo"') - lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` - ;; - esac - -cfgfile="$ofile" - - cat <<__EOF__ >> "$cfgfile" -# ### BEGIN LIBTOOL TAG CONFIG: $tagname - -# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: - -# Shell to use when invoking shell scripts. -SHELL=$lt_SHELL - -# Whether or not to build shared libraries. -build_libtool_libs=$enable_shared - -# Whether or not to build static libraries. -build_old_libs=$enable_static - -# Whether or not to add -lc for building shared libraries. -build_libtool_need_lc=$archive_cmds_need_lc_F77 - -# Whether or not to disallow shared libs when runtime libs are static -allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_F77 - -# Whether or not to optimize for fast installation. -fast_install=$enable_fast_install - -# The host system. -host_alias=$host_alias -host=$host -host_os=$host_os - -# The build system. -build_alias=$build_alias -build=$build -build_os=$build_os - -# An echo program that does not interpret backslashes. -echo=$lt_echo - -# The archiver. -AR=$lt_AR -AR_FLAGS=$lt_AR_FLAGS - -# A C compiler. -LTCC=$lt_LTCC - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# A language-specific compiler. -CC=$lt_compiler_F77 - -# Is the compiler the GNU C compiler? -with_gcc=$GCC_F77 - -# An ERE matcher. -EGREP=$lt_EGREP - -# The linker used to build libraries. -LD=$lt_LD_F77 - -# Whether we need hard or soft links. -LN_S=$lt_LN_S - -# A BSD-compatible nm program. -NM=$lt_NM - -# A symbol stripping program -STRIP=$lt_STRIP - -# Used to examine libraries when file_magic_cmd begins "file" -MAGIC_CMD=$MAGIC_CMD - -# Used on cygwin: DLL creation program. -DLLTOOL="$DLLTOOL" - -# Used on cygwin: object dumper. -OBJDUMP="$OBJDUMP" - -# Used on cygwin: assembler. -AS="$AS" - -# The name of the directory that contains temporary libtool files. -objdir=$objdir - -# How to create reloadable object files. -reload_flag=$lt_reload_flag -reload_cmds=$lt_reload_cmds - -# How to pass a linker flag through the compiler. -wl=$lt_lt_prog_compiler_wl_F77 - -# Object file suffix (normally "o"). -objext="$ac_objext" - -# Old archive suffix (normally "a"). -libext="$libext" - -# Shared library suffix (normally ".so"). -shrext_cmds='$shrext_cmds' - -# Executable file suffix (normally ""). -exeext="$exeext" - -# Additional compiler flags for building library objects. -pic_flag=$lt_lt_prog_compiler_pic_F77 -pic_mode=$pic_mode - -# What is the maximum length of a command? -max_cmd_len=$lt_cv_sys_max_cmd_len - -# Does compiler simultaneously support -c and -o options? -compiler_c_o=$lt_lt_cv_prog_compiler_c_o_F77 - -# Must we lock files when doing compilation? -need_locks=$lt_need_locks - -# Do we need the lib prefix for modules? -need_lib_prefix=$need_lib_prefix - -# Do we need a version for libraries? -need_version=$need_version - -# Whether dlopen is supported. -dlopen_support=$enable_dlopen - -# Whether dlopen of programs is supported. -dlopen_self=$enable_dlopen_self - -# Whether dlopen of statically linked programs is supported. -dlopen_self_static=$enable_dlopen_self_static - -# Compiler flag to prevent dynamic linking. -link_static_flag=$lt_lt_prog_compiler_static_F77 - -# Compiler flag to turn off builtin functions. -no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_F77 - -# Compiler flag to allow reflexive dlopens. -export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_F77 - -# Compiler flag to generate shared objects directly from archives. -whole_archive_flag_spec=$lt_whole_archive_flag_spec_F77 - -# Compiler flag to generate thread-safe objects. -thread_safe_flag_spec=$lt_thread_safe_flag_spec_F77 - -# Library versioning type. -version_type=$version_type - -# Format of library name prefix. -libname_spec=$lt_libname_spec - -# List of archive names. First name is the real one, the rest are links. -# The last name is the one that the linker finds with -lNAME. -library_names_spec=$lt_library_names_spec - -# The coded name of the library, if different from the real name. -soname_spec=$lt_soname_spec - -# Commands used to build and install an old-style archive. -RANLIB=$lt_RANLIB -old_archive_cmds=$lt_old_archive_cmds_F77 -old_postinstall_cmds=$lt_old_postinstall_cmds -old_postuninstall_cmds=$lt_old_postuninstall_cmds - -# Create an old-style archive from a shared archive. -old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_F77 - -# Create a temporary old-style archive to link instead of a shared archive. -old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_F77 - -# Commands used to build and install a shared archive. -archive_cmds=$lt_archive_cmds_F77 -archive_expsym_cmds=$lt_archive_expsym_cmds_F77 -postinstall_cmds=$lt_postinstall_cmds -postuninstall_cmds=$lt_postuninstall_cmds - -# Commands used to build a loadable module (assumed same as above if empty) -module_cmds=$lt_module_cmds_F77 -module_expsym_cmds=$lt_module_expsym_cmds_F77 - -# Commands to strip libraries. -old_striplib=$lt_old_striplib -striplib=$lt_striplib - -# Dependencies to place before the objects being linked to create a -# shared library. -predep_objects=$lt_predep_objects_F77 - -# Dependencies to place after the objects being linked to create a -# shared library. -postdep_objects=$lt_postdep_objects_F77 - -# Dependencies to place before the objects being linked to create a -# shared library. -predeps=$lt_predeps_F77 - -# Dependencies to place after the objects being linked to create a -# shared library. -postdeps=$lt_postdeps_F77 - -# The directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_F77 - -# The library search path used internally by the compiler when linking -# a shared library. -compiler_lib_search_path=$lt_compiler_lib_search_path_F77 - -# Method to check whether dependent libraries are shared objects. -deplibs_check_method=$lt_deplibs_check_method - -# Command to use when deplibs_check_method == file_magic. -file_magic_cmd=$lt_file_magic_cmd - -# Flag that allows shared libraries with undefined symbols to be built. -allow_undefined_flag=$lt_allow_undefined_flag_F77 - -# Flag that forces no undefined symbols. -no_undefined_flag=$lt_no_undefined_flag_F77 - -# Commands used to finish a libtool library installation in a directory. -finish_cmds=$lt_finish_cmds - -# Same as above, but a single script fragment to be evaled but not shown. -finish_eval=$lt_finish_eval - -# Take the output of nm and produce a listing of raw symbols and C names. -global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe - -# Transform the output of nm in a proper C declaration -global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl - -# Transform the output of nm in a C name address pair -global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address - -# This is the shared library runtime path variable. -runpath_var=$runpath_var - -# This is the shared library path variable. -shlibpath_var=$shlibpath_var - -# Is shlibpath searched before the hard-coded library search path? -shlibpath_overrides_runpath=$shlibpath_overrides_runpath - -# How to hardcode a shared library path into an executable. -hardcode_action=$hardcode_action_F77 - -# Whether we should hardcode library paths into libraries. -hardcode_into_libs=$hardcode_into_libs - -# Flag to hardcode \$libdir into a binary during linking. -# This must work even if \$libdir does not exist. -hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_F77 - -# If ld is used when linking, flag to hardcode \$libdir into -# a binary during linking. This must work even if \$libdir does -# not exist. -hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_F77 - -# Whether we need a single -rpath flag with a separated argument. -hardcode_libdir_separator=$lt_hardcode_libdir_separator_F77 - -# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the -# resulting binary. -hardcode_direct=$hardcode_direct_F77 - -# Set to yes if using the -LDIR flag during linking hardcodes DIR into the -# resulting binary. -hardcode_minus_L=$hardcode_minus_L_F77 - -# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into -# the resulting binary. -hardcode_shlibpath_var=$hardcode_shlibpath_var_F77 - -# Set to yes if building a shared library automatically hardcodes DIR into the library -# and all subsequent libraries and executables linked against it. -hardcode_automatic=$hardcode_automatic_F77 - -# Variables whose values should be saved in libtool wrapper scripts and -# restored at relink time. -variables_saved_for_relink="$variables_saved_for_relink" - -# Whether libtool must link a program against all its dependency libraries. -link_all_deplibs=$link_all_deplibs_F77 - -# Compile-time system search path for libraries -sys_lib_search_path_spec=$lt_sys_lib_search_path_spec - -# Run-time system search path for libraries -sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec - -# Fix the shell variable \$srcfile for the compiler. -fix_srcfile_path=$lt_fix_srcfile_path - -# Set to yes if exported symbols are required. -always_export_symbols=$always_export_symbols_F77 - -# The commands to list exported symbols. -export_symbols_cmds=$lt_export_symbols_cmds_F77 - -# The commands to extract the exported symbol list from a shared archive. -extract_expsyms_cmds=$lt_extract_expsyms_cmds - -# Symbols that should not be listed in the preloaded symbols. -exclude_expsyms=$lt_exclude_expsyms_F77 - -# Symbols that must always be exported. -include_expsyms=$lt_include_expsyms_F77 - -# ### END LIBTOOL TAG CONFIG: $tagname - -__EOF__ - - -else - # If there is no Makefile yet, we rely on a make rule to execute - # `config.status --recheck' to rerun these tests and create the - # libtool script then. - ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` - if test -f "$ltmain_in"; then - test -f Makefile && make "$ltmain" - fi -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -CC="$lt_save_CC" - - else - tagname="" - fi - ;; - - GCJ) - if test -n "$GCJ" && test "X$GCJ" != "Xno"; then - - -# Source file extension for Java test sources. -ac_ext=java - -# Object file extension for compiled Java test sources. -objext=o -objext_GCJ=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code="class foo {}" - -# Code to be used in simple link tests -lt_simple_link_test_code='public class conftest { public static void main(String argv) {}; }' - -# ltmain only uses $CC for tagged configurations so make sure $CC is set. - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# save warnings/boilerplate of simple test code -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_compiler_boilerplate=`cat conftest.err` -$rm conftest* - -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* - - -# Allow CC to be a program name with arguments. -lt_save_CC="$CC" -CC=${GCJ-"gcj"} -compiler=$CC -compiler_GCJ=$CC -for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - -# GCJ did not exist at the time GCC didn't implicitly link libc in. -archive_cmds_need_lc_GCJ=no - -old_archive_cmds_GCJ=$old_archive_cmds - - -lt_prog_compiler_no_builtin_flag_GCJ= - -if test "$GCC" = yes; then - lt_prog_compiler_no_builtin_flag_GCJ=' -fno-builtin' - - -{ echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 -echo $ECHO_N "checking if $compiler supports -fno-rtti -fno-exceptions... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_rtti_exceptions=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="-fno-rtti -fno-exceptions" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:16621: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:16625: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_rtti_exceptions=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_rtti_exceptions" >&6; } - -if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then - lt_prog_compiler_no_builtin_flag_GCJ="$lt_prog_compiler_no_builtin_flag_GCJ -fno-rtti -fno-exceptions" -else - : -fi - -fi - -lt_prog_compiler_wl_GCJ= -lt_prog_compiler_pic_GCJ= -lt_prog_compiler_static_GCJ= - -{ echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 -echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6; } - - if test "$GCC" = yes; then - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_static_GCJ='-static' - - case $host_os in - aix*) - # All AIX code is PIC. - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_GCJ='-Bstatic' - fi - ;; - - amigaos*) - # FIXME: we need at least 68020 code to build shared libraries, but - # adding the `-m68020' flag to GCC prevents building anything better, - # like `-m68040'. - lt_prog_compiler_pic_GCJ='-m68020 -resident32 -malways-restore-a4' - ;; - - beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) - # PIC is the default for these OSes. - ;; - - mingw* | cygwin* | 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). - # Although the cygwin gcc ignores -fPIC, still need this for old-style - # (--disable-auto-import) libraries - - ;; - - darwin* | rhapsody*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - lt_prog_compiler_pic_GCJ='-fno-common' - ;; - - interix3-9*) - # Interix 3.x gcc -fpic/-fPIC options generate broken code. - # Instead, we relocate shared libraries at runtime. - ;; - - msdosdjgpp*) - # Just because we use GCC doesn't mean we suddenly get shared libraries - # on systems that don't support them. - lt_prog_compiler_can_build_shared_GCJ=no - enable_shared=no - ;; - - sysv4*MP*) - if test -d /usr/nec; then - lt_prog_compiler_pic_GCJ=-Kconform_pic - fi - ;; - - hpux*) - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic_GCJ='-fPIC' - ;; - esac - ;; - - *) - lt_prog_compiler_pic_GCJ='-fPIC' - ;; - esac - else - # PORTME Check for flag to pass linker flags through the system compiler. - case $host_os in - aix*) - lt_prog_compiler_wl_GCJ='-Wl,' - if test "$host_cpu" = ia64; then - # AIX 5 now supports IA64 processor - lt_prog_compiler_static_GCJ='-Bstatic' - else - lt_prog_compiler_static_GCJ='-bnso -bI:/lib/syscalls.exp' - fi - ;; - darwin*) - # PIC is the default on this platform - # Common symbols not allowed in MH_DYLIB files - case $cc_basename in - xlc*) - lt_prog_compiler_pic_GCJ='-qnocommon' - lt_prog_compiler_wl_GCJ='-Wl,' - ;; - esac - ;; - - mingw* | cygwin* | 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). - - ;; - - hpux9* | hpux10* | hpux11*) - lt_prog_compiler_wl_GCJ='-Wl,' - # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but - # not for PA HP-UX. - case $host_cpu in - hppa*64*|ia64*) - # +Z the default - ;; - *) - lt_prog_compiler_pic_GCJ='+Z' - ;; - esac - # Is there a better lt_prog_compiler_static that works with the bundled CC? - lt_prog_compiler_static_GCJ='${wl}-a ${wl}archive' - ;; - - irix5* | irix6* | nonstopux*) - lt_prog_compiler_wl_GCJ='-Wl,' - # PIC (with -KPIC) is the default. - lt_prog_compiler_static_GCJ='-non_shared' - ;; - - newsos6) - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - - linux* | k*bsd*-gnu) - case $cc_basename in - icc* | ecc*) - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-static' - ;; - pgcc* | pgf77* | pgf90* | pgf95*) - # Portland Group compilers (*not* the Pentium gcc compiler, - # which looks to be a dead project) - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_pic_GCJ='-fpic' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - ccc*) - lt_prog_compiler_wl_GCJ='-Wl,' - # All Alpha code is PIC. - lt_prog_compiler_static_GCJ='-non_shared' - ;; - *) - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) - # Sun C 5.9 - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - lt_prog_compiler_wl_GCJ='-Wl,' - ;; - *Sun\ F*) - # Sun Fortran 8.3 passes all unrecognized flags to the linker - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - lt_prog_compiler_wl_GCJ='' - ;; - esac - ;; - esac - ;; - - osf3* | osf4* | osf5*) - lt_prog_compiler_wl_GCJ='-Wl,' - # All OSF/1 code is PIC. - lt_prog_compiler_static_GCJ='-non_shared' - ;; - - rdos*) - lt_prog_compiler_static_GCJ='-non_shared' - ;; - - solaris*) - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - case $cc_basename in - f77* | f90* | f95*) - lt_prog_compiler_wl_GCJ='-Qoption ld ';; - *) - lt_prog_compiler_wl_GCJ='-Wl,';; - esac - ;; - - sunos4*) - lt_prog_compiler_wl_GCJ='-Qoption ld ' - lt_prog_compiler_pic_GCJ='-PIC' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - - sysv4 | sysv4.2uw2* | sysv4.3*) - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - - sysv4*MP*) - if test -d /usr/nec ;then - lt_prog_compiler_pic_GCJ='-Kconform_pic' - lt_prog_compiler_static_GCJ='-Bstatic' - fi - ;; - - sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_pic_GCJ='-KPIC' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - - unicos*) - lt_prog_compiler_wl_GCJ='-Wl,' - lt_prog_compiler_can_build_shared_GCJ=no - ;; - - uts4*) - lt_prog_compiler_pic_GCJ='-pic' - lt_prog_compiler_static_GCJ='-Bstatic' - ;; - - *) - lt_prog_compiler_can_build_shared_GCJ=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_GCJ" >&5 -echo "${ECHO_T}$lt_prog_compiler_pic_GCJ" >&6; } - -# -# Check to make sure the PIC flag actually works. -# -if test -n "$lt_prog_compiler_pic_GCJ"; then - -{ echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_GCJ works" >&5 -echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_GCJ works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_pic_works_GCJ+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_pic_works_GCJ=no - ac_outfile=conftest.$ac_objext - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - lt_compiler_flag="$lt_prog_compiler_pic_GCJ" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - # The option is referenced via a variable to avoid confusing sed. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:16911: $lt_compile\"" >&5) - (eval "$lt_compile" 2>conftest.err) - ac_status=$? - cat conftest.err >&5 - echo "$as_me:16915: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s "$ac_outfile"; then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings other than the usual output. - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_pic_works_GCJ=yes - fi - fi - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works_GCJ" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_pic_works_GCJ" >&6; } - -if test x"$lt_cv_prog_compiler_pic_works_GCJ" = xyes; then - case $lt_prog_compiler_pic_GCJ in - "" | " "*) ;; - *) lt_prog_compiler_pic_GCJ=" $lt_prog_compiler_pic_GCJ" ;; - esac -else - lt_prog_compiler_pic_GCJ= - lt_prog_compiler_can_build_shared_GCJ=no -fi - -fi -case $host_os in - # For platforms which do not support PIC, -DPIC is meaningless: - *djgpp*) - lt_prog_compiler_pic_GCJ= - ;; - *) - lt_prog_compiler_pic_GCJ="$lt_prog_compiler_pic_GCJ" - ;; -esac - -# -# Check to make sure the static flag actually works. -# -wl=$lt_prog_compiler_wl_GCJ eval lt_tmp_static_flag=\"$lt_prog_compiler_static_GCJ\" -{ echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5 -echo $ECHO_N "checking if $compiler static flag $lt_tmp_static_flag works... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_static_works_GCJ+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_static_works_GCJ=no - save_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS $lt_tmp_static_flag" - echo "$lt_simple_link_test_code" > conftest.$ac_ext - if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then - # The linker can only warn and ignore the option if not recognized - # So say no if there are warnings - if test -s conftest.err; then - # Append any errors to the config.log. - cat conftest.err 1>&5 - $echo "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp - $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 - if diff conftest.exp conftest.er2 >/dev/null; then - lt_cv_prog_compiler_static_works_GCJ=yes - fi - else - lt_cv_prog_compiler_static_works_GCJ=yes - fi - fi - $rm -r conftest* - LDFLAGS="$save_LDFLAGS" - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works_GCJ" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_static_works_GCJ" >&6; } - -if test x"$lt_cv_prog_compiler_static_works_GCJ" = xyes; then - : -else - lt_prog_compiler_static_GCJ= -fi - - -{ echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 -echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6; } -if test "${lt_cv_prog_compiler_c_o_GCJ+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_prog_compiler_c_o_GCJ=no - $rm -r conftest 2>/dev/null - mkdir conftest - cd conftest - mkdir out - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - lt_compiler_flag="-o out/conftest2.$ac_objext" - # Insert the option either (1) after the last *FLAGS variable, or - # (2) before a word containing "conftest.", or (3) at the end. - # Note that $ac_compile itself does not contain backslashes and begins - # with a dollar sign (not a hyphen), so the echo should work correctly. - lt_compile=`echo "$ac_compile" | $SED \ - -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ - -e 's: ^ *conftest\.: $lt_compiler_flag&:; t' \ - -e 's:$: $lt_compiler_flag:'` - (eval echo "\"\$as_me:17015: $lt_compile\"" >&5) - (eval "$lt_compile" 2>out/conftest.err) - ac_status=$? - cat out/conftest.err >&5 - echo "$as_me:17019: \$? = $ac_status" >&5 - if (exit $ac_status) && test -s out/conftest2.$ac_objext - then - # The compiler can only warn and ignore the option if not recognized - # So say no if there are warnings - $echo "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp - $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 - if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then - lt_cv_prog_compiler_c_o_GCJ=yes - fi - fi - chmod u+w . 2>&5 - $rm conftest* - # SGI C++ compiler will create directory out/ii_files/ for - # template instantiation - test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files - $rm out/* && rmdir out - cd .. - rmdir conftest - $rm conftest* - -fi -{ echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_GCJ" >&5 -echo "${ECHO_T}$lt_cv_prog_compiler_c_o_GCJ" >&6; } - - -hard_links="nottested" -if test "$lt_cv_prog_compiler_c_o_GCJ" = no && test "$need_locks" != no; then - # do not overwrite the value of need_locks provided by the user - { echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 -echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6; } - hard_links=yes - $rm conftest* - ln conftest.a conftest.b 2>/dev/null && hard_links=no - touch conftest.a - ln conftest.a conftest.b 2>&5 || hard_links=no - ln conftest.a conftest.b 2>/dev/null && hard_links=no - { echo "$as_me:$LINENO: result: $hard_links" >&5 -echo "${ECHO_T}$hard_links" >&6; } - if test "$hard_links" = no; then - { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 -echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} - need_locks=warn - fi -else - need_locks=no -fi - -{ echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 -echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6; } - - runpath_var= - allow_undefined_flag_GCJ= - enable_shared_with_static_runtimes_GCJ=no - archive_cmds_GCJ= - archive_expsym_cmds_GCJ= - old_archive_From_new_cmds_GCJ= - old_archive_from_expsyms_cmds_GCJ= - export_dynamic_flag_spec_GCJ= - whole_archive_flag_spec_GCJ= - thread_safe_flag_spec_GCJ= - hardcode_libdir_flag_spec_GCJ= - hardcode_libdir_flag_spec_ld_GCJ= - hardcode_libdir_separator_GCJ= - hardcode_direct_GCJ=no - hardcode_minus_L_GCJ=no - hardcode_shlibpath_var_GCJ=unsupported - link_all_deplibs_GCJ=unknown - hardcode_automatic_GCJ=no - module_cmds_GCJ= - module_expsym_cmds_GCJ= - always_export_symbols_GCJ=no - export_symbols_cmds_GCJ='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' - # include_expsyms should be a list of space-separated symbols to be *always* - # included in the symbol list - include_expsyms_GCJ= - # exclude_expsyms can be an extended regexp of symbols to exclude - # it will be wrapped by ` (' and `)$', so one must not match beginning or - # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', - # as well as any symbol that contains `d'. - exclude_expsyms_GCJ='_GLOBAL_OFFSET_TABLE_|_GLOBAL__FID_.*' - # 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. - # Exclude shared library initialization/finalization symbols. - extract_expsyms_cmds= - # Just being paranoid about ensuring that cc_basename is set. - for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - - case $host_os in - cygwin* | mingw* | pw32*) - # FIXME: the MSVC++ port hasn't been tested in a loooong time - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - if test "$GCC" != yes; then - with_gnu_ld=no - fi - ;; - interix*) - # we just hope/assume this is gcc and not c89 (= MSVC++) - with_gnu_ld=yes - ;; - openbsd*) - with_gnu_ld=no - ;; - esac - - ld_shlibs_GCJ=yes - if test "$with_gnu_ld" = yes; then - # If archive_cmds runs LD, not CC, wlarc should be empty - wlarc='${wl}' - - # Set some defaults for GNU ld with shared library support. These - # are reset later if shared libraries are not supported. Putting them - # here allows them to be overridden if necessary. - runpath_var=LD_RUN_PATH - hardcode_libdir_flag_spec_GCJ='${wl}--rpath ${wl}$libdir' - export_dynamic_flag_spec_GCJ='${wl}--export-dynamic' - # ancient GNU ld didn't support --whole-archive et. al. - if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then - whole_archive_flag_spec_GCJ="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' - else - whole_archive_flag_spec_GCJ= - fi - supports_anon_versioning=no - case `$LD -v 2>/dev/null` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10.*) ;; # catch versions < 2.11 - *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... - *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... - *\ 2.11.*) ;; # other 2.11 versions - *) supports_anon_versioning=yes ;; - esac - - # See if GNU ld supports shared libraries. - case $host_os in - aix3-9*) - # On AIX/PPC, the GNU linker is very broken - if test "$host_cpu" != ia64; then - ld_shlibs_GCJ=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*) - archive_cmds_GCJ='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_minus_L_GCJ=yes - - # Samuel A. Falvo II <kc5tja@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. - ld_shlibs_GCJ=no - ;; - - beos*) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - allow_undefined_flag_GCJ=unsupported - # Joseph Beckenbach <jrb3@best.com> says some releases of gcc - # support --undefined. This deserves some investigation. FIXME - archive_cmds_GCJ='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - else - ld_shlibs_GCJ=no - fi - ;; - - cygwin* | mingw* | pw32*) - # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, GCJ) is actually meaningless, - # as there is no search path for DLLs. - hardcode_libdir_flag_spec_GCJ='-L$libdir' - allow_undefined_flag_GCJ=unsupported - always_export_symbols_GCJ=no - enable_shared_with_static_runtimes_GCJ=yes - export_symbols_cmds_GCJ='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^BCDGRS /s/.* \(^ *\)/\1 DATA/'\'' -e '\''/^AITW /s/.* //'\'' | sort | uniq > $export_symbols' - - if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - # If the export-symbols file already is a .def file (1st line - # is EXPORTS), use it as is; otherwise, prepend... - archive_expsym_cmds_GCJ='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then - cp $export_symbols $output_objdir/$soname.def; - else - echo EXPORTS > $output_objdir/$soname.def; - cat $export_symbols >> $output_objdir/$soname.def; - fi~ - $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' - else - ld_shlibs_GCJ=no - fi - ;; - - interix3-9*) - hardcode_direct_GCJ=no - hardcode_shlibpath_var_GCJ=no - hardcode_libdir_flag_spec_GCJ='${wl}-rpath,$libdir' - export_dynamic_flag_spec_GCJ='${wl}-E' - # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. - # Instead, shared libraries are loaded at an image base (0x10000000 by - # default) and relocated if they conflict, which is a slow very memory - # consuming and fragmenting process. To avoid this, we pick a random, - # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link - # time. Moving up from 0x10000000 also allows more sbrk(2) space. - archive_cmds_GCJ='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - archive_expsym_cmds_GCJ='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' - ;; - - gnu* | linux* | k*bsd*-gnu) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - tmp_addflag= - case $cc_basename,$host_cpu in - pgcc*) # Portland Group C compiler - whole_archive_flag_spec_GCJ='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag' - ;; - pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers - whole_archive_flag_spec_GCJ='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_addflag=' $pic_flag -Mnomain' ;; - ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 - tmp_addflag=' -i_dynamic' ;; - efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 - tmp_addflag=' -i_dynamic -nofor_main' ;; - ifc* | ifort*) # Intel Fortran compiler - tmp_addflag=' -nofor_main' ;; - esac - case `$CC -V 2>&1 | sed 5q` in - *Sun\ C*) # Sun C 5.9 - whole_archive_flag_spec_GCJ='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' - tmp_sharedflag='-G' ;; - *Sun\ F*) # Sun Fortran 8.3 - tmp_sharedflag='-G' ;; - *) - tmp_sharedflag='-shared' ;; - esac - archive_cmds_GCJ='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - - if test $supports_anon_versioning = yes; then - archive_expsym_cmds_GCJ='$echo "{ global:" > $output_objdir/$libname.ver~ - cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ - $echo "local: *; };" >> $output_objdir/$libname.ver~ - $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' - fi - link_all_deplibs_GCJ=no - else - ld_shlibs_GCJ=no - fi - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds_GCJ='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' - wlarc= - else - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - fi - ;; - - solaris*) - if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then - ld_shlibs_GCJ=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 - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs_GCJ=no - fi - ;; - - sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) - case `$LD -v 2>&1` in - *\ 01.* | *\ 2.0-9.* | *\ 2.10-5.*) - ld_shlibs_GCJ=no - cat <<_LT_EOF 1>&2 - -*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not -*** reliably create shared libraries on SCO systems. Therefore, libtool -*** is disabling shared libraries support. We urge you to upgrade GNU -*** binutils to release 2.16.91.0.3 or newer. Another option is to modify -*** your PATH or compiler configuration so that the native linker is -*** used, and then restart. - -_LT_EOF - ;; - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - hardcode_libdir_flag_spec_GCJ='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib' - archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname,\${SCOABSPATH:+${install_libdir}/}$soname,-retain-symbols-file,$export_symbols -o $lib' - else - ld_shlibs_GCJ=no - fi - ;; - esac - ;; - - sunos4*) - archive_cmds_GCJ='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' - wlarc= - hardcode_direct_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - *) - if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' - archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' - else - ld_shlibs_GCJ=no - fi - ;; - esac - - if test "$ld_shlibs_GCJ" = no; then - runpath_var= - hardcode_libdir_flag_spec_GCJ= - export_dynamic_flag_spec_GCJ= - whole_archive_flag_spec_GCJ= - fi - else - # PORTME fill in a description of your system's linker (not GNU ld) - case $host_os in - aix3*) - allow_undefined_flag_GCJ=unsupported - always_export_symbols_GCJ=yes - archive_expsym_cmds_GCJ='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' - # Note: this linker hardcodes the directories in LIBPATH if there - # are no directories specified by -L. - hardcode_minus_L_GCJ=yes - if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then - # Neither direct hardcoding nor static linking is supported with a - # broken collect2. - hardcode_direct_GCJ=unsupported - fi - ;; - - aix4-9*) - if test "$host_cpu" = ia64; then - # On IA64, the linker does run time linking by default, so we don't - # have to do anything special. - aix_use_runtimelinking=no - exp_sym_flag='-Bexport' - no_entry_flag="" - else - # If we're using GNU nm, then we don't want the "-C" option. - # -C means demangle to AIX nm, but means don't demangle with GNU nm - if $NM -V 2>&1 | grep 'GNU' > /dev/null; then - export_symbols_cmds_GCJ='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - else - export_symbols_cmds_GCJ='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' - fi - aix_use_runtimelinking=no - - # Test if we are trying to use run time linking or normal - # AIX style linking. If -brtl is somewhere in LDFLAGS, we - # need to do runtime linking. - case $host_os in aix4.23|aix4.23.*|aix5-9*) - for ld_flag in $LDFLAGS; do - if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then - aix_use_runtimelinking=yes - break - fi - done - ;; - esac - - exp_sym_flag='-bexport' - no_entry_flag='-bnoentry' - fi - - # When large executables or shared objects are built, AIX ld can - # have problems creating the table of contents. If linking a library - # or program results in "error TOC overflow" add -mminimal-toc to - # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not - # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. - - archive_cmds_GCJ='' - hardcode_direct_GCJ=yes - hardcode_libdir_separator_GCJ=':' - link_all_deplibs_GCJ=yes - - if test "$GCC" = yes; then - case $host_os in aix4.012|aix4.012.*) - # We only want to do this on AIX 4.2 and lower, the check - # below for broken collect2 doesn't work under 4.3+ - collect2name=`${CC} -print-prog-name=collect2` - if test -f "$collect2name" && \ - strings "$collect2name" | grep resolve_lib_name >/dev/null - then - # We have reworked collect2 - : - else - # We have old collect2 - hardcode_direct_GCJ=unsupported - # It fails to find uninstalled libraries when the uninstalled - # path is not listed in the libpath. Setting hardcode_minus_L - # to unsupported forces relinking - hardcode_minus_L_GCJ=yes - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_libdir_separator_GCJ= - fi - ;; - esac - shared_flag='-shared' - if test "$aix_use_runtimelinking" = yes; then - shared_flag="$shared_flag "'${wl}-G' - fi - else - # not using gcc - if test "$host_cpu" = ia64; then - # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release - # chokes on -Wl,-G. The following line is correct: - shared_flag='-G' - else - if test "$aix_use_runtimelinking" = yes; then - shared_flag='${wl}-G' - else - shared_flag='${wl}-bM:SRE' - fi - fi - fi - - # It seems that -bexpall does not export symbols beginning with - # underscore (_), so it is better to generate a list of symbols to export. - always_export_symbols_GCJ=yes - if test "$aix_use_runtimelinking" = yes; then - # Warning - without using the other runtime loading flags (-brtl), - # -berok will link without error, but may produce a broken library. - allow_undefined_flag_GCJ='-berok' - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_GCJ='${wl}-blibpath:$libdir:'"$aix_libpath" - archive_expsym_cmds_GCJ="\$CC"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" - else - if test "$host_cpu" = ia64; then - hardcode_libdir_flag_spec_GCJ='${wl}-R $libdir:/usr/lib:/lib' - allow_undefined_flag_GCJ="-z nodefs" - archive_expsym_cmds_GCJ="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols" - else - # Determine the default libpath from the value encoded in an empty executable. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - -lt_aix_libpath_sed=' - /Import File Strings/,/^$/ { - /^0/ { - s/^0 *\(.*\)$/\1/ - p - } - }' -aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` -# 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 "$lt_aix_libpath_sed"` -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi - - hardcode_libdir_flag_spec_GCJ='${wl}-blibpath:$libdir:'"$aix_libpath" - # Warning - without using the other run time loading flags, - # -berok will link without error, but may produce a broken library. - no_undefined_flag_GCJ=' ${wl}-bernotok' - allow_undefined_flag_GCJ=' ${wl}-berok' - # Exported symbols can be pulled into shared objects from archives - whole_archive_flag_spec_GCJ='$convenience' - archive_cmds_need_lc_GCJ=yes - # This is similar to how AIX traditionally builds its shared libraries. - archive_expsym_cmds_GCJ="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' - fi - fi - ;; - - amigaos*) - archive_cmds_GCJ='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_minus_L_GCJ=yes - # see comment about different semantics on the GNU ld section - ld_shlibs_GCJ=no - ;; - - bsdi45*) - export_dynamic_flag_spec_GCJ=-rdynamic - ;; - - cygwin* | mingw* | pw32*) - # When not using gcc, we currently assume that we are using - # Microsoft Visual C++. - # hardcode_libdir_flag_spec is actually meaningless, as there is - # no search path for DLLs. - hardcode_libdir_flag_spec_GCJ=' ' - allow_undefined_flag_GCJ=unsupported - # Tell ltmain to make .lib files, not .a files. - libext=lib - # Tell ltmain to make .dll files, not .so files. - shrext_cmds=".dll" - # FIXME: Setting linknames here is a bad hack. - archive_cmds_GCJ='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' - # The linker will automatically build a .lib file if we build a DLL. - old_archive_From_new_cmds_GCJ='true' - # FIXME: Should let the user specify the lib program. - old_archive_cmds_GCJ='lib -OUT:$oldlib$oldobjs$old_deplibs' - fix_srcfile_path_GCJ='`cygpath -w "$srcfile"`' - enable_shared_with_static_runtimes_GCJ=yes - ;; - - darwin* | rhapsody*) - case $host_os in - rhapsody* | darwin1.012) - allow_undefined_flag_GCJ='${wl}-undefined ${wl}suppress' - ;; - *) # Darwin 1.3 on - if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then - allow_undefined_flag_GCJ='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - else - case ${MACOSX_DEPLOYMENT_TARGET} in - 10.012) - allow_undefined_flag_GCJ='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' - ;; - 10.*) - allow_undefined_flag_GCJ='${wl}-undefined ${wl}dynamic_lookup' - ;; - esac - fi - ;; - esac - archive_cmds_need_lc_GCJ=no - hardcode_direct_GCJ=no - hardcode_automatic_GCJ=yes - hardcode_shlibpath_var_GCJ=unsupported - whole_archive_flag_spec_GCJ='' - link_all_deplibs_GCJ=yes - if test "$GCC" = yes ; then - output_verbose_link_cmd='echo' - archive_cmds_GCJ="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}" - module_cmds_GCJ="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}" - archive_expsym_cmds_GCJ="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}" - module_expsym_cmds_GCJ="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}" - else - case $cc_basename in - xlc*) - output_verbose_link_cmd='echo' - archive_cmds_GCJ='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $xlcverstring' - module_cmds_GCJ='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' - # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds - archive_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $xlcverstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - module_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^ *,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' - ;; - *) - ld_shlibs_GCJ=no - ;; - esac - fi - ;; - - dgux*) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_shlibpath_var_GCJ=no - ;; - - freebsd1*) - ld_shlibs_GCJ=no - ;; - - # FreeBSD 2.2.012 allows us to include c++rt0.o to get C++ constructor - # support. Future versions do this automatically, but an explicit c++rt0.o - # does not break anything, and helps significantly (at the cost of a little - # extra space). - freebsd2.2*) - archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' - hardcode_libdir_flag_spec_GCJ='-R$libdir' - hardcode_direct_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - # Unfortunately, older versions of FreeBSD 2 do not have this feature. - freebsd2*) - archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_GCJ=yes - hardcode_minus_L_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - # FreeBSD 3 and greater uses gcc -shared to do shared libraries. - freebsd* | dragonfly*) - archive_cmds_GCJ='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec_GCJ='-R$libdir' - hardcode_direct_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - hpux9*) - if test "$GCC" = yes; then - archive_cmds_GCJ='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - else - archive_cmds_GCJ='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' - fi - hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - hardcode_direct_GCJ=yes - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_GCJ=yes - export_dynamic_flag_spec_GCJ='${wl}-E' - ;; - - hpux10*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - archive_cmds_GCJ='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_GCJ='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - - hardcode_direct_GCJ=yes - export_dynamic_flag_spec_GCJ='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_GCJ=yes - fi - ;; - - hpux11*) - if test "$GCC" = yes -a "$with_gnu_ld" = no; then - case $host_cpu in - hppa*64*) - archive_cmds_GCJ='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds_GCJ='$CC -shared ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_GCJ='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - else - case $host_cpu in - hppa*64*) - archive_cmds_GCJ='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - ;; - ia64*) - archive_cmds_GCJ='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' - ;; - *) - archive_cmds_GCJ='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' - ;; - esac - fi - if test "$with_gnu_ld" = no; then - hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - - case $host_cpu in - hppa*64*|ia64*) - hardcode_libdir_flag_spec_ld_GCJ='+b $libdir' - hardcode_direct_GCJ=no - hardcode_shlibpath_var_GCJ=no - ;; - *) - hardcode_direct_GCJ=yes - export_dynamic_flag_spec_GCJ='${wl}-E' - - # hardcode_minus_L: Not really in the search PATH, - # but as the default location of the library. - hardcode_minus_L_GCJ=yes - ;; - esac - fi - ;; - - irix5* | irix6* | nonstopux*) - if test "$GCC" = yes; then - archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - archive_cmds_GCJ='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec_ld_GCJ='-rpath $libdir' - fi - hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - link_all_deplibs_GCJ=yes - ;; - - netbsd* | netbsdelf*-gnu) - if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then - archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out - else - archive_cmds_GCJ='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF - fi - hardcode_libdir_flag_spec_GCJ='-R$libdir' - hardcode_direct_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - newsos6) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_GCJ=yes - hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - hardcode_shlibpath_var_GCJ=no - ;; - - openbsd*) - if test -f /usr/libexec/ld.so; then - hardcode_direct_GCJ=yes - hardcode_shlibpath_var_GCJ=no - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - archive_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' - hardcode_libdir_flag_spec_GCJ='${wl}-rpath,$libdir' - export_dynamic_flag_spec_GCJ='${wl}-E' - else - case $host_os in - openbsd01.* | openbsd2.0-7 | openbsd2.0-7.*) - archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_GCJ='-R$libdir' - ;; - *) - archive_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' - hardcode_libdir_flag_spec_GCJ='${wl}-rpath,$libdir' - ;; - esac - fi - else - ld_shlibs_GCJ=no - fi - ;; - - os2*) - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_minus_L_GCJ=yes - allow_undefined_flag_GCJ=unsupported - archive_cmds_GCJ='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' - old_archive_From_new_cmds_GCJ='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' - ;; - - osf3*) - if test "$GCC" = yes; then - allow_undefined_flag_GCJ=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_GCJ='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - else - allow_undefined_flag_GCJ=' -expect_unresolved \*' - archive_cmds_GCJ='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - fi - hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' - hardcode_libdir_separator_GCJ=: - ;; - - osf4* | osf5*) # as osf3* with the addition of -msym flag - if test "$GCC" = yes; then - allow_undefined_flag_GCJ=' ${wl}-expect_unresolved ${wl}\*' - archive_cmds_GCJ='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' - hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' - else - allow_undefined_flag_GCJ=' -expect_unresolved \*' - archive_cmds_GCJ='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' - archive_expsym_cmds_GCJ='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ - $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' - - # Both c and cxx compiler support -rpath directly - hardcode_libdir_flag_spec_GCJ='-rpath $libdir' - fi - hardcode_libdir_separator_GCJ=: - ;; - - solaris*) - no_undefined_flag_GCJ=' -z text' - if test "$GCC" = yes; then - wlarc='${wl}' - archive_cmds_GCJ='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' - else - wlarc='' - archive_cmds_GCJ='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' - archive_expsym_cmds_GCJ='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ - $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' - fi - hardcode_libdir_flag_spec_GCJ='-R$libdir' - hardcode_shlibpath_var_GCJ=no - case $host_os in - solaris2.0-5 | solaris2.0-5.*) ;; - *) - # The compiler driver will combine and reorder linker options, - # but understands `-z linker_flag'. GCC discards it without `$wl', - # but is careful enough not to reorder. - # Supported since Solaris 2.6 (maybe 2.5.1?) - if test "$GCC" = yes; then - whole_archive_flag_spec_GCJ='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' - else - whole_archive_flag_spec_GCJ='-z allextract$convenience -z defaultextract' - fi - ;; - esac - link_all_deplibs_GCJ=yes - ;; - - sunos4*) - if test "x$host_vendor" = xsequent; then - # Use $CC to link under sequent, because it throws in some extra .o - # files that make .init and .fini sections work. - archive_cmds_GCJ='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_GCJ='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' - fi - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_direct_GCJ=yes - hardcode_minus_L_GCJ=yes - hardcode_shlibpath_var_GCJ=no - ;; - - sysv4) - case $host_vendor in - sni) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_GCJ=yes # is this really true??? - ;; - siemens) - ## LD is ld it makes a PLAMLIB - ## CC just makes a GrossModule. - archive_cmds_GCJ='$LD -G -o $lib $libobjs $deplibs $linker_flags' - reload_cmds_GCJ='$CC -r -o $output$reload_objs' - hardcode_direct_GCJ=no - ;; - motorola) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_direct_GCJ=no #Motorola manual says yes, but my tests say they lie - ;; - esac - runpath_var='LD_RUN_PATH' - hardcode_shlibpath_var_GCJ=no - ;; - - sysv4.3*) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var_GCJ=no - export_dynamic_flag_spec_GCJ='-Bexport' - ;; - - sysv4*MP*) - if test -d /usr/nec; then - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_shlibpath_var_GCJ=no - runpath_var=LD_RUN_PATH - hardcode_runpath_var=yes - ld_shlibs_GCJ=yes - fi - ;; - - sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.01.10* | unixware7* | sco3.2v5.0.024*) - no_undefined_flag_GCJ='${wl}-z,text' - archive_cmds_need_lc_GCJ=no - hardcode_shlibpath_var_GCJ=no - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds_GCJ='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_GCJ='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - sysv5* | sco3.2v5* | sco5v6*) - # Note: We can NOT use -z defs as we might desire, because we do not - # link with -lc, and that would cause any symbols used from libc to - # always be unresolved, which means just about no library would - # ever link correctly. If we're not using GNU ld we use -z text - # though, which does catch some bad symbols but isn't as heavy-handed - # as -z defs. - no_undefined_flag_GCJ='${wl}-z,text' - allow_undefined_flag_GCJ='${wl}-z,nodefs' - archive_cmds_need_lc_GCJ=no - hardcode_shlibpath_var_GCJ=no - hardcode_libdir_flag_spec_GCJ='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' - hardcode_libdir_separator_GCJ=':' - link_all_deplibs_GCJ=yes - export_dynamic_flag_spec_GCJ='${wl}-Bexport' - runpath_var='LD_RUN_PATH' - - if test "$GCC" = yes; then - archive_cmds_GCJ='$CC -shared ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - else - archive_cmds_GCJ='$CC -G ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - archive_expsym_cmds_GCJ='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,\${SCOABSPATH:+${install_libdir}/}$soname -o $lib $libobjs $deplibs $compiler_flags' - fi - ;; - - uts4*) - archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' - hardcode_libdir_flag_spec_GCJ='-L$libdir' - hardcode_shlibpath_var_GCJ=no - ;; - - *) - ld_shlibs_GCJ=no - ;; - esac - fi - -{ echo "$as_me:$LINENO: result: $ld_shlibs_GCJ" >&5 -echo "${ECHO_T}$ld_shlibs_GCJ" >&6; } -test "$ld_shlibs_GCJ" = no && can_build_shared=no - -# -# Do we need to explicitly link libc? -# -case "x$archive_cmds_need_lc_GCJ" in -x|xyes) - # Assume -lc should be added - archive_cmds_need_lc_GCJ=yes - - if test "$enable_shared" = yes && test "$GCC" = yes; then - case $archive_cmds_GCJ in - *'~'*) - # FIXME: we may have to deal with multi-command sequences. - ;; - '$CC '*) - # Test whether the compiler implicitly links with -lc since on some - # systems, -lgcc has to come before -lc. If gcc already passes -lc - # to ld, don't add -lc before -lgcc. - { echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 -echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6; } - $rm conftest* - echo "$lt_simple_compile_test_code" > conftest.$ac_ext - - if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 - (eval $ac_compile) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } 2>conftest.err; then - soname=conftest - lib=conftest - libobjs=conftest.$ac_objext - deplibs= - wl=$lt_prog_compiler_wl_GCJ - pic_flag=$lt_prog_compiler_pic_GCJ - compiler_flags=-v - linker_flags=-v - verstring= - output_objdir=. - libname=conftest - lt_save_allow_undefined_flag=$allow_undefined_flag_GCJ - allow_undefined_flag_GCJ= - if { (eval echo "$as_me:$LINENO: \"$archive_cmds_GCJ 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 - (eval $archive_cmds_GCJ 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } - then - archive_cmds_need_lc_GCJ=no - else - archive_cmds_need_lc_GCJ=yes - fi - allow_undefined_flag_GCJ=$lt_save_allow_undefined_flag - else - cat conftest.err 1>&5 - fi - $rm conftest* - { echo "$as_me:$LINENO: result: $archive_cmds_need_lc_GCJ" >&5 -echo "${ECHO_T}$archive_cmds_need_lc_GCJ" >&6; } - ;; - esac - fi - ;; -esac - -{ echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 -echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6; } -library_names_spec= -libname_spec='lib$name' -soname_spec= -shrext_cmds=".so" -postinstall_cmds= -postuninstall_cmds= -finish_cmds= -finish_eval= -shlibpath_var= -shlibpath_overrides_runpath=unknown -version_type=none -dynamic_linker="$host_os ld.so" -sys_lib_dlsearch_path_spec="/lib /usr/lib" - -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-9*) - 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 - ;; - -bsdi45*) - version_type=linux - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' - shlibpath_var=LD_LIBRARY_PATH - sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" - sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" - # the default ld.so.conf also contains /usr/contrib/lib and - # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow - # libtool to hard-code these into programs - ;; - -cygwin* | mingw* | pw32*) - version_type=windows - shrext_cmds=".dll" - need_version=no - need_lib_prefix=no - - case $GCC,$host_os in - yes,cygwin* | yes,mingw* | yes,pw32*) - library_names_spec='$libname.dll.a' - # DLL is installed to $(libdir)/../bin by postinstall_cmds - postinstall_cmds='base_file=`basename \${file}`~ - dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ - dldir=$destdir/`dirname \$dlpath`~ - test -d \$dldir || mkdir -p \$dldir~ - $install_prog $dir/$dlname \$dldir/$dlname~ - chmod a+x \$dldir/$dlname' - postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ - dlpath=$dir/\$dldll~ - $rm \$dlpath' - shlibpath_overrides_runpath=yes - - case $host_os in - cygwin*) - # Cygwin DLLs use 'cyg' prefix rather than 'lib' - soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" - ;; - mingw*) - # MinGW DLLs use traditional 'lib' prefix - soname_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` - if echo "$sys_lib_search_path_spec" | grep ';c-zC-Z:/' >/dev/null; then - # It is most probably a Windows format PATH printed by - # mingw gcc, but we are running on Cygwin. Gcc prints its search - # path with ; separators, and with drive letters. We can handle the - # drive letters (cygwin fileutils understands them), so leave them, - # especially as we might pass files found there to a mingw objdump, - # which wouldn't understand a cygwinified path. Ahh. - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` - else - sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` - fi - ;; - pw32*) - # pw32 DLLs use 'pw' prefix rather than 'lib' - library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext}' - ;; - esac - ;; - - *) - library_names_spec='${libname}`echo ${release} | $SED -e 's/./-/g'`${versuffix}${shared_ext} $libname.lib' - ;; - esac - dynamic_linker='Win32 ld.exe' - # FIXME: first we should search . and the directory the executable is in - shlibpath_var=PATH - ;; - -darwin* | rhapsody*) - dynamic_linker="$host_os dyld" - version_type=darwin - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' - soname_spec='${libname}${release}${major}$shared_ext' - shlibpath_overrides_runpath=yes - shlibpath_var=DYLD_LIBRARY_PATH - shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' - - 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 - ;; - -freebsd* | dragonfly*) - # DragonFly does not have aout. When/if they implement a new - # versioning mechanism, adjust this. - if test -x /usr/bin/objformat; then - objformat=`/usr/bin/objformat` - else - case $host_os in - freebsd123*) objformat=aout ;; - *) objformat=elf ;; - esac - fi - version_type=freebsd-$objformat - case $version_type in - freebsd-elf*) - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - need_version=no - need_lib_prefix=no - ;; - freebsd-*) - library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' - need_version=yes - ;; - esac - shlibpath_var=LD_LIBRARY_PATH - case $host_os in - freebsd2*) - shlibpath_overrides_runpath=yes - ;; - freebsd3.01* | freebsdelf3.01*) - shlibpath_overrides_runpath=yes - hardcode_into_libs=yes - ;; - freebsd3.2-9* | freebsdelf3.2-9* | \ - freebsd4.0-5 | freebsdelf4.0-5 | freebsd4.1.1 | freebsdelf4.1.1) - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - *) # from 4.6 on, and DragonFly - shlibpath_overrides_runpath=yes - 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' - ;; - -interix3-9*) - 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' - dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - ;; - -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* | k*bsd*-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' - 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>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^ *hwcap /d;s/:, / /g;s/=^=*$//;s/=^= * / /g;/^$/d' | tr '\n' ' '` - sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" - fi - - # We used to test for /lib/ld.so.1 and disable shared libraries on - # powerpc, because MkLinux only supported shared libraries with the - # GNU dynamic linker. Since this was broken with cross compilers, - # most powerpc-linux boxes support dynamic linking these days and - # people can always --disable-shared, the test was removed, and we - # assume the GNU/Linux dynamic linker is in use. - dynamic_linker='GNU/Linux ld.so' - ;; - -netbsdelf*-gnu) - version_type=linux - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - shlibpath_overrides_runpath=no - hardcode_into_libs=yes - dynamic_linker='NetBSD ld.elf_so' - ;; - -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 - sys_lib_dlsearch_path_spec="/usr/lib" - need_lib_prefix=no - # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. - case $host_os in - openbsd3.3 | openbsd3.3.*) need_version=yes ;; - *) need_version=no ;; - esac - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' - finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' - shlibpath_var=LD_LIBRARY_PATH - if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then - case $host_os in - openbsd2.89 | openbsd2.89.*) - shlibpath_overrides_runpath=no - ;; - *) - shlibpath_overrides_runpath=yes - ;; - esac - 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" - ;; - -rdos*) - dynamic_linker=no - ;; - -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.3*) - 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 - ;; - -sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) - version_type=freebsd-elf - need_lib_prefix=no - need_version=no - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - hardcode_into_libs=yes - if test "$with_gnu_ld" = yes; then - sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' - shlibpath_overrides_runpath=no - else - sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' - shlibpath_overrides_runpath=yes - case $host_os in - sco3.2v5*) - sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" - ;; - esac - fi - sys_lib_dlsearch_path_spec='/usr/lib' - ;; - -uts4*) - version_type=linux - library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' - soname_spec='${libname}${release}${shared_ext}$major' - shlibpath_var=LD_LIBRARY_PATH - ;; - -*) - dynamic_linker=no - ;; -esac -{ echo "$as_me:$LINENO: result: $dynamic_linker" >&5 -echo "${ECHO_T}$dynamic_linker" >&6; } -test "$dynamic_linker" = no && can_build_shared=no - -if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_search_path_spec="$sys_lib_search_path_spec" -fi - -sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec" -if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - lt_cv_sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec" -fi - -sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec" - -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 - -{ echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 -echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6; } -hardcode_action_GCJ= -if test -n "$hardcode_libdir_flag_spec_GCJ" || \ - test -n "$runpath_var_GCJ" || \ - test "X$hardcode_automatic_GCJ" = "Xyes" ; then - - # We can hardcode non-existant directories. - if test "$hardcode_direct_GCJ" != no && - # If the only mechanism to avoid hardcoding is shlibpath_var, we - # have to relink, otherwise we might link with an installed library - # when we should be linking with a yet-to-be-installed one - ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, GCJ)" != no && - test "$hardcode_minus_L_GCJ" != no; then - # Linking always hardcodes the temporary library directory. - hardcode_action_GCJ=relink - else - # We can link without hardcoding, and we can hardcode nonexisting dirs. - hardcode_action_GCJ=immediate - fi -else - # We cannot hardcode anything, or else we can only hardcode existing - # directories. - hardcode_action_GCJ=unsupported -fi -{ echo "$as_me:$LINENO: result: $hardcode_action_GCJ" >&5 -echo "${ECHO_T}$hardcode_action_GCJ" >&6; } - -if test "$hardcode_action_GCJ" = relink; then - # Fast installation is not supported - enable_fast_install=no -elif test "$shlibpath_overrides_runpath" = yes || - test "$enable_shared" = no; then - # Fast installation is not necessary - enable_fast_install=needless -fi - - -# 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 LTCFLAGS NM \ - SED SHELL STRIP \ - libname_spec library_names_spec soname_spec extract_expsyms_cmds \ - old_striplib striplib file_magic_cmd finish_cmds finish_eval \ - deplibs_check_method reload_flag reload_cmds need_locks \ - lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ - lt_cv_sys_global_symbol_to_c_name_address \ - sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ - old_postinstall_cmds old_postuninstall_cmds \ - compiler_GCJ \ - CC_GCJ \ - LD_GCJ \ - lt_prog_compiler_wl_GCJ \ - lt_prog_compiler_pic_GCJ \ - lt_prog_compiler_static_GCJ \ - lt_prog_compiler_no_builtin_flag_GCJ \ - export_dynamic_flag_spec_GCJ \ - thread_safe_flag_spec_GCJ \ - whole_archive_flag_spec_GCJ \ - enable_shared_with_static_runtimes_GCJ \ - old_archive_cmds_GCJ \ - old_archive_from_new_cmds_GCJ \ - predep_objects_GCJ \ - postdep_objects_GCJ \ - predeps_GCJ \ - postdeps_GCJ \ - compiler_lib_search_path_GCJ \ - compiler_lib_search_dirs_GCJ \ - archive_cmds_GCJ \ - archive_expsym_cmds_GCJ \ - postinstall_cmds_GCJ \ - postuninstall_cmds_GCJ \ - old_archive_from_expsyms_cmds_GCJ \ - allow_undefined_flag_GCJ \ - no_undefined_flag_GCJ \ - export_symbols_cmds_GCJ \ - hardcode_libdir_flag_spec_GCJ \ - hardcode_libdir_flag_spec_ld_GCJ \ - hardcode_libdir_separator_GCJ \ - hardcode_automatic_GCJ \ - module_cmds_GCJ \ - module_expsym_cmds_GCJ \ - lt_cv_prog_compiler_c_o_GCJ \ - fix_srcfile_path_GCJ \ - exclude_expsyms_GCJ \ - include_expsyms_GCJ; do - - case $var in - old_archive_cmds_GCJ | \ - old_archive_from_new_cmds_GCJ | \ - archive_cmds_GCJ | \ - archive_expsym_cmds_GCJ | \ - module_cmds_GCJ | \ - module_expsym_cmds_GCJ | \ - old_archive_from_expsyms_cmds_GCJ | \ - export_symbols_cmds_GCJ | \ - extract_expsyms_cmds | reload_cmds | finish_cmds | \ - postinstall_cmds | postuninstall_cmds | \ - old_postinstall_cmds | old_postuninstall_cmds | \ - sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) - # Double-quote double-evaled strings. - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" - ;; - *) - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" - ;; - esac - done - - case $lt_echo in - *'\$0 --fallback-echo"') - lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` - ;; - esac - -cfgfile="$ofile" - - cat <<__EOF__ >> "$cfgfile" -# ### BEGIN LIBTOOL TAG CONFIG: $tagname - -# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: - -# Shell to use when invoking shell scripts. -SHELL=$lt_SHELL - -# Whether or not to build shared libraries. -build_libtool_libs=$enable_shared - -# Whether or not to build static libraries. -build_old_libs=$enable_static - -# Whether or not to add -lc for building shared libraries. -build_libtool_need_lc=$archive_cmds_need_lc_GCJ - -# Whether or not to disallow shared libs when runtime libs are static -allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_GCJ - -# Whether or not to optimize for fast installation. -fast_install=$enable_fast_install - -# The host system. -host_alias=$host_alias -host=$host -host_os=$host_os - -# The build system. -build_alias=$build_alias -build=$build -build_os=$build_os - -# An echo program that does not interpret backslashes. -echo=$lt_echo - -# The archiver. -AR=$lt_AR -AR_FLAGS=$lt_AR_FLAGS - -# A C compiler. -LTCC=$lt_LTCC - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# A language-specific compiler. -CC=$lt_compiler_GCJ - -# Is the compiler the GNU C compiler? -with_gcc=$GCC_GCJ - -# An ERE matcher. -EGREP=$lt_EGREP - -# The linker used to build libraries. -LD=$lt_LD_GCJ - -# Whether we need hard or soft links. -LN_S=$lt_LN_S - -# A BSD-compatible nm program. -NM=$lt_NM - -# A symbol stripping program -STRIP=$lt_STRIP - -# Used to examine libraries when file_magic_cmd begins "file" -MAGIC_CMD=$MAGIC_CMD - -# Used on cygwin: DLL creation program. -DLLTOOL="$DLLTOOL" - -# Used on cygwin: object dumper. -OBJDUMP="$OBJDUMP" - -# Used on cygwin: assembler. -AS="$AS" - -# The name of the directory that contains temporary libtool files. -objdir=$objdir - -# How to create reloadable object files. -reload_flag=$lt_reload_flag -reload_cmds=$lt_reload_cmds - -# How to pass a linker flag through the compiler. -wl=$lt_lt_prog_compiler_wl_GCJ - -# Object file suffix (normally "o"). -objext="$ac_objext" - -# Old archive suffix (normally "a"). -libext="$libext" - -# Shared library suffix (normally ".so"). -shrext_cmds='$shrext_cmds' - -# Executable file suffix (normally ""). -exeext="$exeext" - -# Additional compiler flags for building library objects. -pic_flag=$lt_lt_prog_compiler_pic_GCJ -pic_mode=$pic_mode - -# What is the maximum length of a command? -max_cmd_len=$lt_cv_sys_max_cmd_len - -# Does compiler simultaneously support -c and -o options? -compiler_c_o=$lt_lt_cv_prog_compiler_c_o_GCJ - -# Must we lock files when doing compilation? -need_locks=$lt_need_locks - -# Do we need the lib prefix for modules? -need_lib_prefix=$need_lib_prefix - -# Do we need a version for libraries? -need_version=$need_version - -# Whether dlopen is supported. -dlopen_support=$enable_dlopen - -# Whether dlopen of programs is supported. -dlopen_self=$enable_dlopen_self - -# Whether dlopen of statically linked programs is supported. -dlopen_self_static=$enable_dlopen_self_static - -# Compiler flag to prevent dynamic linking. -link_static_flag=$lt_lt_prog_compiler_static_GCJ - -# Compiler flag to turn off builtin functions. -no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_GCJ - -# Compiler flag to allow reflexive dlopens. -export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_GCJ - -# Compiler flag to generate shared objects directly from archives. -whole_archive_flag_spec=$lt_whole_archive_flag_spec_GCJ - -# Compiler flag to generate thread-safe objects. -thread_safe_flag_spec=$lt_thread_safe_flag_spec_GCJ - -# Library versioning type. -version_type=$version_type - -# Format of library name prefix. -libname_spec=$lt_libname_spec - -# List of archive names. First name is the real one, the rest are links. -# The last name is the one that the linker finds with -lNAME. -library_names_spec=$lt_library_names_spec - -# The coded name of the library, if different from the real name. -soname_spec=$lt_soname_spec - -# Commands used to build and install an old-style archive. -RANLIB=$lt_RANLIB -old_archive_cmds=$lt_old_archive_cmds_GCJ -old_postinstall_cmds=$lt_old_postinstall_cmds -old_postuninstall_cmds=$lt_old_postuninstall_cmds - -# Create an old-style archive from a shared archive. -old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_GCJ - -# Create a temporary old-style archive to link instead of a shared archive. -old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_GCJ - -# Commands used to build and install a shared archive. -archive_cmds=$lt_archive_cmds_GCJ -archive_expsym_cmds=$lt_archive_expsym_cmds_GCJ -postinstall_cmds=$lt_postinstall_cmds -postuninstall_cmds=$lt_postuninstall_cmds - -# Commands used to build a loadable module (assumed same as above if empty) -module_cmds=$lt_module_cmds_GCJ -module_expsym_cmds=$lt_module_expsym_cmds_GCJ - -# Commands to strip libraries. -old_striplib=$lt_old_striplib -striplib=$lt_striplib - -# Dependencies to place before the objects being linked to create a -# shared library. -predep_objects=$lt_predep_objects_GCJ - -# Dependencies to place after the objects being linked to create a -# shared library. -postdep_objects=$lt_postdep_objects_GCJ - -# Dependencies to place before the objects being linked to create a -# shared library. -predeps=$lt_predeps_GCJ - -# Dependencies to place after the objects being linked to create a -# shared library. -postdeps=$lt_postdeps_GCJ - -# The directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_GCJ - -# The library search path used internally by the compiler when linking -# a shared library. -compiler_lib_search_path=$lt_compiler_lib_search_path_GCJ - -# Method to check whether dependent libraries are shared objects. -deplibs_check_method=$lt_deplibs_check_method - -# Command to use when deplibs_check_method == file_magic. -file_magic_cmd=$lt_file_magic_cmd - -# Flag that allows shared libraries with undefined symbols to be built. -allow_undefined_flag=$lt_allow_undefined_flag_GCJ - -# Flag that forces no undefined symbols. -no_undefined_flag=$lt_no_undefined_flag_GCJ - -# Commands used to finish a libtool library installation in a directory. -finish_cmds=$lt_finish_cmds - -# Same as above, but a single script fragment to be evaled but not shown. -finish_eval=$lt_finish_eval - -# Take the output of nm and produce a listing of raw symbols and C names. -global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe - -# Transform the output of nm in a proper C declaration -global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl - -# Transform the output of nm in a C name address pair -global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address - -# This is the shared library runtime path variable. -runpath_var=$runpath_var - -# This is the shared library path variable. -shlibpath_var=$shlibpath_var - -# Is shlibpath searched before the hard-coded library search path? -shlibpath_overrides_runpath=$shlibpath_overrides_runpath - -# How to hardcode a shared library path into an executable. -hardcode_action=$hardcode_action_GCJ - -# Whether we should hardcode library paths into libraries. -hardcode_into_libs=$hardcode_into_libs - -# Flag to hardcode \$libdir into a binary during linking. -# This must work even if \$libdir does not exist. -hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_GCJ - -# If ld is used when linking, flag to hardcode \$libdir into -# a binary during linking. This must work even if \$libdir does -# not exist. -hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_GCJ - -# Whether we need a single -rpath flag with a separated argument. -hardcode_libdir_separator=$lt_hardcode_libdir_separator_GCJ - -# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the -# resulting binary. -hardcode_direct=$hardcode_direct_GCJ - -# Set to yes if using the -LDIR flag during linking hardcodes DIR into the -# resulting binary. -hardcode_minus_L=$hardcode_minus_L_GCJ - -# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into -# the resulting binary. -hardcode_shlibpath_var=$hardcode_shlibpath_var_GCJ - -# Set to yes if building a shared library automatically hardcodes DIR into the library -# and all subsequent libraries and executables linked against it. -hardcode_automatic=$hardcode_automatic_GCJ - -# Variables whose values should be saved in libtool wrapper scripts and -# restored at relink time. -variables_saved_for_relink="$variables_saved_for_relink" - -# Whether libtool must link a program against all its dependency libraries. -link_all_deplibs=$link_all_deplibs_GCJ - -# Compile-time system search path for libraries -sys_lib_search_path_spec=$lt_sys_lib_search_path_spec - -# Run-time system search path for libraries -sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec - -# Fix the shell variable \$srcfile for the compiler. -fix_srcfile_path=$lt_fix_srcfile_path - -# Set to yes if exported symbols are required. -always_export_symbols=$always_export_symbols_GCJ - -# The commands to list exported symbols. -export_symbols_cmds=$lt_export_symbols_cmds_GCJ - -# The commands to extract the exported symbol list from a shared archive. -extract_expsyms_cmds=$lt_extract_expsyms_cmds - -# Symbols that should not be listed in the preloaded symbols. -exclude_expsyms=$lt_exclude_expsyms_GCJ - -# Symbols that must always be exported. -include_expsyms=$lt_include_expsyms_GCJ - -# ### END LIBTOOL TAG CONFIG: $tagname - -__EOF__ - - -else - # If there is no Makefile yet, we rely on a make rule to execute - # `config.status --recheck' to rerun these tests and create the - # libtool script then. - ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` - if test -f "$ltmain_in"; then - test -f Makefile && make "$ltmain" - fi -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -CC="$lt_save_CC" - - else - tagname="" - fi - ;; - - RC) - - -# Source file extension for RC test sources. -ac_ext=rc - -# Object file extension for compiled RC test sources. -objext=o -objext_RC=$objext - -# Code to be used in simple compile tests -lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' - -# Code to be used in simple link tests -lt_simple_link_test_code="$lt_simple_compile_test_code" - -# ltmain only uses $CC for tagged configurations so make sure $CC is set. - -# If no C compiler was specified, use CC. -LTCC=${LTCC-"$CC"} - -# If no C compiler flags were specified, use CFLAGS. -LTCFLAGS=${LTCFLAGS-"$CFLAGS"} - -# Allow CC to be a program name with arguments. -compiler=$CC - - -# save warnings/boilerplate of simple test code -ac_outfile=conftest.$ac_objext -echo "$lt_simple_compile_test_code" >conftest.$ac_ext -eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_compiler_boilerplate=`cat conftest.err` -$rm conftest* - -ac_outfile=conftest.$ac_objext -echo "$lt_simple_link_test_code" >conftest.$ac_ext -eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err -_lt_linker_boilerplate=`cat conftest.err` -$rm -r conftest* - - -# Allow CC to be a program name with arguments. -lt_save_CC="$CC" -CC=${RC-"windres"} -compiler=$CC -compiler_RC=$CC -for cc_temp in $compiler""; do - case $cc_temp in - compile | *\\/compile | ccache | *\\/ccache ) ;; - distcc | *\\/distcc | purify | *\\/purify ) ;; - \-*) ;; - *) break;; - esac -done -cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` - -lt_cv_prog_compiler_c_o_RC=yes - -# The else clause should only fire when bootstrapping the -# libtool distribution, otherwise you forgot to ship ltmain.sh -# with your package, and you will get complaints that there are -# no rules to generate ltmain.sh. -if test -f "$ltmain"; then - # See if we are running on zsh, and set the options which allow our commands through - # without removal of \ escapes. - if test -n "${ZSH_VERSION+set}" ; then - setopt NO_GLOB_SUBST - fi - # Now quote all the things that may contain metacharacters while being - # careful not to overquote the AC_SUBSTed values. We take copies of the - # variables and quote the copies for generation of the libtool script. - for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC LTCFLAGS NM \ - SED SHELL STRIP \ - libname_spec library_names_spec soname_spec extract_expsyms_cmds \ - old_striplib striplib file_magic_cmd finish_cmds finish_eval \ - deplibs_check_method reload_flag reload_cmds need_locks \ - lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ - lt_cv_sys_global_symbol_to_c_name_address \ - sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ - old_postinstall_cmds old_postuninstall_cmds \ - compiler_RC \ - CC_RC \ - LD_RC \ - lt_prog_compiler_wl_RC \ - lt_prog_compiler_pic_RC \ - lt_prog_compiler_static_RC \ - lt_prog_compiler_no_builtin_flag_RC \ - export_dynamic_flag_spec_RC \ - thread_safe_flag_spec_RC \ - whole_archive_flag_spec_RC \ - enable_shared_with_static_runtimes_RC \ - old_archive_cmds_RC \ - old_archive_from_new_cmds_RC \ - predep_objects_RC \ - postdep_objects_RC \ - predeps_RC \ - postdeps_RC \ - compiler_lib_search_path_RC \ - compiler_lib_search_dirs_RC \ - archive_cmds_RC \ - archive_expsym_cmds_RC \ - postinstall_cmds_RC \ - postuninstall_cmds_RC \ - old_archive_from_expsyms_cmds_RC \ - allow_undefined_flag_RC \ - no_undefined_flag_RC \ - export_symbols_cmds_RC \ - hardcode_libdir_flag_spec_RC \ - hardcode_libdir_flag_spec_ld_RC \ - hardcode_libdir_separator_RC \ - hardcode_automatic_RC \ - module_cmds_RC \ - module_expsym_cmds_RC \ - lt_cv_prog_compiler_c_o_RC \ - fix_srcfile_path_RC \ - exclude_expsyms_RC \ - include_expsyms_RC; do - - case $var in - old_archive_cmds_RC | \ - old_archive_from_new_cmds_RC | \ - archive_cmds_RC | \ - archive_expsym_cmds_RC | \ - module_cmds_RC | \ - module_expsym_cmds_RC | \ - old_archive_from_expsyms_cmds_RC | \ - export_symbols_cmds_RC | \ - extract_expsyms_cmds | reload_cmds | finish_cmds | \ - postinstall_cmds | postuninstall_cmds | \ - old_postinstall_cmds | old_postuninstall_cmds | \ - sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) - # Double-quote double-evaled strings. - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" - ;; - *) - eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" - ;; - esac - done - - case $lt_echo in - *'\$0 --fallback-echo"') - lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` - ;; - esac - -cfgfile="$ofile" - - cat <<__EOF__ >> "$cfgfile" -# ### BEGIN LIBTOOL TAG CONFIG: $tagname - -# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: - -# Shell to use when invoking shell scripts. -SHELL=$lt_SHELL - -# Whether or not to build shared libraries. -build_libtool_libs=$enable_shared - -# Whether or not to build static libraries. -build_old_libs=$enable_static - -# Whether or not to add -lc for building shared libraries. -build_libtool_need_lc=$archive_cmds_need_lc_RC - -# Whether or not to disallow shared libs when runtime libs are static -allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_RC - -# Whether or not to optimize for fast installation. -fast_install=$enable_fast_install - -# The host system. -host_alias=$host_alias -host=$host -host_os=$host_os - -# The build system. -build_alias=$build_alias -build=$build -build_os=$build_os - -# An echo program that does not interpret backslashes. -echo=$lt_echo - -# The archiver. -AR=$lt_AR -AR_FLAGS=$lt_AR_FLAGS - -# A C compiler. -LTCC=$lt_LTCC - -# LTCC compiler flags. -LTCFLAGS=$lt_LTCFLAGS - -# A language-specific compiler. -CC=$lt_compiler_RC - -# Is the compiler the GNU C compiler? -with_gcc=$GCC_RC - -# An ERE matcher. -EGREP=$lt_EGREP - -# The linker used to build libraries. -LD=$lt_LD_RC - -# Whether we need hard or soft links. -LN_S=$lt_LN_S - -# A BSD-compatible nm program. -NM=$lt_NM - -# A symbol stripping program -STRIP=$lt_STRIP - -# Used to examine libraries when file_magic_cmd begins "file" -MAGIC_CMD=$MAGIC_CMD - -# Used on cygwin: DLL creation program. -DLLTOOL="$DLLTOOL" - -# Used on cygwin: object dumper. -OBJDUMP="$OBJDUMP" - -# Used on cygwin: assembler. -AS="$AS" - -# The name of the directory that contains temporary libtool files. -objdir=$objdir - -# How to create reloadable object files. -reload_flag=$lt_reload_flag -reload_cmds=$lt_reload_cmds - -# How to pass a linker flag through the compiler. -wl=$lt_lt_prog_compiler_wl_RC - -# Object file suffix (normally "o"). -objext="$ac_objext" - -# Old archive suffix (normally "a"). -libext="$libext" - -# Shared library suffix (normally ".so"). -shrext_cmds='$shrext_cmds' - -# Executable file suffix (normally ""). -exeext="$exeext" - -# Additional compiler flags for building library objects. -pic_flag=$lt_lt_prog_compiler_pic_RC -pic_mode=$pic_mode - -# What is the maximum length of a command? -max_cmd_len=$lt_cv_sys_max_cmd_len - -# Does compiler simultaneously support -c and -o options? -compiler_c_o=$lt_lt_cv_prog_compiler_c_o_RC - -# Must we lock files when doing compilation? -need_locks=$lt_need_locks - -# Do we need the lib prefix for modules? -need_lib_prefix=$need_lib_prefix - -# Do we need a version for libraries? -need_version=$need_version - -# Whether dlopen is supported. -dlopen_support=$enable_dlopen - -# Whether dlopen of programs is supported. -dlopen_self=$enable_dlopen_self - -# Whether dlopen of statically linked programs is supported. -dlopen_self_static=$enable_dlopen_self_static - -# Compiler flag to prevent dynamic linking. -link_static_flag=$lt_lt_prog_compiler_static_RC - -# Compiler flag to turn off builtin functions. -no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_RC - -# Compiler flag to allow reflexive dlopens. -export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_RC - -# Compiler flag to generate shared objects directly from archives. -whole_archive_flag_spec=$lt_whole_archive_flag_spec_RC - -# Compiler flag to generate thread-safe objects. -thread_safe_flag_spec=$lt_thread_safe_flag_spec_RC - -# Library versioning type. -version_type=$version_type - -# Format of library name prefix. -libname_spec=$lt_libname_spec - -# List of archive names. First name is the real one, the rest are links. -# The last name is the one that the linker finds with -lNAME. -library_names_spec=$lt_library_names_spec - -# The coded name of the library, if different from the real name. -soname_spec=$lt_soname_spec - -# Commands used to build and install an old-style archive. -RANLIB=$lt_RANLIB -old_archive_cmds=$lt_old_archive_cmds_RC -old_postinstall_cmds=$lt_old_postinstall_cmds -old_postuninstall_cmds=$lt_old_postuninstall_cmds - -# Create an old-style archive from a shared archive. -old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_RC - -# Create a temporary old-style archive to link instead of a shared archive. -old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_RC - -# Commands used to build and install a shared archive. -archive_cmds=$lt_archive_cmds_RC -archive_expsym_cmds=$lt_archive_expsym_cmds_RC -postinstall_cmds=$lt_postinstall_cmds -postuninstall_cmds=$lt_postuninstall_cmds - -# Commands used to build a loadable module (assumed same as above if empty) -module_cmds=$lt_module_cmds_RC -module_expsym_cmds=$lt_module_expsym_cmds_RC - -# Commands to strip libraries. -old_striplib=$lt_old_striplib -striplib=$lt_striplib - -# Dependencies to place before the objects being linked to create a -# shared library. -predep_objects=$lt_predep_objects_RC - -# Dependencies to place after the objects being linked to create a -# shared library. -postdep_objects=$lt_postdep_objects_RC - -# Dependencies to place before the objects being linked to create a -# shared library. -predeps=$lt_predeps_RC - -# Dependencies to place after the objects being linked to create a -# shared library. -postdeps=$lt_postdeps_RC - -# The directories searched by this compiler when creating a shared -# library -compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_RC - -# The library search path used internally by the compiler when linking -# a shared library. -compiler_lib_search_path=$lt_compiler_lib_search_path_RC - -# Method to check whether dependent libraries are shared objects. -deplibs_check_method=$lt_deplibs_check_method - -# Command to use when deplibs_check_method == file_magic. -file_magic_cmd=$lt_file_magic_cmd - -# Flag that allows shared libraries with undefined symbols to be built. -allow_undefined_flag=$lt_allow_undefined_flag_RC - -# Flag that forces no undefined symbols. -no_undefined_flag=$lt_no_undefined_flag_RC - -# Commands used to finish a libtool library installation in a directory. -finish_cmds=$lt_finish_cmds - -# Same as above, but a single script fragment to be evaled but not shown. -finish_eval=$lt_finish_eval - -# Take the output of nm and produce a listing of raw symbols and C names. -global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe - -# Transform the output of nm in a proper C declaration -global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl - -# Transform the output of nm in a C name address pair -global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address - -# This is the shared library runtime path variable. -runpath_var=$runpath_var - -# This is the shared library path variable. -shlibpath_var=$shlibpath_var - -# Is shlibpath searched before the hard-coded library search path? -shlibpath_overrides_runpath=$shlibpath_overrides_runpath - -# How to hardcode a shared library path into an executable. -hardcode_action=$hardcode_action_RC - -# Whether we should hardcode library paths into libraries. -hardcode_into_libs=$hardcode_into_libs - -# Flag to hardcode \$libdir into a binary during linking. -# This must work even if \$libdir does not exist. -hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_RC - -# If ld is used when linking, flag to hardcode \$libdir into -# a binary during linking. This must work even if \$libdir does -# not exist. -hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_RC - -# Whether we need a single -rpath flag with a separated argument. -hardcode_libdir_separator=$lt_hardcode_libdir_separator_RC - -# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the -# resulting binary. -hardcode_direct=$hardcode_direct_RC - -# Set to yes if using the -LDIR flag during linking hardcodes DIR into the -# resulting binary. -hardcode_minus_L=$hardcode_minus_L_RC - -# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into -# the resulting binary. -hardcode_shlibpath_var=$hardcode_shlibpath_var_RC - -# Set to yes if building a shared library automatically hardcodes DIR into the library -# and all subsequent libraries and executables linked against it. -hardcode_automatic=$hardcode_automatic_RC - -# Variables whose values should be saved in libtool wrapper scripts and -# restored at relink time. -variables_saved_for_relink="$variables_saved_for_relink" - -# Whether libtool must link a program against all its dependency libraries. -link_all_deplibs=$link_all_deplibs_RC - -# Compile-time system search path for libraries -sys_lib_search_path_spec=$lt_sys_lib_search_path_spec - -# Run-time system search path for libraries -sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec - -# Fix the shell variable \$srcfile for the compiler. -fix_srcfile_path=$lt_fix_srcfile_path - -# Set to yes if exported symbols are required. -always_export_symbols=$always_export_symbols_RC - -# The commands to list exported symbols. -export_symbols_cmds=$lt_export_symbols_cmds_RC - -# The commands to extract the exported symbol list from a shared archive. -extract_expsyms_cmds=$lt_extract_expsyms_cmds - -# Symbols that should not be listed in the preloaded symbols. -exclude_expsyms=$lt_exclude_expsyms_RC - -# Symbols that must always be exported. -include_expsyms=$lt_include_expsyms_RC - -# ### END LIBTOOL TAG CONFIG: $tagname - -__EOF__ - - -else - # If there is no Makefile yet, we rely on a make rule to execute - # `config.status --recheck' to rerun these tests and create the - # libtool script then. - ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` - if test -f "$ltmain_in"; then - test -f Makefile && make "$ltmain" - fi -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -CC="$lt_save_CC" - - ;; - - *) - { { echo "$as_me:$LINENO: error: Unsupported tag name: $tagname" >&5 -echo "$as_me: error: Unsupported tag name: $tagname" >&2;} - { (exit 1); exit 1; }; } - ;; - esac - - # Append the new tag name to the list of available tags. - if test -n "$tagname" ; then - available_tags="$available_tags $tagname" - fi - fi - done - IFS="$lt_save_ifs" - - # Now substitute the updated list of available tags. - if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then - mv "${ofile}T" "$ofile" - chmod +x "$ofile" - else - rm -f "${ofile}T" - { { echo "$as_me:$LINENO: error: unable to update list of available tagged configurations." >&5 -echo "$as_me: error: unable to update list of available tagged configurations." >&2;} - { (exit 1); exit 1; }; } - fi -fi - - - -# This can be used to rebuild libtool when needed -LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh" - -# Always use our own libtool. -LIBTOOL='$(SHELL) $(top_builddir)/libtool' - -# Prevent multiple expansion - - - - - - - - - - - - - - - - - - - - - - - - -{ echo "$as_me:$LINENO: checking whether byte ordering is bigendian" >&5 -echo $ECHO_N "checking whether byte ordering is bigendian... $ECHO_C" >&6; } -if test "${ac_cv_c_bigendian+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - # See if sys/param.h defines the BYTE_ORDER macro. -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <sys/types.h> -#include <sys/param.h> - -int -main () -{ -#if ! (defined BYTE_ORDER && defined BIG_ENDIAN && defined LITTLE_ENDIAN \ - && BYTE_ORDER && BIG_ENDIAN && LITTLE_ENDIAN) - bogus endian macros -#endif - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - # It does; now see whether it defined to BIG_ENDIAN or not. -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <sys/types.h> -#include <sys/param.h> - -int -main () -{ -#if BYTE_ORDER != BIG_ENDIAN - not big endian -#endif - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_cv_c_bigendian=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_c_bigendian=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - # It does not; compile a test program. -if test "$cross_compiling" = yes; then - # try to guess the endianness by grepping values into an object file - ac_cv_c_bigendian=unknown - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -short int ascii_mm = { 0x4249, 0x4765, 0x6E44, 0x6961, 0x6E53, 0x7953, 0 }; -short int ascii_ii = { 0x694C, 0x5454, 0x656C, 0x6E45, 0x6944, 0x6E61, 0 }; -void _ascii () { char *s = (char *) ascii_mm; s = (char *) ascii_ii; } -short int ebcdic_ii = { 0x89D3, 0xE3E3, 0x8593, 0x95C5, 0x89C4, 0x9581, 0 }; -short int ebcdic_mm = { 0xC2C9, 0xC785, 0x95C4, 0x8981, 0x95E2, 0xA8E2, 0 }; -void _ebcdic () { char *s = (char *) ebcdic_mm; s = (char *) ebcdic_ii; } -int -main () -{ - _ascii (); _ebcdic (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - if grep BIGenDianSyS conftest.$ac_objext >/dev/null ; then - ac_cv_c_bigendian=yes -fi -if grep LiTTleEnDian conftest.$ac_objext >/dev/null ; then - if test "$ac_cv_c_bigendian" = unknown; then - ac_cv_c_bigendian=no - else - # finding both strings is unlikely to happen, but who knows? - ac_cv_c_bigendian=unknown - fi -fi -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -int -main () -{ - - /* Are we little or big endian? From Harbison&Steele. */ - union - { - long int l; - char csizeof (long int); - } u; - u.l = 1; - return u.csizeof (long int) - 1 == 1; - - ; - return 0; -} -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - ac_cv_c_bigendian=no -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -ac_cv_c_bigendian=yes -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -{ echo "$as_me:$LINENO: result: $ac_cv_c_bigendian" >&5 -echo "${ECHO_T}$ac_cv_c_bigendian" >&6; } -case $ac_cv_c_bigendian in - yes) - -cat >>confdefs.h <<\_ACEOF -#define WORDS_BIGENDIAN 1 -_ACEOF - ;; - no) - ;; - *) - { { echo "$as_me:$LINENO: error: unknown endianness -presetting ac_cv_c_bigendian=no (or yes) will help" >&5 -echo "$as_me: error: unknown endianness -presetting ac_cv_c_bigendian=no (or yes) will help" >&2;} - { (exit 1); exit 1; }; } ;; -esac - -{ echo "$as_me:$LINENO: checking host system type" >&5 -echo $ECHO_N "checking host system type... $ECHO_C" >&6; } -if test "${ac_cv_host+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test "x$host_alias" = x; then - ac_cv_host=$ac_cv_build -else - ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || - { { echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&5 -echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&2;} - { (exit 1); exit 1; }; } -fi - -fi -{ echo "$as_me:$LINENO: result: $ac_cv_host" >&5 -echo "${ECHO_T}$ac_cv_host" >&6; } -case $ac_cv_host in -*-*-*) ;; -*) { { echo "$as_me:$LINENO: error: invalid value of canonical host" >&5 -echo "$as_me: error: invalid value of canonical host" >&2;} - { (exit 1); exit 1; }; };; -esac -host=$ac_cv_host -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_host -shift -host_cpu=$1 -host_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -host_os=$* -IFS=$ac_save_IFS -case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac - - - - - -if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. -set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_path_PKG_CONFIG+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $PKG_CONFIG in - \\/* | ?:\\/*) - ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - ;; -esac -fi -PKG_CONFIG=$ac_cv_path_PKG_CONFIG -if test -n "$PKG_CONFIG"; then - { echo "$as_me:$LINENO: result: $PKG_CONFIG" >&5 -echo "${ECHO_T}$PKG_CONFIG" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_path_PKG_CONFIG"; then - ac_pt_PKG_CONFIG=$PKG_CONFIG - # Extract the first word of "pkg-config", so it can be a program name with args. -set dummy pkg-config; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $ac_pt_PKG_CONFIG in - \\/* | ?:\\/*) - ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - ;; -esac -fi -ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG -if test -n "$ac_pt_PKG_CONFIG"; then - { echo "$as_me:$LINENO: result: $ac_pt_PKG_CONFIG" >&5 -echo "${ECHO_T}$ac_pt_PKG_CONFIG" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_pt_PKG_CONFIG" = x; then - PKG_CONFIG="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - PKG_CONFIG=$ac_pt_PKG_CONFIG - fi -else - PKG_CONFIG="$ac_cv_path_PKG_CONFIG" -fi - -fi -if test -n "$PKG_CONFIG"; then - _pkg_min_version=0.9.0 - { echo "$as_me:$LINENO: checking pkg-config is at least version $_pkg_min_version" >&5 -echo $ECHO_N "checking pkg-config is at least version $_pkg_min_version... $ECHO_C" >&6; } - if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - PKG_CONFIG="" - fi - -fi - -########################################################################### -# General Checks - - - -if test $cross_compiling = yes; then - CROSS_COMPILING_TRUE= - CROSS_COMPILING_FALSE='#' -else - CROSS_COMPILING_TRUE='#' - CROSS_COMPILING_FALSE= -fi - - -{ echo "$as_me:$LINENO: checking whether x86 architecture" >&5 -echo $ECHO_N "checking whether x86 architecture... $ECHO_C" >&6; } -def_arch_x86=0 -case $host_cpu in - "i386" | "i486" | "i586" | "i686" | "i786" | "x86_64") - echo "yes" - def_arch_x86=1;; - *) - echo "no";; -esac - -cat >>confdefs.h <<_ACEOF -#define ARCH_X86 $def_arch_x86 -_ACEOF - - -# determine the right gcc switch for CPU specific optimizations -# (only if the user did not provide one) -CXX_CPU_SWITCH= -if ! echo "X $CXXFLAGS " | grep -q -- " \(-march=\|-mcpu=\|-mtune=\|-arch=\)" ; then - if test "$def_arch_x86" = 1 -a "$host_cpu" != "x86_64"; then - CXX_CPU_SWITCH="-march=$host_cpu" - elif test "$target_cpu" = "ppc"; then - CXX_CPU_SWITCH="-arch=$host_cpu" - fi -fi - - -# check if we're on MS Windows - -for ac_header in mmsystem.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <windef.h> - - -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - eval "$as_ac_Header=yes" -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - eval "$as_ac_Header=no" -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - have_windows=1 -else - have_windows=0 -fi - -done - - - -if test $have_windows = "1"; then - HAVE_WINDOWS_TRUE= - HAVE_WINDOWS_FALSE='#' -else - HAVE_WINDOWS_TRUE='#' - HAVE_WINDOWS_FALSE= -fi - - -{ echo "$as_me:$LINENO: checking whether UNIX98 compatible" >&5 -echo $ECHO_N "checking whether UNIX98 compatible... $ECHO_C" >&6; } - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -if test "$cross_compiling" = yes; then - have_unix98="no" - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -#ifndef _GNU_SOURCE -#define _GNU_SOURCE 1 -#endif -#include <features.h> -void main(void) { -#if _XOPEN_SOURCE >= 500 -exit(0); /* UNIX98 compatible */ -#else -exit(-1); /* not UNIX98 compatible */ -#endif -} - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - have_unix98="yes" -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -have_unix98="no" -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -{ echo "$as_me:$LINENO: result: $have_unix98" >&5 -echo "${ECHO_T}$have_unix98" >&6; } -if test "$have_unix98" = "no" -a "have_windows" = "0"; then - if test "x$HAVE_UNIX98" = "x"; then - echo "LinuxSampler only runs on UNIX98 compatible systems, which is mandatory for" - echo "pthread_mutexattr_settype() call in Mutex.cpp. You may want to run - echo "./configure with environment variable HAVE_UNIX98=1 in case you think you - echo "have a UNIX98 compatible system." - exit -1; - fi -fi - -# check for <features.h> - -for ac_header in features.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - - -# test for POSIX thread library - - - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - -acx_pthread_ok=no - -# We used to check for pthread.h first, but this fails if pthread.h -# requires special compiler flags (e.g. on True64 or Sequent). -# It gets checked for in the link test anyway. - -# First of all, check if the user has set any of the PTHREAD_LIBS, -# etcetera environment variables, and if threads linking works using -# them: -if test x"$PTHREAD_LIBS$PTHREAD_CFLAGS" != x; then - save_CFLAGS="$CFLAGS" - CFLAGS="$CFLAGS $PTHREAD_CFLAGS" - save_LIBS="$LIBS" - LIBS="$PTHREAD_LIBS $LIBS" - { echo "$as_me:$LINENO: checking for pthread_join in LIBS=$PTHREAD_LIBS with CFLAGS=$PTHREAD_CFLAGS" >&5 -echo $ECHO_N "checking for pthread_join in LIBS=$PTHREAD_LIBS with CFLAGS=$PTHREAD_CFLAGS... $ECHO_C" >&6; } - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char pthread_join (); -int -main () -{ -return pthread_join (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - acx_pthread_ok=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - { echo "$as_me:$LINENO: result: $acx_pthread_ok" >&5 -echo "${ECHO_T}$acx_pthread_ok" >&6; } - if test x"$acx_pthread_ok" = xno; then - PTHREAD_LIBS="" - PTHREAD_CFLAGS="" - fi - LIBS="$save_LIBS" - CFLAGS="$save_CFLAGS" -fi - -# We must check for the threads library under a number of different -# names; the ordering is very important because some systems -# (e.g. DEC) have both -lpthread and -lpthreads, where one of the -# libraries is broken (non-POSIX). - -# Create a list of thread flags to try. Items starting with a "-" are -# C compiler flags, and other items are library names, except for "none" -# which indicates that we try without any flags at all, and "pthread-config" -# which is a program returning the flags for the Pth emulation library. - -acx_pthread_flags="pthreads none -Kthread -kthread lthread -pthread -pthreads -mthreads pthread --thread-safe -mt pthread-config" - -# The ordering *is* (sometimes) important. Some notes on the -# individual items follow: - -# pthreads: AIX (must check this before -lpthread) -# none: in case threads are in libc; should be tried before -Kthread and -# other compiler flags to prevent continual compiler warnings -# -Kthread: Sequent (threads in libc, but -Kthread needed for pthread.h) -# -kthread: FreeBSD kernel threads (preferred to -pthread since SMP-able) -# lthread: LinuxThreads port on FreeBSD (also preferred to -pthread) -# -pthread: Linux/gcc (kernel threads), BSD/gcc (userland threads) -# -pthreads: Solaris/gcc -# -mthreads: Mingw32/gcc, Lynx/gcc -# -mt: Sun Workshop C (may only link SunOS threads -lthread, but it -# doesn't hurt to check since this sometimes defines pthreads too; -# also defines -D_REENTRANT) -# ... -mt is also the pthreads flag for HP/aCC -# pthread: Linux, etcetera -# --thread-safe: KAI C++ -# pthread-config: use pthread-config program (for GNU Pth library) - -case "${host_cpu}-${host_os}" in - *solaris*) - - # On Solaris (at least, for some versions), libc contains stubbed - # (non-functional) versions of the pthreads routines, so link-based - # tests will erroneously succeed. (We need to link with -pthreads/-mt/ - # -lpthread.) (The stubs are missing pthread_cleanup_push, or rather - # a function called by this macro, so we could check for that, but - # who knows whether they'll stub that too in a future libc.) So, - # we'll just look for -pthreads and -lpthread first: - - acx_pthread_flags="-pthreads pthread -mt -pthread $acx_pthread_flags" - ;; -esac - -if test x"$acx_pthread_ok" = xno; then -for flag in $acx_pthread_flags; do - - case $flag in - none) - { echo "$as_me:$LINENO: checking whether pthreads work without any flags" >&5 -echo $ECHO_N "checking whether pthreads work without any flags... $ECHO_C" >&6; } - ;; - - -*) - { echo "$as_me:$LINENO: checking whether pthreads work with $flag" >&5 -echo $ECHO_N "checking whether pthreads work with $flag... $ECHO_C" >&6; } - PTHREAD_CFLAGS="$flag" - ;; - - pthread-config) - # Extract the first word of "pthread-config", so it can be a program name with args. -set dummy pthread-config; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_acx_pthread_config+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$acx_pthread_config"; then - ac_cv_prog_acx_pthread_config="$acx_pthread_config" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_acx_pthread_config="yes" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - test -z "$ac_cv_prog_acx_pthread_config" && ac_cv_prog_acx_pthread_config="no" -fi -fi -acx_pthread_config=$ac_cv_prog_acx_pthread_config -if test -n "$acx_pthread_config"; then - { echo "$as_me:$LINENO: result: $acx_pthread_config" >&5 -echo "${ECHO_T}$acx_pthread_config" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - if test x"$acx_pthread_config" = xno; then continue; fi - PTHREAD_CFLAGS="`pthread-config --cflags`" - PTHREAD_LIBS="`pthread-config --ldflags` `pthread-config --libs`" - ;; - - *) - { echo "$as_me:$LINENO: checking for the pthreads library -l$flag" >&5 -echo $ECHO_N "checking for the pthreads library -l$flag... $ECHO_C" >&6; } - PTHREAD_LIBS="-l$flag" - ;; - esac - - save_LIBS="$LIBS" - save_CFLAGS="$CFLAGS" - LIBS="$PTHREAD_LIBS $LIBS" - CFLAGS="$CFLAGS $PTHREAD_CFLAGS" - - # Check for various functions. We must include pthread.h, - # since some functions may be macros. (On the Sequent, we - # need a special flag -Kthread to make this header compile.) - # We check for pthread_join because it is in -lpthread on IRIX - # while pthread_create is in libc. We check for pthread_attr_init - # due to DEC craziness with -lpthreads. We check for - # pthread_cleanup_push because it is one of the few pthread - # functions on Solaris that doesn't have a non-functional libc stub. - # We try pthread_create on general principles. - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <pthread.h> -int -main () -{ -pthread_t th; pthread_join(th, 0); - pthread_attr_init(0); pthread_cleanup_push(0, 0); - pthread_create(0,0,0,0); pthread_cleanup_pop(0); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - acx_pthread_ok=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - - LIBS="$save_LIBS" - CFLAGS="$save_CFLAGS" - - { echo "$as_me:$LINENO: result: $acx_pthread_ok" >&5 -echo "${ECHO_T}$acx_pthread_ok" >&6; } - if test "x$acx_pthread_ok" = xyes; then - break; - fi - - PTHREAD_LIBS="" - PTHREAD_CFLAGS="" -done -fi - -# Various other checks: -if test "x$acx_pthread_ok" = xyes; then - save_LIBS="$LIBS" - LIBS="$PTHREAD_LIBS $LIBS" - save_CFLAGS="$CFLAGS" - CFLAGS="$CFLAGS $PTHREAD_CFLAGS" - - # Detect AIX lossage: JOINABLE attribute is called UNDETACHED. - { echo "$as_me:$LINENO: checking for joinable pthread attribute" >&5 -echo $ECHO_N "checking for joinable pthread attribute... $ECHO_C" >&6; } - attr_name=unknown - for attr in PTHREAD_CREATE_JOINABLE PTHREAD_CREATE_UNDETACHED; do - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <pthread.h> -int -main () -{ -int attr=$attr; return attr; - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - attr_name=$attr; break -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - done - { echo "$as_me:$LINENO: result: $attr_name" >&5 -echo "${ECHO_T}$attr_name" >&6; } - if test "$attr_name" != PTHREAD_CREATE_JOINABLE; then - -cat >>confdefs.h <<_ACEOF -#define PTHREAD_CREATE_JOINABLE $attr_name -_ACEOF - - fi - - { echo "$as_me:$LINENO: checking if more special flags are required for pthreads" >&5 -echo $ECHO_N "checking if more special flags are required for pthreads... $ECHO_C" >&6; } - flag=no - case "${host_cpu}-${host_os}" in - *-aix* | *-freebsd* | *-darwin*) flag="-D_THREAD_SAFE";; - *solaris* | *-osf* | *-hpux*) flag="-D_REENTRANT";; - esac - { echo "$as_me:$LINENO: result: ${flag}" >&5 -echo "${ECHO_T}${flag}" >&6; } - if test "x$flag" != xno; then - PTHREAD_CFLAGS="$flag $PTHREAD_CFLAGS" - fi - - LIBS="$save_LIBS" - CFLAGS="$save_CFLAGS" - - # More AIX lossage: must compile with xlc_r or cc_r - if test x"$GCC" != xyes; then - for ac_prog in xlc_r cc_r -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_PTHREAD_CC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$PTHREAD_CC"; then - ac_cv_prog_PTHREAD_CC="$PTHREAD_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_PTHREAD_CC="$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -PTHREAD_CC=$ac_cv_prog_PTHREAD_CC -if test -n "$PTHREAD_CC"; then - { echo "$as_me:$LINENO: result: $PTHREAD_CC" >&5 -echo "${ECHO_T}$PTHREAD_CC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$PTHREAD_CC" && break -done -test -n "$PTHREAD_CC" || PTHREAD_CC="${CC}" - - else - PTHREAD_CC=$CC - fi -else - PTHREAD_CC="$CC" -fi - - - - - -# Finally, execute ACTION-IF-FOUND/ACTION-IF-NOT-FOUND: -if test x"$acx_pthread_ok" = xyes; then - -cat >>confdefs.h <<\_ACEOF -#define HAVE_PTHREAD 1 -_ACEOF - - : -else - acx_pthread_ok=no - -fi -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -LIBS="$PTHREAD_LIBS $LIBS" -CFLAGS="$CFLAGS $PTHREAD_CFLAGS" -CXXFLAGS="$CXXFLAGS $PTHREAD_CFLAGS" -CC="$PTHREAD_CC" - -# check for a bug in NPTL-enabled glibc -# (see Gentoo bug report #194076) -# Check whether --enable-nptl-bug-check was given. -if test "${enable_nptl_bug_check+set}" = set; then - enableval=$enable_nptl_bug_check; config_check_nptl_bug="$enableval" -else - config_check_nptl_bug="yes" - -fi - -if test "$config_check_nptl_bug" = "yes"; then - - - - { echo "$as_me:$LINENO: checking for NPTL bug" >&5 -echo $ECHO_N "checking for NPTL bug... $ECHO_C" >&6; } - - - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - if test "$cross_compiling" = yes; then - - { echo "$as_me:$LINENO: result: disabled" >&5 -echo "${ECHO_T}disabled" >&6; } - : - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - -#include <stdlib.h> - -#if WIN32 - -int main() { - exit(0); -} - -#else /* POSIX system */ - -#include <stdio.h> -#include <pthread.h> -#include <unistd.h> - -pthread_attr_t __thread_attr; -pthread_t __thread_id; - -pthread_mutex_t __posix_mutex; -pthread_mutexattr_t __posix_mutexattr; - -/// entry point for the spawned thread -void* __pthread_launcher(void* p) { - // let the thread be killable under any circumstances - // (without this function call, this test always succeeds !) - pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL); - - // this will block this 2nd thread, since we already - // locked this mutex by the main thread - pthread_mutex_lock(&__posix_mutex); - - // here we would access shared resources, etc. - - // just pro forma, the remainder of this function is actually not of - // interest, since this thread is always terminated at its mutex lock call - pthread_mutex_unlock(&__posix_mutex); - return NULL; -} - -int main() { - - // initialize mutex and thread attribute - pthread_mutexattr_init(&__posix_mutexattr); - pthread_mutex_init(&__posix_mutex, &__posix_mutexattr); - pthread_attr_init(&__thread_attr); - - // already lock the mutex by the main thread ... - pthread_mutex_lock(&__posix_mutex); - - int res; - - // create and run a 2nd thread - res = pthread_create(&__thread_id, &__thread_attr, __pthread_launcher, NULL); - if (res) { - exit(-1); - } - - // give the other thread a chance to spawn - usleep(400000); - - // kill the other thread - pthread_cancel(__thread_id); - pthread_detach(__thread_id); - - // give the other thread a chance to finish its execution - usleep(400000); - - // cleanup - // (just pro forma, doesnt actually matter for this test case) - pthread_attr_destroy(&__thread_attr); - pthread_mutex_destroy(&__posix_mutex); - pthread_mutexattr_destroy(&__posix_mutexattr); - - exit(0); -} -#endif /* WIN32 */ - - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - : - -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) - - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - - echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" - echo "You seem to have a buggy PTHREAD library! LinuxSampler would" - echo "probably crash due to this. Please report us the system you are" - echo "using and/or file a bug report to the bug tracking system of" - echo "your distribution." - echo "If you have a NPTL-enabled glibc AND it was compiled for TLS as" - echo "well, you can try to circumvent this problem for now by setting" - echo "the environment variable LD_ASSUME_KERNEL=\"2.4.1\" , which" - echo "should cause this test to pass." - echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!" - { { echo "$as_me:$LINENO: error: possibly NPTL glibc bug detected" >&5 -echo "$as_me: error: possibly NPTL glibc bug detected" >&2;} - { (exit 1); exit 1; }; } - - -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -else - echo "NPTL glibc bug check disabled" -fi - -# FIXME: this is actually a dependency of libgig, not of LS directly, why -# isn't it hidden by libgig? - -for ac_header in uuid/uuid.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - -{ echo "$as_me:$LINENO: checking for library containing uuid_generate" >&5 -echo $ECHO_N "checking for library containing uuid_generate... $ECHO_C" >&6; } -if test "${ac_cv_search_uuid_generate+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_func_search_save_LIBS=$LIBS -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char uuid_generate (); -int -main () -{ -return uuid_generate (); - ; - return 0; -} -_ACEOF -for ac_lib in '' uuid; do - if test -z "$ac_lib"; then - ac_res="none required" - else - ac_res=-l$ac_lib - LIBS="-l$ac_lib $ac_func_search_save_LIBS" - fi - rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_search_uuid_generate=$ac_res -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext - if test "${ac_cv_search_uuid_generate+set}" = set; then - break -fi -done -if test "${ac_cv_search_uuid_generate+set}" = set; then - : -else - ac_cv_search_uuid_generate=no -fi -rm conftest.$ac_ext -LIBS=$ac_func_search_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_search_uuid_generate" >&5 -echo "${ECHO_T}$ac_cv_search_uuid_generate" >&6; } -ac_res=$ac_cv_search_uuid_generate -if test "$ac_res" != no; then - test "$ac_res" = "none required" || LIBS="$ac_res $LIBS" - -fi - - - - -########################################################################### -# Checks for available audio and MIDI systems / drivers -# (we throw an error if there's not at least one system for audio output and MIDI input available) - -have_midi_input_driver="false" -have_audio_output_driver="false" - -# ALSA -# Check whether --enable-alsa-driver was given. -if test "${enable_alsa_driver+set}" = set; then - enableval=$enable_alsa_driver; config_alsa_driver="$enableval" -else - config_alsa_driver="yes" - -fi - -have_alsa=0 -if test "$config_alsa_driver" = "yes"; then - if test "${ac_cv_header_alsa_asoundlib_h+set}" = set; then - { echo "$as_me:$LINENO: checking for alsa/asoundlib.h" >&5 -echo $ECHO_N "checking for alsa/asoundlib.h... $ECHO_C" >&6; } -if test "${ac_cv_header_alsa_asoundlib_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_alsa_asoundlib_h" >&5 -echo "${ECHO_T}$ac_cv_header_alsa_asoundlib_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking alsa/asoundlib.h usability" >&5 -echo $ECHO_N "checking alsa/asoundlib.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <alsa/asoundlib.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking alsa/asoundlib.h presence" >&5 -echo $ECHO_N "checking alsa/asoundlib.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <alsa/asoundlib.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: alsa/asoundlib.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: alsa/asoundlib.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for alsa/asoundlib.h" >&5 -echo $ECHO_N "checking for alsa/asoundlib.h... $ECHO_C" >&6; } -if test "${ac_cv_header_alsa_asoundlib_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_alsa_asoundlib_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_alsa_asoundlib_h" >&5 -echo "${ECHO_T}$ac_cv_header_alsa_asoundlib_h" >&6; } - -fi -if test $ac_cv_header_alsa_asoundlib_h = yes; then - { echo "$as_me:$LINENO: checking for main in -lasound" >&5 -echo $ECHO_N "checking for main in -lasound... $ECHO_C" >&6; } -if test "${ac_cv_lib_asound_main+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-lasound $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - -int -main () -{ -return main (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_asound_main=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_asound_main=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_asound_main" >&5 -echo "${ECHO_T}$ac_cv_lib_asound_main" >&6; } -if test $ac_cv_lib_asound_main = yes; then - have_alsa=1 - -else - have_alsa=0 - -fi - - -else - have_alsa=0 - -fi - - - if test "$have_alsa" = "1"; then - have_midi_input_driver="true" - have_audio_output_driver="true"; - fi - - echo -n "checking Alsa version... " - - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - if test "$cross_compiling" = yes; then - alsa_major=0 - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - #include <alsa/asoundlib.h> - void main(void) { - /* ensure backward compatibility */ - #if !defined(SND_LIB_MAJOR) && defined(SOUNDLIB_VERSION_MAJOR) - #define SND_LIB_MAJOR SOUNDLIB_VERSION_MAJOR - #endif - exit(SND_LIB_MAJOR); - } - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - alsa_major=0 -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -alsa_major=$? -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - if test "$cross_compiling" = yes; then - alsa_minor=0 - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - #include <alsa/asoundlib.h> - void main(void) { - /* ensure backward compatibility */ - #if !defined(SND_LIB_MINOR) && defined(SOUNDLIB_VERSION_MINOR) - #define SND_LIB_MINOR SOUNDLIB_VERSION_MINOR - #endif - exit(SND_LIB_MINOR); - } - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - alsa_minor=0 -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -alsa_minor=$? -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - if test "$cross_compiling" = yes; then - alsa_subminor=0 - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - #include <alsa/asoundlib.h> - void main(void) { - /* ensure backward compatibility */ - #if !defined(SND_LIB_SUBMINOR) && defined(SOUNDLIB_VERSION_SUBMINOR) - #define SND_LIB_SUBMINOR SOUNDLIB_VERSION_SUBMINOR - #endif - exit(SND_LIB_SUBMINOR); - } - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - alsa_subminor=0 -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -alsa_subminor=$? -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - echo "$alsa_major.$alsa_minor.$alsa_subminor"; - -cat >>confdefs.h <<_ACEOF -#define ALSA_MAJOR $alsa_major -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define ALSA_MINOR $alsa_minor -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define ALSA_SUBMINOR $alsa_subminor -_ACEOF - -else - echo "ALSA support disabled by configure script parameter" -fi - - -if test $have_alsa = "1"; then - HAVE_ALSA_TRUE= - HAVE_ALSA_FALSE='#' -else - HAVE_ALSA_TRUE='#' - HAVE_ALSA_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_ALSA $have_alsa -_ACEOF - -config_have_alsa="no" -if test $have_alsa = "1"; then - config_have_alsa="yes" -fi - -# JACK -# Check whether --enable-jack-driver was given. -if test "${enable_jack_driver+set}" = set; then - enableval=$enable_jack_driver; config_jack_driver="$enableval" -else - config_jack_driver="yes" - -fi - -have_jack=0 -if test "$config_jack_driver" = "yes"; then - -pkg_failed=no -{ echo "$as_me:$LINENO: checking for JACK" >&5 -echo $ECHO_N "checking for JACK... $ECHO_C" >&6; } - -if test -n "$PKG_CONFIG"; then - if test -n "$JACK_CFLAGS"; then - pkg_cv_JACK_CFLAGS="$JACK_CFLAGS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"jack\"") >&5 - ($PKG_CONFIG --exists --print-errors "jack") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_JACK_CFLAGS=`$PKG_CONFIG --cflags "jack" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi -if test -n "$PKG_CONFIG"; then - if test -n "$JACK_LIBS"; then - pkg_cv_JACK_LIBS="$JACK_LIBS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"jack\"") >&5 - ($PKG_CONFIG --exists --print-errors "jack") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_JACK_LIBS=`$PKG_CONFIG --libs "jack" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi - - - -if test $pkg_failed = yes; then - -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fi - if test $_pkg_short_errors_supported = yes; then - JACK_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "jack"` - else - JACK_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "jack"` - fi - # Put the nasty error message in config.log where it belongs - echo "$JACK_PKG_ERRORS" >&5 - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - have_jack=0 -elif test $pkg_failed = untried; then - have_jack=0 -else - JACK_CFLAGS=$pkg_cv_JACK_CFLAGS - JACK_LIBS=$pkg_cv_JACK_LIBS - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - have_jack=1 -fi - if test $have_jack = "1"; then - - - linuxsampler_save_LIBS=$LIBS - LIBS="$JACK_LIBS $LIBS" - - -for ac_func in jack_client_name_size jack_client_open -do -as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -{ echo "$as_me:$LINENO: checking for $ac_func" >&5 -echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6; } -if { as_var=$as_ac_var; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -/* Define $ac_func to an innocuous variant, in case <limits.h> declares $ac_func. - For example, HP-UX 11i <limits.h> declares gettimeofday. */ -#define $ac_func innocuous_$ac_func - -/* System header to define __stub macros and hopefully few prototypes, - which can conflict with char $ac_func (); below. - Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - <limits.h> exists even on freestanding compilers. */ - -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - -#undef $ac_func - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char $ac_func (); -/* The GNU C library defines this for functions which it implements - to always fail with ENOSYS. Some functions are actually named - something starting with __ and the normal name is an alias. */ -#if defined __stub_$ac_func || defined __stub___$ac_func -choke me -#endif - -int -main () -{ -return $ac_func (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - eval "$as_ac_var=yes" -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - eval "$as_ac_var=no" -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -fi -ac_res=`eval echo '${'$as_ac_var'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -if test `eval echo '${'$as_ac_var'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -_ACEOF - -fi -done - - LIBS=$linuxsampler_save_LIBS - have_audio_output_driver="true"; - fi -else - echo "JACK support disabled by configure script parameter" -fi - - -if test $have_jack = "1"; then - HAVE_JACK_TRUE= - HAVE_JACK_FALSE='#' -else - HAVE_JACK_TRUE='#' - HAVE_JACK_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_JACK $have_jack -_ACEOF - -config_have_jack="no" -if test $have_jack = "1"; then - config_have_jack="yes" -fi - -# JACK MIDI -have_jack_midi=0 -if test $have_jack = "1"; then - linuxsampler_save_CFLAGS=$CFLAGS - linuxsampler_save_LIBS=$LIBS - CFLAGS="$JACK_CFLAGS $CFLAGS" - LIBS="$JACK_LIBS $LIBS" - if test "${ac_cv_header_jack_midiport_h+set}" = set; then - { echo "$as_me:$LINENO: checking for jack/midiport.h" >&5 -echo $ECHO_N "checking for jack/midiport.h... $ECHO_C" >&6; } -if test "${ac_cv_header_jack_midiport_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_jack_midiport_h" >&5 -echo "${ECHO_T}$ac_cv_header_jack_midiport_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking jack/midiport.h usability" >&5 -echo $ECHO_N "checking jack/midiport.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <jack/midiport.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking jack/midiport.h presence" >&5 -echo $ECHO_N "checking jack/midiport.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <jack/midiport.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: jack/midiport.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: jack/midiport.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: jack/midiport.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: jack/midiport.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: jack/midiport.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: jack/midiport.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: jack/midiport.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: jack/midiport.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: jack/midiport.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for jack/midiport.h" >&5 -echo $ECHO_N "checking for jack/midiport.h... $ECHO_C" >&6; } -if test "${ac_cv_header_jack_midiport_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_jack_midiport_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_jack_midiport_h" >&5 -echo "${ECHO_T}$ac_cv_header_jack_midiport_h" >&6; } - -fi -if test $ac_cv_header_jack_midiport_h = yes; then - have_jack_midi=1 -else - have_jack_midi=0 -fi - - - if test $have_jack_midi = "1"; then - -for ac_func in jack_midi_get_event_count -do -as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -{ echo "$as_me:$LINENO: checking for $ac_func" >&5 -echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6; } -if { as_var=$as_ac_var; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -/* Define $ac_func to an innocuous variant, in case <limits.h> declares $ac_func. - For example, HP-UX 11i <limits.h> declares gettimeofday. */ -#define $ac_func innocuous_$ac_func - -/* System header to define __stub macros and hopefully few prototypes, - which can conflict with char $ac_func (); below. - Prefer <limits.h> to <assert.h> if __STDC__ is defined, since - <limits.h> exists even on freestanding compilers. */ - -#ifdef __STDC__ -# include <limits.h> -#else -# include <assert.h> -#endif - -#undef $ac_func - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char $ac_func (); -/* The GNU C library defines this for functions which it implements - to always fail with ENOSYS. Some functions are actually named - something starting with __ and the normal name is an alias. */ -#if defined __stub_$ac_func || defined __stub___$ac_func -choke me -#endif - -int -main () -{ -return $ac_func (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - eval "$as_ac_var=yes" -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - eval "$as_ac_var=no" -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -fi -ac_res=`eval echo '${'$as_ac_var'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -if test `eval echo '${'$as_ac_var'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -_ACEOF - -fi -done - - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <jack/midiport.h> -int -main () -{ - - jack_midi_clear_buffer(0, 0); - - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - -cat >>confdefs.h <<\_ACEOF -#define JACK_MIDI_FUNCS_NEED_NFRAMES 1 -_ACEOF - -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - have_midi_input_driver="true" - fi - CFLAGS=$linuxsampler_save_CFLAGS - LIBS=$linuxsampler_save_LIBS -fi - - -if test $have_jack_midi = "1"; then - HAVE_JACK_MIDI_TRUE= - HAVE_JACK_MIDI_FALSE='#' -else - HAVE_JACK_MIDI_TRUE='#' - HAVE_JACK_MIDI_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_JACK_MIDI $have_jack_midi -_ACEOF - -config_have_jack_midi="no" -if test $have_jack_midi = "1"; then - config_have_jack_midi="yes" -fi - -# ARTS -# Check whether --enable-arts-driver was given. -if test "${enable_arts_driver+set}" = set; then - enableval=$enable_arts_driver; config_arts_driver="$enableval" -else - config_arts_driver="yes" - -fi - -have_arts=0 -if test "$config_arts_driver" = "yes"; then - - -# Check whether --with-arts-prefix was given. -if test "${with_arts_prefix+set}" = set; then - withval=$with_arts_prefix; arts_prefix="$withval" -else - arts_prefix="" -fi - -# Check whether --enable-artstest was given. -if test "${enable_artstest+set}" = set; then - enableval=$enable_artstest; enable_artstest=$enableval -else - enable_artstest=yes -fi - - - if test x$arts_prefix != x ; then - arts_args="$arts_args --arts-prefix=$arts_prefix" - if test x${ARTS_CONFIG+set} != xset ; then - ARTS_CONFIG=$arts_prefix/bin/artsc-config - fi - fi - - - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}artsc-config", so it can be a program name with args. -set dummy ${ac_tool_prefix}artsc-config; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_path_ARTS_CONFIG+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $ARTS_CONFIG in - \\/* | ?:\\/*) - ac_cv_path_ARTS_CONFIG="$ARTS_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_ARTS_CONFIG="$as_dir/$ac_word$ac_exec_ext" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - ;; -esac -fi -ARTS_CONFIG=$ac_cv_path_ARTS_CONFIG -if test -n "$ARTS_CONFIG"; then - { echo "$as_me:$LINENO: result: $ARTS_CONFIG" >&5 -echo "${ECHO_T}$ARTS_CONFIG" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_path_ARTS_CONFIG"; then - ac_pt_ARTS_CONFIG=$ARTS_CONFIG - # Extract the first word of "artsc-config", so it can be a program name with args. -set dummy artsc-config; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_path_ac_pt_ARTS_CONFIG+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $ac_pt_ARTS_CONFIG in - \\/* | ?:\\/*) - ac_cv_path_ac_pt_ARTS_CONFIG="$ac_pt_ARTS_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_ac_pt_ARTS_CONFIG="$as_dir/$ac_word$ac_exec_ext" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - ;; -esac -fi -ac_pt_ARTS_CONFIG=$ac_cv_path_ac_pt_ARTS_CONFIG -if test -n "$ac_pt_ARTS_CONFIG"; then - { echo "$as_me:$LINENO: result: $ac_pt_ARTS_CONFIG" >&5 -echo "${ECHO_T}$ac_pt_ARTS_CONFIG" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_pt_ARTS_CONFIG" = x; then - ARTS_CONFIG="no" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - ARTS_CONFIG=$ac_pt_ARTS_CONFIG - fi -else - ARTS_CONFIG="$ac_cv_path_ARTS_CONFIG" -fi - - - min_arts_version=0.9.5 - { echo "$as_me:$LINENO: checking for ARTS artsc - version >= $min_arts_version" >&5 -echo $ECHO_N "checking for ARTS artsc - version >= $min_arts_version... $ECHO_C" >&6; } - no_arts="" - if test "$ARTS_CONFIG" = "no" ; then - no_arts=yes - else - ARTS_CFLAGS=`$ARTS_CONFIG $artsconf_args --cflags` - ARTS_LIBS=`$ARTS_CONFIG $artsconf_args --libs` - - arts_major_version=`$ARTS_CONFIG $arts_args --version | \ - sed 's/\(0-9*\).\(0-9*\).\(0-9*\)/\1/'` - arts_minor_version=`$ARTS_CONFIG $arts_args --version | \ - sed 's/\(0-9*\).\(0-9*\).\(0-9*\)/\2/'` - arts_micro_version=`$ARTS_CONFIG $arts_config_args --version | \ - sed 's/\(0-9*\).\(0-9*\).\(0-9*\)/\3/'` - if test "x$enable_artstest" = "xyes" ; then - ac_save_CFLAGS="$CFLAGS" - ac_save_LIBS="$LIBS" - CFLAGS="$CFLAGS $ARTS_CFLAGS" - LIBS="$LIBS $ARTS_LIBS" - -{ echo "$as_me:$LINENO: checking for arts_init in -lartsc" >&5 -echo $ECHO_N "checking for arts_init in -lartsc... $ECHO_C" >&6; } -if test "${ac_cv_lib_artsc_arts_init+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-lartsc $ARTS_LIBS $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char arts_init (); -int -main () -{ -return arts_init (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_artsc_arts_init=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_artsc_arts_init=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_artsc_arts_init" >&5 -echo "${ECHO_T}$ac_cv_lib_artsc_arts_init" >&6; } -if test $ac_cv_lib_artsc_arts_init = yes; then - cat >>confdefs.h <<_ACEOF -#define HAVE_LIBARTSC 1 -_ACEOF - - LIBS="-lartsc $LIBS" - -else - no_arts=yes -fi - - - rm -f conf.artstest - if test "$cross_compiling" = yes; then - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -#include <stdio.h> -#include <artsc.h> - -int -main () -{ - return 0; - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - : -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - no_arts=yes -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <artsc.h> - -char* -my_strdup (char *str) -{ - char *new_str; - - if (str) - { - new_str = malloc ((strlen (str) + 1) * sizeof(char)); - strcpy (new_str, str); - } - else - new_str = NULL; - - return new_str; -} - -int main () -{ - int major, minor, micro; - char *tmp_version; - - system ("touch conf.artstest"); - - /* HP/UX 9 (%@#!) writes to sscanf strings */ - tmp_version = my_strdup("$min_arts_version"); - if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, µ) != 3) { - printf("%s, bad version string\n", "$min_arts_version"); - exit(1); - } - - if (($arts_major_version > major) || - (($arts_major_version == major) && ($arts_minor_version > minor)) || - (($arts_major_version == major) && ($arts_minor_version == minor) && ($arts_micro_version >= micro))) - { - return 0; - } - else - { - printf("\n*** 'artsc-config --version' returned %d.%d.%d, but the minimum version\n", $arts_major_version, $arts_minor_version, $arts_micro_version); - printf("*** of ARTS required is %d.%d.%d. If artsc-config is correct, then it is\n", major, minor, micro); - printf("*** best to upgrade to the required version.\n"); - printf("*** If artsc-config was wrong, set the environment variable ARTS_CONFIG\n"); - printf("*** to point to the correct copy of artsc-config, and remove the file\n"); - printf("*** config.cache before re-running configure\n"); - return 1; - } -} - - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - : -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -no_arts=yes -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - CFLAGS="$ac_save_CFLAGS" - LIBS="$ac_save_LIBS" - fi - fi - if test "x$no_arts" = x ; then - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - have_arts=1 - else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - if test "$ARTS_CONFIG" = "no" ; then - echo "*** The artsc-config script installed by ARTS could not be found" - echo "*** If ARTS was installed in PREFIX, make sure PREFIX/bin is in" - echo "*** your path, or set the ARTS_CONFIG environment variable to the" - echo "*** full path to artsc-config." - else - if test -f conf.artstest ; then - : - else - echo "*** Could not run ARTS test program, checking why..." - CFLAGS="$CFLAGS $ARTS_CFLAGS" - LIBS="$LIBS $ARTS_LIBS" - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -#include <stdio.h> -#include <artsc.h> - -int -main () -{ - return 0; - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - echo "*** The test program compiled, but did not run. This usually means" - echo "*** that the run-time linker is not finding ARTS or finding the wrong" - echo "*** version of ARTS. If it is not finding ARTS, you'll need to set your" - echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point" - echo "*** to the installed location Also, make sure you have run ldconfig if that" - echo "*** is required on your system" - echo "***" - echo "*** If you have an old version installed, it is best to remove it, although" - echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - echo "*** The test program failed to compile or link. See the file config.log for the" - echo "*** exact error that occured. This usually means ARTS was incorrectly installed" - echo "*** or that you have moved ARTS since it was installed. In the latter case, you" - echo "*** may want to edit the artsc-config script: $ARTS_CONFIG" -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext - CFLAGS="$ac_save_CFLAGS" - LIBS="$ac_save_LIBS" - fi - fi - ARTS_CFLAGS="" - ARTS_LIBS="" - have_arts=0 - fi - - - rm -f conf.artstest - ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - if test "$have_arts" = "1"; then - have_audio_output_driver="true" - fi -else - echo "ARTS support disabled by configure script parameter" -fi - - -if test "$have_arts" = "1"; then - HAVE_ARTS_TRUE= - HAVE_ARTS_FALSE='#' -else - HAVE_ARTS_TRUE='#' - HAVE_ARTS_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_ARTS $have_arts -_ACEOF - -config_have_arts="no" -if test $have_arts = "1"; then - config_have_arts="yes" -fi - -# ASIO AUDIO (Win32) -# Check whether --enable-asiosdk-dir was given. -if test "${enable_asiosdk_dir+set}" = set; then - enableval=$enable_asiosdk_dir; config_asiosdk_dir="${enableval}" -else - config_asiosdk_dir="." - -fi - - - -# Check whether --enable-asio-driver was given. -if test "${enable_asio_driver+set}" = set; then - enableval=$enable_asio_driver; config_asio_driver="$enableval" -else - config_asio_driver="yes" - -fi - -have_asio=0 -ASIOSDK_BASEDIR= -if test "$config_asio_driver" = "yes"; then - asiosdk_headerfile=$config_asiosdk_dir/ASIOSDK2/common/asio.h - echo -n "checking for ASIO headerfile: $asiosdk_headerfile ...." - if test -e $asiosdk_headerfile ; then - echo yes - have_asio=1 - ASIOSDK_BASEDIR="$config_asiosdk_dir" - else - echo no - have_asio=0 - fi - if test "$have_asio" = "1"; then - have_audio_output_driver="true" - fi -else - echo "Windows ASIO support disabled by configure script parameter" -fi - - - -if test $have_asio = "1"; then - HAVE_ASIO_TRUE= - HAVE_ASIO_FALSE='#' -else - HAVE_ASIO_TRUE='#' - HAVE_ASIO_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_ASIO $have_asio -_ACEOF - -config_have_asio="no" -if test $have_asio = "1"; then - config_have_asio="yes" -fi - -# MidiShare (Linux, OS X, Windows) -# Check whether --enable-midishare-driver was given. -if test "${enable_midishare_driver+set}" = set; then - enableval=$enable_midishare_driver; config_midishare_driver="$enableval" -else - config_midishare_driver="yes" - -fi - -have_midishare=0 -if test "$config_midishare_driver" = "yes"; then - if test "${ac_cv_header_MidiShare_h+set}" = set; then - { echo "$as_me:$LINENO: checking for MidiShare.h" >&5 -echo $ECHO_N "checking for MidiShare.h... $ECHO_C" >&6; } -if test "${ac_cv_header_MidiShare_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_MidiShare_h" >&5 -echo "${ECHO_T}$ac_cv_header_MidiShare_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking MidiShare.h usability" >&5 -echo $ECHO_N "checking MidiShare.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <MidiShare.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking MidiShare.h presence" >&5 -echo $ECHO_N "checking MidiShare.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <MidiShare.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: MidiShare.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: MidiShare.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: MidiShare.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: MidiShare.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: MidiShare.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: MidiShare.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: MidiShare.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: MidiShare.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: MidiShare.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: MidiShare.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: MidiShare.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for MidiShare.h" >&5 -echo $ECHO_N "checking for MidiShare.h... $ECHO_C" >&6; } -if test "${ac_cv_header_MidiShare_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_MidiShare_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_MidiShare_h" >&5 -echo "${ECHO_T}$ac_cv_header_MidiShare_h" >&6; } - -fi -if test $ac_cv_header_MidiShare_h = yes; then - { echo "$as_me:$LINENO: checking for MidiCountEvs in -lMidiShare" >&5 -echo $ECHO_N "checking for MidiCountEvs in -lMidiShare... $ECHO_C" >&6; } -if test "${ac_cv_lib_MidiShare_MidiCountEvs+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-lMidiShare $LIBS" -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char MidiCountEvs (); -int -main () -{ -return MidiCountEvs (); - ; - return 0; -} -_ACEOF -rm -f conftest.$ac_objext conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && - $as_test_x conftest$ac_exeext; then - ac_cv_lib_MidiShare_MidiCountEvs=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_cv_lib_MidiShare_MidiCountEvs=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ echo "$as_me:$LINENO: result: $ac_cv_lib_MidiShare_MidiCountEvs" >&5 -echo "${ECHO_T}$ac_cv_lib_MidiShare_MidiCountEvs" >&6; } -if test $ac_cv_lib_MidiShare_MidiCountEvs = yes; then - have_midishare=1 -else - have_midishare=0 - -fi - - -else - have_midishare=0 - -fi - - - if test "$have_midishare" = "1"; then - have_midi_input_driver="true" - fi -else - echo "MidiShare support disabled by configure script parameter" -fi - - -if test $have_midishare = "1"; then - HAVE_MIDISHARE_TRUE= - HAVE_MIDISHARE_FALSE='#' -else - HAVE_MIDISHARE_TRUE='#' - HAVE_MIDISHARE_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_MIDISHARE $have_midishare -_ACEOF - -config_have_midishare="no" -if test $have_midishare = "1"; then - config_have_midishare="yes" -fi - -# CoreMIDI (OS X) -# Check whether --enable-coremidi-driver was given. -if test "${enable_coremidi_driver+set}" = set; then - enableval=$enable_coremidi_driver; config_coremidi_driver="$enableval" -else - config_coremidi_driver="yes" - -fi - -have_coremidi=0 -if test "$config_coremidi_driver" = "yes"; then - if test "${ac_cv_header_CoreMIDI_CoreMIDI_h+set}" = set; then - { echo "$as_me:$LINENO: checking for CoreMIDI/CoreMIDI.h" >&5 -echo $ECHO_N "checking for CoreMIDI/CoreMIDI.h... $ECHO_C" >&6; } -if test "${ac_cv_header_CoreMIDI_CoreMIDI_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_CoreMIDI_CoreMIDI_h" >&5 -echo "${ECHO_T}$ac_cv_header_CoreMIDI_CoreMIDI_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking CoreMIDI/CoreMIDI.h usability" >&5 -echo $ECHO_N "checking CoreMIDI/CoreMIDI.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <CoreMIDI/CoreMIDI.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking CoreMIDI/CoreMIDI.h presence" >&5 -echo $ECHO_N "checking CoreMIDI/CoreMIDI.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <CoreMIDI/CoreMIDI.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreMIDI/CoreMIDI.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: CoreMIDI/CoreMIDI.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for CoreMIDI/CoreMIDI.h" >&5 -echo $ECHO_N "checking for CoreMIDI/CoreMIDI.h... $ECHO_C" >&6; } -if test "${ac_cv_header_CoreMIDI_CoreMIDI_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_CoreMIDI_CoreMIDI_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_CoreMIDI_CoreMIDI_h" >&5 -echo "${ECHO_T}$ac_cv_header_CoreMIDI_CoreMIDI_h" >&6; } - -fi -if test $ac_cv_header_CoreMIDI_CoreMIDI_h = yes; then - have_coremidi=1 -else - have_coremidi=0 - -fi - - - if test "$have_coremidi" = "1"; then - have_midi_input_driver="true" - fi -else - echo "CoreMIDI support disabled by configure script parameter" -fi - - -if test $have_coremidi = "1"; then - HAVE_COREMIDI_TRUE= - HAVE_COREMIDI_FALSE='#' -else - HAVE_COREMIDI_TRUE='#' - HAVE_COREMIDI_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_COREMIDI $have_coremidi -_ACEOF - -config_have_coremidi="no" -if test $have_coremidi = "1"; then - config_have_coremidi="yes" -fi - -# CoreAudio (OS X) -# Check whether --enable-coreaudio-driver was given. -if test "${enable_coreaudio_driver+set}" = set; then - enableval=$enable_coreaudio_driver; config_coreaudio_driver="$enableval" -else - config_coreaudio_driver="yes" - -fi - -have_coreaudio=0 -if test "$config_coreaudio_driver" = "yes"; then - if test "${ac_cv_header_CoreAudio_CoreAudio_h+set}" = set; then - { echo "$as_me:$LINENO: checking for CoreAudio/CoreAudio.h" >&5 -echo $ECHO_N "checking for CoreAudio/CoreAudio.h... $ECHO_C" >&6; } -if test "${ac_cv_header_CoreAudio_CoreAudio_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_CoreAudio_CoreAudio_h" >&5 -echo "${ECHO_T}$ac_cv_header_CoreAudio_CoreAudio_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking CoreAudio/CoreAudio.h usability" >&5 -echo $ECHO_N "checking CoreAudio/CoreAudio.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <CoreAudio/CoreAudio.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking CoreAudio/CoreAudio.h presence" >&5 -echo $ECHO_N "checking CoreAudio/CoreAudio.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <CoreAudio/CoreAudio.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: CoreAudio/CoreAudio.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: CoreAudio/CoreAudio.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for CoreAudio/CoreAudio.h" >&5 -echo $ECHO_N "checking for CoreAudio/CoreAudio.h... $ECHO_C" >&6; } -if test "${ac_cv_header_CoreAudio_CoreAudio_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_CoreAudio_CoreAudio_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_CoreAudio_CoreAudio_h" >&5 -echo "${ECHO_T}$ac_cv_header_CoreAudio_CoreAudio_h" >&6; } - -fi -if test $ac_cv_header_CoreAudio_CoreAudio_h = yes; then - have_coreaudio=1 -else - have_coreaudio=0 - -fi - - - if test "$have_coreaudio" = "1"; then - have_audio_output_driver="true" - fi -else - echo "CoreAudio support disabled by configure script parameter" -fi - - -if test $have_coreaudio = "1"; then - HAVE_COREAUDIO_TRUE= - HAVE_COREAUDIO_FALSE='#' -else - HAVE_COREAUDIO_TRUE='#' - HAVE_COREAUDIO_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_COREAUDIO $have_coreaudio -_ACEOF - -config_have_coreaudio="no" -if test $have_coreaudio = "1"; then - config_have_coreaudio="yes" -fi - -# MME MIDI (Win32) -# Check whether --enable-mmemidi-driver was given. -if test "${enable_mmemidi_driver+set}" = set; then - enableval=$enable_mmemidi_driver; config_mmemidi_driver="$enableval" -else - config_mmemidi_driver="yes" - -fi - -have_mmemidi=0 -if test "$config_mmemidi_driver" = "yes"; then - -for ac_header in mmsystem.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - have_mmemidi=1 -else - have_mmemidi=0 - -fi - -done - - if test "$have_mmemidi" = "1"; then - have_midi_input_driver="true" - fi -else - echo "MME MIDI support disabled by configure script parameter" -fi - - -if test $have_mmemidi = "1"; then - HAVE_MME_MIDI_TRUE= - HAVE_MME_MIDI_FALSE='#' -else - HAVE_MME_MIDI_TRUE='#' - HAVE_MME_MIDI_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_MME_MIDI $have_mmemidi -_ACEOF - -config_have_mme="no" -if test $have_mmemidi = "1"; then - config_have_mme="yes" -fi - -# DSSI - -for ac_header in dssi.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - config_have_dssi="yes" -else - config_have_dssi="no" -fi - -done - - - -if test $config_have_dssi = "yes"; then - HAVE_DSSI_TRUE= - HAVE_DSSI_FALSE='#' -else - HAVE_DSSI_TRUE='#' - HAVE_DSSI_FALSE= -fi - - -# LV2 - -pkg_failed=no -{ echo "$as_me:$LINENO: checking for LV2" >&5 -echo $ECHO_N "checking for LV2... $ECHO_C" >&6; } - -if test -n "$PKG_CONFIG"; then - if test -n "$LV2_CFLAGS"; then - pkg_cv_LV2_CFLAGS="$LV2_CFLAGS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"lv2core\"") >&5 - ($PKG_CONFIG --exists --print-errors "lv2core") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_LV2_CFLAGS=`$PKG_CONFIG --cflags "lv2core" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi -if test -n "$PKG_CONFIG"; then - if test -n "$LV2_LIBS"; then - pkg_cv_LV2_LIBS="$LV2_LIBS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"lv2core\"") >&5 - ($PKG_CONFIG --exists --print-errors "lv2core") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_LV2_LIBS=`$PKG_CONFIG --libs "lv2core" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi - - - -if test $pkg_failed = yes; then - -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fi - if test $_pkg_short_errors_supported = yes; then - LV2_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "lv2core"` - else - LV2_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "lv2core"` - fi - # Put the nasty error message in config.log where it belongs - echo "$LV2_PKG_ERRORS" >&5 - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - config_have_lv2="no" -elif test $pkg_failed = untried; then - config_have_lv2="no" -else - LV2_CFLAGS=$pkg_cv_LV2_CFLAGS - LV2_LIBS=$pkg_cv_LV2_LIBS - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - config_have_lv2="yes" -fi -if test $config_have_lv2 = "no"; then - if test "${ac_cv_header_lv2_h+set}" = set; then - { echo "$as_me:$LINENO: checking for lv2.h" >&5 -echo $ECHO_N "checking for lv2.h... $ECHO_C" >&6; } -if test "${ac_cv_header_lv2_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_lv2_h" >&5 -echo "${ECHO_T}$ac_cv_header_lv2_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking lv2.h usability" >&5 -echo $ECHO_N "checking lv2.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <lv2.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking lv2.h presence" >&5 -echo $ECHO_N "checking lv2.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <lv2.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: lv2.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: lv2.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: lv2.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: lv2.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: lv2.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: lv2.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: lv2.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: lv2.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: lv2.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: lv2.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: lv2.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for lv2.h" >&5 -echo $ECHO_N "checking for lv2.h... $ECHO_C" >&6; } -if test "${ac_cv_header_lv2_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_lv2_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_lv2_h" >&5 -echo "${ECHO_T}$ac_cv_header_lv2_h" >&6; } - -fi -if test $ac_cv_header_lv2_h = yes; then - config_have_lv2="yes" -else - config_have_lv2="no" -fi - - -fi - - -if test $config_have_lv2 = "yes"; then - HAVE_LV2_TRUE= - HAVE_LV2_FALSE='#' -else - HAVE_LV2_TRUE='#' - HAVE_LV2_FALSE= -fi - - -# VST -# Check whether --enable-vstsdk-dir was given. -if test "${enable_vstsdk_dir+set}" = set; then - enableval=$enable_vstsdk_dir; VSTSDK_DIR="${enableval}" -else - VSTSDK_DIR= - -fi - - - - -if test "x$VSTSDK_DIR" != "x"; then - HAVE_VST_TRUE= - HAVE_VST_FALSE='#' -else - HAVE_VST_TRUE='#' - HAVE_VST_FALSE= -fi - -config_have_vst="no" -if test "x$VSTSDK_DIR" != "x"; then - config_have_vst="yes" -fi - -# AU - -for ac_header in AudioUnit/AudioUnit.h -do -as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - { echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking $ac_header usability" >&5 -echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <$ac_header> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking $ac_header presence" >&5 -echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <$ac_header> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for $ac_header" >&5 -echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6; } -if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - eval "$as_ac_Header=\$ac_header_preproc" -fi -ac_res=`eval echo '${'$as_ac_Header'}'` - { echo "$as_me:$LINENO: result: $ac_res" >&5 -echo "${ECHO_T}$ac_res" >&6; } - -fi -if test `eval echo '${'$as_ac_Header'}'` = yes; then - cat >>confdefs.h <<_ACEOF -#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - config_have_au="yes" -else - config_have_au="no" -fi - -done - - - -if test $config_have_au = "yes"; then - HAVE_AU_TRUE= - HAVE_AU_FALSE='#' -else - HAVE_AU_TRUE='#' - HAVE_AU_FALSE= -fi - - - -if test "$AUFLAGS" != ""; then - HAVE_AUFLAGS_TRUE= - HAVE_AUFLAGS_FALSE='#' -else - HAVE_AUFLAGS_TRUE='#' - HAVE_AUFLAGS_FALSE= -fi - - - -# have we found at least one MIDI input and one audio output driver ? -if test "$have_midi_input_driver" = "false"; then - echo "No supported MIDI input system found!" - echo "Sorry, LinuxSampler only supports the following MIDI drivers at the moment:" - echo "ALSA, JACK, MIDIShare, CoreMIDI, MME." - echo "If you think you have one of those available on your system, make sure you" - echo "also have the respective development (header) files installed." - exit -1; -fi -if test "$have_audio_output_driver" = "false"; then - echo "No supported audio output system found!" - echo "Sorry, LinuxSampler only supports ALSA, JACK, ARTS and ASIO as audio output" - echo "driver at the moment!" - exit -1; -fi - - - -########################################################################### -# Checks for various DLL libraries - -# Check presence of libgig -libgig_version="3.3.0" - -pkg_failed=no -{ echo "$as_me:$LINENO: checking for GIG" >&5 -echo $ECHO_N "checking for GIG... $ECHO_C" >&6; } - -if test -n "$PKG_CONFIG"; then - if test -n "$GIG_CFLAGS"; then - pkg_cv_GIG_CFLAGS="$GIG_CFLAGS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"gig >= \$libgig_version\"") >&5 - ($PKG_CONFIG --exists --print-errors "gig >= $libgig_version") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_GIG_CFLAGS=`$PKG_CONFIG --cflags "gig >= $libgig_version" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi -if test -n "$PKG_CONFIG"; then - if test -n "$GIG_LIBS"; then - pkg_cv_GIG_LIBS="$GIG_LIBS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"gig >= \$libgig_version\"") >&5 - ($PKG_CONFIG --exists --print-errors "gig >= $libgig_version") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_GIG_LIBS=`$PKG_CONFIG --libs "gig >= $libgig_version" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi - - - -if test $pkg_failed = yes; then - -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fi - if test $_pkg_short_errors_supported = yes; then - GIG_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "gig >= $libgig_version"` - else - GIG_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "gig >= $libgig_version"` - fi - # Put the nasty error message in config.log where it belongs - echo "$GIG_PKG_ERRORS" >&5 - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - HAVE_GIG=false -elif test $pkg_failed = untried; then - HAVE_GIG=false -else - GIG_CFLAGS=$pkg_cv_GIG_CFLAGS - GIG_LIBS=$pkg_cv_GIG_LIBS - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - HAVE_GIG=true -fi -if test "$HAVE_GIG" = "false"; then - echo "Required libgig version not found!" - echo "You need to have libgig version ${libgig_version} installed!" - exit -1; -else - echo "yes, found libgig $libgig_version" -fi - - - -# Instruments DB feature (requires SQLite 3.3) -# Check whether --enable-instruments-db was given. -if test "${enable_instruments_db+set}" = set; then - enableval=$enable_instruments_db; config_instruments_db="$enableval" -else - config_instruments_db="yes" - -fi - -HAVE_SQLITE3=0; -if test "$config_instruments_db" = "yes"; then - # Check presence of sqlite3 - sqlite_version="3.3" - -pkg_failed=no -{ echo "$as_me:$LINENO: checking for SQLITE3" >&5 -echo $ECHO_N "checking for SQLITE3... $ECHO_C" >&6; } - -if test -n "$PKG_CONFIG"; then - if test -n "$SQLITE3_CFLAGS"; then - pkg_cv_SQLITE3_CFLAGS="$SQLITE3_CFLAGS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"sqlite3 >= \$sqlite_version\"") >&5 - ($PKG_CONFIG --exists --print-errors "sqlite3 >= $sqlite_version") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_SQLITE3_CFLAGS=`$PKG_CONFIG --cflags "sqlite3 >= $sqlite_version" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi -if test -n "$PKG_CONFIG"; then - if test -n "$SQLITE3_LIBS"; then - pkg_cv_SQLITE3_LIBS="$SQLITE3_LIBS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"sqlite3 >= \$sqlite_version\"") >&5 - ($PKG_CONFIG --exists --print-errors "sqlite3 >= $sqlite_version") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_SQLITE3_LIBS=`$PKG_CONFIG --libs "sqlite3 >= $sqlite_version" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi - - - -if test $pkg_failed = yes; then - -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fi - if test $_pkg_short_errors_supported = yes; then - SQLITE3_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "sqlite3 >= $sqlite_version"` - else - SQLITE3_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "sqlite3 >= $sqlite_version"` - fi - # Put the nasty error message in config.log where it belongs - echo "$SQLITE3_PKG_ERRORS" >&5 - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - HAVE_SQLITE3=false -elif test $pkg_failed = untried; then - HAVE_SQLITE3=false -else - SQLITE3_CFLAGS=$pkg_cv_SQLITE3_CFLAGS - SQLITE3_LIBS=$pkg_cv_SQLITE3_LIBS - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - HAVE_SQLITE3=true -fi - - - if test $HAVE_SQLITE3 = false; then - HAVE_SQLITE3=0 - config_instruments_db="no" - echo "*** Required sqlite version not found!" - echo "*** You need to have sqlite version ${sqlite_version} or higher" - echo "*** for instruments database support to be enabled." - echo "*** Support for instruments DB will be disabled!" - else - HAVE_SQLITE3=1 - fi -else - echo "Instruments DB feature disabled by configure script parameter" -fi - - -if test $HAVE_SQLITE3 = 1; then - HAVE_SQLITE3_TRUE= - HAVE_SQLITE3_FALSE='#' -else - HAVE_SQLITE3_TRUE='#' - HAVE_SQLITE3_FALSE= -fi - - -cat >>confdefs.h <<_ACEOF -#define HAVE_SQLITE3 $HAVE_SQLITE3 -_ACEOF - - - - -########################################################################### -# Handle Configuration Options - -# TODO: should we use AC_ARG_VAR(variable, description) instead? - -# Check whether --enable-asm was given. -if test "${enable_asm+set}" = set; then - enableval=$enable_asm; config_asm="$enableval" -else - config_asm="yes" - -fi - -if test "$config_asm" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_ASM 1 -_ACEOF - -fi - -# Check whether --enable-dev-mode was given. -if test "${enable_dev_mode+set}" = set; then - enableval=$enable_dev_mode; config_dev_mode="$enableval" -else - config_dev_mode="no" - -fi - -if test "$config_dev_mode" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEVMODE 1 -_ACEOF - -fi - -# Check whether --enable-debug-level was given. -if test "${enable_debug_level+set}" = set; then - enableval=$enable_debug_level; config_debug_level="${enableval}" -else - config_debug_level="1" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEBUG_LEVEL $config_debug_level -_ACEOF - - -# Check whether --enable-rt-exceptions was given. -if test "${enable_rt_exceptions+set}" = set; then - enableval=$enable_rt_exceptions; config_rt_exceptions="$enableval" -else - config_rt_exceptions="no" - -fi - -if test "$config_rt_exceptions" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_RT_EXCEPTIONS 1 -_ACEOF - -fi - -# Check whether --enable-pthread-testcancel was given. -if test "${enable_pthread_testcancel+set}" = set; then - enableval=$enable_pthread_testcancel; config_pthread_testcancel="$enableval" -else - config_pthread_testcancel="no" - -fi - -if test "$config_pthread_testcancel" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PTHREAD_TESTCANCEL 1 -_ACEOF - -fi - -# Check whether --enable-preload-samples was given. -if test "${enable_preload_samples+set}" = set; then - enableval=$enable_preload_samples; config_preload_samples="${enableval}" -else - config_preload_samples="32768" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PRELOAD_SAMPLES $config_preload_samples -_ACEOF - - -# Check whether --enable-max-pitch was given. -if test "${enable_max_pitch+set}" = set; then - enableval=$enable_max_pitch; config_max_pitch="${enableval}" -else - config_max_pitch="4" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_MAX_PITCH $config_max_pitch -_ACEOF - - -# Check whether --enable-max-events was given. -if test "${enable_max_events+set}" = set; then - enableval=$enable_max_events; config_max_events="${enableval}" -else - config_max_events="1024" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_MAX_EVENTS_PER_FRAGMENT $config_max_events -_ACEOF - - -# Check whether --enable-eg-bottom was given. -if test "${enable_eg_bottom+set}" = set; then - enableval=$enable_eg_bottom; config_eg_bottom="${enableval}" -else - config_eg_bottom="0.001" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_EG_BOTTOM $config_eg_bottom -_ACEOF - - -# Check whether --enable-eg-min-release-time was given. -if test "${enable_eg_min_release_time+set}" = set; then - enableval=$enable_eg_min_release_time; config_eg_min_release_time="${enableval}" -else - config_eg_min_release_time="0.0025" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_EG_MIN_RELEASE_TIME $config_eg_min_release_time -_ACEOF - - -# Check whether --enable-refill-streams was given. -if test "${enable_refill_streams+set}" = set; then - enableval=$enable_refill_streams; config_refill_streams="${enableval}" -else - config_refill_streams="4" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_REFILL_STREAMS_PER_RUN $config_refill_streams -_ACEOF - - -# Check whether --enable-stream-min-refill was given. -if test "${enable_stream_min_refill+set}" = set; then - enableval=$enable_stream_min_refill; config_stream_min_refill="${enableval}" -else - config_stream_min_refill="1024" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_STREAM_MIN_REFILL_SIZE $config_stream_min_refill -_ACEOF - - -# Check whether --enable-stream-max-refill was given. -if test "${enable_stream_max_refill+set}" = set; then - enableval=$enable_stream_max_refill; config_stream_max_refill="${enableval}" -else - config_stream_max_refill="65536" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_STREAM_MAX_REFILL_SIZE $config_stream_max_refill -_ACEOF - - -# Check whether --enable-stream-size was given. -if test "${enable_stream_size+set}" = set; then - enableval=$enable_stream_size; config_stream_size="${enableval}" -else - config_stream_size="262144" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_STREAM_BUFFER_SIZE $config_stream_size -_ACEOF - - -# Check whether --enable-max-streams was given. -if test "${enable_max_streams+set}" = set; then - enableval=$enable_max_streams; config_max_streams="${enableval}" -else - config_max_streams="90" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEFAULT_MAX_STREAMS $config_max_streams -_ACEOF - - -# Check whether --enable-max-voices was given. -if test "${enable_max_voices+set}" = set; then - enableval=$enable_max_voices; config_max_voices="${enableval}" -else - config_max_voices="64" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEFAULT_MAX_VOICES $config_max_voices -_ACEOF - - -# Check whether --enable-subfragment-size was given. -if test "${enable_subfragment_size+set}" = set; then - enableval=$enable_subfragment_size; config_subfragment_size="${enableval}" -else - config_subfragment_size="32" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEFAULT_SUBFRAGMENT_SIZE $config_subfragment_size -_ACEOF - - -# Check whether --enable-global-attenuation-default was given. -if test "${enable_global_attenuation_default+set}" = set; then - enableval=$enable_global_attenuation_default; config_global_attenuation_default="${enableval}" -else - config_global_attenuation_default="0.35" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_GLOBAL_ATTENUATION_DEFAULT $config_global_attenuation_default -_ACEOF - - -# Check whether --enable-voice-steal-algo was given. -if test "${enable_voice_steal_algo+set}" = set; then - enableval=$enable_voice_steal_algo; if test ! "(" "${enableval}" = "none" \ - -o "${enableval}" = "oldestvoiceonkey" \ - -o "${enableval}" = "oldestkey" ")" ; then - { { echo "$as_me:$LINENO: error: Unknown voice stealing algorithm for parameter --enable-voice-steal-algo" >&5 -echo "$as_me: error: Unknown voice stealing algorithm for parameter --enable-voice-steal-algo" >&2;} - { (exit 1); exit 1; }; } - else - config_voice_steal_algo="${enableval}" - fi - -else - config_voice_steal_algo="oldestvoiceonkey" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_VOICE_STEAL_ALGO voice_steal_algo_${config_voice_steal_algo} -_ACEOF - - -# Check whether --enable-sysex-buffer-size was given. -if test "${enable_sysex_buffer_size+set}" = set; then - enableval=$enable_sysex_buffer_size; config_sysex_buffer_size="${enableval}" -else - config_sysex_buffer_size="2048" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_SYSEX_BUFFER_SIZE $config_sysex_buffer_size -_ACEOF - - -# Check whether --enable-force-filter was given. -if test "${enable_force_filter+set}" = set; then - enableval=$enable_force_filter; config_force_filter="$enableval" -else - config_force_filter="no" - -fi - -if test "$config_force_filter" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_FORCE_FILTER 1 -_ACEOF - -fi - -# Check whether --enable-filter-cutoff-min was given. -if test "${enable_filter_cutoff_min+set}" = set; then - enableval=$enable_filter_cutoff_min; config_filter_cutoff_min="${enableval}" -else - config_filter_cutoff_min="100.0" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_FILTER_CUTOFF_MIN ${config_filter_cutoff_min}f -_ACEOF - - -# Check whether --enable-filter-cutoff-max was given. -if test "${enable_filter_cutoff_max+set}" = set; then - enableval=$enable_filter_cutoff_max; config_filter_cutoff_max="${enableval}" -else - config_filter_cutoff_max="10000.0" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_FILTER_CUTOFF_MAX ${config_filter_cutoff_max}f -_ACEOF - - -# Check whether --enable-override-cutoff-ctrl was given. -if test "${enable_override_cutoff_ctrl+set}" = set; then - enableval=$enable_override_cutoff_ctrl; config_override_cutoff_ctrl="${enableval}" -else - config_override_cutoff_ctrl="no" - -fi - -if test ! "$config_override_cutoff_ctrl" = "no"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_OVERRIDE_CUTOFF_CTRL $config_override_cutoff_ctrl -_ACEOF - -fi - -# Check whether --enable-override-resonance-ctrl was given. -if test "${enable_override_resonance_ctrl+set}" = set; then - enableval=$enable_override_resonance_ctrl; config_override_resonance_ctrl="${enableval}" -else - config_override_resonance_ctrl="no" - -fi - -if test ! "$config_override_resonance_ctrl" = "no"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_OVERRIDE_RESONANCE_CTRL $config_override_resonance_ctrl -_ACEOF - -fi - -# Check whether --enable-override-filter-type was given. -if test "${enable_override_filter_type+set}" = set; then - enableval=$enable_override_filter_type; if test "${enableval}" = "hp" ; then - config_override_filter_type="::gig::vcf_type_highpass" - elif test "${enableval}" = "bp" ; then - config_override_filter_type="::gig::vcf_type_bandpass" - elif test "${enableval}" = "br" ; then - config_override_filter_type="::gig::vcf_type_bandreject" - elif test "${enableval}" = "lp" ; then - config_override_filter_type="::gig::vcf_type_lowpass" - elif test "${enableval}" = "lpt" ; then - config_override_filter_type="::gig::vcf_type_lowpassturbo" - elif test ! "${enableval}" = "no"; then - { { echo "$as_me:$LINENO: error: Unknown filter type for parameter --enable-override-filter-type" >&5 -echo "$as_me: error: Unknown filter type for parameter --enable-override-filter-type" >&2;} - { (exit 1); exit 1; }; } - fi - -else - config_override_filter_type="no" - -fi - -if test ! "$config_override_filter_type" = "no"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_OVERRIDE_FILTER_TYPE $config_override_filter_type -_ACEOF - -fi - -# Check whether --enable-gs-checksum was given. -if test "${enable_gs_checksum+set}" = set; then - enableval=$enable_gs_checksum; config_assert_gs_sysex_checksum="$enableval" -else - config_assert_gs_sysex_checksum="no" - -fi - -if test "config_assert_gs_sysex_checksum" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_ASSERT_GS_SYSEX_CHECKSUM 1 -_ACEOF - -fi - -# Check whether --enable-portamento-time-min was given. -if test "${enable_portamento_time_min+set}" = set; then - enableval=$enable_portamento_time_min; config_portamento_time_min="${enableval}" -else - config_portamento_time_min="0.1" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PORTAMENTO_TIME_MIN $config_portamento_time_min -_ACEOF - - -# Check whether --enable-portamento-time-max was given. -if test "${enable_portamento_time_max+set}" = set; then - enableval=$enable_portamento_time_max; config_portamento_time_max="${enableval}" -else - config_portamento_time_max="32" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PORTAMENTO_TIME_MAX $config_portamento_time_max -_ACEOF - - -# Check whether --enable-portamento-time-default was given. -if test "${enable_portamento_time_default+set}" = set; then - enableval=$enable_portamento_time_default; config_portamento_time_default="${enableval}" -else - config_portamento_time_default="1" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PORTAMENTO_TIME_DEFAULT $config_portamento_time_default -_ACEOF - - -# Check whether --enable-signed-triang-algo was given. -if test "${enable_signed_triang_algo+set}" = set; then - enableval=$enable_signed_triang_algo; if test ! "(" "${enableval}" = "intmath" \ - -o "${enableval}" = "intmathabs" \ - -o "${enableval}" = "diharmonic" ")" ; then - { { echo "$as_me:$LINENO: error: Unknown triangular wave algorithm for parameter --enable-signed-triang-algo" >&5 -echo "$as_me: error: Unknown triangular wave algorithm for parameter --enable-signed-triang-algo" >&2;} - { (exit 1); exit 1; }; } - else - config_signed_triang_algo="${enableval}" - fi - -else - config_signed_triang_algo="benchmark" - -fi - - -# Check whether --enable-unsigned-triang-algo was given. -if test "${enable_unsigned_triang_algo+set}" = set; then - enableval=$enable_unsigned_triang_algo; if test ! "(" "${enableval}" = "intmath" \ - -o "${enableval}" = "intmathabs" \ - -o "${enableval}" = "diharmonic" ")" ; then - { { echo "$as_me:$LINENO: error: Unknown triangular wave algorithm for parameter --enable-unsigned-triang-algo" >&5 -echo "$as_me: error: Unknown triangular wave algorithm for parameter --enable-unsigned-triang-algo" >&2;} - { (exit 1); exit 1; }; } - else - config_unsigned_triang_algo="${enableval}" - fi - -else - config_unsigned_triang_algo="benchmark" - -fi - - -# Check whether --enable-process-muted-channels was given. -if test "${enable_process_muted_channels+set}" = set; then - enableval=$enable_process_muted_channels; config_process_muted_channels="$enableval" -else - config_process_muted_channels="no" - -fi - -if test "$config_process_muted_channels" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PROCESS_MUTED_CHANNELS 1 -_ACEOF - -fi - -# Check whether --enable-process-all-notes-off was given. -if test "${enable_process_all_notes_off+set}" = set; then - enableval=$enable_process_all_notes_off; config_process_all_notes_off="$enableval" -else - config_process_all_notes_off="yes" - -fi - -if test "$config_process_all_notes_off" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_PROCESS_ALL_NOTES_OFF 1 -_ACEOF - -fi - -# Check whether --enable-interpolate-volume was given. -if test "${enable_interpolate_volume+set}" = set; then - enableval=$enable_interpolate_volume; config_interpolate_volume="$enableval" -else - config_interpolate_volume="yes" - -fi - -if test "$config_interpolate_volume" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_INTERPOLATE_VOLUME 1 -_ACEOF - -fi - -# Check whether --enable-master-volume-sysex-by-port was given. -if test "${enable_master_volume_sysex_by_port+set}" = set; then - enableval=$enable_master_volume_sysex_by_port; config_master_volume_sysex_by_port="$enableval" -else - config_master_volume_sysex_by_port="no" - -fi - -if test "$config_master_volume_sysex_by_port" = "yes"; then - -cat >>confdefs.h <<_ACEOF -#define CONFIG_MASTER_VOLUME_SYSEX_BY_PORT 1 -_ACEOF - -fi - -# Check whether --enable-plugin-dir was given. -if test "${enable_plugin_dir+set}" = set; then - enableval=$enable_plugin_dir; config_plugin_dir="${enableval}" -else - config_plugin_dir="${libdir}/linuxsampler/plugins" - -fi - - - -# Check whether --enable-default-instruments-db-location was given. -if test "${enable_default_instruments_db_location+set}" = set; then - enableval=$enable_default_instruments_db_location; config_default_instruments_db_file="${enableval}" -else - config_default_instruments_db_file="/var/lib/linuxsampler/instruments.db" - -fi - - -cat >>confdefs.h <<_ACEOF -#define CONFIG_DEFAULT_INSTRUMENTS_DB_LOCATION "$config_default_instruments_db_file" -_ACEOF - - - - -########################################################################### -# Automatic Benchmarks (to detect the best algorithms for the system) - - - -if test "$config_signed_triang_algo" = "benchmark"; then - echo -n "benchmarking for the best (signed) triangular oscillator algorithm... " - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - if test "$cross_compiling" = yes; then - triang_signed=0 - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - #define SIGNED 1 - #define SILENT 1 - #include "${srcdir}/benchmarks/triang.cpp" - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - triang_signed=0 -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -triang_signed=$? -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - if test "$triang_signed" = "2"; then - config_signed_triang_algo="intmath" - echo "integer math" - elif test "$triang_signed" = "3"; then - config_signed_triang_algo="diharmonic" - echo "di harmonics" - elif test "$triang_signed" = "5"; then - config_signed_triang_algo="intmathabs" - echo "integer math using abs()" - else - echo "Benchmark of signed triangular wave algorithms failed!" - echo "Maybe you are doing cross compilation? In that case you have to select" - echo "an algorithm manually with './configure --enable-signed-triang-algo=...'" - echo "Call './configure --help' for further information or read configure.in." - exit -1; - fi -else - case "$config_signed_triang_algo" in - intmath) - triang_signed=2 ;; - diharmonic) - triang_signed=3 ;; - intmathabs) - triang_signed=5 ;; - esac -fi - -cat >>confdefs.h <<_ACEOF -#define CONFIG_SIGNED_TRIANG_ALGO ${triang_signed} -_ACEOF - - -if test "$config_unsigned_triang_algo" = "benchmark"; then - echo -n "benchmarking for the best (unsigned) triangular oscillator algorithm... " - ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - if test "$cross_compiling" = yes; then - triang_unsigned=0 - -else - cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ - - #define SIGNED 0 - #define SILENT 1 - #include "${srcdir}/benchmarks/triang.cpp" - -_ACEOF -rm -f conftest$ac_exeext -if { (ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { ac_try='./conftest$ac_exeext' - { (case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; }; then - triang_unsigned=0 -else - echo "$as_me: program exited with status $ac_status" >&5 -echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -( exit $ac_status ) -triang_unsigned=$? -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -fi - - - if test "$triang_unsigned" = "2"; then - config_unsigned_triang_algo="intmath" - echo "integer math" - elif test "$triang_unsigned" = "3"; then - config_unsigned_triang_algo="diharmonic" - echo "di harmonics" - elif test "$triang_unsigned" = "5"; then - config_unsigned_triang_algo="intmathabs" - echo "integer math using abs()" - else - echo "Benchmark of unsigned triangular wave algorithms failed!" - echo "Maybe you are doing cross compilation? In that case you have to select" - echo "an algorithm manually with './configure --enable-unsigned-triang-algo=...'" - echo "Call './configure --help' for further information or read configure.in." - exit -1; - fi -else - case "$config_unsigned_triang_algo" in - intmath) - triang_unsigned=2 ;; - diharmonic) - triang_unsigned=3 ;; - intmathabs) - triang_unsigned=5 ;; - esac -fi - -cat >>confdefs.h <<_ACEOF -#define CONFIG_UNSIGNED_TRIANG_ALGO ${triang_unsigned} -_ACEOF - - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -########################################################################### -# Create Build Files - -ac_config_headers="$ac_config_headers config.h" - -am__api_version="1.8" -# Find a good install program. We prefer a C program (faster), -# so one script is as good as another. But avoid the broken or -# incompatible versions: -# SysV /etc/install, /usr/sbin/install -# SunOS /usr/etc/install -# IRIX /sbin/install -# AIX /bin/install -# AmigaOS /C/install, which installs bootblocks on floppy discs -# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag -# AFS /usr/afsws/bin/install, which mishandles nonexistent args -# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" -# OS/2's system install, which has a completely different semantic -# ./install, which can be erroneously created by make from ./install.sh. -{ echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5 -echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6; } -if test -z "$INSTALL"; then -if test "${ac_cv_path_install+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - # Account for people who put trailing slashes in PATH elements. -case $as_dir/ in - ./ | .// | /cC/* | \ - /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ - ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \ - /usr/ucb/* ) ;; - *) - # OSF1 and SCO ODT 3.0 have their own names for install. - # Don't use installbsd from OSF since it installs stuff as root - # by default. - for ac_prog in ginstall scoinst install; do - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then - if test $ac_prog = install && - grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # AIX install. It has an incompatible calling convention. - : - elif test $ac_prog = install && - grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # program-specific install script used by HP pwplus--don't use. - : - else - ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" - break 3 - fi - fi - done - done - ;; -esac -done -IFS=$as_save_IFS - - -fi - if test "${ac_cv_path_install+set}" = set; then - INSTALL=$ac_cv_path_install - else - # As a last resort, use the slow shell script. Don't cache a - # value for INSTALL within a source directory, because that will - # break other packages using the cache if that directory is - # removed, or if the value is a relative name. - INSTALL=$ac_install_sh - fi -fi -{ echo "$as_me:$LINENO: result: $INSTALL" >&5 -echo "${ECHO_T}$INSTALL" >&6; } - -# Use test -z because SunOS4 sh mishandles braces in ${var-val}. -# It thinks the first close brace ends the variable substitution. -test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' - -test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' - -test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' - -{ echo "$as_me:$LINENO: checking whether build environment is sane" >&5 -echo $ECHO_N "checking whether build environment is sane... $ECHO_C" >&6; } -# Just in case -sleep 1 -echo timestamp > conftest.file -# Do `set' in a subshell so we don't clobber the current shell's -# arguments. Must try -L first in case configure is actually a -# symlink; some systems play weird games with the mod time of symlinks -# (eg FreeBSD returns the mod time of the symlink's containing -# directory). -if ( - set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` - if test "$*" = "X"; then - # -L didn't work. - set X `ls -t $srcdir/configure conftest.file` - fi - rm -f conftest.file - if test "$*" != "X $srcdir/configure conftest.file" \ - && test "$*" != "X conftest.file $srcdir/configure"; then - - # If neither matched, then we have a broken ls. This can happen - # if, for instance, CONFIG_SHELL is bash and it inherits a - # broken ls alias from the environment. This has actually - # happened. Such a system could not be considered "sane". - { { echo "$as_me:$LINENO: error: ls -t appears to fail. Make sure there is not a broken -alias in your environment" >&5 -echo "$as_me: error: ls -t appears to fail. Make sure there is not a broken -alias in your environment" >&2;} - { (exit 1); exit 1; }; } - fi - - test "$2" = conftest.file - ) -then - # Ok. - : -else - { { echo "$as_me:$LINENO: error: newly created file is older than distributed files! -Check your system clock" >&5 -echo "$as_me: error: newly created file is older than distributed files! -Check your system clock" >&2;} - { (exit 1); exit 1; }; } -fi -{ echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } -test "$program_prefix" != NONE && - program_transform_name="s&^&$program_prefix&;$program_transform_name" -# Use a double $ so make ignores it. -test "$program_suffix" != NONE && - program_transform_name="s&\$&$program_suffix&;$program_transform_name" -# Double any \ or $. echo might interpret backslashes. -# By default was `s,x,x', remove it if useless. -cat <<\_ACEOF >conftest.sed -s/\\$/&&/g;s/;s,x,x,$// -_ACEOF -program_transform_name=`echo $program_transform_name | sed -f conftest.sed` -rm -f conftest.sed - -# expand $ac_aux_dir to an absolute path -am_aux_dir=`cd $ac_aux_dir && pwd` - -test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" -# Use eval to expand $SHELL -if eval "$MISSING --run true"; then - am_missing_run="$MISSING --run " -else - am_missing_run= - { echo "$as_me:$LINENO: WARNING: \`missing' script is too old or missing" >&5 -echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;} -fi - -if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then - # Keeping the `.' argument allows $(mkdir_p) to be used without - # argument. Indeed, we sometimes output rules like - # $(mkdir_p) $(somedir) - # where $(somedir) is conditionally defined. - # (`test -n '$(somedir)' && $(mkdir_p) $(somedir)' is a more - # expensive solution, as it forces Make to start a sub-shell.) - mkdir_p='mkdir -p -- .' -else - # On NextStep and OpenStep, the `mkdir' command does not - # recognize any option. It will interpret all options as - # directories to create, and then abort because `.' already - # exists. - for d in ./-p ./--version; - do - test -d $d && rmdir $d - done - # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. - if test -f "$ac_aux_dir/mkinstalldirs"; then - mkdir_p='$(mkinstalldirs)' - else - mkdir_p='$(install_sh) -d' - fi -fi - -for ac_prog in gawk mawk nawk awk -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_AWK+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$AWK"; then - ac_cv_prog_AWK="$AWK" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_AWK="$ac_prog" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -AWK=$ac_cv_prog_AWK -if test -n "$AWK"; then - { echo "$as_me:$LINENO: result: $AWK" >&5 -echo "${ECHO_T}$AWK" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - test -n "$AWK" && break -done - -{ echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5 -echo $ECHO_N "checking whether ${MAKE-make} sets \$(MAKE)... $ECHO_C" >&6; } -set x ${MAKE-make}; ac_make=`echo "$2" | sed 's/+/p/g; s/^a-zA-Z0-9_/_/g'` -if { as_var=ac_cv_prog_make_${ac_make}_set; eval "test \"\${$as_var+set}\" = set"; }; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - cat >conftest.make <<\_ACEOF -SHELL = /bin/sh -all: - @echo '@@@%%%=$(MAKE)=@@@%%%' -_ACEOF -# GNU make sometimes prints "make1: Entering...", which would confuse us. -case `${MAKE-make} -f conftest.make 2>/dev/null` in - *@@@%%%=?*=@@@%%%*) - eval ac_cv_prog_make_${ac_make}_set=yes;; - *) - eval ac_cv_prog_make_${ac_make}_set=no;; -esac -rm -f conftest.make -fi -if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - SET_MAKE= -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - SET_MAKE="MAKE=${MAKE-make}" -fi - -rm -rf .tst 2>/dev/null -mkdir .tst 2>/dev/null -if test -d .tst; then - am__leading_dot=. -else - am__leading_dot=_ -fi -rmdir .tst 2>/dev/null - -DEPDIR="${am__leading_dot}deps" - -ac_config_commands="$ac_config_commands depfiles" - - -am_make=${MAKE-make} -cat > confinc << 'END' -am__doit: - @echo done -.PHONY: am__doit -END -# If we don't find an include directive, just comment out the code. -{ echo "$as_me:$LINENO: checking for style of include used by $am_make" >&5 -echo $ECHO_N "checking for style of include used by $am_make... $ECHO_C" >&6; } -am__include="#" -am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# We grep out `Entering directory' and `Leaving directory' -# messages which can occur if `w' ends up in MAKEFLAGS. -# In particular we don't look at `^make:' because GNU make might -# be invoked under some other name (usually "gmake"), in which -# case it prints its new name instead of `make'. -if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then - am__include=include - am__quote= - _am_result=GNU -fi -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then - am__include=.include - am__quote="\"" - _am_result=BSD - fi -fi - - -{ echo "$as_me:$LINENO: result: $_am_result" >&5 -echo "${ECHO_T}$_am_result" >&6; } -rm -f confinc confmf - -# Check whether --enable-dependency-tracking was given. -if test "${enable_dependency_tracking+set}" = set; then - enableval=$enable_dependency_tracking; -fi - -if test "x$enable_dependency_tracking" != xno; then - am_depcomp="$ac_aux_dir/depcomp" - AMDEPBACKSLASH='\' -fi - - -if test "x$enable_dependency_tracking" != xno; then - AMDEP_TRUE= - AMDEP_FALSE='#' -else - AMDEP_TRUE='#' - AMDEP_FALSE= -fi - - - -# test to see if srcdir already configured -if test "`cd $srcdir && pwd`" != "`pwd`" && - test -f $srcdir/config.status; then - { { echo "$as_me:$LINENO: error: source directory already configured; run \"make distclean\" there first" >&5 -echo "$as_me: error: source directory already configured; run \"make distclean\" there first" >&2;} - { (exit 1); exit 1; }; } -fi - -# test whether we have cygpath -if test -z "$CYGPATH_W"; then - if (cygpath --version) >/dev/null 2>/dev/null; then - CYGPATH_W='cygpath -w' - else - CYGPATH_W=echo - fi -fi - - -# Define the identity of the package. - PACKAGE=linuxsampler - VERSION="$LINUXSAMPLER_RELEASE_MAJOR.$LINUXSAMPLER_RELEASE_MINOR.$LINUXSAMPLER_RELEASE_BUILD" - - -cat >>confdefs.h <<_ACEOF -#define PACKAGE "$PACKAGE" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define VERSION "$VERSION" -_ACEOF - -# Some tools Automake needs. - -ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} - - -AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} - - -AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} - - -AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} - - -MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} - - -AMTAR=${AMTAR-"${am_missing_run}tar"} - -install_sh=${install_sh-"$am_aux_dir/install-sh"} - -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'. However `strip' might not be the right -# tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. -if test "$cross_compiling" != no; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. -set dummy ${ac_tool_prefix}strip; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_STRIP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$STRIP"; then - ac_cv_prog_STRIP="$STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_STRIP="${ac_tool_prefix}strip" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -STRIP=$ac_cv_prog_STRIP -if test -n "$STRIP"; then - { echo "$as_me:$LINENO: result: $STRIP" >&5 -echo "${ECHO_T}$STRIP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_STRIP"; then - ac_ct_STRIP=$STRIP - # Extract the first word of "strip", so it can be a program name with args. -set dummy strip; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -n "$ac_ct_STRIP"; then - ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_STRIP="strip" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - -fi -fi -ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP -if test -n "$ac_ct_STRIP"; then - { echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 -echo "${ECHO_T}$ac_ct_STRIP" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - if test "x$ac_ct_STRIP" = x; then - STRIP=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&5 -echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools -whose name does not start with the host triplet. If you think this -configuration is useful to you, please write to autoconf@gnu.org." >&2;} -ac_tool_warned=yes ;; -esac - STRIP=$ac_ct_STRIP - fi -else - STRIP="$ac_cv_prog_STRIP" -fi - -fi -INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" - -# We need awk for the "check" target. The system "awk" is bad on -# some platforms. - - -depcc="$CC" am_compiler_list= - -{ echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 -echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6; } -if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then - # We make a subdir and do the tests there. Otherwise we can end up - # making bogus files that we don't know about and never remove. For - # instance it was reported that on HP-UX the gcc test will end up - # making a dummy file named `D' -- because `-MD' means `put the output - # in D'. - mkdir conftest.dir - # Copy depcomp to subdir because otherwise we won't find it if we're - # using a relative directory. - cp "$am_depcomp" conftest.dir - cd conftest.dir - # We will build objects and dependencies in a subdirectory because - # it helps to detect inapplicable dependency modes. For instance - # both Tru64's cc and ICC support -MD to output dependencies as a - # side effect of compilation, but ICC will put the dependencies in - # the current directory while Tru64 will put them in the object - # directory. - mkdir sub - - am_cv_CC_dependencies_compiler_type=none - if test "$am_compiler_list" = ""; then - am_compiler_list=`sed -n 's/^#*\(a-zA-Z0-9*\))$/\1/p' < ./depcomp` - fi - for depmode in $am_compiler_list; do - # Setup a source with many dependencies, because some compilers - # like to wrap large dependency lists on column 80 (with \), and - # we should not choose a depcomp mode which is confused by this. - # - # We need to recreate these files for each test, as the compiler may - # overwrite some of them when testing with obscure command lines. - # This happens at least with the AIX C compiler. - : > sub/conftest.c - for i in 1 2 3 4 5 6; do - echo '#include "conftst'$i'.h"' >> sub/conftest.c - # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with - # Solaris 8's {/usr,}/bin/sh. - touch sub/conftst$i.h - done - echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf - - case $depmode in - nosideeffect) - # after this tag, mechanisms are not by side-effect, so they'll - # only be used when explicitly requested - if test "x$enable_dependency_tracking" = xyes; then - continue - else - break - fi - ;; - none) break ;; - esac - # We check with `-c' and `-o' for the sake of the "dashmstdout" - # mode. It turns out that the SunPro C++ compiler does not properly - # handle `-M -o', and we need to detect this. - if depmode=$depmode \ - source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ - depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ - $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ - >/dev/null 2>conftest.err && - grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && - grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && - ${MAKE-make} -s -f confmf > /dev/null 2>&1; then - # icc doesn't choke on unknown options, it will just issue warnings - # or remarks (even with -Werror). So we grep stderr for any message - # that says an option was ignored or not supported. - # When given -MP, icc 7.0 and 7.1 complain thusly: - # icc: Command line warning: ignoring option '-M'; no argument required - # The diagnosis changed in icc 8.0: - # icc: Command line remark: option '-MP' not supported - if (grep 'ignoring option' conftest.err || - grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else - am_cv_CC_dependencies_compiler_type=$depmode - break - fi - fi - done - - cd .. - rm -rf conftest.dir -else - am_cv_CC_dependencies_compiler_type=none -fi - -fi -{ echo "$as_me:$LINENO: result: $am_cv_CC_dependencies_compiler_type" >&5 -echo "${ECHO_T}$am_cv_CC_dependencies_compiler_type" >&6; } -CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type - - - -if - test "x$enable_dependency_tracking" != xno \ - && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then - am__fastdepCC_TRUE= - am__fastdepCC_FALSE='#' -else - am__fastdepCC_TRUE='#' - am__fastdepCC_FALSE= -fi - - -depcc="$CXX" am_compiler_list= - -{ echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 -echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6; } -if test "${am_cv_CXX_dependencies_compiler_type+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then - # We make a subdir and do the tests there. Otherwise we can end up - # making bogus files that we don't know about and never remove. For - # instance it was reported that on HP-UX the gcc test will end up - # making a dummy file named `D' -- because `-MD' means `put the output - # in D'. - mkdir conftest.dir - # Copy depcomp to subdir because otherwise we won't find it if we're - # using a relative directory. - cp "$am_depcomp" conftest.dir - cd conftest.dir - # We will build objects and dependencies in a subdirectory because - # it helps to detect inapplicable dependency modes. For instance - # both Tru64's cc and ICC support -MD to output dependencies as a - # side effect of compilation, but ICC will put the dependencies in - # the current directory while Tru64 will put them in the object - # directory. - mkdir sub - - am_cv_CXX_dependencies_compiler_type=none - if test "$am_compiler_list" = ""; then - am_compiler_list=`sed -n 's/^#*\(a-zA-Z0-9*\))$/\1/p' < ./depcomp` - fi - for depmode in $am_compiler_list; do - # Setup a source with many dependencies, because some compilers - # like to wrap large dependency lists on column 80 (with \), and - # we should not choose a depcomp mode which is confused by this. - # - # We need to recreate these files for each test, as the compiler may - # overwrite some of them when testing with obscure command lines. - # This happens at least with the AIX C compiler. - : > sub/conftest.c - for i in 1 2 3 4 5 6; do - echo '#include "conftst'$i'.h"' >> sub/conftest.c - # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with - # Solaris 8's {/usr,}/bin/sh. - touch sub/conftst$i.h - done - echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf - - case $depmode in - nosideeffect) - # after this tag, mechanisms are not by side-effect, so they'll - # only be used when explicitly requested - if test "x$enable_dependency_tracking" = xyes; then - continue - else - break - fi - ;; - none) break ;; - esac - # We check with `-c' and `-o' for the sake of the "dashmstdout" - # mode. It turns out that the SunPro C++ compiler does not properly - # handle `-M -o', and we need to detect this. - if depmode=$depmode \ - source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ - depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ - $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ - >/dev/null 2>conftest.err && - grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && - grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && - ${MAKE-make} -s -f confmf > /dev/null 2>&1; then - # icc doesn't choke on unknown options, it will just issue warnings - # or remarks (even with -Werror). So we grep stderr for any message - # that says an option was ignored or not supported. - # When given -MP, icc 7.0 and 7.1 complain thusly: - # icc: Command line warning: ignoring option '-M'; no argument required - # The diagnosis changed in icc 8.0: - # icc: Command line remark: option '-MP' not supported - if (grep 'ignoring option' conftest.err || - grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else - am_cv_CXX_dependencies_compiler_type=$depmode - break - fi - fi - done - - cd .. - rm -rf conftest.dir -else - am_cv_CXX_dependencies_compiler_type=none -fi - -fi -{ echo "$as_me:$LINENO: result: $am_cv_CXX_dependencies_compiler_type" >&5 -echo "${ECHO_T}$am_cv_CXX_dependencies_compiler_type" >&6; } -CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type - - - -if - test "x$enable_dependency_tracking" != xno \ - && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then - am__fastdepCXX_TRUE= - am__fastdepCXX_FALSE='#' -else - am__fastdepCXX_TRUE='#' - am__fastdepCXX_FALSE= -fi - - - - -ac_ext=cpp -ac_cpp='$CXXCPP $CPPFLAGS' -ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_cxx_compiler_gnu - - -# autoconf 2.59/libtool 1.5.12 bug? work-around. Without a check like -# this, the dlfcn.h check in am_prog_libtool may fail. - -if test "${ac_cv_header_stdlib_h+set}" = set; then - { echo "$as_me:$LINENO: checking for stdlib.h" >&5 -echo $ECHO_N "checking for stdlib.h... $ECHO_C" >&6; } -if test "${ac_cv_header_stdlib_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_stdlib_h" >&5 -echo "${ECHO_T}$ac_cv_header_stdlib_h" >&6; } -else - # Is the header compilable? -{ echo "$as_me:$LINENO: checking stdlib.h usability" >&5 -echo $ECHO_N "checking stdlib.h usability... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -$ac_includes_default -#include <stdlib.h> -_ACEOF -rm -f conftest.$ac_objext -if { (ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_compile") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } && { - test -z "$ac_cxx_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then - ac_header_compiler=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_compiler=no -fi - -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -echo "${ECHO_T}$ac_header_compiler" >&6; } - -# Is the header present? -{ echo "$as_me:$LINENO: checking stdlib.h presence" >&5 -echo $ECHO_N "checking stdlib.h presence... $ECHO_C" >&6; } -cat >conftest.$ac_ext <<_ACEOF -/* confdefs.h. */ -_ACEOF -cat confdefs.h >>conftest.$ac_ext -cat >>conftest.$ac_ext <<_ACEOF -/* end confdefs.h. */ -#include <stdlib.h> -_ACEOF -if { (ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1 - ac_status=$? - grep -v '^ *+' conftest.er1 >conftest.err - rm -f conftest.er1 - cat conftest.err >&5 - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); } >/dev/null && { - test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || - test ! -s conftest.err - }; then - ac_header_preproc=yes -else - echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_header_preproc=no -fi - -rm -f conftest.err conftest.$ac_ext -{ echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -echo "${ECHO_T}$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_cxx_preproc_warn_flag in - yes:no: ) - { echo "$as_me:$LINENO: WARNING: stdlib.h: accepted by the compiler, rejected by the preprocessor!" >&5 -echo "$as_me: WARNING: stdlib.h: accepted by the compiler, rejected by the preprocessor!" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: proceeding with the compiler's result" >&5 -echo "$as_me: WARNING: stdlib.h: proceeding with the compiler's result" >&2;} - ac_header_preproc=yes - ;; - no:yes:* ) - { echo "$as_me:$LINENO: WARNING: stdlib.h: present but cannot be compiled" >&5 -echo "$as_me: WARNING: stdlib.h: present but cannot be compiled" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: check for missing prerequisite headers?" >&5 -echo "$as_me: WARNING: stdlib.h: check for missing prerequisite headers?" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: see the Autoconf documentation" >&5 -echo "$as_me: WARNING: stdlib.h: see the Autoconf documentation" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: section \"Present But Cannot Be Compiled\"" >&5 -echo "$as_me: WARNING: stdlib.h: section \"Present But Cannot Be Compiled\"" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: proceeding with the preprocessor's result" >&5 -echo "$as_me: WARNING: stdlib.h: proceeding with the preprocessor's result" >&2;} - { echo "$as_me:$LINENO: WARNING: stdlib.h: in the future, the compiler will take precedence" >&5 -echo "$as_me: WARNING: stdlib.h: in the future, the compiler will take precedence" >&2;} - - ;; -esac -{ echo "$as_me:$LINENO: checking for stdlib.h" >&5 -echo $ECHO_N "checking for stdlib.h... $ECHO_C" >&6; } -if test "${ac_cv_header_stdlib_h+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - ac_cv_header_stdlib_h=$ac_header_preproc -fi -{ echo "$as_me:$LINENO: result: $ac_cv_header_stdlib_h" >&5 -echo "${ECHO_T}$ac_cv_header_stdlib_h" >&6; } - -fi - - - -ac_config_files="$ac_config_files Makefile man/Makefile man/linuxsampler.1 src/Makefile src/db/Makefile src/network/Makefile src/engines/Makefile src/engines/gig/Makefile src/engines/common/Makefile src/effects/Makefile src/common/Makefile src/testcases/Makefile src/drivers/Makefile src/drivers/audio/Makefile src/drivers/midi/Makefile src/plugins/Makefile src/hostplugins/Makefile src/hostplugins/dssi/Makefile src/hostplugins/lv2/Makefile src/hostplugins/vst/Makefile src/hostplugins/au/Makefile linuxsampler.spec debian/Makefile Artwork/Makefile scripts/Makefile osx/Makefile osx/linuxsampler.xcodeproj/Makefile Documentation/Makefile Documentation/Engines/Makefile Documentation/Engines/gig/Makefile linuxsampler.pc Doxyfile" - -cat >confcache <<\_ACEOF -# This file is a shell script that caches the results of configure -# tests run on this system so they can be shared between configure -# scripts and configure runs, see configure's option --config-cache. -# It is not useful on other systems. If it contains results you don't -# want to keep, you may remove or edit it. -# -# config.status only pays attention to the cache file if you give it -# the --recheck option to rerun configure. -# -# `ac_cv_env_foo' variables (set or unset) will be overridden when -# loading this file, other *unset* `ac_cv_foo' will be assigned the -# following values. - -_ACEOF - -# The following way of writing the cache mishandles newlines in values, -# but we know of no workaround that is simple, portable, and efficient. -# So, we kill variables containing newlines. -# Ultrix sh set writes to stderr and can't be redirected directly, -# and sets the high bit in the cache file unless we assign to the vars. -( - for ac_var in `(set) 2>&1 | sed -n 's/^\(a-zA-Z_a-zA-Z0-9_*\)=.*/\1/p'`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { echo "$as_me:$LINENO: WARNING: Cache variable $ac_var contains a newline." >&5 -echo "$as_me: WARNING: Cache variable $ac_var contains a newline." >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - *) $as_unset $ac_var ;; - esac ;; - esac - done - - (set) 2>&1 | - case $as_nl`(ac_space=' '; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - # `set' does not quote correctly, so add quotes (double-quote - # substitution turns \\\\ into \\, and sed turns \\ into \). - sed -n \ - "s/'/'\\\\''/g; - s/^\\(_$as_cr_alnum*_cv__$as_cr_alnum*\\)=\\(.*\\)/\\1='\\2'/p" - ;; #( - *) - # `set' quotes correctly as required by POSIX, so do not add quotes. - sed -n "/^_$as_cr_alnum*_cv__$as_cr_alnum*=/p" - ;; - esac | - sort -) | - sed ' - /^ac_cv_env_/b end - t clear - :clear - s/^\(^=*\)=\(.*{}.*\)$/test "${\1+set}" = set || &/ - t end - s/^\(^=*\)=\(.*\)$/\1=${\1=\2}/ - :end' >>confcache -if diff "$cache_file" confcache >/dev/null 2>&1; then :; else - if test -w "$cache_file"; then - test "x$cache_file" != "x/dev/null" && - { echo "$as_me:$LINENO: updating cache $cache_file" >&5 -echo "$as_me: updating cache $cache_file" >&6;} - cat confcache >$cache_file - else - { echo "$as_me:$LINENO: not updating unwritable cache $cache_file" >&5 -echo "$as_me: not updating unwritable cache $cache_file" >&6;} - fi -fi -rm -f confcache - -test "x$prefix" = xNONE && prefix=$ac_default_prefix -# Let make expand exec_prefix. -test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' - -DEFS=-DHAVE_CONFIG_H - -ac_libobjs= -ac_ltlibobjs= -for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue - # 1. Remove the extension, and $U if already installed. - ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' - ac_i=`echo "$ac_i" | sed "$ac_script"` - # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR - # will be set to the directory where LIBOBJS objects are built. - ac_libobjs="$ac_libobjs \${LIBOBJDIR}$ac_i\$U.$ac_objext" - ac_ltlibobjs="$ac_ltlibobjs \${LIBOBJDIR}$ac_i"'$U.lo' -done -LIBOBJS=$ac_libobjs - -LTLIBOBJS=$ac_ltlibobjs - - -if test -z "${CROSS_COMPILING_TRUE}" && test -z "${CROSS_COMPILING_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"CROSS_COMPILING\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"CROSS_COMPILING\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_WINDOWS_TRUE}" && test -z "${HAVE_WINDOWS_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_WINDOWS\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_WINDOWS\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_ALSA_TRUE}" && test -z "${HAVE_ALSA_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_ALSA\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_ALSA\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_JACK_TRUE}" && test -z "${HAVE_JACK_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_JACK\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_JACK\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_JACK_MIDI_TRUE}" && test -z "${HAVE_JACK_MIDI_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_JACK_MIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_JACK_MIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_ARTS_TRUE}" && test -z "${HAVE_ARTS_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_ARTS\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_ARTS\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_ASIO_TRUE}" && test -z "${HAVE_ASIO_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_ASIO\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_ASIO\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_MIDISHARE_TRUE}" && test -z "${HAVE_MIDISHARE_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_MIDISHARE\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_MIDISHARE\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_COREMIDI_TRUE}" && test -z "${HAVE_COREMIDI_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_COREMIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_COREMIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_COREAUDIO_TRUE}" && test -z "${HAVE_COREAUDIO_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_COREAUDIO\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_COREAUDIO\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_MME_MIDI_TRUE}" && test -z "${HAVE_MME_MIDI_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_MME_MIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_MME_MIDI\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_DSSI_TRUE}" && test -z "${HAVE_DSSI_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_DSSI\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_DSSI\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_LV2_TRUE}" && test -z "${HAVE_LV2_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_LV2\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_LV2\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_VST_TRUE}" && test -z "${HAVE_VST_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_VST\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_VST\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_AU_TRUE}" && test -z "${HAVE_AU_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_AU\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_AU\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_AUFLAGS_TRUE}" && test -z "${HAVE_AUFLAGS_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_AUFLAGS\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_AUFLAGS\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${HAVE_SQLITE3_TRUE}" && test -z "${HAVE_SQLITE3_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"HAVE_SQLITE3\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"HAVE_SQLITE3\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"AMDEP\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"AMDEP\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCC\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"am__fastdepCC\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi -if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then - { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCXX\" was never defined. -Usually this means the macro was only invoked conditionally." >&5 -echo "$as_me: error: conditional \"am__fastdepCXX\" was never defined. -Usually this means the macro was only invoked conditionally." >&2;} - { (exit 1); exit 1; }; } -fi - -: ${CONFIG_STATUS=./config.status} -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files $CONFIG_STATUS" -{ echo "$as_me:$LINENO: creating $CONFIG_STATUS" >&5 -echo "$as_me: creating $CONFIG_STATUS" >&6;} -cat >$CONFIG_STATUS <<_ACEOF -#! $SHELL -# Generated by $as_me. -# Run this file to recreate the current configuration. -# Compiler output produced by configure, useful for debugging -# configure, is in config.log if it exists. - -debug=false -ac_cs_recheck=false -ac_cs_silent=false -SHELL=\${CONFIG_SHELL-$SHELL} -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF -## --------------------- ## -## M4sh Initialization. ## -## --------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in - *posix*) set -o posix ;; -esac - -fi - - - - -# PATH needs CR -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - -# The user is always right. -if test "${PATH_SEPARATOR+set}" != set; then - echo "#! /bin/sh" >conf$$.sh - echo "exit 0" >>conf$$.sh - chmod +x conf$$.sh - if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then - PATH_SEPARATOR=';' - else - PATH_SEPARATOR=: - fi - rm -f conf$$.sh -fi - -# Support unset when possible. -if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then - as_unset=unset -else - as_unset=false -fi - - -# IFS -# We need space, tab and new line, in precisely that order. Quoting is -# there to prevent editors from complaining about space-tab. -# (If _AS_PATH_WALK were called with IFS unset, it would disable word -# splitting by setting IFS to empty value.) -as_nl=' -' -IFS=" "" $as_nl" - -# Find who we are. Look in the path if we contain no directory separator. -case $0 in - *\\/* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break -done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - { (exit 1); exit 1; } -fi - -# Work around bugs in pre-3.0 UWIN ksh. -for as_var in ENV MAIL MAILPATH -do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var -done -PS1='$ ' -PS2='> ' -PS4='+ ' - -# NLS nuisances. -for as_var in \ - LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ - LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ - LC_TELEPHONE LC_TIME -do - if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then - eval $as_var=C; export $as_var - else - ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var - fi -done - -# Required to use basename. -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - - -# Name of the executable. -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\(^/^/*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -echo X/"$0" | - sed '/^.*\/\(^/^/*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# CDPATH. -$as_unset CDPATH - - - - as_lineno_1=$LINENO - as_lineno_2=$LINENO - test "x$as_lineno_1" != "x$as_lineno_2" && - test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2" || { - - # Create $as_me.lineno as a copy of $as_myself, but with $LINENO - # uniformly replaced by the line number. The first 'sed' inserts a - # line-number line after each line using $LINENO; the second 'sed' - # does the real work. The second script uses 'N' to pair each - # line-number line with the line containing $LINENO, and appends - # trailing '-' during substitution so that $LINENO is not a special - # case at line end. - # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the - # scripts with optimization help from Paolo Bonzini. Blame Lee - # E. McMahon (1931-1989) for sed's syntax. :-) - sed -n ' - p - /$LINENO/= - ' <$as_myself | - sed ' - s/$LINENO.*/&-/ - t lineno - b - :lineno - N - :loop - s/$LINENO\(^'$as_cr_alnum'_.*\n\)\(.*\)/\2\1\2/ - t loop - s/-\n.*// - ' >$as_me.lineno && - chmod +x "$as_me.lineno" || - { echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2 - { (exit 1); exit 1; }; } - - # Don't try to exec as it changes $0, causing all sort of problems - # (the dirname of $0 is not the place where we might find the - # original and so on. Autoconf is especially sensitive to this). - . "./$as_me.lineno" - # Exit status is that of the last command. - exit -} - - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in --n*) - case `echo 'x\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - *) ECHO_C='\c';; - esac;; -*) - ECHO_N='-n';; -esac - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir -fi -echo >conf$$.file -if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -p'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -p' -elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln -else - as_ln_s='cp -p' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - -if mkdir -p . 2>/dev/null; then - as_mkdir_p=: -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - -if test -x / >/dev/null 2>&1; then - as_test_x='test -x' -else - if ls -dL / >/dev/null 2>&1; then - as_ls_L_option=L - else - as_ls_L_option= - fi - as_test_x=' - eval sh -c '\'' - if test -d "$1"; then - test -d "$1/."; - else - case $1 in - -*)set "./$1";; - esac; - case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in - ???sx*):;;*)false;;esac;fi - '\'' sh - ' -fi -as_executable_p=$as_test_x - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%^_$as_cr_alnum%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%^_$as_cr_alnum%_%g'" - - -exec 6>&1 - -# Save the log message, to keep $0 and so on meaningful, and to -# report actual input values of CONFIG_FILES etc. instead of their -# values after options handling. -ac_log=" -This file was extended by $as_me, which was -generated by GNU Autoconf 2.61. Invocation command line was - - CONFIG_FILES = $CONFIG_FILES - CONFIG_HEADERS = $CONFIG_HEADERS - CONFIG_LINKS = $CONFIG_LINKS - CONFIG_COMMANDS = $CONFIG_COMMANDS - $ $0 $@ - -on `(hostname || uname -n) 2>/dev/null | sed 1q` -" - -_ACEOF - -cat >>$CONFIG_STATUS <<_ACEOF -# Files that config.status was made for. -config_files="$ac_config_files" -config_headers="$ac_config_headers" -config_commands="$ac_config_commands" - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF -ac_cs_usage="\ -\`$as_me' instantiates files from templates according to the -current configuration. - -Usage: $0 OPTIONS FILE... - - -h, --help print this help, then exit - -V, --version print version number and configuration settings, then exit - -q, --quiet do not print progress messages - -d, --debug don't remove temporary files - --recheck update $as_me by reconfiguring in the same conditions - --file=FILE:TEMPLATE - instantiate the configuration file FILE - --header=FILE:TEMPLATE - instantiate the configuration header FILE - -Configuration files: -$config_files - -Configuration headers: -$config_headers - -Configuration commands: -$config_commands - -Report bugs to <bug-autoconf@gnu.org>." - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF -ac_cs_version="\\ -config.status -configured by $0, generated by GNU Autoconf 2.61, - with options \\"`echo "$ac_configure_args" | sed 's/^ //; s/\\""\`\$/\\\\&/g'`\\" - -Copyright (C) 2006 Free Software Foundation, Inc. -This config.status script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it." - -ac_pwd='$ac_pwd' -srcdir='$srcdir' -INSTALL='$INSTALL' -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF -# If no file are specified by the user, then we need to provide default -# value. By we need to know if files were specified by the user. -ac_need_defaults=: -while test $# != 0 -do - case $1 in - --*=*) - ac_option=`expr "X$1" : 'X\(^=*\)='` - ac_optarg=`expr "X$1" : 'X^=*=\(.*\)'` - ac_shift=: - ;; - *) - ac_option=$1 - ac_optarg=$2 - ac_shift=shift - ;; - esac - - case $ac_option in - # Handling of the options. - -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) - ac_cs_recheck=: ;; - --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) - echo "$ac_cs_version"; exit ;; - --debug | --debu | --deb | --de | --d | -d ) - debug=: ;; - --file | --fil | --fi | --f ) - $ac_shift - CONFIG_FILES="$CONFIG_FILES $ac_optarg" - ac_need_defaults=false;; - --header | --heade | --head | --hea ) - $ac_shift - CONFIG_HEADERS="$CONFIG_HEADERS $ac_optarg" - ac_need_defaults=false;; - --he | --h) - # Conflict between --help and --header - { echo "$as_me: error: ambiguous option: $1 -Try \`$0 --help' for more information." >&2 - { (exit 1); exit 1; }; };; - --help | --hel | -h ) - echo "$ac_cs_usage"; exit ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil | --si | --s) - ac_cs_silent=: ;; - - # This is an error. - -*) { echo "$as_me: error: unrecognized option: $1 -Try \`$0 --help' for more information." >&2 - { (exit 1); exit 1; }; } ;; - - *) ac_config_targets="$ac_config_targets $1" - ac_need_defaults=false ;; - - esac - shift -done - -ac_configure_extra_args= - -if $ac_cs_silent; then - exec 6>/dev/null - ac_configure_extra_args="$ac_configure_extra_args --silent" -fi - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF -if \$ac_cs_recheck; then - echo "running CONFIG_SHELL=$SHELL $SHELL $0 "$ac_configure_args \$ac_configure_extra_args " --no-create --no-recursion" >&6 - CONFIG_SHELL=$SHELL - export CONFIG_SHELL - exec $SHELL "$0"$ac_configure_args \$ac_configure_extra_args --no-create --no-recursion -fi - -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF -exec 5>>config.log -{ - echo - sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX -## Running $as_me. ## -_ASBOX - echo "$ac_log" -} >&5 - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF -# -# INIT-COMMANDS -# -AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF - -# Handling of arguments. -for ac_config_target in $ac_config_targets -do - case $ac_config_target in - "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;; - "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; - "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; - "man/Makefile") CONFIG_FILES="$CONFIG_FILES man/Makefile" ;; - "man/linuxsampler.1") CONFIG_FILES="$CONFIG_FILES man/linuxsampler.1" ;; - "src/Makefile") CONFIG_FILES="$CONFIG_FILES src/Makefile" ;; - "src/db/Makefile") CONFIG_FILES="$CONFIG_FILES src/db/Makefile" ;; - "src/network/Makefile") CONFIG_FILES="$CONFIG_FILES src/network/Makefile" ;; - "src/engines/Makefile") CONFIG_FILES="$CONFIG_FILES src/engines/Makefile" ;; - "src/engines/gig/Makefile") CONFIG_FILES="$CONFIG_FILES src/engines/gig/Makefile" ;; - "src/engines/common/Makefile") CONFIG_FILES="$CONFIG_FILES src/engines/common/Makefile" ;; - "src/effects/Makefile") CONFIG_FILES="$CONFIG_FILES src/effects/Makefile" ;; - "src/common/Makefile") CONFIG_FILES="$CONFIG_FILES src/common/Makefile" ;; - "src/testcases/Makefile") CONFIG_FILES="$CONFIG_FILES src/testcases/Makefile" ;; - "src/drivers/Makefile") CONFIG_FILES="$CONFIG_FILES src/drivers/Makefile" ;; - "src/drivers/audio/Makefile") CONFIG_FILES="$CONFIG_FILES src/drivers/audio/Makefile" ;; - "src/drivers/midi/Makefile") CONFIG_FILES="$CONFIG_FILES src/drivers/midi/Makefile" ;; - "src/plugins/Makefile") CONFIG_FILES="$CONFIG_FILES src/plugins/Makefile" ;; - "src/hostplugins/Makefile") CONFIG_FILES="$CONFIG_FILES src/hostplugins/Makefile" ;; - "src/hostplugins/dssi/Makefile") CONFIG_FILES="$CONFIG_FILES src/hostplugins/dssi/Makefile" ;; - "src/hostplugins/lv2/Makefile") CONFIG_FILES="$CONFIG_FILES src/hostplugins/lv2/Makefile" ;; - "src/hostplugins/vst/Makefile") CONFIG_FILES="$CONFIG_FILES src/hostplugins/vst/Makefile" ;; - "src/hostplugins/au/Makefile") CONFIG_FILES="$CONFIG_FILES src/hostplugins/au/Makefile" ;; - "linuxsampler.spec") CONFIG_FILES="$CONFIG_FILES linuxsampler.spec" ;; - "debian/Makefile") CONFIG_FILES="$CONFIG_FILES debian/Makefile" ;; - "Artwork/Makefile") CONFIG_FILES="$CONFIG_FILES Artwork/Makefile" ;; - "scripts/Makefile") CONFIG_FILES="$CONFIG_FILES scripts/Makefile" ;; - "osx/Makefile") CONFIG_FILES="$CONFIG_FILES osx/Makefile" ;; - "osx/linuxsampler.xcodeproj/Makefile") CONFIG_FILES="$CONFIG_FILES osx/linuxsampler.xcodeproj/Makefile" ;; - "Documentation/Makefile") CONFIG_FILES="$CONFIG_FILES Documentation/Makefile" ;; - "Documentation/Engines/Makefile") CONFIG_FILES="$CONFIG_FILES Documentation/Engines/Makefile" ;; - "Documentation/Engines/gig/Makefile") CONFIG_FILES="$CONFIG_FILES Documentation/Engines/gig/Makefile" ;; - "linuxsampler.pc") CONFIG_FILES="$CONFIG_FILES linuxsampler.pc" ;; - "Doxyfile") CONFIG_FILES="$CONFIG_FILES Doxyfile" ;; - - *) { { echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5 -echo "$as_me: error: invalid argument: $ac_config_target" >&2;} - { (exit 1); exit 1; }; };; - esac -done - - -# If the user did not use the arguments to specify the items to instantiate, -# then the envvar interface is used. Set only those that are not. -# We use the long form for the default assignment because of an extremely -# bizarre bug on SunOS 4.1.3. -if $ac_need_defaults; then - test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files - test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers - test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands -fi - -# Have a temporary directory for convenience. Make it in the build tree -# simply because there is no reason against having it here, and in addition, -# creating and moving files from /tmp can sometimes cause problems. -# Hook for its removal unless debugging. -# Note that there is a small window in which the directory will not be cleaned: -# after its creation but before its name has been assigned to `$tmp'. -$debug || -{ - tmp= - trap 'exit_status=$? - { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status -' 0 - trap '{ (exit 1); exit 1; }' 1 2 13 15 -} -# Create a (secure) tmp directory for tmp files. - -{ - tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -n "$tmp" && test -d "$tmp" -} || -{ - tmp=./conf$$-$RANDOM - (umask 077 && mkdir "$tmp") -} || -{ - echo "$me: cannot create a temporary directory in ." >&2 - { (exit 1); exit 1; } -} - -# -# Set up the sed scripts for CONFIG_FILES section. -# - -# No need to generate the scripts if there are no CONFIG_FILES. -# This happens for instance when ./config.status config.h -if test -n "$CONFIG_FILES"; then - -_ACEOF - - - -ac_delim='%!_!# ' -for ac_last_try in false false false false false :; do - cat >conf$$subs.sed <<_ACEOF -SHELL!$SHELL$ac_delim -PATH_SEPARATOR!$PATH_SEPARATOR$ac_delim -PACKAGE_NAME!$PACKAGE_NAME$ac_delim -PACKAGE_TARNAME!$PACKAGE_TARNAME$ac_delim -PACKAGE_VERSION!$PACKAGE_VERSION$ac_delim -PACKAGE_STRING!$PACKAGE_STRING$ac_delim -PACKAGE_BUGREPORT!$PACKAGE_BUGREPORT$ac_delim -exec_prefix!$exec_prefix$ac_delim -prefix!$prefix$ac_delim -program_transform_name!$program_transform_name$ac_delim -bindir!$bindir$ac_delim -sbindir!$sbindir$ac_delim -libexecdir!$libexecdir$ac_delim -datarootdir!$datarootdir$ac_delim -datadir!$datadir$ac_delim -sysconfdir!$sysconfdir$ac_delim -sharedstatedir!$sharedstatedir$ac_delim -localstatedir!$localstatedir$ac_delim -includedir!$includedir$ac_delim -oldincludedir!$oldincludedir$ac_delim -docdir!$docdir$ac_delim -infodir!$infodir$ac_delim -htmldir!$htmldir$ac_delim -dvidir!$dvidir$ac_delim -pdfdir!$pdfdir$ac_delim -psdir!$psdir$ac_delim -libdir!$libdir$ac_delim -localedir!$localedir$ac_delim -mandir!$mandir$ac_delim -DEFS!$DEFS$ac_delim -ECHO_C!$ECHO_C$ac_delim -ECHO_N!$ECHO_N$ac_delim -ECHO_T!$ECHO_T$ac_delim -LIBS!$LIBS$ac_delim -build_alias!$build_alias$ac_delim -host_alias!$host_alias$ac_delim -target_alias!$target_alias$ac_delim -CXX!$CXX$ac_delim -CXXFLAGS!$CXXFLAGS$ac_delim -LDFLAGS!$LDFLAGS$ac_delim -CPPFLAGS!$CPPFLAGS$ac_delim -ac_ct_CXX!$ac_ct_CXX$ac_delim -EXEEXT!$EXEEXT$ac_delim -OBJEXT!$OBJEXT$ac_delim -build!$build$ac_delim -build_cpu!$build_cpu$ac_delim -build_vendor!$build_vendor$ac_delim -build_os!$build_os$ac_delim -host!$host$ac_delim -host_cpu!$host_cpu$ac_delim -host_vendor!$host_vendor$ac_delim -host_os!$host_os$ac_delim -CC!$CC$ac_delim -CFLAGS!$CFLAGS$ac_delim -ac_ct_CC!$ac_ct_CC$ac_delim -SED!$SED$ac_delim -GREP!$GREP$ac_delim -EGREP!$EGREP$ac_delim -LN_S!$LN_S$ac_delim -ECHO!$ECHO$ac_delim -AR!$AR$ac_delim -RANLIB!$RANLIB$ac_delim -STRIP!$STRIP$ac_delim -DSYMUTIL!$DSYMUTIL$ac_delim -NMEDIT!$NMEDIT$ac_delim -DLLTOOL!$DLLTOOL$ac_delim -AS!$AS$ac_delim -OBJDUMP!$OBJDUMP$ac_delim -CPP!$CPP$ac_delim -CXXCPP!$CXXCPP$ac_delim -F77!$F77$ac_delim -FFLAGS!$FFLAGS$ac_delim -ac_ct_F77!$ac_ct_F77$ac_delim -LIBTOOL!$LIBTOOL$ac_delim -SHLIB_VERSION_ARG!$SHLIB_VERSION_ARG$ac_delim -SHARED_VERSION_INFO!$SHARED_VERSION_INFO$ac_delim -PKG_CONFIG!$PKG_CONFIG$ac_delim -CROSS_COMPILING_TRUE!$CROSS_COMPILING_TRUE$ac_delim -CROSS_COMPILING_FALSE!$CROSS_COMPILING_FALSE$ac_delim -CXX_CPU_SWITCH!$CXX_CPU_SWITCH$ac_delim -HAVE_WINDOWS_TRUE!$HAVE_WINDOWS_TRUE$ac_delim -HAVE_WINDOWS_FALSE!$HAVE_WINDOWS_FALSE$ac_delim -acx_pthread_config!$acx_pthread_config$ac_delim -PTHREAD_CC!$PTHREAD_CC$ac_delim -PTHREAD_LIBS!$PTHREAD_LIBS$ac_delim -PTHREAD_CFLAGS!$PTHREAD_CFLAGS$ac_delim -HAVE_ALSA_TRUE!$HAVE_ALSA_TRUE$ac_delim -HAVE_ALSA_FALSE!$HAVE_ALSA_FALSE$ac_delim -JACK_CFLAGS!$JACK_CFLAGS$ac_delim -JACK_LIBS!$JACK_LIBS$ac_delim -HAVE_JACK_TRUE!$HAVE_JACK_TRUE$ac_delim -HAVE_JACK_FALSE!$HAVE_JACK_FALSE$ac_delim -HAVE_JACK_MIDI_TRUE!$HAVE_JACK_MIDI_TRUE$ac_delim -HAVE_JACK_MIDI_FALSE!$HAVE_JACK_MIDI_FALSE$ac_delim -ARTS_CONFIG!$ARTS_CONFIG$ac_delim -ARTS_CFLAGS!$ARTS_CFLAGS$ac_delim -ARTS_LIBS!$ARTS_LIBS$ac_delim -_ACEOF - - if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97; then - break - elif $ac_last_try; then - { { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5 -echo "$as_me: error: could not make $CONFIG_STATUS" >&2;} - { (exit 1); exit 1; }; } - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done - -ac_eof=`sed -n '/^CEOF0-9*$/s/CEOF/0/p' conf$$subs.sed` -if test -n "$ac_eof"; then - ac_eof=`echo "$ac_eof" | sort -nru | sed 1q` - ac_eof=`expr $ac_eof + 1` -fi - -cat >>$CONFIG_STATUS <<_ACEOF -cat >"\$tmp/subs-1.sed" <<\CEOF$ac_eof -/@a-zA-Z_a-zA-Z_0-9*@/!b -_ACEOF -sed ' -s/,\\&/\\&/g; s/@/@|#_!!_#|/g -s/^/s,@/; s/!/@,|#_!!_#|/ -:n -t n -s/'"$ac_delim"'$/,g/; t -s/$/\\/; p -N; s/^.*\n//; s/,\\&/\\&/g; s/@/@|#_!!_#|/g; b n -' >>$CONFIG_STATUS <conf$$subs.sed -rm -f conf$$subs.sed -cat >>$CONFIG_STATUS <<_ACEOF -CEOF$ac_eof -_ACEOF - - -ac_delim='%!_!# ' -for ac_last_try in false false false false false :; do - cat >conf$$subs.sed <<_ACEOF -HAVE_ARTS_TRUE!$HAVE_ARTS_TRUE$ac_delim -HAVE_ARTS_FALSE!$HAVE_ARTS_FALSE$ac_delim -config_asiosdk_dir!$config_asiosdk_dir$ac_delim -ASIOSDK_BASEDIR!$ASIOSDK_BASEDIR$ac_delim -HAVE_ASIO_TRUE!$HAVE_ASIO_TRUE$ac_delim -HAVE_ASIO_FALSE!$HAVE_ASIO_FALSE$ac_delim -HAVE_MIDISHARE_TRUE!$HAVE_MIDISHARE_TRUE$ac_delim -HAVE_MIDISHARE_FALSE!$HAVE_MIDISHARE_FALSE$ac_delim -HAVE_COREMIDI_TRUE!$HAVE_COREMIDI_TRUE$ac_delim -HAVE_COREMIDI_FALSE!$HAVE_COREMIDI_FALSE$ac_delim -HAVE_COREAUDIO_TRUE!$HAVE_COREAUDIO_TRUE$ac_delim -HAVE_COREAUDIO_FALSE!$HAVE_COREAUDIO_FALSE$ac_delim -HAVE_MME_MIDI_TRUE!$HAVE_MME_MIDI_TRUE$ac_delim -HAVE_MME_MIDI_FALSE!$HAVE_MME_MIDI_FALSE$ac_delim -HAVE_DSSI_TRUE!$HAVE_DSSI_TRUE$ac_delim -HAVE_DSSI_FALSE!$HAVE_DSSI_FALSE$ac_delim -LV2_CFLAGS!$LV2_CFLAGS$ac_delim -LV2_LIBS!$LV2_LIBS$ac_delim -HAVE_LV2_TRUE!$HAVE_LV2_TRUE$ac_delim -HAVE_LV2_FALSE!$HAVE_LV2_FALSE$ac_delim -VSTSDK_DIR!$VSTSDK_DIR$ac_delim -HAVE_VST_TRUE!$HAVE_VST_TRUE$ac_delim -HAVE_VST_FALSE!$HAVE_VST_FALSE$ac_delim -HAVE_AU_TRUE!$HAVE_AU_TRUE$ac_delim -HAVE_AU_FALSE!$HAVE_AU_FALSE$ac_delim -HAVE_AUFLAGS_TRUE!$HAVE_AUFLAGS_TRUE$ac_delim -HAVE_AUFLAGS_FALSE!$HAVE_AUFLAGS_FALSE$ac_delim -GIG_CFLAGS!$GIG_CFLAGS$ac_delim -GIG_LIBS!$GIG_LIBS$ac_delim -SQLITE3_CFLAGS!$SQLITE3_CFLAGS$ac_delim -SQLITE3_LIBS!$SQLITE3_LIBS$ac_delim -HAVE_SQLITE3_TRUE!$HAVE_SQLITE3_TRUE$ac_delim -HAVE_SQLITE3_FALSE!$HAVE_SQLITE3_FALSE$ac_delim -config_plugin_dir!$config_plugin_dir$ac_delim -config_default_instruments_db_file!$config_default_instruments_db_file$ac_delim -INSTALL_PROGRAM!$INSTALL_PROGRAM$ac_delim -INSTALL_SCRIPT!$INSTALL_SCRIPT$ac_delim -INSTALL_DATA!$INSTALL_DATA$ac_delim -CYGPATH_W!$CYGPATH_W$ac_delim -PACKAGE!$PACKAGE$ac_delim -VERSION!$VERSION$ac_delim -ACLOCAL!$ACLOCAL$ac_delim -AUTOCONF!$AUTOCONF$ac_delim -AUTOMAKE!$AUTOMAKE$ac_delim -AUTOHEADER!$AUTOHEADER$ac_delim -MAKEINFO!$MAKEINFO$ac_delim -AMTAR!$AMTAR$ac_delim -install_sh!$install_sh$ac_delim -INSTALL_STRIP_PROGRAM!$INSTALL_STRIP_PROGRAM$ac_delim -mkdir_p!$mkdir_p$ac_delim -AWK!$AWK$ac_delim -SET_MAKE!$SET_MAKE$ac_delim -am__leading_dot!$am__leading_dot$ac_delim -DEPDIR!$DEPDIR$ac_delim -am__include!$am__include$ac_delim -am__quote!$am__quote$ac_delim -AMDEP_TRUE!$AMDEP_TRUE$ac_delim -AMDEP_FALSE!$AMDEP_FALSE$ac_delim -AMDEPBACKSLASH!$AMDEPBACKSLASH$ac_delim -CCDEPMODE!$CCDEPMODE$ac_delim -am__fastdepCC_TRUE!$am__fastdepCC_TRUE$ac_delim -am__fastdepCC_FALSE!$am__fastdepCC_FALSE$ac_delim -CXXDEPMODE!$CXXDEPMODE$ac_delim -am__fastdepCXX_TRUE!$am__fastdepCXX_TRUE$ac_delim -am__fastdepCXX_FALSE!$am__fastdepCXX_FALSE$ac_delim -LIBOBJS!$LIBOBJS$ac_delim -LTLIBOBJS!$LTLIBOBJS$ac_delim -_ACEOF - - if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 67; then - break - elif $ac_last_try; then - { { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5 -echo "$as_me: error: could not make $CONFIG_STATUS" >&2;} - { (exit 1); exit 1; }; } - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done - -ac_eof=`sed -n '/^CEOF0-9*$/s/CEOF/0/p' conf$$subs.sed` -if test -n "$ac_eof"; then - ac_eof=`echo "$ac_eof" | sort -nru | sed 1q` - ac_eof=`expr $ac_eof + 1` -fi - -cat >>$CONFIG_STATUS <<_ACEOF -cat >"\$tmp/subs-2.sed" <<\CEOF$ac_eof -/@a-zA-Z_a-zA-Z_0-9*@/!b end -_ACEOF -sed ' -s/,\\&/\\&/g; s/@/@|#_!!_#|/g -s/^/s,@/; s/!/@,|#_!!_#|/ -:n -t n -s/'"$ac_delim"'$/,g/; t -s/$/\\/; p -N; s/^.*\n//; s/,\\&/\\&/g; s/@/@|#_!!_#|/g; b n -' >>$CONFIG_STATUS <conf$$subs.sed -rm -f conf$$subs.sed -cat >>$CONFIG_STATUS <<_ACEOF -:end -s/|#_!!_#|//g -CEOF$ac_eof -_ACEOF - - -# VPATH may cause trouble with some makes, so we remove $(srcdir), -# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and -# trailing colons and then remove the whole line if VPATH becomes empty -# (actually we leave an empty line to preserve line numbers). -if test "x$srcdir" = x.; then - ac_vpsub='/^ *VPATH *=/{ -s/:*\$(srcdir):*/:/ -s/:*\${srcdir}:*/:/ -s/:*@srcdir@:*/:/ -s/^\(^=*= *\):*/\1/ -s/:*$// -s/^^=*= *$// -}' -fi - -cat >>$CONFIG_STATUS <<\_ACEOF -fi # test -n "$CONFIG_FILES" - - -for ac_tag in :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS -do - case $ac_tag in - :FHLC) ac_mode=$ac_tag; continue;; - esac - case $ac_mode$ac_tag in - :FHL*:*);; - :L* | :C*:*) { { echo "$as_me:$LINENO: error: Invalid tag $ac_tag." >&5 -echo "$as_me: error: Invalid tag $ac_tag." >&2;} - { (exit 1); exit 1; }; };; - :FH-) ac_tag=-:-;; - :FH*) ac_tag=$ac_tag:$ac_tag.in;; - esac - ac_save_IFS=$IFS - IFS=: - set x $ac_tag - IFS=$ac_save_IFS - shift - ac_file=$1 - shift - - case $ac_mode in - :L) ac_source=$1;; - :FH) - ac_file_inputs= - for ac_f - do - case $ac_f in - -) ac_f="$tmp/stdin";; - *) # Look for the file first in the build tree, then in the source tree - # (if the path is not absolute). The absolute path cannot be DOS-style, - # because $ac_f cannot contain `:'. - test -f "$ac_f" || - case $ac_f in - \\/$*) false;; - *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; - esac || - { { echo "$as_me:$LINENO: error: cannot find input file: $ac_f" >&5 -echo "$as_me: error: cannot find input file: $ac_f" >&2;} - { (exit 1); exit 1; }; };; - esac - ac_file_inputs="$ac_file_inputs $ac_f" - done - - # Let's still pretend it is `configure' which instantiates (i.e., don't - # use $as_me), people would be surprised to read: - # /* config.h. Generated by config.status. */ - configure_input="Generated from "`IFS=: - echo $* | sed 's|^^:*/||;s|:^:*/|, |g'`" by configure." - if test x"$ac_file" != x-; then - configure_input="$ac_file. $configure_input" - { echo "$as_me:$LINENO: creating $ac_file" >&5 -echo "$as_me: creating $ac_file" >&6;} - fi - - case $ac_tag in - *:-:* | *:-) cat >"$tmp/stdin";; - esac - ;; - esac - - ac_dir=`$as_dirname -- "$ac_file" || -$as_expr X"$ac_file" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$ac_file" : 'X\(//\)^/' \| \ - X"$ac_file" : 'X\(//\)$' \| \ - X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || -echo X"$ac_file" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - { as_dir="$ac_dir" - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || { $as_mkdir_p && mkdir -p "$as_dir"; } || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$as_dir" : 'X\(//\)^/' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -echo X"$as_dir" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || { { echo "$as_me:$LINENO: error: cannot create directory $as_dir" >&5 -echo "$as_me: error: cannot create directory $as_dir" >&2;} - { (exit 1); exit 1; }; }; } - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.\\/,,'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`echo "$ac_dir_suffix" | sed 's,/^\\/*,/..,g;s,/,,'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - \\/* | ?:\\/* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - - case $ac_mode in - :F) - # - # CONFIG_FILE - # - - case $INSTALL in - \\/$* | ?:\\/* ) ac_INSTALL=$INSTALL ;; - *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; - esac -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF -# If the template does not know about datarootdir, expand it. -# FIXME: This hack should be removed a few years after 2.60. -ac_datarootdir_hack=; ac_datarootdir_seen= - -case `sed -n '/datarootdir/ { - p - q -} -/@datadir@/p -/@docdir@/p -/@infodir@/p -/@localedir@/p -/@mandir@/p -' $ac_file_inputs` in -*datarootdir*) ac_datarootdir_seen=yes;; -*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) - { echo "$as_me:$LINENO: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 -echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF - ac_datarootdir_hack=' - s&@datadir@&$datadir&g - s&@docdir@&$docdir&g - s&@infodir@&$infodir&g - s&@localedir@&$localedir&g - s&@mandir@&$mandir&g - s&\\\${datarootdir}&$datarootdir&g' ;; -esac -_ACEOF - -# Neutralize VPATH when `$srcdir' = `.'. -# Shell code in configure.ac might set extrasub. -# FIXME: do we really want to maintain this feature? -cat >>$CONFIG_STATUS <<_ACEOF - sed "$ac_vpsub -$extrasub -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF -:t -/@a-zA-Z_a-zA-Z_0-9*@/!b -s&@configure_input@&$configure_input&;t t -s&@top_builddir@&$ac_top_builddir_sub&;t t -s&@srcdir@&$ac_srcdir&;t t -s&@abs_srcdir@&$ac_abs_srcdir&;t t -s&@top_srcdir@&$ac_top_srcdir&;t t -s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t -s&@builddir@&$ac_builddir&;t t -s&@abs_builddir@&$ac_abs_builddir&;t t -s&@abs_top_builddir@&$ac_abs_top_builddir&;t t -s&@INSTALL@&$ac_INSTALL&;t t -$ac_datarootdir_hack -" $ac_file_inputs | sed -f "$tmp/subs-1.sed" | sed -f "$tmp/subs-2.sed" >$tmp/out - -test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^ *datarootdir *:*=/p' "$tmp/out"`; test -z "$ac_out"; } && - { echo "$as_me:$LINENO: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined." >&5 -echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined." >&2;} - - rm -f "$tmp/stdin" - case $ac_file in - -) cat "$tmp/out"; rm -f "$tmp/out";; - *) rm -f "$ac_file"; mv "$tmp/out" $ac_file;; - esac - ;; - :H) - # - # CONFIG_HEADER - # -_ACEOF - -# Transform confdefs.h into a sed script `conftest.defines', that -# substitutes the proper values into config.h.in to produce config.h. -rm -f conftest.defines conftest.tail -# First, append a space to every undef/define line, to ease matching. -echo 's/$/ /' >conftest.defines -# Then, protect against being on the right side of a sed subst, or in -# an unquoted here document, in config.status. If some macros were -# called several times there might be several #defines for the same -# symbol, which is useless. But do not sort them, since the last -# AC_DEFINE must be honored. -ac_word_re=_$as_cr_Letters_$as_cr_alnum* -# These sed commands are passed to sed as "A NAME B PARAMS C VALUE D", where -# NAME is the cpp macro being defined, VALUE is the value it is being given. -# PARAMS is the parameter list in the macro definition--in most cases, it's -# just an empty string. -ac_dA='s,^\\( #*\\)^ *\\( *' -ac_dB='\\) (.*,\\1define\\2' -ac_dC=' ' -ac_dD=' ,' - -uniq confdefs.h | - sed -n ' - t rset - :rset - s/^ *# *define *// - t ok - d - :ok - s/\\&,/\\&/g - s/^\('"$ac_word_re"'\)\((^()*)\) *\(.*\)/ '"$ac_dA"'\1'"$ac_dB"'\2'"${ac_dC}"'\3'"$ac_dD"'/p - s/^\('"$ac_word_re"'\) *\(.*\)/'"$ac_dA"'\1'"$ac_dB$ac_dC"'\2'"$ac_dD"'/p - ' >>conftest.defines - -# Remove the space that was appended to ease matching. -# Then replace #undef with comments. This is necessary, for -# example, in the case of _POSIX_SOURCE, which is predefined and required -# on some systems where configure will not decide to define it. -# (The regexp can be short, since the line contains either #define or #undef.) -echo 's/ $// -s,^ #*u.*,/* & */,' >>conftest.defines - -# Break up conftest.defines: -ac_max_sed_lines=50 - -# First sed command is: sed -f defines.sed $ac_file_inputs >"$tmp/out1" -# Second one is: sed -f defines.sed "$tmp/out1" >"$tmp/out2" -# Third one will be: sed -f defines.sed "$tmp/out2" >"$tmp/out1" -# et cetera. -ac_in='$ac_file_inputs' -ac_out='"$tmp/out1"' -ac_nxt='"$tmp/out2"' - -while : -do - # Write a here document: - cat >>$CONFIG_STATUS <<_ACEOF - # First, check the format of the line: - cat >"\$tmp/defines.sed" <<\\CEOF -/^ *# *undef *$ac_word_re *\$/b def -/^ *# *define *$ac_word_re( /b def -b -:def -_ACEOF - sed ${ac_max_sed_lines}q conftest.defines >>$CONFIG_STATUS - echo 'CEOF - sed -f "$tmp/defines.sed"' "$ac_in >$ac_out" >>$CONFIG_STATUS - ac_in=$ac_out; ac_out=$ac_nxt; ac_nxt=$ac_in - sed 1,${ac_max_sed_lines}d conftest.defines >conftest.tail - grep . conftest.tail >/dev/null || break - rm -f conftest.defines - mv conftest.tail conftest.defines -done -rm -f conftest.defines conftest.tail - -echo "ac_result=$ac_in" >>$CONFIG_STATUS -cat >>$CONFIG_STATUS <<\_ACEOF - if test x"$ac_file" != x-; then - echo "/* $configure_input */" >"$tmp/config.h" - cat "$ac_result" >>"$tmp/config.h" - if diff $ac_file "$tmp/config.h" >/dev/null 2>&1; then - { echo "$as_me:$LINENO: $ac_file is unchanged" >&5 -echo "$as_me: $ac_file is unchanged" >&6;} - else - rm -f $ac_file - mv "$tmp/config.h" $ac_file - fi - else - echo "/* $configure_input */" - cat "$ac_result" - fi - rm -f "$tmp/out12" -# Compute $ac_file's index in $config_headers. -_am_stamp_count=1 -for _am_header in $config_headers :; do - case $_am_header in - $ac_file | $ac_file:* ) - break ;; - * ) - _am_stamp_count=`expr $_am_stamp_count + 1` ;; - esac -done -echo "timestamp for $ac_file" >`$as_dirname -- $ac_file || -$as_expr X$ac_file : 'X\(.*^/\)//*^/^/*/*$' \| \ - X$ac_file : 'X\(//\)^/' \| \ - X$ac_file : 'X\(//\)$' \| \ - X$ac_file : 'X\(/\)' \| . 2>/dev/null || -echo X$ac_file | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'`/stamp-h$_am_stamp_count - ;; - - :C) { echo "$as_me:$LINENO: executing $ac_file commands" >&5 -echo "$as_me: executing $ac_file commands" >&6;} - ;; - esac - - - case $ac_file$ac_mode in - "depfiles":C) test x"$AMDEP_TRUE" != x"" || for mf in $CONFIG_FILES; do - # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named `Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # So let's grep whole file. - if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then - dirpart=`$as_dirname -- "$mf" || -$as_expr X"$mf" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$mf" : 'X\(//\)^/' \| \ - X"$mf" : 'X\(//\)$' \| \ - X"$mf" : 'X\(/\)' \| . 2>/dev/null || -echo X"$mf" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - else - continue - fi - grep '^DEP_FILES *= *^ #' < "$mf" > /dev/null || continue - # Extract the definition of DEP_FILES from the Makefile without - # running `make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - # When using ansi2knr, U may be empty or an underscore; expand it - U=`sed -n 's/^U = //p' < "$mf"` - test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR" - # We invoke sed twice because it is the simplest approach to - # changing $(DEPDIR) to its actual value in the expansion. - for file in `sed -n ' - /^DEP_FILES = .*\\\\$/ { - s/^DEP_FILES = // - :loop - s/\\\\$// - p - n - /\\\\$/ b loop - p - } - /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`$as_dirname -- "$file" || -$as_expr X"$file" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$file" : 'X\(//\)^/' \| \ - X"$file" : 'X\(//\)$' \| \ - X"$file" : 'X\(/\)' \| . 2>/dev/null || -echo X"$file" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - { as_dir=$dirpart/$fdir - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || { $as_mkdir_p && mkdir -p "$as_dir"; } || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*^/\)//*^/^/*/*$' \| \ - X"$as_dir" : 'X\(//\)^/' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -echo X"$as_dir" | - sed '/^X\(.*^/\)\/\/*^/^/*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)^/.*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || { { echo "$as_me:$LINENO: error: cannot create directory $as_dir" >&5 -echo "$as_me: error: cannot create directory $as_dir" >&2;} - { (exit 1); exit 1; }; }; } - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done -done - ;; - - esac -done # for ac_tag - - -{ (exit 0); exit 0; } -_ACEOF -chmod +x $CONFIG_STATUS -ac_clean_files=$ac_clean_files_save - - -# configure is writing to config.log, and then calls config.status. -# config.status does its own redirection, appending to config.log. -# Unfortunately, on DOS this fails, as config.log is still kept open -# by configure, so config.status won't be able to write to it; its -# output is simply discarded. So we exec the FD to /dev/null, -# effectively closing config.log, so it can be properly (re)opened and -# appended to by config.status. When coming back to configure, we -# need to make the FD available again. -if test "$no_create" != yes; then - ac_cs_success=: - ac_config_status_args= - test "$silent" = yes && - ac_config_status_args="$ac_config_status_args --quiet" - exec 5>/dev/null - $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false - exec 5>>config.log - # Use ||, not &&, to avoid exiting from the if with $? = 1, which - # would make configure fail if this is the last instruction. - $ac_cs_success || { (exit 1); exit 1; } -fi - - -# resolve all nested variables in '${config_plugin_dir}' -# (merely for providing a human readable summary below) -while test $config_plugin_dir != `eval echo ${config_plugin_dir}` ; do - config_plugin_dir=`eval echo ${config_plugin_dir}` -done - - -########################################################################### -# Output All Configuration Options - -echo "" -echo "#####################################################################" -echo "# LinuxSampler Configuration #" -echo "#-------------------------------------------------------------------#" -echo "# Release Version: ${LINUXSAMPLER_RELEASE_MAJOR}.${LINUXSAMPLER_RELEASE_MINOR}.${LINUXSAMPLER_RELEASE_BUILD}" -echo "# LSCP Version: ${LSCP_RELEASE_MAJOR}.${LSCP_RELEASE_MINOR}" -echo "#-------------------------------------------------------------------" -echo "# Assembly Optimizations: ${config_asm}" -echo "# Development Mode: ${config_dev_mode}" -echo "# Debug Level: ${config_debug_level}" -echo "# Use Exceptions in RT Context: ${config_rt_exceptions}" -echo "# Preload Samples: ${config_preload_samples}" -echo "# Maximum Pitch: ${config_max_pitch} (octaves)" -echo "# Maximum Events: ${config_max_events}" -echo "# Envelope Bottom Level: ${config_eg_bottom} (linear)" -echo "# Envelope Minimum Release Time: ${config_eg_min_release_time} s" -echo "# Streams to be refilled per Disk Thread Cycle: ${config_refill_streams}" -echo "# Minimum Stream Refill Size: ${config_stream_min_refill}" -echo "# Maximum Stream Refill Size: ${config_stream_max_refill}" -echo "# Stream Size: ${config_stream_size}" -echo "# Default Maximum Disk Streams: ${config_max_streams}" -echo "# Default Maximum Voices: ${config_max_voices}" -echo "# Default Subfragment Size: ${config_subfragment_size}" -echo "# Default Global Volume Attenuation: ${config_global_attenuation_default}" -echo "# Voice Stealing Algorithm: ${config_voice_steal_algo}" -echo "# Signed Triangular Oscillator Algorithm: ${config_signed_triang_algo}" -echo "# Unsigned Triangular Oscillator Algorithm: ${config_unsigned_triang_algo}" -echo "# SysEx Buffer Size: ${config_sysex_buffer_size} Byte" -echo "# Min. Portamento Time: ${config_portamento_time_min} s" -echo "# Max. Portamento Time: ${config_portamento_time_max} s" -echo "# Default Portamento Time: ${config_portamento_time_default} s" -echo "# Force Filter Usage: ${config_force_filter}" -echo "# Filter Cutoff Minimum: ${config_filter_cutoff_min} Hz" -echo "# Filter Cutoff Maximum: ${config_filter_cutoff_max} Hz" -echo "# Override Filter Cutoff Controller: ${config_override_cutoff_ctrl}" -echo "# Override Filter Resonance Controller: ${config_override_resonance_ctrl}" -echo "# Override Filter Type: ${config_override_filter_type}" -echo "# Assert GS SysEx Checksum: ${config_assert_gs_sysex_checksum}" -echo "# Process Muted Channels: ${config_process_muted_channels}" -echo "# Process All-Notes-Off MIDI message: ${config_process_all_notes_off}" -echo "# Apply global volume SysEx by MIDI port: ${config_master_volume_sysex_by_port}" -echo "# Interpolate Volume: ${config_interpolate_volume}" -echo "# Instruments database support: ${config_instruments_db}" -if test "$config_instruments_db" = "yes"; then -echo "# Instruments DB default location: ${config_default_instruments_db_file}" -fi -echo "# Plugin Path: ${config_plugin_dir}" -echo "#-------------------------------------------------------------------" -echo "# MIDI Input Drivers:" -echo "# ALSA: ${config_have_alsa}, JACK: ${config_have_jack_midi}, CoreMIDI: ${config_have_coremidi}, MME: ${config_have_mme}, MidiShare: ${config_have_midishare}" -echo "#-------------------------------------------------------------------" -echo "# Audio Output Drivers:" -echo "# ALSA: ${config_have_alsa}, JACK: ${config_have_jack}, ARTS: ${config_have_arts}, CoreAudio: ${config_have_coreaudio}, ASIO: ${config_have_asio}" -echo "#-------------------------------------------------------------------" -echo "# Building sampler as plugin for following host standards:" -echo "# DSSI: ${config_have_dssi}, LV2: ${config_have_lv2}, VST: ${config_have_vst}, AU: ${config_have_au}" -echo "#-------------------------------------------------------------------#" -echo "# Read './configure --help' or file 'configure.in' for details. #" -echo "#####################################################################" -echo "" -echo "Good. Now type 'make' to compile, followed by 'make install' as root." -echo ""
View file
linuxsampler-1.0.0.tar.bz2/debian/Makefile.in
Deleted
@@ -1,398 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = debian -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ - -# include debian files into distribution -EXTRA_DIST = changelog \ - compat \ - control \ - copyright \ - dirs \ - docs \ - liblinuxsampler-dev.doc-base \ - liblinuxsampler-dev.docs \ - liblinuxsampler-dev.install \ - liblinuxsampler.docs \ - liblinuxsampler.install \ - linuxsampler.docs \ - linuxsampler.install \ - linuxsampler.1 \ - linuxsampler.sgml \ - postinst \ - postrm \ - rules \ - README.Debian - -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu debian/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu debian/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-generic \ - mostlyclean-libtool pdf pdf-am ps ps-am uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/depcomp
Deleted
@@ -1,526 +0,0 @@ -#! /bin/sh -# depcomp - compile a program generating dependencies as side-effects - -scriptversion=2004-04-25.13 - -# Copyright (C) 1999, 2000, 2003, 2004 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@dcc.unicamp.br>. - -case $1 in - '') - echo "$0: No command. Try \`$0 --help' for more information." 1>&2 - exit 1; - ;; - -h | --h*) - cat <<\EOF -Usage: depcomp --help --version PROGRAM ARGS - -Run PROGRAMS ARGS to compile a file, generating dependencies -as side-effects. - -Environment variables: - depmode Dependency tracking mode. - source Source file read by `PROGRAMS ARGS'. - object Object file output by `PROGRAMS ARGS'. - depfile Dependency file to output. - tmpdepfile Temporary file to use when outputing dependencies. - libtool Whether libtool is used (yes/no). - -Report bugs to <bug-automake@gnu.org>. -EOF - exit 0 - ;; - -v | --v*) - echo "depcomp $scriptversion" - exit 0 - ;; -esac - -if test -z "$depmode" || test -z "$source" || test -z "$object"; then - echo "depcomp: Variables source, object and depmode must be set" 1>&2 - exit 1 -fi -# `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. In older versions, this file always lives in the - # current directory. Also, the AIX compiler puts `$object:' at the - # start of each line; $object doesn't have directory information. - # Version 6 uses the directory in both cases. - stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'` - tmpdepfile="$stripped.u" - if test "$libtool" = yes; then - "$@" -Wc,-M - else - "$@" -M - fi - stat=$? - - if test -f "$tmpdepfile"; then : - else - stripped=`echo "$stripped" | sed 's,^.*/,,'` - tmpdepfile="$stripped.u" - fi - - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - - if test -f "$tmpdepfile"; then - outname="$stripped.o" - # Each line is of the form `foo.o: dependent.h'. - # Do two passes, one to just change these to - # `$object: dependent.h' and one to simply `dependent.h:'. - sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile" - sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile" - else - # The sourcefile does not contain any dependencies, so just - # store a dummy comment line, to avoid errors with the Makefile - # "include basename.Plo" scheme. - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" - ;; - -icc) - # Intel's C compiler understands `-MD -MF file'. However on - # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c - # ICC 7.0 will fill foo.d with something like - # foo.o: sub/foo.c - # foo.o: sub/foo.h - # which is wrong. We want: - # sub/foo.o: sub/foo.c - # sub/foo.o: sub/foo.h - # sub/foo.c: - # sub/foo.h: - # ICC 7.1 will output - # foo.o: sub/foo.c sub/foo.h - # and will wrap long lines using \ : - # foo.o: sub/foo.c ... \ - # sub/foo.h ... \ - # ... - - "$@" -MD -MF "$tmpdepfile" - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - rm -f "$depfile" - # Each line is of the form `foo.o: dependent.h', - # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. - # Do two passes, one to just change these to - # `$object: dependent.h' and one to simply `dependent.h:'. - sed "s,^^:*:,$object :," < "$tmpdepfile" > "$depfile" - # Some versions of the HPUX 10.20 sed can't process this invocation - # correctly. Breaking it into two sed invocations is a workaround. - sed 's,^^:*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" | - sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -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 - # Dependencies are output in .lo.d with libtool 1.4. - # They are output in .o.d with libtool 1.5. - tmpdepfile1="$dir.libs/$base.lo.d" - tmpdepfile2="$dir.libs/$base.o.d" - tmpdepfile3="$dir.libs/$base.d" - "$@" -Wc,-MD - else - tmpdepfile1="$dir$base.o.d" - tmpdepfile2="$dir$base.d" - tmpdepfile3="$dir$base.d" - "$@" -MD - fi - - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" - exit $stat - fi - - if test -f "$tmpdepfile1"; then - tmpdepfile="$tmpdepfile1" - elif test -f "$tmpdepfile2"; then - tmpdepfile="$tmpdepfile2" - else - tmpdepfile="$tmpdepfile3" - fi - if test -f "$tmpdepfile"; then - sed -e "s,^.*\.a-z*:,$object:," < "$tmpdepfile" > "$depfile" - # That's a tab and a space in the . - sed -e 's,^.*\.a-z*: *,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" - else - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" - ;; - -#nosideeffect) - # This comment above is used by automake to tell side-effect - # dependency tracking mechanisms from slower ones. - -dashmstdout) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout, regardless of -o. - "$@" || exit $? - - # Remove the call to Libtool. - if test "$libtool" = yes; then - while test $1 != '--mode=compile'; do - shift - done - shift - fi - - # Remove `-o $object'. - IFS=" " - for arg - do - case $arg in - -o) - shift - ;; - $object) - shift - ;; - *) - set fnord "$@" "$arg" - shift # fnord - shift # $arg - ;; - esac - done - - test -z "$dashmflag" && dashmflag=-M - # Require at least two characters before searching for `:' - # in the target name. This is to cope with DOS-style filenames: - # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise. - "$@" $dashmflag | - sed 's:^ *^: ^:^:*\: *:'"$object"'\: :' > "$tmpdepfile" - rm -f "$depfile" - cat < "$tmpdepfile" > "$depfile" - tr ' ' ' -' < "$tmpdepfile" | \ -## Some versions of the HPUX 10.20 sed can't process this invocation -## correctly. Breaking it into two sed invocations is a workaround. - sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -dashXmstdout) - # This case only exists to satisfy depend.m4. It is never actually - # run, as this mode is specially recognized in the preamble. - exit 1 - ;; - -makedepend) - "$@" || exit $? - # Remove any Libtool call - if test "$libtool" = yes; then - while test $1 != '--mode=compile'; do - shift - done - shift - fi - # X makedepend - shift - cleared=no - for arg in "$@"; do - case $cleared in - no) - set ""; shift - cleared=yes ;; - esac - case "$arg" in - -D*|-I*) - set fnord "$@" "$arg"; shift ;; - # Strip any option that makedepend may not understand. Remove - # the object too, otherwise makedepend will parse it as a source file. - -*|$object) - ;; - *) - set fnord "$@" "$arg"; shift ;; - esac - done - obj_suffix="`echo $object | sed 's/^.*\././'`" - touch "$tmpdepfile" - ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" - rm -f "$depfile" - cat < "$tmpdepfile" > "$depfile" - sed '1,2d' "$tmpdepfile" | tr ' ' ' -' | \ -## Some versions of the HPUX 10.20 sed can't process this invocation -## correctly. Breaking it into two sed invocations is a workaround. - sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" "$tmpdepfile".bak - ;; - -cpp) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout. - "$@" || exit $? - - # Remove the call to Libtool. - if test "$libtool" = yes; then - while test $1 != '--mode=compile'; do - shift - done - shift - fi - - # Remove `-o $object'. - IFS=" " - for arg - do - case $arg in - -o) - shift - ;; - $object) - shift - ;; - *) - set fnord "$@" "$arg" - shift # fnord - shift # $arg - ;; - esac - done - - "$@" -E | - sed -n '/^# 0-90-9* "\(^"*\)".*/ s:: \1 \\:p' | - sed '$ s: \\$::' > "$tmpdepfile" - rm -f "$depfile" - echo "$object : \\" > "$depfile" - cat < "$tmpdepfile" >> "$depfile" - sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -msvisualcpp) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout, regardless of -o, - # because we must use -o when running libtool. - "$@" || exit $? - IFS=" " - for arg - do - case "$arg" in - "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") - set fnord "$@" - shift - shift - ;; - *) - set fnord "$@" "$arg" - shift - shift - ;; - esac - done - "$@" -E | - sed -n '/^#line 0-90-9* "\(^"*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile" - rm -f "$depfile" - echo "$object : \\" > "$depfile" - . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile" - echo " " >> "$depfile" - . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -none) - exec "$@" - ;; - -*) - echo "Unknown depmode $depmode" 1>&2 - exit 1 - ;; -esac - -exit 0 - -# Local Variables: -# mode: shell-script -# sh-indentation: 2 -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-end: "$" -# End:
View file
linuxsampler-1.0.0.tar.bz2/install-sh
Deleted
@@ -1,325 +0,0 @@ -#!/bin/sh -# install - install a program, script, or datafile - -scriptversion=2004-04-01.17 - -# This originates from X11R5 (mit/util/scripts/install.sh), which was -# later released in X11R6 (xc/config/util/install.sh) with the -# following copyright and license. -# -# Copyright (C) 1994 X Consortium -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to -# deal in the Software without restriction, including without limitation the -# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or -# sell copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- -# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# -# Except as contained in this notice, the name of the X Consortium shall not -# be used in advertising or otherwise to promote the sale, use or other deal- -# ings in this Software without prior written authorization from the X Consor- -# tium. -# -# -# FSF changes to this file are in the public domain. -# -# Calling this script install-sh is preferred over install.sh, to prevent -# `make' implicit rules from creating a file called install from it -# when there is no Makefile. -# -# This script is compatible with the BSD install script, but was written -# from scratch. 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= - -usage="Usage: $0 OPTION... SRCFILE DSTFILE - or: $0 OPTION... SRCFILES... DIRECTORY - or: $0 -d DIRECTORIES... - -In the first form, install SRCFILE to DSTFILE, removing SRCFILE by default. -In the second, create the directory path DIR. - -Options: --b=TRANSFORMBASENAME --c copy source (using $cpprog) instead of moving (using $mvprog). --d create directories instead of installing files. --g GROUP $chgrp installed files to GROUP. --m MODE $chmod installed files to MODE. --o USER $chown installed files to USER. --s strip installed files (using $stripprog). --t=TRANSFORM ---help display this help and exit. ---version display version info and exit. - -Environment variables override the default commands: - CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG -" - -while test -n "$1"; do - case $1 in - -b=*) transformbasename=`echo $1 | sed 's/-b=//'` - shift - continue;; - - -c) instcmd=$cpprog - shift - continue;; - - -d) dir_arg=true - shift - continue;; - - -g) chgrpcmd="$chgrpprog $2" - shift - shift - continue;; - - --help) echo "$usage"; exit 0;; - - -m) chmodcmd="$chmodprog $2" - shift - shift - continue;; - - -o) chowncmd="$chownprog $2" - shift - shift - continue;; - - -s) stripcmd=$stripprog - shift - continue;; - - -t=*) transformarg=`echo $1 | sed 's/-t=//'` - shift - continue;; - - --version) echo "$0 $scriptversion"; exit 0;; - - *) # When -d is used, all remaining arguments are directories to create. - test -n "$dir_arg" && break - # Otherwise, the last argument is the destination. Remove it from $@. - for arg - do - if test -n "$dstarg"; then - # $@ is not empty: it contains at least $arg. - set fnord "$@" "$dstarg" - shift # fnord - fi - shift # arg - dstarg=$arg - done - break;; - esac -done - -if test -z "$1"; then - if test -z "$dir_arg"; then - echo "$0: no input file specified." >&2 - exit 1 - fi - # It's OK to call `install-sh -d' without argument. - # This can happen when creating conditional directories. - exit 0 -fi - -for src -do - # Protect names starting with `-'. - case $src in - -*) src=./$src ;; - esac - - if test -n "$dir_arg"; then - dst=$src - src= - - if test -d "$dst"; then - instcmd=: - chmodcmd= - else - instcmd=$mkdirprog - 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 test ! -f "$src" && test ! -d "$src"; then - echo "$0: $src does not exist." >&2 - exit 1 - fi - - if test -z "$dstarg"; then - echo "$0: no destination specified." >&2 - exit 1 - fi - - dst=$dstarg - # Protect names starting with `-'. - case $dst in - -*) dst=./$dst ;; - esac - - # If destination is a directory, append the input filename; won't work - # if double slashes aren't ignored. - if test -d "$dst"; then - dst=$dst/`basename "$src"` - fi - fi - - # This sed command emulates the dirname command. - dstdir=`echo "$dst" | sed -e 's,^/*$,,;s,/$,,;s,^$,.,'` - - # Make sure that the destination directory exists. - - # Skip lots of stat calls in the usual case. - if test ! -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 test $# -ne 0 ; do - pathcomp=$pathcomp$1 - shift - if test ! -d "$pathcomp"; then - $mkdirprog "$pathcomp" || lasterr=$? - # mkdir can fail with a `File exist' error in case several - # install-sh are creating the directory concurrently. This - # is OK. - test ! -d "$pathcomp" && { (exit ${lasterr-1}); exit; } - fi - pathcomp=$pathcomp/ - done - fi - - if test -n "$dir_arg"; then - $doit $instcmd "$dst" \ - && { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \ - && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \ - && { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \ - && { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; } - - else - # If we're going to rename the final executable, determine the name now. - if test -z "$transformarg"; then - dstfile=`basename "$dst"` - else - dstfile=`basename "$dst" $transformbasename \ - | sed $transformarg`$transformbasename - fi - - # don't allow the sed command to completely eliminate the filename. - test -z "$dstfile" && dstfile=`basename "$dst"` - - # Make a couple of temp file names in the proper directory. - dsttmp=$dstdir/_inst.$$_ - rmtmp=$dstdir/_rm.$$_ - - # Trap to clean up those temp files at exit. - trap 'status=$?; rm -f "$dsttmp" "$rmtmp" && exit $status' 0 - trap '(exit $?); exit' 1 2 13 15 - - # Move or copy the file name to the temp name - $doit $instcmd "$src" "$dsttmp" && - - # and set any options; do chmod last to preserve setuid bits. - # - # If any of these fail, we abort the whole thing. If we want to - # ignore errors from any of these, just make sure not to ignore - # errors from the above "$doit $instcmd $src $dsttmp" command. - # - { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \ - && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \ - && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \ - && { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } && - - # Now rename the file to the real destination. - { $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \ - || { - # The rename failed, perhaps because mv can't rename something else - # to itself, or perhaps because mv is so ancient that it does not - # support -f. - - # Now remove or move aside any old file at destination location. - # We try this two ways since rm can't unlink itself on some - # systems and the destination file might be busy for other - # reasons. In this case, the final cleanup might fail but the new - # file should still install successfully. - { - if test -f "$dstdir/$dstfile"; then - $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \ - || $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \ - || { - echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2 - (exit 1); exit - } - else - : - fi - } && - - # Now rename the file to the real destination. - $doit $mvcmd "$dsttmp" "$dstdir/$dstfile" - } - } - fi || { (exit 1); exit; } -done - -# The final little trick to "correctly" pass the exit status to the exit trap. -{ - (exit 0); exit -} - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-end: "$" -# End:
View file
linuxsampler-1.0.0.tar.bz2/ltmain.sh
Deleted
@@ -1,6964 +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, 2006, -# 2007, 2008 Free Software Foundation, Inc. -# Originally by Gordon Matzigkeit <gord@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.26 Debian 1.5.26-4" -TIMESTAMP=" (1.1220.2.493 2008/02/01 16:58:18)" - -# Be Bourne compatible (taken from Autoconf:_AS_BOURNE_COMPATIBLE). -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac -fi -BIN_SH=xpg4; export BIN_SH # for Tru64 -DUALCASE=1; export DUALCASE # for MKS sh - -# 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 X|tr X '\101'` in - A) # ASCII based system - # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr - SP2NL='tr \040 \012' - NL2SP='tr \015\012 \040\040' - ;; - *) # EBCDIC based system - SP2NL='tr \100 \n' - NL2SP='tr \r\n \100\100' - ;; -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. -lt_env= -for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES -do - eval "if test \"\${$lt_var+set}\" = set; then - save_$lt_var=\$$lt_var - lt_env=\"$lt_var=\$$lt_var \$lt_env\" - $lt_var=C - export $lt_var - fi" -done - -if test -n "$lt_env"; then - lt_env="env $lt_env" -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= -duplicate_deps=no -preserve_args= -lo2o="s/\\.lo\$/.${objext}/" -o2lo="s/\\.${objext}\$/.lo/" -extracted_archives= -extracted_serial=0 - -##################################### -# Shell function definitions: -# This seems to be the best place for them - -# func_mktempdir string -# Make a temporary directory that won't clash with other running -# libtool processes, and avoids race conditions if possible. If -# given, STRING is the basename for that directory. -func_mktempdir () -{ - my_template="${TMPDIR-/tmp}/${1-$progname}" - - if test "$run" = ":"; then - # Return a directory name, but don't create it in dry-run mode - my_tmpdir="${my_template}-$$" - else - - # If mktemp works, use that first and foremost - my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null` - - if test ! -d "$my_tmpdir"; then - # Failing that, at least try and use $RANDOM to avoid a race - my_tmpdir="${my_template}-${RANDOM-0}$$" - - save_mktempdir_umask=`umask` - umask 0077 - $mkdir "$my_tmpdir" - umask $save_mktempdir_umask - fi - - # If we're not in dry-run mode, bomb out on failure - test -d "$my_tmpdir" || { - $echo "cannot create temporary directory \`$my_tmpdir'" 1>&2 - exit $EXIT_FAILURE - } - fi - - $echo "X$my_tmpdir" | $Xsed -} - - -# 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 /{ - s,.*,import, - p - q - } - }'` - case $win32_nmres in - import*) win32_libid_type="x86 archive import";; - *) win32_libid_type="x86 archive static";; - esac - fi - ;; - *DLL*) - win32_libid_type="x86 DLL" - ;; - *executable*) # but shell scripts are "executable" too... - case $win32_fileres in - *MS\ Windows\ PE\ Intel*) - win32_libid_type="x86 DLL" - ;; - esac - ;; - esac - $echo $win32_libid_type -} - - -# func_infer_tag arg -# Infer tagged configuration to use if any are available and -# if one wasn't chosen via the "--tag" command line option. -# Only attempt this if the compiler in the base compile -# command doesn't match the default compiler. -# arg is usually of the form 'gcc ...' -func_infer_tag () -{ - if test -n "$available_tags" && test -z "$tagname"; then - CC_quoted= - for arg in $CC; do - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - CC_quoted="$CC_quoted $arg" - done - case $@ in - # Blanks in the command may have been stripped by the calling shell, - # but not from the CC environment variable when configure was run. - " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;; - # Blanks at the start of $base_compile will cause this to fail - # if we don't check for them as well. - *) - for z in $available_tags; do - if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then - # Evaluate the configuration. - eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" - CC_quoted= - for arg in $CC; do - # Double-quote args containing other shell metacharacters. - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - CC_quoted="$CC_quoted $arg" - done - case "$@ " in - " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) - # The compiler in the base compile command matches - # the one in the tagged configuration. - # Assume this is the tagged configuration we want. - tagname=$z - break - ;; - esac - fi - done - # If $tagname still isn't set, then no tagged configuration - # was found and let the user know that the "--tag" command - # line option must be used. - if test -z "$tagname"; then - $echo "$modename: unable to infer tagged configuration" - $echo "$modename: specify a tag with \`--tag'" 1>&2 - exit $EXIT_FAILURE -# else -# $echo "$modename: using $tagname tagged configuration" - fi - ;; - esac - fi -} - - -# func_extract_an_archive dir oldlib -func_extract_an_archive () -{ - f_ex_an_ar_dir="$1"; shift - f_ex_an_ar_oldlib="$1" - - $show "(cd $f_ex_an_ar_dir && $AR x $f_ex_an_ar_oldlib)" - $run eval "(cd \$f_ex_an_ar_dir && $AR x \$f_ex_an_ar_oldlib)" || exit $? - if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then - : - else - $echo "$modename: ERROR: object name conflicts: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" 1>&2 - exit $EXIT_FAILURE - fi -} - -# func_extract_archives gentop oldlib ... -func_extract_archives () -{ - my_gentop="$1"; shift - my_oldlibs=${1+"$@"} - my_oldobjs="" - my_xlib="" - my_xabs="" - my_xdir="" - my_status="" - - $show "${rm}r $my_gentop" - $run ${rm}r "$my_gentop" - $show "$mkdir $my_gentop" - $run $mkdir "$my_gentop" - my_status=$? - if test "$my_status" -ne 0 && test ! -d "$my_gentop"; then - exit $my_status - fi - - for my_xlib in $my_oldlibs; do - # Extract the objects. - case $my_xlib in - \\/* | A-Za-z:\\/*) my_xabs="$my_xlib" ;; - *) my_xabs=`pwd`"/$my_xlib" ;; - esac - my_xlib=`$echo "X$my_xlib" | $Xsed -e 's%^.*/%%'` - my_xlib_u=$my_xlib - while :; do - case " $extracted_archives " in - *" $my_xlib_u "*) - extracted_serial=`expr $extracted_serial + 1` - my_xlib_u=lt$extracted_serial-$my_xlib ;; - *) break ;; - esac - done - extracted_archives="$extracted_archives $my_xlib_u" - my_xdir="$my_gentop/$my_xlib_u" - - $show "${rm}r $my_xdir" - $run ${rm}r "$my_xdir" - $show "$mkdir $my_xdir" - $run $mkdir "$my_xdir" - exit_status=$? - if test "$exit_status" -ne 0 && test ! -d "$my_xdir"; then - exit $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\" - -disable_libs=no - -# 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 - -Copyright (C) 2008 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." - 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 - preserve_args="$preserve_args --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 - -case $disable_libs in -no) - ;; -shared) - build_libtool_libs=no - build_old_libs=yes - ;; -static) - build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` - ;; -esac - -# If this variable is set in any of the actions, the command in it -# will be execed at the end. This prevents here-documents from being -# left over by shells. -exec_cmd= - -if test -z "$show_help"; then - - # Infer the operation mode. - if test -z "$mode"; then - $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2 - $echo "*** Future versions of Libtool will require --mode=MODE be specified." 1>&2 - case $nonopt in - *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*) - mode=link - for arg - do - case $arg in - -c) - mode=compile - break - ;; - esac - done - ;; - *db | *dbx | *strace | *truss) - mode=execute - ;; - *install*|cp|mv) - mode=install - ;; - *rm) - mode=uninstall - ;; - *) - # If we have no mode, but dlfiles were specified, then do execute mode. - test -n "$execute_dlfiles" && mode=execute - - # Just use the default operation mode. - if test -z "$mode"; then - if test -n "$nonopt"; then - $echo "$modename: warning: cannot infer operation mode from \`$nonopt'" 1>&2 - else - $echo "$modename: warning: cannot infer operation mode without MODE-ARGS" 1>&2 - fi - fi - ;; - esac - fi - - # Only execute mode is allowed to have -dlopen flags. - if test -n "$execute_dlfiles" && test "$mode" != execute; then - $echo "$modename: unrecognized option \`-dlopen'" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - # Change the help message to a mode-specific one. - generic_help="$help" - help="Try \`$modename --help --mode=$mode' for more information." - - # These modes are in order of execution frequency so that they run quickly. - case $mode in - # libtool compile mode - compile) - modename="$modename: compile" - # Get the compilation command and the source file. - base_compile= - srcfile="$nonopt" # always keep a non-empty value in "srcfile" - suppress_opt=yes - suppress_output= - arg_mode=normal - libobj= - later= - - for arg - do - case $arg_mode in - arg ) - # do not "continue". Instead, add this to base_compile - lastarg="$arg" - arg_mode=normal - ;; - - target ) - libobj="$arg" - arg_mode=normal - continue - ;; - - normal ) - # Accept any command-line options. - case $arg in - -o) - if test -n "$libobj" ; then - $echo "$modename: you cannot specify \`-o' more than once" 1>&2 - exit $EXIT_FAILURE - fi - arg_mode=target - continue - ;; - - -static | -prefer-pic | -prefer-non-pic) - later="$later $arg" - continue - ;; - - -no-suppress) - suppress_opt=no - continue - ;; - - -Xcompiler) - arg_mode=arg # the next one goes into the "base_compile" arg list - continue # The current "srcfile" will either be retained or - ;; # replaced later. I would guess that would be a bug. - - -Wc,*) - args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"` - lastarg= - save_ifs="$IFS"; IFS=',' - for arg in $args; do - IFS="$save_ifs" - - # Double-quote args containing other shell metacharacters. - # Many Bourne shells cannot handle close brackets correctly - # in scan sets, so we specify it separately. - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - lastarg="$lastarg $arg" - done - IFS="$save_ifs" - lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"` - - # Add the arguments to base_compile. - base_compile="$base_compile $lastarg" - continue - ;; - - * ) - # Accept the current argument as the source file. - # The previous "srcfile" becomes the current argument. - # - lastarg="$srcfile" - srcfile="$arg" - ;; - esac # case $arg - ;; - esac # case $arg_mode - - # Aesthetically quote the previous argument. - lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"` - - case $lastarg in - # Double-quote args containing other shell metacharacters. - # Many Bourne shells cannot handle close brackets correctly - # in scan sets, and some SunOS ksh mistreat backslash-escaping - # in scan sets (worked around with variable expansion), - # and furthermore cannot handle '|' '&' '(' ')' in scan sets - # at all, so we specify them separately. - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - lastarg="\"$lastarg\"" - ;; - esac - - base_compile="$base_compile $lastarg" - done # for arg - - case $arg_mode in - arg) - $echo "$modename: you must specify an argument for -Xcompile" - exit $EXIT_FAILURE - ;; - target) - $echo "$modename: you must specify a target with \`-o'" 1>&2 - exit $EXIT_FAILURE - ;; - *) - # Get the name of the library object. - -z "$libobj" && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'` - ;; - esac - - # Recognize several different file suffixes. - # If the user specifies -o file.o, it is replaced with file.lo - xform='cCFSifmso' - case $libobj in - *.ada) xform=ada ;; - *.adb) xform=adb ;; - *.ads) xform=ads ;; - *.asm) xform=asm ;; - *.c++) xform=c++ ;; - *.cc) xform=cc ;; - *.ii) xform=ii ;; - *.class) xform=class ;; - *.cpp) xform=cpp ;; - *.cxx) xform=cxx ;; - *.fF09?) xform=fF09. ;; - *.for) xform=for ;; - *.java) xform=java ;; - *.obj) xform=obj ;; - *.sx) xform=sx ;; - esac - - libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"` - - case $libobj in - *.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;; - *) - $echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2 - exit $EXIT_FAILURE - ;; - esac - - func_infer_tag $base_compile - - for arg in $later; do - case $arg in - -static) - build_old_libs=yes - continue - ;; - - -prefer-pic) - pic_mode=yes - continue - ;; - - -prefer-non-pic) - pic_mode=no - continue - ;; - esac - done - - qlibobj=`$echo "X$libobj" | $Xsed -e "$sed_quote_subst"` - case $qlibobj in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - qlibobj="\"$qlibobj\"" ;; - esac - test "X$libobj" != "X$qlibobj" \ - && $echo "X$libobj" | grep '~#^*{};<>?"'"'"' &()|`$' \ - && $echo "$modename: libobj name \`$libobj' may not contain shell special characters." - objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'` - xdir=`$echo "X$obj" | $Xsed -e 's%/^/*$%%'` - if test "X$xdir" = "X$obj"; then - xdir= - else - xdir=$xdir/ - fi - lobj=${xdir}$objdir/$objname - - if test -z "$base_compile"; then - $echo "$modename: you must specify a compilation command" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - # Delete any leftover library objects. - if test "$build_old_libs" = yes; then - removelist="$obj $lobj $libobj ${libobj}T" - else - removelist="$lobj $libobj ${libobj}T" - fi - - $run $rm $removelist - trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 - - # On Cygwin there's no "real" PIC flag so we must build both object types - case $host_os in - cygwin* | mingw* | pw32* | os2*) - pic_mode=default - ;; - esac - if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then - # non-PIC code in shared libraries is not supported - pic_mode=default - fi - - # Calculate the filename of the output object if compiler does - # not support -o with -c - if test "$compiler_c_o" = no; then - output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.^.*$%%'`.${objext} - lockfile="$output_obj.lock" - removelist="$removelist $output_obj $lockfile" - trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 - else - output_obj= - need_locks=no - lockfile= - fi - - # Lock this critical section if it is needed - # We use this script file to make the link, it avoids creating a new file - if test "$need_locks" = yes; then - until $run ln "$progpath" "$lockfile" 2>/dev/null; do - $show "Waiting for $lockfile to be removed" - sleep 2 - done - elif test "$need_locks" = warn; then - if test -f "$lockfile"; then - $echo "\ -*** ERROR, $lockfile exists and contains: -`cat $lockfile 2>/dev/null` - -This indicates that another process is trying to use the same -temporary object file, and libtool could not work around it because -your compiler does not support \`-c' and \`-o' together. If you -repeat this compilation, it may succeed, by chance, but you had better -avoid parallel builds (make -j) in this platform, or get a better -compiler." - - $run $rm $removelist - exit $EXIT_FAILURE - fi - $echo "$srcfile" > "$lockfile" - fi - - if test -n "$fix_srcfile_path"; then - eval srcfile=\"$fix_srcfile_path\" - fi - qsrcfile=`$echo "X$srcfile" | $Xsed -e "$sed_quote_subst"` - case $qsrcfile in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - qsrcfile="\"$qsrcfile\"" ;; - esac - - $run $rm "$libobj" "${libobj}T" - - # Create a libtool object file (analogous to a ".la" file), - # but don't create it if we're doing a dry run. - test -z "$run" && cat > ${libobj}T <<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 - exit_status=$? - if test "$exit_status" -ne 0 && test ! -d "${xdir}$objdir"; then - exit $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 $lt_env "$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 $lt_env "$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= - notinst_path= # paths that contain not-installed libtool libraries - 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 - single_module="${wl}-single_module" - - 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 | -static-libtool-libs) - case $arg in - -all-static) - 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 - prefer_static_libs=yes - ;; - -static) - if test -z "$pic_flag" && test -n "$link_static_flag"; then - dlopen_self=$dlopen_self_static - fi - prefer_static_libs=built - ;; - -static-libtool-libs) - if test -z "$pic_flag" && test -n "$link_static_flag"; then - dlopen_self=$dlopen_self_static - fi - prefer_static_libs=yes - ;; - esac - build_libtool_libs=no - build_old_libs=yes - break - ;; - esac - done - - # See if our shared archives depend on static archives. - test -n "$old_archive_from_new_cmds" && build_old_libs=yes - - # Go through the arguments, transforming them on the way. - while test "$#" -gt 0; do - arg="$1" - shift - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - qarg=\"`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`\" ### testsuite: skip nested quoting test - ;; - *) qarg=$arg ;; - esac - libtool_args="$libtool_args $qarg" - - # If the previous option needs an argument, assign it. - if test -n "$prev"; then - case $prev in - output) - compile_command="$compile_command @OUTPUT@" - finalize_command="$finalize_command @OUTPUT@" - ;; - esac - - case $prev in - dlfiles|dlprefiles) - if test "$preload" = no; then - # Add the symbol object into the linking commands. - compile_command="$compile_command @SYMFILE@" - finalize_command="$finalize_command @SYMFILE@" - preload=yes - fi - case $arg in - *.la | *.lo) ;; # We handle these cases below. - force) - if test "$dlself" = no; then - dlself=needless - export_dynamic=yes - fi - prev= - continue - ;; - self) - if test "$prev" = dlprefiles; then - dlself=yes - elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then - dlself=yes - else - dlself=needless - export_dynamic=yes - fi - prev= - continue - ;; - *) - if test "$prev" = dlfiles; then - dlfiles="$dlfiles $arg" - else - dlprefiles="$dlprefiles $arg" - fi - prev= - continue - ;; - esac - ;; - expsyms) - export_symbols="$arg" - if test ! -f "$arg"; then - $echo "$modename: symbol file \`$arg' does not exist" - exit $EXIT_FAILURE - fi - prev= - continue - ;; - expsyms_regex) - export_symbols_regex="$arg" - prev= - continue - ;; - inst_prefix) - inst_prefix_dir="$arg" - prev= - continue - ;; - precious_regex) - precious_files_regex="$arg" - prev= - continue - ;; - release) - release="-$arg" - prev= - continue - ;; - objectlist) - if test -f "$arg"; then - save_arg=$arg - moreargs= - for fil in `cat $save_arg` - do -# moreargs="$moreargs $fil" - arg=$fil - # A libtool-controlled object. - - # Check to see that this really is a libtool object. - if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then - pic_object= - non_pic_object= - - # Read the .lo file - # If there is no directory component, then add one. - case $arg in - */* | *\\*) . $arg ;; - *) . ./$arg ;; - esac - - if test -z "$pic_object" || \ - test -z "$non_pic_object" || - test "$pic_object" = none && \ - test "$non_pic_object" = none; then - $echo "$modename: cannot find name of object for \`$arg'" 1>&2 - exit $EXIT_FAILURE - fi - - # Extract subdirectory from the argument. - xdir=`$echo "X$arg" | $Xsed -e 's%/^/*$%%'` - if test "X$xdir" = "X$arg"; then - xdir= - else - xdir="$xdir/" - fi - - if test "$pic_object" != none; then - # Prepend the subdirectory the object is found in. - pic_object="$xdir$pic_object" - - if test "$prev" = dlfiles; then - if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then - dlfiles="$dlfiles $pic_object" - prev= - continue - else - # If libtool objects are unsupported, then we need to preload. - prev=dlprefiles - fi - fi - - # CHECK ME: I think I busted this. -Ossama - if test "$prev" = dlprefiles; then - # Preload the old-style object. - dlprefiles="$dlprefiles $pic_object" - prev= - fi - - # A PIC object. - libobjs="$libobjs $pic_object" - arg="$pic_object" - fi - - # Non-PIC object. - if test "$non_pic_object" != none; then - # Prepend the subdirectory the object is found in. - non_pic_object="$xdir$non_pic_object" - - # A standard non-PIC object - non_pic_objects="$non_pic_objects $non_pic_object" - if test -z "$pic_object" || test "$pic_object" = none ; then - arg="$non_pic_object" - fi - else - # If the PIC object exists, use it instead. - # $xdir was prepended to $pic_object above. - non_pic_object="$pic_object" - non_pic_objects="$non_pic_objects $non_pic_object" - 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|darwin_framework_skip) - test "$prev" = "darwin_framework" && compiler_flags="$compiler_flags $arg" - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - prev= - continue - ;; - *) - eval "$prev=\"\$arg\"" - prev= - continue - ;; - esac - fi # test -n "$prev" - - prevarg="$arg" - - case $arg in - -all-static) - if test -n "$link_static_flag"; then - compile_command="$compile_command $link_static_flag" - finalize_command="$finalize_command $link_static_flag" - fi - continue - ;; - - -allow-undefined) - # FIXME: remove this flag sometime in the future. - $echo "$modename: \`-allow-undefined' is deprecated because it is the default" 1>&2 - continue - ;; - - -avoid-version) - avoid_version=yes - continue - ;; - - -dlopen) - prev=dlfiles - continue - ;; - - -dlpreopen) - prev=dlprefiles - continue - ;; - - -export-dynamic) - export_dynamic=yes - continue - ;; - - -export-symbols | -export-symbols-regex) - if test -n "$export_symbols" || test -n "$export_symbols_regex"; then - $echo "$modename: more than one -exported-symbols argument is not allowed" - exit $EXIT_FAILURE - fi - if test "X$arg" = "X-export-symbols"; then - prev=expsyms - else - prev=expsyms_regex - fi - continue - ;; - - -framework|-arch|-isysroot) - case " $CC " in - *" ${arg} ${1} "* | *" ${arg} ${1} "*) - prev=darwin_framework_skip ;; - *) compiler_flags="$compiler_flags $arg" - prev=darwin_framework ;; - esac - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - continue - ;; - - -inst-prefix-dir) - prev=inst_prefix - continue - ;; - - # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* - # so, if we see these flags be careful not to treat them like -L - -LA-ZA-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 - absdir="$dir" - notinst_path="$notinst_path $dir" - 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*) - testbindir=`$echo "X$dir" | $Xsed -e 's*/lib$*/bin*'` - case :$dllsearchpath: in - *":$dir:"*) ;; - *) dllsearchpath="$dllsearchpath:$dir";; - esac - case :$dllsearchpath: in - *":$testbindir:"*) ;; - *) dllsearchpath="$dllsearchpath:$testbindir";; - esac - ;; - esac - continue - ;; - - -l*) - if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos*) - # These systems don't actually have a C or math library (as such) - continue - ;; - *-*-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 - ;; - *-*-sco3.2v5* | *-*-sco5v6*) - # Causes problems with __ctype - test "X$arg" = "X-lc" && continue - ;; - *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) - # Compiler inserts libc in the correct place for threads to work - test "X$arg" = "X-lc" && 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|-threads) - compiler_flags="$compiler_flags $arg" - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - continue - ;; - - -multi_module) - single_module="${wl}-multi_module" - continue - ;; - - -module) - module=yes - continue - ;; - - # -64, -mips0-9 enable 64-bit mode on the SGI compiler - # -r0-90-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 - # -m*, -t45*, -txscale* pass through architecture-specific - # compiler args for GCC - # -p, -pg, --coverage, -fprofile-* pass through profiling flag for GCC - # -F/path gives path to uninstalled frameworks, gcc on darwin - # @file GCC response files - -64|-mips0-9|-r0-90-9*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ - -t45*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*) - - # Unknown arguments in both finalize_command and compile_command need - # to be aesthetically quoted because they are evaled later. - arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - compiler_flags="$compiler_flags $arg" - continue - ;; - - -shrext) - prev=shrext - continue - ;; - - -no-fast-install) - fast_install=no - continue - ;; - - -no-install) - case $host in - *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin*) - # The PATH hackery in wrapper scripts is required on Windows - # and Darwin 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 | -static-libtool-libs) - # The effects of -static are defined in a previous loop. - # We used to do the same as -all-static on platforms that - # didn't have a PIC flag, but the assumption that the effects - # would be equivalent was wrong. It would break on at least - # Digital Unix and AIX. - continue - ;; - - -thread-safe) - thread_safe=yes - continue - ;; - - -version-info) - prev=vinfo - continue - ;; - -version-number) - prev=vinfo - vinfo_number=yes - continue - ;; - - -Wc,*) - args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'` - arg= - save_ifs="$IFS"; IFS=',' - for flag in $args; do - IFS="$save_ifs" - case $flag in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - flag="\"$flag\"" - ;; - esac - arg="$arg $wl$flag" - compiler_flags="$compiler_flags $flag" - done - IFS="$save_ifs" - arg=`$echo "X$arg" | $Xsed -e "s/^ //"` - ;; - - -Wl,*) - args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wl,//'` - arg= - save_ifs="$IFS"; IFS=',' - for flag in $args; do - IFS="$save_ifs" - case $flag in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - flag="\"$flag\"" - ;; - esac - arg="$arg $wl$flag" - compiler_flags="$compiler_flags $wl$flag" - linker_flags="$linker_flags $flag" - done - IFS="$save_ifs" - arg=`$echo "X$arg" | $Xsed -e "s/^ //"` - ;; - - -Xcompiler) - prev=xcompiler - continue - ;; - - -Xlinker) - prev=xlinker - continue - ;; - - -XCClinker) - prev=xcclinker - continue - ;; - - # Some other compiler flag. - -* | +*) - # Unknown arguments in both finalize_command and compile_command need - # to be aesthetically quoted because they are evaled later. - arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - ;; - - *.$objext) - # A standard object. - objs="$objs $arg" - ;; - - *.lo) - # A libtool-controlled object. - - # Check to see that this really is a libtool object. - if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then - pic_object= - non_pic_object= - - # Read the .lo file - # If there is no directory component, then add one. - case $arg in - */* | *\\*) . $arg ;; - *) . ./$arg ;; - esac - - if test -z "$pic_object" || \ - test -z "$non_pic_object" || - test "$pic_object" = none && \ - test "$non_pic_object" = none; then - $echo "$modename: cannot find name of object for \`$arg'" 1>&2 - exit $EXIT_FAILURE - fi - - # Extract subdirectory from the argument. - xdir=`$echo "X$arg" | $Xsed -e 's%/^/*$%%'` - if test "X$xdir" = "X$arg"; then - xdir= - else - xdir="$xdir/" - fi - - if test "$pic_object" != none; then - # Prepend the subdirectory the object is found in. - pic_object="$xdir$pic_object" - - if test "$prev" = dlfiles; then - if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then - dlfiles="$dlfiles $pic_object" - prev= - continue - else - # If libtool objects are unsupported, then we need to preload. - prev=dlprefiles - fi - fi - - # CHECK ME: I think I busted this. -Ossama - if test "$prev" = dlprefiles; then - # Preload the old-style object. - dlprefiles="$dlprefiles $pic_object" - prev= - fi - - # A PIC object. - libobjs="$libobjs $pic_object" - arg="$pic_object" - fi - - # Non-PIC object. - if test "$non_pic_object" != none; then - # Prepend the subdirectory the object is found in. - non_pic_object="$xdir$non_pic_object" - - # A standard non-PIC object - non_pic_objects="$non_pic_objects $non_pic_object" - if test -z "$pic_object" || test "$pic_object" = none ; then - arg="$non_pic_object" - fi - else - # If the PIC object exists, use it instead. - # $xdir was prepended to $pic_object above. - non_pic_object="$pic_object" - non_pic_objects="$non_pic_objects $non_pic_object" - fi - else - # Only an error if not doing a dry-run. - if test -z "$run"; then - $echo "$modename: \`$arg' is not a valid libtool object" 1>&2 - exit $EXIT_FAILURE - else - # Dry-run case. - - # Extract subdirectory from the argument. - xdir=`$echo "X$arg" | $Xsed -e 's%/^/*$%%'` - if test "X$xdir" = "X$arg"; then - xdir= - else - xdir="$xdir/" - fi - - pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"` - non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"` - libobjs="$libobjs $pic_object" - non_pic_objects="$non_pic_objects $non_pic_object" - fi - fi - ;; - - *.$libext) - # An archive. - deplibs="$deplibs $arg" - old_deplibs="$old_deplibs $arg" - continue - ;; - - *.la) - # A libtool-controlled library. - - if test "$prev" = dlfiles; then - # This library was specified with -dlopen. - dlfiles="$dlfiles $arg" - prev= - elif test "$prev" = dlprefiles; then - # The library was specified with -dlpreopen. - dlprefiles="$dlprefiles $arg" - prev= - else - deplibs="$deplibs $arg" - fi - continue - ;; - - # Some other compiler argument. - *) - # Unknown arguments in both finalize_command and compile_command need - # to be aesthetically quoted because they are evaled later. - arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - ;; - esac # arg - - # Now actually substitute the argument into the commands. - if test -n "$arg"; then - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - fi - done # argument parsing loop - - if test -n "$prev"; then - $echo "$modename: the \`$prevarg' option requires an argument" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then - eval arg=\"$export_dynamic_flag_spec\" - compile_command="$compile_command $arg" - finalize_command="$finalize_command $arg" - fi - - oldlibs= - # calculate the name of the file, without its directory - outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'` - libobjs_save="$libobjs" - - if test -n "$shlibpath_var"; then - # get the directories listed in $shlibpath_var - eval shlib_search_path=\`\$echo \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\` - else - shlib_search_path= - fi - eval sys_lib_search_path=\"$sys_lib_search_path_spec\" - eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" - - output_objdir=`$echo "X$output" | $Xsed -e 's%/^/*$%%'` - if test "X$output_objdir" = "X$output"; then - output_objdir="$objdir" - else - output_objdir="$output_objdir/$objdir" - fi - # Create the object directory. - if test ! -d "$output_objdir"; then - $show "$mkdir $output_objdir" - $run $mkdir $output_objdir - exit_status=$? - if test "$exit_status" -ne 0 && test ! -d "$output_objdir"; then - exit $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 - case $linkmode in - lib) - passes="conv link" - for file in $dlfiles $dlprefiles; do - case $file in - *.la) ;; - *) - $echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2 - exit $EXIT_FAILURE - ;; - esac - done - ;; - prog) - compile_deplibs= - finalize_deplibs= - alldeplibs=no - newdlfiles= - newdlprefiles= - passes="conv scan dlopen dlpreopen link" - ;; - *) passes="conv" - ;; - esac - for pass in $passes; do - if test "$linkmode,$pass" = "lib,link" || - test "$linkmode,$pass" = "prog,scan"; then - libs="$deplibs" - deplibs= - fi - if test "$linkmode" = prog; then - case $pass in - dlopen) libs="$dlfiles" ;; - dlpreopen) libs="$dlprefiles" ;; - link) - libs="$deplibs %DEPLIBS%" - test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs" - ;; - esac - fi - if test "$pass" = dlopen; then - # Collect dlpreopened libraries - save_deplibs="$deplibs" - deplibs= - fi - for deplib in $libs; do - lib= - found=no - case $deplib in - -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads) - 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//'` - if test "$linkmode" = lib; then - searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" - else - searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" - fi - for searchdir in $searchdirs; do - for search_ext in .la $std_shrext .so .a; do - # Search the libtool library - lib="$searchdir/lib${name}${search_ext}" - 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' or unhandled argument \`$deplib'" 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 "$prefer_static_libs,$installed" = "built,yes"; } || - test -z "$old_library"; }; then - # We need to hardcode the library path - if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then - # Make sure the rpath contains only unique directories. - case "$temp_rpath " in - *" $dir "*) ;; - *" $absdir "*) ;; - *) temp_rpath="$temp_rpath $absdir" ;; - esac - fi - - # Hardcode the library path. - # Skip directories that are in the system default run-time - # search path. - case " $sys_lib_dlsearch_path " in - *" $absdir "*) ;; - *) - case "$compile_rpath " in - *" $absdir "*) ;; - *) compile_rpath="$compile_rpath $absdir" - esac - ;; - esac - case " $sys_lib_dlsearch_path " in - *" $libdir "*) ;; - *) - case "$finalize_rpath " in - *" $libdir "*) ;; - *) finalize_rpath="$finalize_rpath $libdir" - esac - ;; - esac - fi # $linkmode,$pass = prog,link... - - if test "$alldeplibs" = yes && - { test "$deplibs_check_method" = pass_all || - { test "$build_libtool_libs" = yes && - test -n "$library_names"; }; }; then - # We only need to search for static libraries - continue - fi - fi - - link_static=no # Whether the deplib will be linked statically - use_static_libs=$prefer_static_libs - if test "$use_static_libs" = built && test "$installed" = yes ; then - use_static_libs=no - fi - if test -n "$library_names" && - { test "$use_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.0.024*) add_dir="-L$dir" ;; - *-*-sysv4*uw2*) add_dir="-L$dir" ;; - *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.01.10* | \ - *-*-unixware7*) add_dir="-L$dir" ;; - *-*-darwin* ) - # if the lib is a module then we can not link against - # it, someone is ignoring the new warnings I added - if /usr/bin/file -L $add 2> /dev/null | - $EGREP ": ^:* bundle" >/dev/null ; then - $echo "** Warning, lib $linklib is a module, not a shared library" - if test -z "$old_library" ; then - $echo - $echo "** And there doesn't seem to be a static archive available" - $echo "** The link will probably fail, sorry" - else - add="$dir/$old_library" - fi - fi - esac - elif test "$hardcode_minus_L" = no; then - case $host in - *-*-sunos*) add_shlibpath="$dir" ;; - esac - add_dir="-L$dir" - add="-l$name" - elif test "$hardcode_shlibpath_var" = no; then - add_shlibpath="$dir" - add="-l$name" - else - lib_linked=no - fi - ;; - relink) - if test "$hardcode_direct" = yes; then - add="$dir/$linklib" - elif test "$hardcode_minus_L" = yes; then - add_dir="-L$dir" - # Try looking first in the location we're being installed to. - if test -n "$inst_prefix_dir"; then - case $libdir in - \\/*) - add_dir="$add_dir -L$inst_prefix_dir$libdir" - ;; - esac - fi - add="-l$name" - elif test "$hardcode_shlibpath_var" = yes; then - add_shlibpath="$dir" - add="-l$name" - else - lib_linked=no - fi - ;; - *) lib_linked=no ;; - esac - - if test "$lib_linked" != yes; then - $echo "$modename: configuration error: unsupported hardcode properties" - exit $EXIT_FAILURE - fi - - if test -n "$add_shlibpath"; then - case :$compile_shlibpath: in - *":$add_shlibpath:"*) ;; - *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;; - esac - fi - if test "$linkmode" = prog; then - test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" - test -n "$add" && compile_deplibs="$add $compile_deplibs" - else - test -n "$add_dir" && deplibs="$add_dir $deplibs" - test -n "$add" && deplibs="$add $deplibs" - if test "$hardcode_direct" != yes && \ - test "$hardcode_minus_L" != yes && \ - test "$hardcode_shlibpath_var" = yes; then - case :$finalize_shlibpath: in - *":$libdir:"*) ;; - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; - esac - fi - fi - fi - - if test "$linkmode" = prog || test "$mode" = relink; then - add_shlibpath= - add_dir= - add= - # Finalize command for both is simple: just hardcode it. - if test "$hardcode_direct" = yes; then - add="$libdir/$linklib" - elif test "$hardcode_minus_L" = yes; then - add_dir="-L$libdir" - add="-l$name" - elif test "$hardcode_shlibpath_var" = yes; then - case :$finalize_shlibpath: in - *":$libdir:"*) ;; - *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; - esac - add="-l$name" - elif test "$hardcode_automatic" = yes; then - if test -n "$inst_prefix_dir" && - test -f "$inst_prefix_dir$libdir/$linklib" ; then - add="$inst_prefix_dir$libdir/$linklib" - else - add="$libdir/$linklib" - fi - else - # We cannot seem to hardcode it, guess we'll fake it. - add_dir="-L$libdir" - # Try looking first in the location we're being installed to. - if test -n "$inst_prefix_dir"; then - case $libdir in - \\/*) - add_dir="$add_dir -L$inst_prefix_dir$libdir" - ;; - esac - fi - add="-l$name" - fi - - if test "$linkmode" = prog; then - test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" - test -n "$add" && finalize_deplibs="$add $finalize_deplibs" - else - test -n "$add_dir" && deplibs="$add_dir $deplibs" - test -n "$add" && deplibs="$add $deplibs" - fi - fi - elif test "$linkmode" = prog; then - # Here we assume that one of hardcode_direct or hardcode_minus_L - # is not unsupported. This is valid on all known static and - # shared platforms. - if test "$hardcode_direct" != unsupported; then - test -n "$old_library" && linklib="$old_library" - compile_deplibs="$dir/$linklib $compile_deplibs" - finalize_deplibs="$dir/$linklib $finalize_deplibs" - else - compile_deplibs="-l$name -L$dir $compile_deplibs" - finalize_deplibs="-l$name -L$dir $finalize_deplibs" - fi - elif test "$build_libtool_libs" = yes; then - # Not a shared library - if test "$deplibs_check_method" != pass_all; then - # We're trying link a shared library against a static one - # but the system doesn't support it. - - # Just print a warning and add the library to dependency_libs so - # that the program can be linked against the static library. - $echo - $echo "*** Warning: This system can not link to static lib archive $lib." - $echo "*** I have the capability to make that library automatically link in when" - $echo "*** you link to this library. But I can only do this if you have a" - $echo "*** shared version of the library, which you do not appear to have." - if test "$module" = yes; then - $echo "*** But as you try to build a module library, libtool will still create " - $echo "*** a static module, that should work as long as the dlopening application" - $echo "*** is linked with the -dlopen flag to resolve symbols at runtime." - if test -z "$global_symbol_pipe"; then - $echo - $echo "*** However, this would only work if libtool was able to extract symbol" - $echo "*** lists from a program, using \`nm' or equivalent, but libtool could" - $echo "*** not find such a program. So, this module is probably useless." - $echo "*** \`nm' from GNU binutils and a full rebuild may help." - fi - if test "$build_old_libs" = no; then - build_libtool_libs=module - build_old_libs=yes - else - build_libtool_libs=no - fi - fi - else - deplibs="$dir/$old_library $deplibs" - link_static=yes - fi - fi # link shared/static library? - - if test "$linkmode" = lib; then - if test -n "$dependency_libs" && - { test "$hardcode_into_libs" != yes || - test "$build_old_libs" = yes || - test "$link_static" = yes; }; then - # Extract -R from dependency_libs - temp_deplibs= - for libdir in $dependency_libs; do - case $libdir in - -R*) temp_xrpath=`$echo "X$libdir" | $Xsed -e 's/^-R//'` - case " $xrpath " in - *" $temp_xrpath "*) ;; - *) xrpath="$xrpath $temp_xrpath";; - esac;; - *) temp_deplibs="$temp_deplibs $libdir";; - esac - done - dependency_libs="$temp_deplibs" - fi - - newlib_search_path="$newlib_search_path $absdir" - # Link against this library - test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" - # ... and its dependency_libs - tmp_libs= - for deplib in $dependency_libs; do - newdependency_libs="$deplib $newdependency_libs" - if test "X$duplicate_deps" = "Xyes" ; then - case "$tmp_libs " in - *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; - esac - fi - tmp_libs="$tmp_libs $deplib" - done - - if test "$link_all_deplibs" != no; then - # Add the search paths of all dependency libraries - for deplib in $dependency_libs; do - case $deplib in - -L*) path="$deplib" ;; - *.la) - dir=`$echo "X$deplib" | $Xsed -e 's%/^/*$%%'` - test "X$dir" = "X$deplib" && dir="." - # We need an absolute path. - case $dir in - \\/* | A-Za-z:\\/*) absdir="$dir" ;; - *) - absdir=`cd "$dir" && pwd` - if test -z "$absdir"; then - $echo "$modename: warning: cannot determine absolute directory name of \`$dir'" 1>&2 - absdir="$dir" - fi - ;; - esac - if grep "^installed=no" $deplib > /dev/null; then - path="$absdir/$objdir" - else - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` - if test -z "$libdir"; then - $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 - exit $EXIT_FAILURE - fi - if test "$absdir" != "$libdir"; then - $echo "$modename: warning: \`$deplib' seems to be moved" 1>&2 - fi - path="$absdir" - fi - depdepl= - case $host in - *-*-darwin*) - # we do not want to link against static libs, - # but need to link against shared - eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` - eval deplibdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` - if test -n "$deplibrary_names" ; then - for tmp in $deplibrary_names ; do - depdepl=$tmp - done - if test -f "$deplibdir/$depdepl" ; then - depdepl="$deplibdir/$depdepl" - elif test -f "$path/$depdepl" ; then - depdepl="$path/$depdepl" - else - # Can't find it, oh well... - 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) - case " $deplibs" in - *\ -l* | *\ -L*) - $echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2 ;; - esac - - 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|none) - 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` - age="$number_minor" - revision="$number_minor" - lt_irix_increment=no - ;; - *) - $echo "$modename: unknown library version type \`$version_type'" 1>&2 - $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 - exit $EXIT_FAILURE - ;; - esac - ;; - no) - current="$2" - revision="$3" - age="$4" - ;; - esac - - # Check that each of the things are valid numbers. - case $current in - 0|1-9|1-90-9|1-90-90-9|1-90-90-90-9|1-90-90-90-90-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-90-9|1-90-90-9|1-90-90-90-9|1-90-90-90-90-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-90-9|1-90-90-9|1-90-90-90-9|1-90-90-90-90-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` - xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision" - verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" - ;; - - freebsd-aout) - major=".$current" - versuffix=".$current.$revision"; - ;; - - freebsd-elf) - major=".$current" - versuffix=".$current"; - ;; - - irix | nonstopux) - if test "X$lt_irix_increment" = "Xno"; then - major=`expr $current - $age` - else - major=`expr $current - $age + 1` - fi - 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. - ;; - *-*-sco3.2v5* | *-*-sco5v6*) - # Causes problems with __ctype - ;; - *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) - # Compiler inserts libc in the correct place for threads to work - ;; - *) - # 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 - if $LTCC $LTCFLAGS -o conftest conftest.c $deplibs; 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" != "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 - if $LTCC $LTCFLAGS -o conftest conftest.c $i; 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 - - - # move library search paths that coincide with paths to not yet - # installed libraries to the beginning of the library search list - new_libs= - for path in $notinst_path; do - case " $new_libs " in - *" -L$path/$objdir "*) ;; - *) - case " $deplibs " in - *" -L$path/$objdir "*) - new_libs="$new_libs -L$path/$objdir" ;; - esac - ;; - esac - done - for deplib in $deplibs; do - case $deplib in - -L*) - case " $new_libs " in - *" $deplib "*) ;; - *) new_libs="$new_libs $deplib" ;; - esac - ;; - *) new_libs="$new_libs $deplib" ;; - esac - done - deplibs="$new_libs" - - - # 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 - case $archive_cmds in - *\$LD*) eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\" ;; - *) eval dep_rpath=\"$hardcode_libdir_flag_spec\" ;; - esac - 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" - linknames= - for link - do - linknames="$linknames $link" - done - - # Use standard objects if they are pic - test -z "$pic_flag" && libobjs=`$echo "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` - - # Prepare the list of exported symbols - if test -z "$export_symbols"; then - if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then - $show "generating symbol list for \`$libname.la'" - export_symbols="$output_objdir/$libname.exp" - $run $rm $export_symbols - cmds=$export_symbols_cmds - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - if len=`expr "X$cmd" : ".*"` && - test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then - $show "$cmd" - $run eval "$cmd" || exit $? - skipped_export=false - else - # The command line is too long to execute in one step. - $show "using reloadable object file for export list..." - skipped_export=: - # Break out early, otherwise skipped_export may be - # set to false by a later but shorter cmd. - break - fi - done - IFS="$save_ifs" - if test -n "$export_symbols_regex"; then - $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\"" - $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' - $show "$mv \"${export_symbols}T\" \"$export_symbols\"" - $run eval '$mv "${export_symbols}T" "$export_symbols"' - fi - fi - fi - - if test -n "$export_symbols" && test -n "$include_expsyms"; then - $run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"' - fi - - tmp_deplibs= - for test_deplib in $deplibs; do - case " $convenience " in - *" $test_deplib "*) ;; - *) - tmp_deplibs="$tmp_deplibs $test_deplib" - ;; - esac - done - deplibs="$tmp_deplibs" - - if test -n "$convenience"; then - if test -n "$whole_archive_flag_spec"; then - save_libobjs=$libobjs - eval libobjs=\"\$libobjs $whole_archive_flag_spec\" - else - gentop="$output_objdir/${outputname}x" - generated="$generated $gentop" - - func_extract_archives $gentop $convenience - libobjs="$libobjs $func_extract_archives_result" - fi - fi - - if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then - eval flag=\"$thread_safe_flag_spec\" - linker_flags="$linker_flags $flag" - fi - - # Make a backup of the uninstalled library when relinking - if test "$mode" = relink; then - $run eval '(cd $output_objdir && $rm ${realname}U && $mv $realname ${realname}U)' || exit $? - fi - - # Do each of the archive commands. - if test "$module" = yes && test -n "$module_cmds" ; then - if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then - eval test_cmds=\"$module_expsym_cmds\" - cmds=$module_expsym_cmds - else - eval test_cmds=\"$module_cmds\" - cmds=$module_cmds - fi - else - if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then - eval test_cmds=\"$archive_expsym_cmds\" - cmds=$archive_expsym_cmds - else - eval test_cmds=\"$archive_cmds\" - cmds=$archive_cmds - fi - fi - - if test "X$skipped_export" != "X:" && - len=`expr "X$test_cmds" : ".*" 2>/dev/null` && - test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then - : - else - # The command line is too long to link in one step, link piecewise. - $echo "creating reloadable object files..." - - # Save the value of $output and $libobjs because we want to - # use them later. If we have whole_archive_flag_spec, we - # want to use save_libobjs as it was before - # whole_archive_flag_spec was expanded, because we can't - # assume the linker understands whole_archive_flag_spec. - # This may have to be revisited, in case too many - # convenience libraries get linked in and end up exceeding - # the spec. - if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then - save_libobjs=$libobjs - fi - save_output=$output - output_la=`$echo "X$output" | $Xsed -e "$basename"` - - # Clear the reloadable object creation command queue and - # initialize k to one. - test_cmds= - concat_cmds= - objlist= - delfiles= - last_robj= - k=1 - output=$output_objdir/$output_la-${k}.$objext - # Loop over the list of objects to be linked. - for obj in $save_libobjs - do - eval test_cmds=\"$reload_cmds $objlist $last_robj\" - if test "X$objlist" = X || - { len=`expr "X$test_cmds" : ".*" 2>/dev/null` && - test "$len" -le "$max_cmd_len"; }; then - objlist="$objlist $obj" - else - # The command $test_cmds is almost too long, add a - # command to the queue. - if test "$k" -eq 1 ; then - # The first file doesn't have a previous command to add. - eval concat_cmds=\"$reload_cmds $objlist $last_robj\" - else - # All subsequent reloadable object files will link in - # the last one created. - eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\" - fi - last_robj=$output_objdir/$output_la-${k}.$objext - k=`expr $k + 1` - output=$output_objdir/$output_la-${k}.$objext - objlist=$obj - len=1 - fi - done - # Handle the remaining objects by creating one last - # reloadable object file. All subsequent reloadable object - # files will link in the last one created. - test -z "$concat_cmds" || concat_cmds=$concat_cmds~ - eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\" - - if ${skipped_export-false}; then - $show "generating symbol list for \`$libname.la'" - export_symbols="$output_objdir/$libname.exp" - $run $rm $export_symbols - libobjs=$output - # Append the command to create the export file. - eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\" - fi - - # Set up a command to remove the reloadable object files - # after they are used. - i=0 - while test "$i" -lt "$k" - do - i=`expr $i + 1` - delfiles="$delfiles $output_objdir/$output_la-${i}.$objext" - done - - $echo "creating a temporary reloadable object file: $output" - - # Loop through the commands generated above and execute them. - save_ifs="$IFS"; IFS='~' - for cmd in $concat_cmds; do - IFS="$save_ifs" - $show "$cmd" - $run eval "$cmd" || exit $? - done - IFS="$save_ifs" - - libobjs=$output - # Restore the value of output. - output=$save_output - - if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then - eval libobjs=\"\$libobjs $whole_archive_flag_spec\" - fi - # Expand the library linking commands again to reset the - # value of $libobjs for piecewise linking. - - # Do each of the archive commands. - if test "$module" = yes && test -n "$module_cmds" ; then - if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then - cmds=$module_expsym_cmds - else - cmds=$module_cmds - fi - else - if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then - cmds=$archive_expsym_cmds - else - cmds=$archive_cmds - fi - fi - - # Append the command to remove the reloadable object files - # to the just-reset $cmds. - eval cmds=\"\$cmds~\$rm $delfiles\" - fi - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - $show "$cmd" - $run eval "$cmd" || { - lt_exit=$? - - # Restore the uninstalled library and exit - if test "$mode" = relink; then - $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)' - fi - - exit $lt_exit - } - done - IFS="$save_ifs" - - # Restore the uninstalled library and exit - if test "$mode" = relink; then - $run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $? - - if test -n "$convenience"; then - if test -z "$whole_archive_flag_spec"; then - $show "${rm}r $gentop" - $run ${rm}r "$gentop" - fi - fi - - exit $EXIT_SUCCESS - fi - - # Create links to the real library. - for linkname in $linknames; do - if test "$realname" != "$linkname"; then - $show "(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)" - $run eval '(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)' || exit $? - fi - done - - # If -module or -export-dynamic was specified, set the dlname. - if test "$module" = yes || test "$export_dynamic" = yes; then - # On all known operating systems, these are identical. - dlname="$soname" - fi - fi - ;; - - obj) - case " $deplibs" in - *\ -l* | *\ -L*) - $echo "$modename: warning: \`-l' and \`-L' are ignored for objects" 1>&2 ;; - esac - - 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 and hope we can get by with - # turning comma into space.. - wl= - - if test -n "$convenience"; then - if test -n "$whole_archive_flag_spec"; then - eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" - reload_conv_objs=$reload_objs\ `$echo "X$tmp_whole_archive_flags" | $Xsed -e 's|,| |g'` - 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 - - - # move library search paths that coincide with paths to not yet - # installed libraries to the beginning of the library search list - new_libs= - for path in $notinst_path; do - case " $new_libs " in - *" -L$path/$objdir "*) ;; - *) - case " $compile_deplibs " in - *" -L$path/$objdir "*) - new_libs="$new_libs -L$path/$objdir" ;; - esac - ;; - esac - done - for deplib in $compile_deplibs; do - case $deplib in - -L*) - case " $new_libs " in - *" $deplib "*) ;; - *) new_libs="$new_libs $deplib" ;; - esac - ;; - *) new_libs="$new_libs $deplib" ;; - esac - done - compile_deplibs="$new_libs" - - - 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*) - testbindir=`$echo "X$libdir" | $Xsed -e 's*/lib$*/bin*'` - case :$dllsearchpath: in - *":$libdir:"*) ;; - *) dllsearchpath="$dllsearchpath:$libdir";; - esac - case :$dllsearchpath: in - *":$testbindir:"*) ;; - *) dllsearchpath="$dllsearchpath:$testbindir";; - 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"' - case $host in - *cygwin* | *mingw* ) - $run eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' - $run eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' - ;; - esac - 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"' - case $host in - *cygwin* | *mingw* ) - $run eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' - $run eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' - ;; - esac - 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 $LTCFLAGS -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")" - $run eval '(cd $output_objdir && $LTCC $LTCFLAGS -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. - case $host in - *cygwin* | *mingw* ) - if test -f "$output_objdir/${outputname}.def" ; then - compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}.def $output_objdir/${outputname}S.${objext}%" | $NL2SP` - finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}.def $output_objdir/${outputname}S.${objext}%" | $NL2SP` - else - compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%" | $NL2SP` - finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%" | $NL2SP` - fi - ;; - * ) - compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%" | $NL2SP` - finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%" | $NL2SP` - ;; - esac - ;; - *) - $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" | $SP2NL | $Xsed -e "s% @SYMFILE@%%" | $NL2SP` - finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "s% @SYMFILE@%%" | $NL2SP` - fi - - if test "$need_relink" = no || test "$build_libtool_libs" != yes; then - # Replace the output file specification. - compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e 's%@OUTPUT@%'"$output"'%g' | $NL2SP` - link_command="$compile_command$compile_rpath" - - # We have no uninstalled library dependencies, so finalize right now. - $show "$link_command" - $run eval "$link_command" - exit_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 $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" | $SP2NL | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g' | $NL2SP` - 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" | $SP2NL | $Xsed -e "$sed_quote_subst" | $NL2SP` - 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* ) - output_name=`basename $output` - output_path=`dirname $output` - cwrappersource="$output_path/$objdir/lt-$output_name.c" - cwrapper="$output_path/$output_name.exe" - $rm $cwrappersource $cwrapper - trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 - - 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> -#include <string.h> -#include <ctype.h> -#include <sys/stat.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 '/' -# define PATH_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 -# ifndef PATH_SEPARATOR_2 -# define PATH_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 */ - -#ifndef PATH_SEPARATOR_2 -# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) -#else /* PATH_SEPARATOR_2 */ -# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) -#endif /* PATH_SEPARATOR_2 */ - -#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) -#define XFREE(stale) do { \ - if (stale) { free ((void *) stale); stale = 0; } \ -} while (0) - -/* -DDEBUG is fairly common in CFLAGS. */ -#undef DEBUG -#if defined DEBUGWRAPPER -# define DEBUG(format, ...) fprintf(stderr, format, __VA_ARGS__) -#else -# define DEBUG(format, ...) -#endif - -const char *program_name = NULL; - -void * xmalloc (size_t num); -char * xstrdup (const char *string); -const char * base_name (const char *name); -char * find_executable(const char *wrapper); -int check_executable(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 (base_name (argv0)); - DEBUG("(main) argv0 : %s\n",argv0); - DEBUG("(main) program_name : %s\n",program_name); - newargz = XMALLOC(char *, argc+2); -EOF - - cat >> $cwrappersource <<EOF - newargz0 = (char *) xstrdup("$SHELL"); -EOF - - cat >> $cwrappersource <<"EOF" - newargz1 = find_executable(argv0); - if (newargz1 == NULL) - lt_fatal("Couldn't find %s", argv0); - DEBUG("(main) found exe at : %s\n",newargz1); - /* we know the script has the same name, without the .exe */ - /* so make sure newargz1 doesn't end in .exe */ - strendzap(newargz1,".exe"); - for (i = 1; i < argc; i++) - newargzi+1 = xstrdup(argvi); - newargzargc+1 = NULL; - - for (i=0; i<argc+1; i++) - { - DEBUG("(main) newargz%d : %s\n",i,newargzi); - ; - } - -EOF - - case $host_os in - mingw*) - cat >> $cwrappersource <<EOF - execv("$SHELL",(char const **)newargz); -EOF - ;; - *) - cat >> $cwrappersource <<EOF - execv("$SHELL",newargz); -EOF - ;; - esac - - cat >> $cwrappersource <<"EOF" - return 127; -} - -void * -xmalloc (size_t num) -{ - void * p = (void *) malloc (num); - if (!p) - lt_fatal ("Memory exhausted"); - - return p; -} - -char * -xstrdup (const char *string) -{ - return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL -; -} - -const char * -base_name (const char *name) -{ - const char *base; - -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - /* Skip over the disk name in MSDOS pathnames. */ - if (isalpha ((unsigned char)name0) && name1 == ':') - name += 2; -#endif - - for (base = name; *name; name++) - if (IS_DIR_SEPARATOR (*name)) - base = name + 1; - return base; -} - -int -check_executable(const char * path) -{ - struct stat st; - - DEBUG("(check_executable) : %s\n", path ? (*path ? path : "EMPTY!") : "NULL!"); - if ((!path) || (!*path)) - return 0; - - if ((stat (path, &st) >= 0) && - ( - /* MinGW & native WIN32 do not support S_IXOTH or S_IXGRP */ -#if defined (S_IXOTH) - ((st.st_mode & S_IXOTH) == S_IXOTH) || -#endif -#if defined (S_IXGRP) - ((st.st_mode & S_IXGRP) == S_IXGRP) || -#endif - ((st.st_mode & S_IXUSR) == S_IXUSR)) - ) - return 1; - else - return 0; -} - -/* Searches for the full path of the wrapper. Returns - newly allocated full path name if found, NULL otherwise */ -char * -find_executable (const char* wrapper) -{ - int has_slash = 0; - const char* p; - const char* p_next; - /* static buffer for getcwd */ - char tmpLT_PATHMAX + 1; - int tmp_len; - char* concat_name; - - DEBUG("(find_executable) : %s\n", wrapper ? (*wrapper ? wrapper : "EMPTY!") : "NULL!"); - - if ((wrapper == NULL) || (*wrapper == '\0')) - return NULL; - - /* Absolute path? */ -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - if (isalpha ((unsigned char)wrapper0) && wrapper1 == ':') - { - concat_name = xstrdup (wrapper); - if (check_executable(concat_name)) - return concat_name; - XFREE(concat_name); - } - else - { -#endif - if (IS_DIR_SEPARATOR (wrapper0)) - { - concat_name = xstrdup (wrapper); - if (check_executable(concat_name)) - return concat_name; - XFREE(concat_name); - } -#if defined (HAVE_DOS_BASED_FILE_SYSTEM) - } -#endif - - for (p = wrapper; *p; p++) - if (*p == '/') - { - has_slash = 1; - break; - } - if (!has_slash) - { - /* no slashes; search PATH */ - const char* path = getenv ("PATH"); - if (path != NULL) - { - for (p = path; *p; p = p_next) - { - const char* q; - size_t p_len; - for (q = p; *q; q++) - if (IS_PATH_SEPARATOR(*q)) - break; - p_len = q - p; - p_next = (*q == '\0' ? q : q + 1); - if (p_len == 0) - { - /* empty path: current directory */ - if (getcwd (tmp, LT_PATHMAX) == NULL) - lt_fatal ("getcwd failed"); - tmp_len = strlen(tmp); - concat_name = XMALLOC(char, tmp_len + 1 + strlen(wrapper) + 1); - memcpy (concat_name, tmp, tmp_len); - concat_nametmp_len = '/'; - strcpy (concat_name + tmp_len + 1, wrapper); - } - else - { - concat_name = XMALLOC(char, p_len + 1 + strlen(wrapper) + 1); - memcpy (concat_name, p, p_len); - concat_namep_len = '/'; - strcpy (concat_name + p_len + 1, wrapper); - } - if (check_executable(concat_name)) - return concat_name; - XFREE(concat_name); - } - } - /* not found in PATH; assume curdir */ - } - /* Relative path | not found in path: prepend cwd */ - if (getcwd (tmp, LT_PATHMAX) == NULL) - lt_fatal ("getcwd failed"); - tmp_len = strlen(tmp); - concat_name = XMALLOC(char, tmp_len + 1 + strlen(wrapper) + 1); - memcpy (concat_name, tmp, tmp_len); - concat_nametmp_len = '/'; - strcpy (concat_name + tmp_len + 1, wrapper); - - if (check_executable(concat_name)) - return concat_name; - XFREE(concat_name); - return NULL; -} - -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 $LTCFLAGS -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' - -# Be Bourne compatible (taken from Autoconf:_AS_BOURNE_COMPATIBLE). -if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then - emulate sh - NULLCMD=: - # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which - # is contrary to our usage. Disable this feature. - alias -g '\${1+\"\$@\"}'='\"\$@\"' - setopt NO_GLOB_SUBST -else - case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac -fi -BIN_SH=xpg4; export BIN_SH # for Tru64 -DUALCASE=1; export DUALCASE # for MKS sh - -# 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 \$*\" - 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" - exit_status=$? - if test "$exit_status" -ne 0 && test ! -d "$gentop"; then - exit $exit_status - fi - fi - - save_oldobjs=$oldobjs - oldobjs= - counter=1 - for obj in $save_oldobjs - do - objbase=`$echo "X$obj" | $Xsed -e 's%^.*/%%'` - case " $oldobjs " in - " ") oldobjs=$obj ;; - *\ /"$objbase "*) - while :; do - # Make sure we don't pick an alternate name that also - # overlaps. - newobj=lt$counter-$objbase - counter=`expr $counter + 1` - case " $oldobjs " in - *\ /"$newobj "*) ;; - *) if test ! -f "$gentop/$newobj"; then break; fi ;; - esac - done - $show "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" - $run ln "$obj" "$gentop/$newobj" || - $run cp "$obj" "$gentop/$newobj" - oldobjs="$oldobjs $gentop/$newobj" - ;; - *) oldobjs="$oldobjs $obj" ;; - esac - done - fi - - eval cmds=\"$old_archive_cmds\" - - if len=`expr "X$cmds" : ".*"` && - test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then - cmds=$old_archive_cmds - else - # the command line is too long to link in one step, link in parts - $echo "using piecewise archive linking..." - save_RANLIB=$RANLIB - RANLIB=: - objlist= - concat_cmds= - save_oldobjs=$oldobjs - - # Is there a better way of finding the last object in the list? - for obj in $save_oldobjs - do - last_oldobj=$obj - done - for obj in $save_oldobjs - do - oldobjs="$objlist $obj" - objlist="$objlist $obj" - eval test_cmds=\"$old_archive_cmds\" - if len=`expr "X$test_cmds" : ".*" 2>/dev/null` && - test "$len" -le "$max_cmd_len"; then - : - else - # the above command should be used before it gets too long - oldobjs=$objlist - if test "$obj" = "$last_oldobj" ; then - RANLIB=$save_RANLIB - fi - test -z "$concat_cmds" || concat_cmds=$concat_cmds~ - eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" - objlist= - fi - done - RANLIB=$save_RANLIB - oldobjs=$objlist - if test "X$oldobjs" = "X" ; then - eval cmds=\"\$concat_cmds\" - else - eval cmds=\"\$concat_cmds~\$old_archive_cmds\" - fi - fi - fi - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - eval cmd=\"$cmd\" - IFS="$save_ifs" - $show "$cmd" - $run eval "$cmd" || exit $? - done - IFS="$save_ifs" - done - - if test -n "$generated"; then - $show "${rm}r$generated" - $run ${rm}r$generated - fi - - # Now create the libtool archive. - case $output in - *.la) - old_library= - test "$build_old_libs" = yes && old_library="$libname.$libext" - $show "creating $output" - - # Preserve any variables that may affect compiler behavior - for var in $variables_saved_for_relink; do - if eval test -z \"\${$var+set}\"; then - relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command" - elif eval var_value=\$$var; test -z "$var_value"; then - relink_command="$var=; export $var; $relink_command" - else - var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"` - relink_command="$var=\"$var_value\"; export $var; $relink_command" - fi - done - # Quote the link command for shipping. - relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" - relink_command=`$echo "X$relink_command" | $SP2NL | $Xsed -e "$sed_quote_subst" | $NL2SP` - if test "$hardcode_automatic" = yes ; then - relink_command= - fi - - - # Only create the output if not a dry run. - if test -z "$run"; then - for installed in no yes; do - if test "$installed" = yes; then - if test -z "$install_libdir"; then - break - fi - output="$output_objdir/$outputname"i - # Replace all uninstalled libtool libraries with the installed ones - newdependency_libs= - for deplib in $dependency_libs; do - case $deplib in - *.la) - name=`$echo "X$deplib" | $Xsed -e 's%^.*/%%'` - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` - if test -z "$libdir"; then - $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 - exit $EXIT_FAILURE - fi - newdependency_libs="$newdependency_libs $libdir/$name" - ;; - *) newdependency_libs="$newdependency_libs $deplib" ;; - esac - done - dependency_libs="$newdependency_libs" - newdlfiles= - for lib in $dlfiles; do - name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` - if test -z "$libdir"; then - $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 - exit $EXIT_FAILURE - fi - newdlfiles="$newdlfiles $libdir/$name" - done - dlfiles="$newdlfiles" - newdlprefiles= - for lib in $dlprefiles; do - name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` - eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` - if test -z "$libdir"; then - $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 - exit $EXIT_FAILURE - fi - newdlprefiles="$newdlprefiles $libdir/$name" - done - dlprefiles="$newdlprefiles" - else - newdlfiles= - for lib in $dlfiles; do - case $lib in - \\/* | A-Za-z:\\/*) abs="$lib" ;; - *) abs=`pwd`"/$lib" ;; - esac - newdlfiles="$newdlfiles $abs" - done - dlfiles="$newdlfiles" - newdlprefiles= - for lib in $dlprefiles; do - case $lib in - \\/* | A-Za-z:\\/*) abs="$lib" ;; - *) abs=`pwd`"/$lib" ;; - esac - newdlprefiles="$newdlprefiles $abs" - done - dlprefiles="$newdlprefiles" - fi - $rm $output - # place dlname in correct position for cygwin - tdlname=$dlname - case $host,$output,$installed,$module,$dlname in - *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;; - esac - $echo > $output "\ -# $outputname - a libtool library file -# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP -# -# Please DO NOT delete this file! -# It is necessary for linking the library. - -# The name that we can dlopen(3). -dlname='$tdlname' - -# Names of this library. -library_names='$library_names' - -# The name of the static archive. -old_library='$old_library' - -# Libraries that this one depends upon. -dependency_libs='$dependency_libs' - -# Version information for $libname. -current=$current -age=$age -revision=$revision - -# Is this an already installed library? -installed=$installed - -# Should we warn about portability when linking against -modules? -shouldnotlink=$module - -# Files to dlopen/dlpreopen -dlopen='$dlfiles' -dlpreopen='$dlprefiles' - -# Directory that this library needs to be installed in: -libdir='$install_libdir'" - if test "$installed" = no && test "$need_relink" = yes; then - $echo >> $output "\ -relink_command=\"$relink_command\"" - fi - done - fi - - # Do a symbolic link so that the libtool archive can be found in - # LD_LIBRARY_PATH before the program is installed. - $show "(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)" - $run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $? - ;; - esac - exit $EXIT_SUCCESS - ;; - - # libtool install mode - install) - modename="$modename: install" - - # There may be an optional sh(1) argument at the beginning of - # install_prog (especially on Windows NT). - if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || - # Allow the use of GNU shtool's install command. - $echo "X$nonopt" | grep shtool > /dev/null; then - # Aesthetically quote it. - arg=`$echo "X$nonopt" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - install_prog="$arg " - arg="$1" - shift - else - install_prog= - arg=$nonopt - fi - - # The real first argument should be the name of the installation program. - # Aesthetically quote it. - arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - install_prog="$install_prog$arg" - - # We need to accept at least all the BSD install flags. - dest= - files= - opts= - prev= - install_type= - isdir=no - stripme= - for arg - do - if test -n "$dest"; then - files="$files $dest" - dest=$arg - continue - fi - - case $arg in - -d) isdir=yes ;; - -f) - case " $install_prog " in - *\\\ /cp\ *) ;; - *) prev=$arg ;; - esac - ;; - -g | -m | -o) prev=$arg ;; - -s) - stripme=" -s" - continue - ;; - -*) - ;; - *) - # If the previous option needed an argument, then skip it. - if test -n "$prev"; then - prev= - else - dest=$arg - continue - fi - ;; - esac - - # Aesthetically quote the argument. - arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` - case $arg in - *\\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ *|**|"") - arg="\"$arg\"" - ;; - esac - install_prog="$install_prog $arg" - done - - if test -z "$install_prog"; then - $echo "$modename: you must specify an install program" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - if test -n "$prev"; then - $echo "$modename: the \`$prev' option requires an argument" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - if test -z "$files"; then - if test -z "$dest"; then - $echo "$modename: no file or destination specified" 1>&2 - else - $echo "$modename: you must specify a destination" 1>&2 - fi - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - # Strip any trailing slash from the destination. - dest=`$echo "X$dest" | $Xsed -e 's%/$%%'` - - # Check to see that the destination is a directory. - test -d "$dest" && isdir=yes - if test "$isdir" = yes; then - destdir="$dest" - destname= - else - destdir=`$echo "X$dest" | $Xsed -e 's%/^/*$%%'` - test "X$destdir" = "X$dest" && destdir=. - destname=`$echo "X$dest" | $Xsed -e 's%^.*/%%'` - - # Not a directory, so check to see that there is only one file specified. - set dummy $files - if test "$#" -gt 2; then - $echo "$modename: \`$dest' is not a directory" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - fi - case $destdir in - \\/* | A-Za-z:\\/*) ;; - *) - for file in $files; do - case $file in - *.lo) ;; - *) - $echo "$modename: \`$destdir' must be an absolute directory name" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - ;; - esac - done - ;; - esac - - # This variable tells wrapper scripts just to set variables rather - # than running their programs. - libtool_install_magic="$magic" - - staticlibs= - future_libdirs= - current_libdirs= - for file in $files; do - - # Do each installation. - case $file in - *.$libext) - # Do the static libraries later. - staticlibs="$staticlibs $file" - ;; - - *.la) - # Check to see that this really is a libtool archive. - if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : - else - $echo "$modename: \`$file' is not a valid libtool archive" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - fi - - library_names= - old_library= - relink_command= - # If there is no directory component, then add one. - case $file in - */* | *\\*) . $file ;; - *) . ./$file ;; - esac - - # Add the libdir to current_libdirs if it is the destination. - if test "X$destdir" = "X$libdir"; then - case "$current_libdirs " in - *" $libdir "*) ;; - *) current_libdirs="$current_libdirs $libdir" ;; - esac - else - # Note the libdir as a future libdir. - case "$future_libdirs " in - *" $libdir "*) ;; - *) future_libdirs="$future_libdirs $libdir" ;; - esac - fi - - dir=`$echo "X$file" | $Xsed -e 's%/^/*$%%'`/ - test "X$dir" = "X$file/" && dir= - dir="$dir$objdir" - - if test -n "$relink_command"; then - # Determine the prefix the user has applied to our future dir. - inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"` - - # Don't allow the user to place us outside of our expected - # location b/c this prevents finding dependent libraries that - # are installed to the same prefix. - # At present, this check doesn't affect windows .dll's that - # are installed into $libdir/../bin (currently, that works fine) - # but it's something to keep an eye on. - if test "$inst_prefix_dir" = "$destdir"; then - $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2 - exit $EXIT_FAILURE - fi - - if test -n "$inst_prefix_dir"; then - # Stick the inst_prefix_dir data into the link command. - relink_command=`$echo "$relink_command" | $SP2NL | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%" | $NL2SP` - else - relink_command=`$echo "$relink_command" | $SP2NL | $SED "s%@inst_prefix_dir@%%" | $NL2SP` - fi - - $echo "$modename: warning: relinking \`$file'" 1>&2 - $show "$relink_command" - if $run eval "$relink_command"; then : - else - $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 - exit $EXIT_FAILURE - fi - fi - - # See the names of the shared library. - set dummy $library_names - if test -n "$2"; then - realname="$2" - shift - shift - - srcname="$realname" - test -n "$relink_command" && srcname="$realname"T - - # Install the shared library and build the symlinks. - $show "$install_prog $dir/$srcname $destdir/$realname" - $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $? - if test -n "$stripme" && test -n "$striplib"; then - $show "$striplib $destdir/$realname" - $run eval "$striplib $destdir/$realname" || exit $? - fi - - if test "$#" -gt 0; then - # Delete the old symlinks, and create new ones. - # Try `ln -sf' first, because the `ln' binary might depend on - # the symlink we replace! Solaris /bin/ln does not understand -f, - # so we also need to try rm && ln -s. - for linkname - do - if test "$linkname" != "$realname"; then - $show "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })" - $run eval "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })" - fi - done - fi - - # Do each command in the postinstall commands. - lib="$destdir/$realname" - cmds=$postinstall_cmds - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - $show "$cmd" - $run eval "$cmd" || { - lt_exit=$? - - # Restore the uninstalled library and exit - if test "$mode" = relink; then - $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)' - fi - - exit $lt_exit - } - done - IFS="$save_ifs" - fi - - # Install the pseudo-library for information purposes. - name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` - instname="$dir/$name"i - $show "$install_prog $instname $destdir/$name" - $run eval "$install_prog $instname $destdir/$name" || exit $? - - # Maybe install the static library, too. - test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library" - ;; - - *.lo) - # Install (i.e. copy) a libtool object. - - # Figure out destination file name, if it wasn't already specified. - if test -n "$destname"; then - destfile="$destdir/$destname" - else - destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` - destfile="$destdir/$destfile" - fi - - # Deduce the name of the destination old-style object file. - case $destfile in - *.lo) - staticdest=`$echo "X$destfile" | $Xsed -e "$lo2o"` - ;; - *.$objext) - staticdest="$destfile" - destfile= - ;; - *) - $echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2 - $echo "$help" 1>&2 - exit $EXIT_FAILURE - ;; - esac - - # Install the libtool object if requested. - if test -n "$destfile"; then - $show "$install_prog $file $destfile" - $run eval "$install_prog $file $destfile" || exit $? - fi - - # Install the old object if enabled. - if test "$build_old_libs" = yes; then - # Deduce the name of the old-style object file. - staticobj=`$echo "X$file" | $Xsed -e "$lo2o"` - - $show "$install_prog $staticobj $staticdest" - $run eval "$install_prog \$staticobj \$staticdest" || exit $? - fi - exit $EXIT_SUCCESS - ;; - - *) - # Figure out destination file name, if it wasn't already specified. - if test -n "$destname"; then - destfile="$destdir/$destname" - else - destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` - destfile="$destdir/$destfile" - fi - - # If the file is missing, and there is a .exe on the end, strip it - # because it is most likely a libtool script we actually want to - # install - stripped_ext="" - case $file in - *.exe) - if test ! -f "$file"; then - file=`$echo $file|${SED} 's,.exe$,,'` - stripped_ext=".exe" - fi - ;; - esac - - # Do a test to see if this is really a libtool program. - case $host in - *cygwin*|*mingw*) - wrapper=`$echo $file | ${SED} -e 's,.exe$,,'` - ;; - *) - wrapper=$file - ;; - esac - if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then - notinst_deplibs= - relink_command= - - # Note that it is not necessary on cygwin/mingw to append a dot to - # foo even if both foo and FILE.exe exist: automatic-append-.exe - # behavior happens only for exec(3), not for open(2)! Also, sourcing - # `FILE.' does not work on cygwin managed mounts. - # - # If there is no directory component, then add one. - case $wrapper in - */* | *\\*) . ${wrapper} ;; - *) . ./${wrapper} ;; - esac - - # Check the variables that should have been set. - if test -z "$notinst_deplibs"; then - $echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2 - exit $EXIT_FAILURE - fi - - finalize=yes - for lib in $notinst_deplibs; do - # Check to see that each library is installed. - libdir= - if test -f "$lib"; then - # If there is no directory component, then add one. - case $lib in - */* | *\\*) . $lib ;; - *) . ./$lib ;; - esac - fi - libfile="$libdir/"`$echo "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test - if test -n "$libdir" && test ! -f "$libfile"; then - $echo "$modename: warning: \`$lib' has not been installed in \`$libdir'" 1>&2 - finalize=no - fi - done - - relink_command= - # Note that it is not necessary on cygwin/mingw to append a dot to - # foo even if both foo and FILE.exe exist: automatic-append-.exe - # behavior happens only for exec(3), not for open(2)! Also, sourcing - # `FILE.' does not work on cygwin managed mounts. - # - # If there is no directory component, then add one. - case $wrapper in - */* | *\\*) . ${wrapper} ;; - *) . ./${wrapper} ;; - esac - - outputname= - if test "$fast_install" = no && test -n "$relink_command"; then - if test "$finalize" = yes && test -z "$run"; then - tmpdir=`func_mktempdir` - file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'` - outputname="$tmpdir/$file" - # Replace the output file specification. - relink_command=`$echo "X$relink_command" | $SP2NL | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g' | $NL2SP` - - $show "$relink_command" - if $run eval "$relink_command"; then : - else - $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 - ${rm}r "$tmpdir" - continue - fi - file="$outputname" - else - $echo "$modename: warning: cannot relink \`$file'" 1>&2 - fi - else - # Install the binary that we compiled earlier. - file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\(^/*\)$%$objdir/\1%"` - fi - fi - - # remove .exe since cygwin /usr/bin/install will append another - # one anyway - case $install_prog,$host in - */usr/bin/install*,*cygwin*) - case $file:$destfile in - *.exe:*.exe) - # this is ok - ;; - *.exe:*) - destfile=$destfile.exe - ;; - *:*.exe) - destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'` - ;; - esac - ;; - esac - $show "$install_prog$stripme $file $destfile" - $run eval "$install_prog\$stripme \$file \$destfile" || exit $? - test -n "$outputname" && ${rm}r "$tmpdir" - ;; - esac - done - - for file in $staticlibs; do - name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` - - # Set up the ranlib parameters. - oldlib="$destdir/$name" - - $show "$install_prog $file $oldlib" - $run eval "$install_prog \$file \$oldlib" || exit $? - - if test -n "$stripme" && test -n "$old_striplib"; then - $show "$old_striplib $oldlib" - $run eval "$old_striplib $oldlib" || exit $? - fi - - # Do each command in the postinstall commands. - cmds=$old_postinstall_cmds - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - $show "$cmd" - $run eval "$cmd" || exit $? - done - IFS="$save_ifs" - done - - if test -n "$future_libdirs"; then - $echo "$modename: warning: remember to run \`$progname --finish$future_libdirs'" 1>&2 - fi - - if test -n "$current_libdirs"; then - # Maybe just do a dry run. - test -n "$run" && current_libdirs=" -n$current_libdirs" - exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' - else - exit $EXIT_SUCCESS - fi - ;; - - # libtool finish mode - finish) - modename="$modename: finish" - libdirs="$nonopt" - admincmds= - - if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then - for dir - do - libdirs="$libdirs $dir" - done - - for libdir in $libdirs; do - if test -n "$finish_cmds"; then - # Do each command in the finish commands. - cmds=$finish_cmds - save_ifs="$IFS"; IFS='~' - for cmd in $cmds; do - IFS="$save_ifs" - eval cmd=\"$cmd\" - $show "$cmd" - $run eval "$cmd" || admincmds="$admincmds - $cmd" - done - IFS="$save_ifs" - fi - if test -n "$finish_eval"; then - # Do the single finish_eval. - eval cmds=\"$finish_eval\" - $run eval "$cmds" || admincmds="$admincmds - $cmds" - fi - done - fi - - # Exit here if they wanted silent mode. - test "$show" = : && exit $EXIT_SUCCESS - - $echo "X----------------------------------------------------------------------" | $Xsed - $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 "X----------------------------------------------------------------------" | $Xsed - 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 - if test ! -f "$dir/$dlname"; then - $echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2 - exit $EXIT_FAILURE - fi - 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 - for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES - do - eval "if test \"\${save_$lt_var+set}\" = set; then - $lt_var=\$save_$lt_var; export $lt_var - fi" - done - - # Now prepare to actually exec the command. - exec_cmd="\$cmd$args" - else - # Display what would be done. - if test -n "$shlibpath_var"; then - eval "\$echo \"\$shlibpath_var=\$$shlibpath_var\"" - $echo "export $shlibpath_var" - fi - $echo "$cmd$args" - exit $EXIT_SUCCESS - 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" - - case "$mode" in - clean) - case " $library_names " in - # " " in the beginning catches empty $dlname - *" $dlname "*) ;; - *) rmfiles="$rmfiles $objdir/$dlname" ;; - esac - test -n "$libdir" && rmfiles="$rmfiles $objdir/$name $objdir/${name}i" - ;; - uninstall) - 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. - ;; - esac - 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@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 uninstalled libtool libraries - -static-libtool-libs - 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 -disable_libs=shared -# ### END LIBTOOL TAG CONFIG: disable-shared - -# ### BEGIN LIBTOOL TAG CONFIG: disable-static -disable_libs=static -# ### END LIBTOOL TAG CONFIG: disable-static - -# Local Variables: -# mode:shell-script -# sh-indentation:2 -# End:
View file
linuxsampler-1.0.0.tar.bz2/man/Makefile.in
Deleted
@@ -1,437 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = man -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in \ - $(srcdir)/linuxsampler.1.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = linuxsampler.1 -SOURCES = -DIST_SOURCES = -man1dir = $(mandir)/man1 -am__installdirs = "$(DESTDIR)$(man1dir)" -NROFF = nroff -MANS = $(man_MANS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ - -# all man files that should be installed -man_MANS = linuxsampler.1 -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu man/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu man/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -linuxsampler.1: $(top_builddir)/config.status $(srcdir)/linuxsampler.1.in - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-man1: $(man1_MANS) $(man_MANS) - @$(NORMAL_INSTALL) - test -z "$(man1dir)" || $(mkdir_p) "$(DESTDIR)$(man1dir)" - @list='$(man1_MANS) $(dist_man1_MANS) $(nodist_man1_MANS)'; \ - l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ - for i in $$l2; do \ - case "$$i" in \ - *.1*) list="$$list $$i" ;; \ - esac; \ - done; \ - for i in $$list; do \ - if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ - else file=$$i; fi; \ - ext=`echo $$i | sed -e 's/^.*\\.//'`; \ - case "$$ext" in \ - 1*) ;; \ - *) ext='1' ;; \ - esac; \ - inst=`echo $$i | sed -e 's/\\.0-9a-z*$$//'`; \ - inst=`echo $$inst | sed -e 's/^.*\///'`; \ - inst=`echo $$inst | sed '$(transform)'`.$$ext; \ - echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man1dir)/$$inst'"; \ - $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man1dir)/$$inst"; \ - done -uninstall-man1: - @$(NORMAL_UNINSTALL) - @list='$(man1_MANS) $(dist_man1_MANS) $(nodist_man1_MANS)'; \ - l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ - for i in $$l2; do \ - case "$$i" in \ - *.1*) list="$$list $$i" ;; \ - esac; \ - done; \ - for i in $$list; do \ - ext=`echo $$i | sed -e 's/^.*\\.//'`; \ - case "$$ext" in \ - 1*) ;; \ - *) ext='1' ;; \ - esac; \ - inst=`echo $$i | sed -e 's/\\.0-9a-z*$$//'`; \ - inst=`echo $$inst | sed -e 's/^.*\///'`; \ - inst=`echo $$inst | sed '$(transform)'`.$$ext; \ - echo " rm -f '$(DESTDIR)$(man1dir)/$$inst'"; \ - rm -f "$(DESTDIR)$(man1dir)/$$inst"; \ - done -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(MANS) -installdirs: - for dir in "$(DESTDIR)$(man1dir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-man - -install-exec-am: - -install-info: install-info-am - -install-man: install-man1 - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am uninstall-man - -uninstall-man: uninstall-man1 - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-man1 \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - uninstall uninstall-am uninstall-info-am uninstall-man \ - uninstall-man1 - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/missing
Deleted
@@ -1,360 +0,0 @@ -#! /bin/sh -# Common stub for a few missing GNU programs while installing. - -scriptversion=2003-09-02.23 - -# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003 -# Free Software Foundation, Inc. -# Originally by Fran,cois Pinard <pinard@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 - -msg="missing on your system" - -case "$1" in ---run) - # Try to run requested program, and just exit if it succeeds. - run= - shift - "$@" && exit 0 - # Exit code 63 means version mismatch. This often happens - # when the user try to use an ancient version of a tool on - # a file that requires a minimum version. In this case we - # we should proceed has if the program had been absent, or - # if --run hadn't been passed. - if test $? = 63; then - run=: - msg="probably too old" - fi - ;; -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 - -Send bug reports to <bug-automake@gnu.org>." - ;; - - -v|--v|--ve|--ver|--vers|--versi|--versio|--version) - echo "missing $scriptversion (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 $msg. You should only need it if - you modified \`acinclude.m4' or \`${configure_ac}'. You might want - to install the \`Automake' and \`Perl' packages. Grab them from - any GNU archive site." - touch aclocal.m4 - ;; - - autoconf) - 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 $msg. You should only need it if - you modified \`${configure_ac}'. You might want to install the - \`Autoconf' and \`GNU m4' packages. Grab them from any GNU - archive site." - touch configure - ;; - - autoheader) - 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 $msg. You should only need it if - you modified \`acconfig.h' or \`${configure_ac}'. You might want - to install the \`Autoconf' and \`GNU m4' packages. Grab them - from any GNU archive site." - files=`sed -n 's/^ *ACM_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 $msg. You should only need it if - you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'. - You might want to install the \`Automake' and \`Perl' packages. - Grab them from any GNU archive site." - find . -type f -name Makefile.am -print | - sed 's/\.am$/.in/' | - while read f; do touch "$f"; done - ;; - - autom4te) - 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, but is $msg. - You might have modified some files without having the - proper tools for further handling them. - You can get \`$1' as part of \`Autoconf' from any GNU - archive site." - - file=`echo "$*" | sed -n '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' $msg. You should only need it if - you modified a \`.y' file. You may need the \`Bison' package - in order for those modifications to take effect. You can get - \`Bison' from any GNU archive site." - rm -f y.tab.c y.tab.h - if $# -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 $msg. You should only need it if - you modified a \`.l' file. You may need the \`Flex' package - in order for those modifications to take effect. You can get - \`Flex' from any GNU archive site." - rm -f lex.yy.c - if $# -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 $msg. You should only need it if - you modified a dependency of a manual page. You may need the - \`Help2man' package in order for those modifications to take - effect. You can get \`Help2man' from any GNU archive site." - - file=`echo "$*" | sed -n '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 $msg. You should only need it if - you modified a \`.texi' or \`.texinfo' file, or any other file - indirectly affecting the aspect of the manual. The spurious - call might also be the consequence of using a buggy \`make' (AIX, - DU, IRIX). You might want to install the \`Texinfo' package or - the \`GNU make' package. Grab either from any GNU archive site." - 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 is $msg. - You might have modified some files without having the - proper tools for further handling them. Check the \`README' file, - it often tells you about the needed prerequisites for installing - this package. You may also peek at any GNU archive site, in case - some other package would contain this missing \`$1' program." - exit 1 - ;; -esac - -exit 0 - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-end: "$" -# End:
View file
linuxsampler-1.0.0.tar.bz2/osx/Makefile.in
Deleted
@@ -1,521 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = osx -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -SUBDIRS = linuxsampler.xcodeproj -EXTRA_DIST = autoconf_builder.sh wrapper.sh README.osx -all: all-recursive - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu osx/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu osx/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile -installdirs: installdirs-recursive -installdirs-am: -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-recursive - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool \ - distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-recursive ctags \ - ctags-recursive distclean distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-man install-strip installcheck \ - installcheck-am installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-generic mostlyclean-libtool \ - mostlyclean-recursive pdf pdf-am ps ps-am tags tags-recursive \ - uninstall uninstall-am uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/osx/linuxsampler.xcodeproj/Makefile.in
Deleted
@@ -1,377 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = osx/linuxsampler.xcodeproj -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -EXTRA_DIST = project.pbxproj -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu osx/linuxsampler.xcodeproj/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu osx/linuxsampler.xcodeproj/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-generic \ - mostlyclean-libtool pdf pdf-am ps ps-am uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/scripts/Makefile.in
Deleted
@@ -1,382 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = scripts -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -EXTRA_DIST = \ - create_instr_db.sh \ - create_instr_db.sql \ - generate_parser.sh \ - update_grammar.pl - -all: all-am - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu scripts/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu scripts/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -tags: TAGS -TAGS: - -ctags: CTAGS -CTAGS: - - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: all all-am check check-am clean clean-generic clean-libtool \ - distclean distclean-generic distclean-libtool distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-generic \ - mostlyclean-libtool pdf pdf-am ps ps-am uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/Makefile.in
Deleted
@@ -1,723 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - - -SOURCES = $(liblinuxsampler_la_SOURCES) $(linuxsampler_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = .. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -bin_PROGRAMS = linuxsampler$(EXEEXT) -subdir = src -DIST_COMMON = $(liblinuxsamplerinclude_HEADERS) $(srcdir)/Makefile.am \ - $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am__installdirs = "$(DESTDIR)$(pkglibdir)" "$(DESTDIR)$(bindir)" "$(DESTDIR)$(liblinuxsamplerincludedir)" -pkglibLTLIBRARIES_INSTALL = $(INSTALL) -LTLIBRARIES = $(pkglib_LTLIBRARIES) -@HAVE_SQLITE3_TRUE@am__DEPENDENCIES_1 = $(top_builddir)/src/db/liblinuxsamplerdb.la -liblinuxsampler_la_DEPENDENCIES = $(am__DEPENDENCIES_1) \ - $(top_builddir)/src/network/liblinuxsamplernetwork.la \ - $(top_builddir)/src/engines/gig/liblinuxsamplergigengine.la \ - $(top_builddir)/src/engines/common/liblinuxsamplercommonengine.la \ - $(top_builddir)/src/engines/liblinuxsamplerengines.la \ - $(top_builddir)/src/drivers/liblinuxsamplerdrivers.la \ - $(top_builddir)/src/drivers/audio/liblinuxsampleraudiodriver.la \ - $(top_builddir)/src/drivers/midi/liblinuxsamplermididriver.la \ - $(top_builddir)/src/plugins/liblinuxsamplerplugins.la \ - $(top_builddir)/src/effects/liblinuxsamplereffects.la \ - $(top_builddir)/src/common/liblinuxsamplercommon.la -am_liblinuxsampler_la_OBJECTS = Sampler.lo -liblinuxsampler_la_OBJECTS = $(am_liblinuxsampler_la_OBJECTS) -binPROGRAMS_INSTALL = $(INSTALL_PROGRAM) -PROGRAMS = $(bin_PROGRAMS) -am_linuxsampler_OBJECTS = linuxsampler.$(OBJEXT) -linuxsampler_OBJECTS = $(am_linuxsampler_OBJECTS) -linuxsampler_DEPENDENCIES = liblinuxsampler.la -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Sampler.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/linuxsampler.Po -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsampler_la_SOURCES) $(linuxsampler_SOURCES) -DIST_SOURCES = $(liblinuxsampler_la_SOURCES) $(linuxsampler_SOURCES) -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -liblinuxsamplerincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplerinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ - -# set the include path found by configure -INCLUDES = $(all_includes) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) -@HAVE_COREMIDI_FALSE@coremidi_ldflags = -@HAVE_COREMIDI_TRUE@coremidi_ldflags = -framework CoreAudio \ -@HAVE_COREMIDI_TRUE@ -framework CoreMIDI \ -@HAVE_COREMIDI_TRUE@ -framework CoreServices \ -@HAVE_COREMIDI_TRUE@ -framework AudioUnit - -@HAVE_SQLITE3_FALSE@sqlite3_lib = -@HAVE_SQLITE3_TRUE@sqlite3_lib = $(top_builddir)/src/db/liblinuxsamplerdb.la -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -SUBDIRS = db network engines common testcases drivers plugins effects . hostplugins -liblinuxsamplerincludedir = $(includedir)/linuxsampler -liblinuxsamplerinclude_HEADERS = Sampler.h EventListeners.h -pkglib_LTLIBRARIES = liblinuxsampler.la -liblinuxsampler_la_SOURCES = Sampler.cpp -liblinuxsampler_la_LIBADD = \ - $(sqlite3_lib) \ - $(top_builddir)/src/network/liblinuxsamplernetwork.la \ - $(top_builddir)/src/engines/gig/liblinuxsamplergigengine.la \ - $(top_builddir)/src/engines/common/liblinuxsamplercommonengine.la \ - $(top_builddir)/src/engines/liblinuxsamplerengines.la \ - $(top_builddir)/src/drivers/liblinuxsamplerdrivers.la \ - $(top_builddir)/src/drivers/audio/liblinuxsampleraudiodriver.la \ - $(top_builddir)/src/drivers/midi/liblinuxsamplermididriver.la \ - $(top_builddir)/src/plugins/liblinuxsamplerplugins.la \ - $(top_builddir)/src/effects/liblinuxsamplereffects.la \ - $(top_builddir)/src/common/liblinuxsamplercommon.la - -liblinuxsampler_la_LDFLAGS = -version-info @SHARED_VERSION_INFO@ @SHLIB_VERSION_ARG@ -no-undefined -linuxsampler_SOURCES = linuxsampler.cpp -linuxsampler_LDADD = liblinuxsampler.la -linuxsampler_LDFLAGS = $(coremidi_ldflags) -all: all-recursive - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -install-pkglibLTLIBRARIES: $(pkglib_LTLIBRARIES) - @$(NORMAL_INSTALL) - test -z "$(pkglibdir)" || $(mkdir_p) "$(DESTDIR)$(pkglibdir)" - @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \ - if test -f $$p; then \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=install $(pkglibLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) '$$p' '$(DESTDIR)$(pkglibdir)/$$f'"; \ - $(LIBTOOL) --mode=install $(pkglibLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) "$$p" "$(DESTDIR)$(pkglibdir)/$$f"; \ - else :; fi; \ - done - -uninstall-pkglibLTLIBRARIES: - @$(NORMAL_UNINSTALL) - @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \ - p="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=uninstall rm -f '$(DESTDIR)$(pkglibdir)/$$p'"; \ - $(LIBTOOL) --mode=uninstall rm -f "$(DESTDIR)$(pkglibdir)/$$p"; \ - done - -clean-pkglibLTLIBRARIES: - -test -z "$(pkglib_LTLIBRARIES)" || rm -f $(pkglib_LTLIBRARIES) - @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsampler.la: $(liblinuxsampler_la_OBJECTS) $(liblinuxsampler_la_DEPENDENCIES) - $(CXXLINK) -rpath $(pkglibdir) $(liblinuxsampler_la_LDFLAGS) $(liblinuxsampler_la_OBJECTS) $(liblinuxsampler_la_LIBADD) $(LIBS) -install-binPROGRAMS: $(bin_PROGRAMS) - @$(NORMAL_INSTALL) - test -z "$(bindir)" || $(mkdir_p) "$(DESTDIR)$(bindir)" - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ - if test -f $$p \ - || test -f $$p1 \ - ; then \ - f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \ - echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) '$$p' '$(DESTDIR)$(bindir)/$$f'"; \ - $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) "$$p" "$(DESTDIR)$(bindir)/$$f" || exit 1; \ - else :; fi; \ - done - -uninstall-binPROGRAMS: - @$(NORMAL_UNINSTALL) - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \ - echo " rm -f '$(DESTDIR)$(bindir)/$$f'"; \ - rm -f "$(DESTDIR)$(bindir)/$$f"; \ - done - -clean-binPROGRAMS: - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ - echo " rm -f $$p $$f"; \ - rm -f $$p $$f ; \ - done -linuxsampler$(EXEEXT): $(linuxsampler_OBJECTS) $(linuxsampler_DEPENDENCIES) - @rm -f linuxsampler$(EXEEXT) - $(CXXLINK) $(linuxsampler_LDFLAGS) $(linuxsampler_OBJECTS) $(linuxsampler_LDADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Sampler.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/linuxsampler.Po@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplerincludeHEADERS: $(liblinuxsamplerinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplerincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplerincludedir)" - @list='$(liblinuxsamplerinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplerincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplerincludedir)/$$f'"; \ - $(liblinuxsamplerincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplerincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplerincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplerinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplerincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplerincludedir)/$$f"; \ - done - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile $(LTLIBRARIES) $(PROGRAMS) $(HEADERS) -installdirs: installdirs-recursive -installdirs-am: - for dir in "$(DESTDIR)$(pkglibdir)" "$(DESTDIR)$(bindir)" "$(DESTDIR)$(liblinuxsamplerincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-binPROGRAMS clean-generic clean-libtool \ - clean-pkglibLTLIBRARIES mostlyclean-am - -distclean: distclean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: install-liblinuxsamplerincludeHEADERS - -install-exec-am: install-binPROGRAMS install-pkglibLTLIBRARIES - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-binPROGRAMS uninstall-info-am \ - uninstall-liblinuxsamplerincludeHEADERS \ - uninstall-pkglibLTLIBRARIES - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-binPROGRAMS clean-generic clean-libtool \ - clean-pkglibLTLIBRARIES clean-recursive ctags ctags-recursive \ - distclean distclean-compile distclean-generic \ - distclean-libtool distclean-recursive distclean-tags distdir \ - dvi dvi-am html html-am info info-am install install-am \ - install-binPROGRAMS install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsamplerincludeHEADERS install-man \ - install-pkglibLTLIBRARIES install-strip installcheck \ - installcheck-am installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool mostlyclean-recursive pdf pdf-am ps ps-am \ - tags tags-recursive uninstall uninstall-am \ - uninstall-binPROGRAMS uninstall-info-am \ - uninstall-liblinuxsamplerincludeHEADERS \ - uninstall-pkglibLTLIBRARIES - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/common/Makefile.in
Deleted
@@ -1,618 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplercommon_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/common -DIST_COMMON = $(liblinuxsamplercommoninclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplercommon_la_LIBADD = -am_liblinuxsamplercommon_la_OBJECTS = global_private.lo Condition.lo \ - ConditionServer.lo Features.lo Mutex.lo optional.lo RTMath.lo \ - stacktrace.lo Thread.lo WorkerThread.lo Path.lo File.lo -liblinuxsamplercommon_la_OBJECTS = \ - $(am_liblinuxsamplercommon_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Condition.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/ConditionServer.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Features.Plo ./$(DEPDIR)/File.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Mutex.Plo ./$(DEPDIR)/Path.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/RTMath.Plo ./$(DEPDIR)/Thread.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/WorkerThread.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/global_private.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/optional.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/stacktrace.Plo -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplercommon_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplercommon_la_SOURCES) -am__installdirs = "$(DESTDIR)$(liblinuxsamplercommonincludedir)" -liblinuxsamplercommonincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplercommoninclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -liblinuxsamplercommonincludedir = $(includedir)/linuxsampler/common -liblinuxsamplercommoninclude_HEADERS = \ - Exception.h \ - Thread.h \ - global.h \ - optional.h \ - Mutex.h \ - SynchronizedConfig.h \ - Condition.h \ - lsatomic.h - -noinst_LTLIBRARIES = liblinuxsamplercommon.la -liblinuxsamplercommon_la_SOURCES = \ - global_private.cpp global_private.h \ - atomic.h \ - ArrayList.h \ - Condition.cpp Condition.h \ - ConditionServer.cpp ConditionServer.h \ - Features.cpp Features.h \ - Mutex.cpp \ - optional.cpp \ - Pool.h \ - ResourceManager.h \ - RingBuffer.h \ - RTMath.cpp RTMath.h \ - stacktrace.c stacktrace.h \ - Thread.cpp Thread.h \ - WorkerThread.cpp WorkerThread.h \ - Path.cpp Path.h \ - File.cpp File.h - -all: all-am - -.SUFFIXES: -.SUFFIXES: .c .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/common/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/common/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplercommon.la: $(liblinuxsamplercommon_la_OBJECTS) $(liblinuxsamplercommon_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplercommon_la_LDFLAGS) $(liblinuxsamplercommon_la_OBJECTS) $(liblinuxsamplercommon_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Condition.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ConditionServer.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Features.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/File.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Mutex.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Path.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/RTMath.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Thread.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/WorkerThread.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/global_private.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/optional.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/stacktrace.Plo@am__quote@ - -.c.o: -@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@ $(COMPILE) -c $< - -.c.obj: -@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'` - -.c.lo: -@am__fastdepCC_TRUE@ if $(LTCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@ $(LTCOMPILE) -c -o $@ $< - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplercommonincludeHEADERS: $(liblinuxsamplercommoninclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplercommonincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplercommonincludedir)" - @list='$(liblinuxsamplercommoninclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplercommonincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplercommonincludedir)/$$f'"; \ - $(liblinuxsamplercommonincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplercommonincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplercommonincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplercommoninclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplercommonincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplercommonincludedir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: - for dir in "$(DESTDIR)$(liblinuxsamplercommonincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-liblinuxsamplercommonincludeHEADERS - -install-exec-am: - @$(NORMAL_INSTALL) - $(MAKE) $(AM_MAKEFLAGS) install-exec-hook - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplercommonincludeHEADERS - @$(NORMAL_INSTALL) - $(MAKE) $(AM_MAKEFLAGS) uninstall-hook - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsamplercommonincludeHEADERS install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am \ - uninstall-liblinuxsamplercommonincludeHEADERS - - -# create the plugins directory (i.e. /usr/lib/linuxsampler/plugins) -install-exec-hook: - mkdir -p $(DESTDIR)$(config_plugin_dir) - -# remove the plugins directory (if empty) -uninstall-hook: - rmdir --ignore-fail-on-non-empty $(DESTDIR)$(config_plugin_dir) -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/db/Makefile.in
Deleted
@@ -1,580 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(liblinuxsamplerdb_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/db -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -am__DEPENDENCIES_1 = -@HAVE_SQLITE3_TRUE@am__DEPENDENCIES_2 = $(am__DEPENDENCIES_1) -@HAVE_SQLITE3_TRUE@liblinuxsamplerdb_la_DEPENDENCIES = \ -@HAVE_SQLITE3_TRUE@ $(am__DEPENDENCIES_2) -am__liblinuxsamplerdb_la_SOURCES_DIST = InstrumentsDb.cpp \ - InstrumentsDb.h InstrumentsDbUtilities.cpp \ - InstrumentsDbUtilities.h -@HAVE_SQLITE3_TRUE@am__objects_1 = \ -@HAVE_SQLITE3_TRUE@ liblinuxsamplerdb_la-InstrumentsDb.lo \ -@HAVE_SQLITE3_TRUE@ liblinuxsamplerdb_la-InstrumentsDbUtilities.lo -@HAVE_SQLITE3_TRUE@am_liblinuxsamplerdb_la_OBJECTS = $(am__objects_1) -liblinuxsamplerdb_la_OBJECTS = $(am_liblinuxsamplerdb_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplerdb_la_SOURCES) -DIST_SOURCES = $(am__liblinuxsamplerdb_la_SOURCES_DIST) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_SQLITE3_TRUE@INCLUDES = $(all_includes) $(GIG_CFLAGS) -@HAVE_SQLITE3_TRUE@AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -@HAVE_SQLITE3_TRUE@METASOURCES = AUTO -@HAVE_SQLITE3_TRUE@sqlite3_lflags = $(SQLITE3_LIBS) -@HAVE_SQLITE3_TRUE@sqlite3_cflags = $(SQLITE3_CFLAGS) -@HAVE_SQLITE3_TRUE@instruments_db_headers = \ -@HAVE_SQLITE3_TRUE@ InstrumentsDb.h InstrumentsDbUtilities.h - -@HAVE_SQLITE3_TRUE@instruments_db_sources = \ -@HAVE_SQLITE3_TRUE@ InstrumentsDb.cpp InstrumentsDb.h \ -@HAVE_SQLITE3_TRUE@ InstrumentsDbUtilities.cpp InstrumentsDbUtilities.h - - -#liblinuxsamplerdbincludedir = $(includedir)/linuxsampler/db -#liblinuxsamplerdbinclude_HEADERS = \ -# $(instruments_db_headers) -@HAVE_SQLITE3_TRUE@noinst_LTLIBRARIES = liblinuxsamplerdb.la -@HAVE_SQLITE3_TRUE@liblinuxsamplerdb_la_SOURCES = \ -@HAVE_SQLITE3_TRUE@ $(instruments_db_sources) - -@HAVE_SQLITE3_TRUE@liblinuxsamplerdb_la_LIBADD = $(sqlite3_lflags) -@HAVE_SQLITE3_TRUE@liblinuxsamplerdb_la_CFLAGS = $(sqlite3_cflags) -@HAVE_SQLITE3_TRUE@liblinuxsamplerdb_la_CXXFLAGS = $(sqlite3_cflags) -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/db/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/db/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplerdb.la: $(liblinuxsamplerdb_la_OBJECTS) $(liblinuxsamplerdb_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplerdb_la_LDFLAGS) $(liblinuxsamplerdb_la_OBJECTS) $(liblinuxsamplerdb_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -liblinuxsamplerdb_la-InstrumentsDb.o: InstrumentsDb.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDb.o -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDb.o `test -f 'InstrumentsDb.cpp' || echo '$(srcdir)/'`InstrumentsDb.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Po"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDb.cpp' object='liblinuxsamplerdb_la-InstrumentsDb.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Po' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDb.o `test -f 'InstrumentsDb.cpp' || echo '$(srcdir)/'`InstrumentsDb.cpp - -liblinuxsamplerdb_la-InstrumentsDb.obj: InstrumentsDb.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDb.obj -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDb.obj `if test -f 'InstrumentsDb.cpp'; then $(CYGPATH_W) 'InstrumentsDb.cpp'; else $(CYGPATH_W) '$(srcdir)/InstrumentsDb.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Po"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDb.cpp' object='liblinuxsamplerdb_la-InstrumentsDb.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Po' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDb.obj `if test -f 'InstrumentsDb.cpp'; then $(CYGPATH_W) 'InstrumentsDb.cpp'; else $(CYGPATH_W) '$(srcdir)/InstrumentsDb.cpp'; fi` - -liblinuxsamplerdb_la-InstrumentsDb.lo: InstrumentsDb.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDb.lo -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDb.lo `test -f 'InstrumentsDb.cpp' || echo '$(srcdir)/'`InstrumentsDb.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Plo"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDb.cpp' object='liblinuxsamplerdb_la-InstrumentsDb.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.Plo' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDb.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDb.lo `test -f 'InstrumentsDb.cpp' || echo '$(srcdir)/'`InstrumentsDb.cpp - -liblinuxsamplerdb_la-InstrumentsDbUtilities.o: InstrumentsDbUtilities.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDbUtilities.o -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.o `test -f 'InstrumentsDbUtilities.cpp' || echo '$(srcdir)/'`InstrumentsDbUtilities.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Po"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDbUtilities.cpp' object='liblinuxsamplerdb_la-InstrumentsDbUtilities.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Po' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.o `test -f 'InstrumentsDbUtilities.cpp' || echo '$(srcdir)/'`InstrumentsDbUtilities.cpp - -liblinuxsamplerdb_la-InstrumentsDbUtilities.obj: InstrumentsDbUtilities.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDbUtilities.obj -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.obj `if test -f 'InstrumentsDbUtilities.cpp'; then $(CYGPATH_W) 'InstrumentsDbUtilities.cpp'; else $(CYGPATH_W) '$(srcdir)/InstrumentsDbUtilities.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Po"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDbUtilities.cpp' object='liblinuxsamplerdb_la-InstrumentsDbUtilities.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Po' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.obj `if test -f 'InstrumentsDbUtilities.cpp'; then $(CYGPATH_W) 'InstrumentsDbUtilities.cpp'; else $(CYGPATH_W) '$(srcdir)/InstrumentsDbUtilities.cpp'; fi` - -liblinuxsamplerdb_la-InstrumentsDbUtilities.lo: InstrumentsDbUtilities.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -MT liblinuxsamplerdb_la-InstrumentsDbUtilities.lo -MD -MP -MF "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.lo `test -f 'InstrumentsDbUtilities.cpp' || echo '$(srcdir)/'`InstrumentsDbUtilities.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo" "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Plo"; else rm -f "$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='InstrumentsDbUtilities.cpp' object='liblinuxsamplerdb_la-InstrumentsDbUtilities.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.Plo' tmpdepfile='$(DEPDIR)/liblinuxsamplerdb_la-InstrumentsDbUtilities.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(liblinuxsamplerdb_la_CXXFLAGS) $(CXXFLAGS) -c -o liblinuxsamplerdb_la-InstrumentsDbUtilities.lo `test -f 'InstrumentsDbUtilities.cpp' || echo '$(srcdir)/'`InstrumentsDbUtilities.cpp - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/Makefile.in
Deleted
@@ -1,650 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplerdrivers_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/drivers -DIST_COMMON = $(liblinuxsamplerdriversinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplerdrivers_la_DEPENDENCIES = -am_liblinuxsamplerdrivers_la_OBJECTS = Device.lo DeviceParameter.lo \ - DeviceParameterFactory.lo Plugin.lo -liblinuxsamplerdrivers_la_OBJECTS = \ - $(am_liblinuxsamplerdrivers_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Device.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/DeviceParameter.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/DeviceParameterFactory.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Plugin.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplerdrivers_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplerdrivers_la_SOURCES) -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -am__installdirs = "$(DESTDIR)$(liblinuxsamplerdriversincludedir)" -liblinuxsamplerdriversincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplerdriversinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -liblinuxsamplerdriversincludedir = $(includedir)/linuxsampler/drivers -liblinuxsamplerdriversinclude_HEADERS = \ - Device.h \ - DeviceParameter.h - -noinst_LTLIBRARIES = liblinuxsamplerdrivers.la -liblinuxsamplerdrivers_la_SOURCES = \ - Device.cpp Device.h \ - DeviceParameter.cpp DeviceParameter.h \ - DeviceParameterFactory.cpp DeviceParameterFactory.h \ - Plugin.cpp Plugin.h - -liblinuxsamplerdrivers_la_LDFLAGS = -#liblinuxsamplerdrivers_la_DEPENDENCIES = -liblinuxsamplerdrivers_la_LIBADD = -SUBDIRS = audio midi -all: all-recursive - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/drivers/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/drivers/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplerdrivers.la: $(liblinuxsamplerdrivers_la_OBJECTS) $(liblinuxsamplerdrivers_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplerdrivers_la_LDFLAGS) $(liblinuxsamplerdrivers_la_OBJECTS) $(liblinuxsamplerdrivers_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Device.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/DeviceParameter.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/DeviceParameterFactory.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Plugin.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplerdriversincludeHEADERS: $(liblinuxsamplerdriversinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplerdriversincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplerdriversincludedir)" - @list='$(liblinuxsamplerdriversinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplerdriversincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplerdriversincludedir)/$$f'"; \ - $(liblinuxsamplerdriversincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplerdriversincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplerdriversincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplerdriversinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplerdriversincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplerdriversincludedir)/$$f"; \ - done - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: installdirs-recursive -installdirs-am: - for dir in "$(DESTDIR)$(liblinuxsamplerdriversincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: install-liblinuxsamplerdriversincludeHEADERS - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplerdriversincludeHEADERS - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-noinstLTLIBRARIES \ - clean-recursive ctags ctags-recursive distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-liblinuxsamplerdriversincludeHEADERS \ - install-man install-strip installcheck installcheck-am \ - installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool mostlyclean-recursive pdf pdf-am ps ps-am \ - tags tags-recursive uninstall uninstall-am uninstall-info-am \ - uninstall-liblinuxsamplerdriversincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/Makefile.in
Deleted
@@ -1,702 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsampleraudiodriver_la_SOURCES) $(nodist_liblinuxsampleraudiodriver_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/drivers/audio -DIST_COMMON = $(liblinuxsampleraudiodriverinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -am__DEPENDENCIES_1 = -liblinuxsampleraudiodriver_la_DEPENDENCIES = $(am__DEPENDENCIES_1) \ - $(am__DEPENDENCIES_1) -am__liblinuxsampleraudiodriver_la_SOURCES_DIST = AudioChannel.cpp \ - AudioChannel.h AudioOutputDevice.cpp AudioOutputDevice.h \ - AudioOutputDeviceFactory.cpp AudioOutputDeviceFactory.h \ - AudioOutputDeviceAlsa.cpp AudioOutputDeviceAlsa.h \ - AudioOutputDeviceJack.cpp AudioOutputDeviceJack.h \ - AudioOutputDeviceArts.cpp AudioOutputDeviceArts.h \ - AudioOutputDeviceAsio.cpp AudioOutputDeviceAsio.h \ - iasiothiscallresolver.cpp iasiothiscallresolver.h \ - AudioOutputDeviceCoreAudio.cpp AudioOutputDeviceCoreAudio.h \ - CAAudioDeviceModel.cpp CAAudioDeviceModel.h \ - AudioOutputDevicePlugin.cpp AudioOutputDevicePlugin.h -@HAVE_ALSA_TRUE@am__objects_1 = AudioOutputDeviceAlsa.lo -@HAVE_JACK_TRUE@am__objects_2 = AudioOutputDeviceJack.lo -@HAVE_ARTS_TRUE@am__objects_3 = AudioOutputDeviceArts.lo -@HAVE_ASIO_TRUE@am__objects_4 = AudioOutputDeviceAsio.lo \ -@HAVE_ASIO_TRUE@ iasiothiscallresolver.lo -@HAVE_COREAUDIO_TRUE@am__objects_5 = AudioOutputDeviceCoreAudio.lo \ -@HAVE_COREAUDIO_TRUE@ CAAudioDeviceModel.lo -am_liblinuxsampleraudiodriver_la_OBJECTS = AudioChannel.lo \ - AudioOutputDevice.lo AudioOutputDeviceFactory.lo \ - $(am__objects_1) $(am__objects_2) $(am__objects_3) \ - $(am__objects_4) $(am__objects_5) AudioOutputDevicePlugin.lo -@HAVE_ASIO_TRUE@am__objects_6 = asio.lo asiodrivers.lo asiolist.lo -nodist_liblinuxsampleraudiodriver_la_OBJECTS = $(am__objects_6) -liblinuxsampleraudiodriver_la_OBJECTS = \ - $(am_liblinuxsampleraudiodriver_la_OBJECTS) \ - $(nodist_liblinuxsampleraudiodriver_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/AudioChannel.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDevice.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceAlsa.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceArts.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceAsio.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceCoreAudio.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceFactory.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDeviceJack.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/AudioOutputDevicePlugin.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/CAAudioDeviceModel.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/asio.Plo ./$(DEPDIR)/asiodrivers.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/asiolist.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/iasiothiscallresolver.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsampleraudiodriver_la_SOURCES) \ - $(nodist_liblinuxsampleraudiodriver_la_SOURCES) -DIST_SOURCES = $(am__liblinuxsampleraudiodriver_la_SOURCES_DIST) -am__installdirs = "$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)" -liblinuxsampleraudiodriverincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsampleraudiodriverinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -@HAVE_ALSA_FALSE@alsa_src = -@HAVE_ALSA_TRUE@alsa_src = AudioOutputDeviceAlsa.cpp AudioOutputDeviceAlsa.h -@HAVE_ALSA_FALSE@alsa_ladd = -@HAVE_ALSA_TRUE@alsa_ladd = -lasound -@HAVE_JACK_FALSE@jack_src = -@HAVE_JACK_TRUE@jack_src = AudioOutputDeviceJack.cpp AudioOutputDeviceJack.h -@HAVE_JACK_FALSE@jack_lflags = -@HAVE_JACK_TRUE@jack_lflags = $(JACK_LIBS) -@HAVE_JACK_FALSE@jack_includes = -@HAVE_JACK_TRUE@jack_includes = $(JACK_CFLAGS) -@HAVE_ARTS_FALSE@arts_src = -@HAVE_ARTS_TRUE@arts_src = AudioOutputDeviceArts.cpp AudioOutputDeviceArts.h -@HAVE_ARTS_FALSE@arts_ladd = -@HAVE_ARTS_TRUE@arts_ladd = @ARTS_LIBS@ -@HAVE_ARTS_FALSE@arts_includes = -@HAVE_ARTS_TRUE@arts_includes = @ARTS_CFLAGS@ -@HAVE_ASIO_FALSE@asio_includes = -@HAVE_ASIO_TRUE@asio_includes = -I@ASIOSDK_BASEDIR@/ASIOSDK2/common -I@ASIOSDK_BASEDIR@/ASIOSDK2/host -I@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc -@HAVE_ASIO_FALSE@asio_3rd_party_src = -@HAVE_ASIO_TRUE@asio_3rd_party_src = @ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp @ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.h @ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp @ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.h @ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp @ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.h -@HAVE_ASIO_FALSE@asio_src = -@HAVE_ASIO_TRUE@asio_src = AudioOutputDeviceAsio.cpp AudioOutputDeviceAsio.h iasiothiscallresolver.cpp iasiothiscallresolver.h -@HAVE_ASIO_FALSE@asio_ladd = -@HAVE_ASIO_TRUE@asio_ladd = -@HAVE_COREAUDIO_FALSE@coreaudio_src = -@HAVE_COREAUDIO_TRUE@coreaudio_src = AudioOutputDeviceCoreAudio.cpp AudioOutputDeviceCoreAudio.h \ -@HAVE_COREAUDIO_TRUE@ CAAudioDeviceModel.cpp CAAudioDeviceModel.h - -@HAVE_COREAUDIO_FALSE@coreaudio_ldflags = -@HAVE_COREAUDIO_TRUE@coreaudio_ldflags = -framework CoreAudio -framework AudioToolbox -liblinuxsampleraudiodriverincludedir = $(includedir)/linuxsampler/drivers/audio -liblinuxsampleraudiodriverinclude_HEADERS = \ - AudioChannel.h \ - AudioOutputDevice.h - -INCLUDES = $(all_includes) $(arts_includes) $(asio_includes) $(jack_includes) -noinst_LTLIBRARIES = liblinuxsampleraudiodriver.la -liblinuxsampleraudiodriver_la_SOURCES = \ - AudioChannel.cpp AudioChannel.h \ - AudioOutputDevice.cpp AudioOutputDevice.h \ - AudioOutputDeviceFactory.cpp AudioOutputDeviceFactory.h \ - $(alsa_src) $(jack_src) $(arts_src) $(asio_src) $(coreaudio_src) \ - AudioOutputDevicePlugin.cpp AudioOutputDevicePlugin.h - -nodist_liblinuxsampleraudiodriver_la_SOURCES = \ - $(asio_3rd_party_src) - -liblinuxsampleraudiodriver_la_LIBADD = $(alsa_ladd) $(arts_ladd) -liblinuxsampleraudiodriver_la_LDFLAGS = $(jack_lflags) $(coreaudio_ldflags) -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/drivers/audio/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/drivers/audio/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsampleraudiodriver.la: $(liblinuxsampleraudiodriver_la_OBJECTS) $(liblinuxsampleraudiodriver_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsampleraudiodriver_la_LDFLAGS) $(liblinuxsampleraudiodriver_la_OBJECTS) $(liblinuxsampleraudiodriver_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioChannel.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDevice.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceAlsa.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceArts.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceAsio.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceCoreAudio.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceFactory.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDeviceJack.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/AudioOutputDevicePlugin.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CAAudioDeviceModel.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/asio.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/asiodrivers.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/asiolist.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/iasiothiscallresolver.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -asio.o: @ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asio.o -MD -MP -MF "$(DEPDIR)/asio.Tpo" -c -o asio.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asio.Tpo" "$(DEPDIR)/asio.Po"; else rm -f "$(DEPDIR)/asio.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' object='asio.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asio.Po' tmpdepfile='$(DEPDIR)/asio.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asio.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp - -asio.obj: @ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asio.obj -MD -MP -MF "$(DEPDIR)/asio.Tpo" -c -o asio.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asio.Tpo" "$(DEPDIR)/asio.Po"; else rm -f "$(DEPDIR)/asio.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' object='asio.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asio.Po' tmpdepfile='$(DEPDIR)/asio.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asio.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp'; fi` - -asio.lo: @ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asio.lo -MD -MP -MF "$(DEPDIR)/asio.Tpo" -c -o asio.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asio.Tpo" "$(DEPDIR)/asio.Plo"; else rm -f "$(DEPDIR)/asio.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' object='asio.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asio.Plo' tmpdepfile='$(DEPDIR)/asio.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asio.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/common/asio.cpp - -asiodrivers.o: @ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiodrivers.o -MD -MP -MF "$(DEPDIR)/asiodrivers.Tpo" -c -o asiodrivers.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiodrivers.Tpo" "$(DEPDIR)/asiodrivers.Po"; else rm -f "$(DEPDIR)/asiodrivers.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' object='asiodrivers.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiodrivers.Po' tmpdepfile='$(DEPDIR)/asiodrivers.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiodrivers.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp - -asiodrivers.obj: @ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiodrivers.obj -MD -MP -MF "$(DEPDIR)/asiodrivers.Tpo" -c -o asiodrivers.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiodrivers.Tpo" "$(DEPDIR)/asiodrivers.Po"; else rm -f "$(DEPDIR)/asiodrivers.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' object='asiodrivers.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiodrivers.Po' tmpdepfile='$(DEPDIR)/asiodrivers.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiodrivers.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp'; fi` - -asiodrivers.lo: @ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiodrivers.lo -MD -MP -MF "$(DEPDIR)/asiodrivers.Tpo" -c -o asiodrivers.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiodrivers.Tpo" "$(DEPDIR)/asiodrivers.Plo"; else rm -f "$(DEPDIR)/asiodrivers.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' object='asiodrivers.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiodrivers.Plo' tmpdepfile='$(DEPDIR)/asiodrivers.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiodrivers.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/asiodrivers.cpp - -asiolist.o: @ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiolist.o -MD -MP -MF "$(DEPDIR)/asiolist.Tpo" -c -o asiolist.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiolist.Tpo" "$(DEPDIR)/asiolist.Po"; else rm -f "$(DEPDIR)/asiolist.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' object='asiolist.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiolist.Po' tmpdepfile='$(DEPDIR)/asiolist.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiolist.o `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp - -asiolist.obj: @ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiolist.obj -MD -MP -MF "$(DEPDIR)/asiolist.Tpo" -c -o asiolist.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiolist.Tpo" "$(DEPDIR)/asiolist.Po"; else rm -f "$(DEPDIR)/asiolist.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' object='asiolist.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiolist.Po' tmpdepfile='$(DEPDIR)/asiolist.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiolist.obj `if test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; then $(CYGPATH_W) '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; else $(CYGPATH_W) '$(srcdir)/@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp'; fi` - -asiolist.lo: @ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT asiolist.lo -MD -MP -MF "$(DEPDIR)/asiolist.Tpo" -c -o asiolist.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/asiolist.Tpo" "$(DEPDIR)/asiolist.Plo"; else rm -f "$(DEPDIR)/asiolist.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' object='asiolist.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/asiolist.Plo' tmpdepfile='$(DEPDIR)/asiolist.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o asiolist.lo `test -f '@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp' || echo '$(srcdir)/'`@ASIOSDK_BASEDIR@/ASIOSDK2/host/pc/asiolist.cpp - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsampleraudiodriverincludeHEADERS: $(liblinuxsampleraudiodriverinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsampleraudiodriverincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)" - @list='$(liblinuxsampleraudiodriverinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsampleraudiodriverincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)/$$f'"; \ - $(liblinuxsampleraudiodriverincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)/$$f"; \ - done - -uninstall-liblinuxsampleraudiodriverincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsampleraudiodriverinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: - for dir in "$(DESTDIR)$(liblinuxsampleraudiodriverincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-liblinuxsampleraudiodriverincludeHEADERS - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsampleraudiodriverincludeHEADERS - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsampleraudiodriverincludeHEADERS install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am \ - uninstall-liblinuxsampleraudiodriverincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/Makefile.in
Deleted
@@ -1,618 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplermididriver_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/drivers/midi -DIST_COMMON = $(liblinuxsamplermididriverinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -am__DEPENDENCIES_1 = -liblinuxsamplermididriver_la_DEPENDENCIES = $(am__DEPENDENCIES_1) \ - $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) -am__liblinuxsamplermididriver_la_SOURCES_DIST = midi.h \ - MidiInputDevice.cpp MidiInputDevice.h \ - MidiInputDeviceFactory.cpp MidiInputDeviceFactory.h \ - MidiInputPort.cpp MidiInputPort.h MidiInstrumentMapper.cpp \ - MidiInstrumentMapper.h VirtualMidiDevice.cpp \ - VirtualMidiDevice.h MidiInputDeviceAlsa.cpp \ - MidiInputDeviceAlsa.h MidiInputDeviceMidiShare.cpp \ - MidiInputDeviceMidiShare.h MidiInputDeviceCoreMidi.cpp \ - MidiInputDeviceCoreMidi.h MidiInputDeviceMme.cpp \ - MidiInputDeviceMme.h MidiInputDeviceJack.cpp \ - MidiInputDeviceJack.h MidiInputDevicePlugin.cpp \ - MidiInputDevicePlugin.h -@HAVE_ALSA_TRUE@am__objects_1 = MidiInputDeviceAlsa.lo -@HAVE_MIDISHARE_TRUE@am__objects_2 = MidiInputDeviceMidiShare.lo -@HAVE_COREMIDI_TRUE@am__objects_3 = MidiInputDeviceCoreMidi.lo -@HAVE_MME_MIDI_TRUE@am__objects_4 = MidiInputDeviceMme.lo -@HAVE_JACK_MIDI_TRUE@am__objects_5 = MidiInputDeviceJack.lo -am_liblinuxsamplermididriver_la_OBJECTS = MidiInputDevice.lo \ - MidiInputDeviceFactory.lo MidiInputPort.lo \ - MidiInstrumentMapper.lo VirtualMidiDevice.lo $(am__objects_1) \ - $(am__objects_2) $(am__objects_3) $(am__objects_4) \ - $(am__objects_5) MidiInputDevicePlugin.lo -liblinuxsamplermididriver_la_OBJECTS = \ - $(am_liblinuxsamplermididriver_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/MidiInputDevice.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceAlsa.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceCoreMidi.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceFactory.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceJack.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceMidiShare.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDeviceMme.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputDevicePlugin.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInputPort.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/MidiInstrumentMapper.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/VirtualMidiDevice.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplermididriver_la_SOURCES) -DIST_SOURCES = $(am__liblinuxsamplermididriver_la_SOURCES_DIST) -am__installdirs = "$(DESTDIR)$(liblinuxsamplermididriverincludedir)" -liblinuxsamplermididriverincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplermididriverinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -@HAVE_ALSA_FALSE@alsa_src = -@HAVE_ALSA_TRUE@alsa_src = MidiInputDeviceAlsa.cpp MidiInputDeviceAlsa.h -@HAVE_ALSA_FALSE@alsa_ladd = -@HAVE_ALSA_TRUE@alsa_ladd = -lasound -@HAVE_MIDISHARE_FALSE@midishare_src = -@HAVE_MIDISHARE_TRUE@midishare_src = MidiInputDeviceMidiShare.cpp MidiInputDeviceMidiShare.h -@HAVE_MIDISHARE_FALSE@midishare_ladd = -@HAVE_MIDISHARE_TRUE@midishare_ladd = -lMidiShare -@HAVE_COREMIDI_FALSE@coremidi_src = -@HAVE_COREMIDI_TRUE@coremidi_src = MidiInputDeviceCoreMidi.cpp MidiInputDeviceCoreMidi.h -@HAVE_COREMIDI_FALSE@coremidi_ldflags = -@HAVE_COREMIDI_TRUE@coremidi_ldflags = -framework CoreMIDI -@HAVE_MME_MIDI_FALSE@mmemidi_src = -@HAVE_MME_MIDI_TRUE@mmemidi_src = MidiInputDeviceMme.cpp MidiInputDeviceMme.h -@HAVE_MME_MIDI_FALSE@mmemidi_ladd = -@HAVE_MME_MIDI_TRUE@mmemidi_ladd = -lwinmm -@HAVE_JACK_MIDI_FALSE@jackmidi_src = -@HAVE_JACK_MIDI_TRUE@jackmidi_src = MidiInputDeviceJack.cpp MidiInputDeviceJack.h -@HAVE_JACK_MIDI_FALSE@jackmidi_includes = -@HAVE_JACK_MIDI_TRUE@jackmidi_includes = $(JACK_CFLAGS) -liblinuxsamplermididriverincludedir = $(includedir)/linuxsampler/drivers/midi -liblinuxsamplermididriverinclude_HEADERS = \ - midi.h \ - MidiInputPort.h \ - MidiInputDevice.h \ - MidiInstrumentMapper.h \ - VirtualMidiDevice.h - -INCLUDES = $(all_includes) $(jackmidi_includes) $(GIG_CFLAGS) -noinst_LTLIBRARIES = liblinuxsamplermididriver.la -liblinuxsamplermididriver_la_SOURCES = \ - midi.h \ - MidiInputDevice.cpp MidiInputDevice.h \ - MidiInputDeviceFactory.cpp MidiInputDeviceFactory.h \ - MidiInputPort.cpp MidiInputPort.h \ - MidiInstrumentMapper.cpp MidiInstrumentMapper.h \ - VirtualMidiDevice.cpp VirtualMidiDevice.h \ - $(alsa_src) \ - $(midishare_src)\ - $(coremidi_src)\ - $(mmemidi_src)\ - $(jackmidi_src)\ - MidiInputDevicePlugin.cpp MidiInputDevicePlugin.h - -liblinuxsamplermididriver_la_LIBADD = $(alsa_ladd) $(midishare_ladd) $(mmemidi_ladd) -liblinuxsamplermididriver_la_LDFLAGS = $(coremidi_ldflags) -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/drivers/midi/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/drivers/midi/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplermididriver.la: $(liblinuxsamplermididriver_la_OBJECTS) $(liblinuxsamplermididriver_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplermididriver_la_LDFLAGS) $(liblinuxsamplermididriver_la_OBJECTS) $(liblinuxsamplermididriver_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDevice.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceAlsa.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceCoreMidi.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceFactory.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceJack.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceMidiShare.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDeviceMme.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputDevicePlugin.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInputPort.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MidiInstrumentMapper.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VirtualMidiDevice.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplermididriverincludeHEADERS: $(liblinuxsamplermididriverinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplermididriverincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplermididriverincludedir)" - @list='$(liblinuxsamplermididriverinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplermididriverincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplermididriverincludedir)/$$f'"; \ - $(liblinuxsamplermididriverincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplermididriverincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplermididriverincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplermididriverinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplermididriverincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplermididriverincludedir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: - for dir in "$(DESTDIR)$(liblinuxsamplermididriverincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-liblinuxsamplermididriverincludeHEADERS - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplermididriverincludeHEADERS - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsamplermididriverincludeHEADERS install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am \ - uninstall-liblinuxsamplermididriverincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/effects/Makefile.in
Deleted
@@ -1,541 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplereffects_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/effects -DIST_COMMON = $(liblinuxsamplereffectsinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplereffects_la_LIBADD = -am_liblinuxsamplereffects_la_OBJECTS = Effect.lo EffectChain.lo -liblinuxsamplereffects_la_OBJECTS = \ - $(am_liblinuxsamplereffects_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Effect.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EffectChain.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplereffects_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplereffects_la_SOURCES) -am__installdirs = "$(DESTDIR)$(liblinuxsamplereffectsincludedir)" -liblinuxsamplereffectsincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplereffectsinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -liblinuxsamplereffectsincludedir = $(includedir)/linuxsampler/effects -liblinuxsamplereffectsinclude_HEADERS = \ - Effect.h \ - EffectChain.h - -noinst_LTLIBRARIES = liblinuxsamplereffects.la -liblinuxsamplereffects_la_SOURCES = \ - Effect.cpp Effect.h \ - EffectChain.cpp EffectChain.h - -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/effects/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/effects/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplereffects.la: $(liblinuxsamplereffects_la_OBJECTS) $(liblinuxsamplereffects_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplereffects_la_LDFLAGS) $(liblinuxsamplereffects_la_OBJECTS) $(liblinuxsamplereffects_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Effect.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EffectChain.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplereffectsincludeHEADERS: $(liblinuxsamplereffectsinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplereffectsincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplereffectsincludedir)" - @list='$(liblinuxsamplereffectsinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplereffectsincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplereffectsincludedir)/$$f'"; \ - $(liblinuxsamplereffectsincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplereffectsincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplereffectsincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplereffectsinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplereffectsincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplereffectsincludedir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: - for dir in "$(DESTDIR)$(liblinuxsamplereffectsincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-liblinuxsamplereffectsincludeHEADERS - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplereffectsincludeHEADERS - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsamplereffectsincludeHEADERS install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am \ - uninstall-liblinuxsamplereffectsincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/engines/Makefile.in
Deleted
@@ -1,659 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplerengines_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/engines -DIST_COMMON = $(liblinuxsamplerengineinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplerengines_la_LIBADD = -am_liblinuxsamplerengines_la_OBJECTS = Engine.lo EngineChannel.lo \ - EngineFactory.lo EngineChannelFactory.lo FxSend.lo \ - InstrumentManager.lo InstrumentManagerThread.lo -liblinuxsamplerengines_la_OBJECTS = \ - $(am_liblinuxsamplerengines_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Engine.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EngineChannel.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EngineChannelFactory.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EngineFactory.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/FxSend.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/InstrumentManager.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/InstrumentManagerThread.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplerengines_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplerengines_la_SOURCES) -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -am__installdirs = "$(DESTDIR)$(liblinuxsamplerengineincludedir)" -liblinuxsamplerengineincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplerengineinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = $(SUBDIRS) -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) $(GIG_CFLAGS) -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -DCONFIG_PLUGIN_DIR=\"$(config_plugin_dir)\" -METASOURCES = AUTO -SUBDIRS = gig common -liblinuxsamplerengineincludedir = $(includedir)/linuxsampler/engines -liblinuxsamplerengineinclude_HEADERS = \ - Engine.h \ - EngineChannel.h \ - FxSend.h \ - InstrumentManager.h - -noinst_LTLIBRARIES = liblinuxsamplerengines.la -liblinuxsamplerengines_la_SOURCES = \ - Engine.cpp Engine.h \ - EngineChannel.cpp EngineChannel.h \ - EngineFactory.cpp EngineFactory.h \ - EngineChannelFactory.cpp EngineChannelFactory.h \ - FxSend.cpp FxSend.h \ - InstrumentManager.cpp InstrumentManager.h \ - InstrumentManagerThread.cpp InstrumentManagerThread.h - -all: all-recursive - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/engines/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/engines/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplerengines.la: $(liblinuxsamplerengines_la_OBJECTS) $(liblinuxsamplerengines_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplerengines_la_LDFLAGS) $(liblinuxsamplerengines_la_OBJECTS) $(liblinuxsamplerengines_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Engine.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EngineChannel.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EngineChannelFactory.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EngineFactory.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/FxSend.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/InstrumentManager.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/InstrumentManagerThread.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplerengineincludeHEADERS: $(liblinuxsamplerengineinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplerengineincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplerengineincludedir)" - @list='$(liblinuxsamplerengineinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplerengineincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplerengineincludedir)/$$f'"; \ - $(liblinuxsamplerengineincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplerengineincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplerengineincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplerengineinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplerengineincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplerengineincludedir)/$$f"; \ - done - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: installdirs-recursive -installdirs-am: - for dir in "$(DESTDIR)$(liblinuxsamplerengineincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: install-liblinuxsamplerengineincludeHEADERS - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplerengineincludeHEADERS - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-noinstLTLIBRARIES \ - clean-recursive ctags ctags-recursive distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-liblinuxsamplerengineincludeHEADERS \ - install-man install-strip installcheck installcheck-am \ - installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool mostlyclean-recursive pdf pdf-am ps ps-am \ - tags tags-recursive uninstall uninstall-am uninstall-info-am \ - uninstall-liblinuxsamplerengineincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/engines/common/Makefile.in
Deleted
@@ -1,512 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(liblinuxsamplercommonengine_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/engines/common -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplercommonengine_la_LIBADD = -am_liblinuxsamplercommonengine_la_OBJECTS = Event.lo -liblinuxsamplercommonengine_la_OBJECTS = \ - $(am_liblinuxsamplercommonengine_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/Event.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplercommonengine_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplercommonengine_la_SOURCES) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -noinst_LTLIBRARIES = liblinuxsamplercommonengine.la -liblinuxsamplercommonengine_la_SOURCES = \ - BiquadFilter.h \ - Event.cpp Event.h \ - LFOBase.h \ - LFOTriangleDiHarmonic.h \ - LFOTriangleIntAbsMath.h \ - LFOTriangleIntMath.h \ - Resampler.h - -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/engines/common/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/engines/common/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplercommonengine.la: $(liblinuxsamplercommonengine_la_OBJECTS) $(liblinuxsamplercommonengine_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplercommonengine_la_LDFLAGS) $(liblinuxsamplercommonengine_la_OBJECTS) $(liblinuxsamplercommonengine_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Event.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Makefile.in
Deleted
@@ -1,543 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(liblinuxsamplergigengine_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/engines/gig -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -am__DEPENDENCIES_1 = -liblinuxsamplergigengine_la_DEPENDENCIES = $(am__DEPENDENCIES_1) -am_liblinuxsamplergigengine_la_OBJECTS = DiskThread.lo EGADSR.lo \ - EGDecay.lo Engine.lo InstrumentResourceManager.lo Stream.lo \ - Voice.lo Synthesizer.lo Profiler.lo EngineChannel.lo \ - SmoothVolume.lo -liblinuxsamplergigengine_la_OBJECTS = \ - $(am_liblinuxsamplergigengine_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/DiskThread.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EGADSR.Plo ./$(DEPDIR)/EGDecay.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Engine.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/EngineChannel.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/InstrumentResourceManager.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Profiler.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/SmoothVolume.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Stream.Plo ./$(DEPDIR)/Synthesizer.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/Voice.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplergigengine_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplergigengine_la_SOURCES) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) $(GIG_CFLAGS) -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math -noinst_LTLIBRARIES = liblinuxsamplergigengine.la -liblinuxsamplergigengine_la_SOURCES = \ - EngineGlobals.h \ - DiskThread.cpp DiskThread.h \ - EGADSR.cpp EGADSR.h \ - EGDecay.cpp EGDecay.h \ - Engine.cpp Engine.h \ - Filter.h \ - InstrumentResourceManager.cpp InstrumentResourceManager.h \ - Stream.cpp Stream.h \ - Voice.cpp Voice.h \ - Synthesizer.cpp Synthesizer.h \ - Profiler.cpp Profiler.h \ - EngineChannel.cpp EngineChannel.h \ - SmoothVolume.cpp SmoothVolume.h \ - SynthesisParam.h - -liblinuxsamplergigengine_la_LIBADD = $(GIG_LIBS) -liblinuxsamplergigengine_la_LDFLAGS = $(GIG_CFLAGS) -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/engines/gig/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/engines/gig/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplergigengine.la: $(liblinuxsamplergigengine_la_OBJECTS) $(liblinuxsamplergigengine_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplergigengine_la_LDFLAGS) $(liblinuxsamplergigengine_la_OBJECTS) $(liblinuxsamplergigengine_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/DiskThread.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EGADSR.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EGDecay.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Engine.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EngineChannel.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/InstrumentResourceManager.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Profiler.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/SmoothVolume.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Stream.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Synthesizer.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Voice.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/Makefile.in
Deleted
@@ -1,524 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/hostplugins -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -SOURCES = -DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ - html-recursive info-recursive install-data-recursive \ - install-exec-recursive install-info-recursive \ - install-recursive installcheck-recursive installdirs-recursive \ - pdf-recursive ps-recursive uninstall-info-recursive \ - uninstall-recursive -ETAGS = etags -CTAGS = ctags -DIST_SUBDIRS = dssi lv2 vst au -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_DSSI_TRUE@DSSI_SUBDIR = dssi -@HAVE_LV2_TRUE@LV2_SUBDIR = lv2 -@HAVE_VST_TRUE@VST_SUBDIR = vst -@HAVE_AU_TRUE@AU_SUBDIR = au -SUBDIRS = $(DSSI_SUBDIR) $(LV2_SUBDIR) $(VST_SUBDIR) $(AU_SUBDIR) -all: all-recursive - -.SUFFIXES: -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/hostplugins/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/hostplugins/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -# This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -# (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - target=`echo $@ | sed s/-recursive//`; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - dot_seen=yes; \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done; \ - if test "$$dot_seen" = "no"; then \ - $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ - fi; test -z "$$fail" - -mostlyclean-recursive clean-recursive distclean-recursive \ -maintainer-clean-recursive: - @set fnord $$MAKEFLAGS; amf=$$2; \ - dot_seen=no; \ - case "$@" in \ - distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ - *) list='$(SUBDIRS)' ;; \ - esac; \ - rev=''; for subdir in $$list; do \ - if test "$$subdir" = "."; then :; else \ - rev="$$subdir $$rev"; \ - fi; \ - done; \ - rev="$$rev ."; \ - target=`echo $@ | sed s/-recursive//`; \ - for subdir in $$rev; do \ - echo "Making $$target in $$subdir"; \ - if test "$$subdir" = "."; then \ - local_target="$$target-am"; \ - else \ - local_target="$$target"; \ - fi; \ - (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ - || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ - done && test -z "$$fail" -tags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ - done -ctags-recursive: - list='$(SUBDIRS)'; for subdir in $$list; do \ - test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ - include_option=--etags-include; \ - empty_fix=.; \ - else \ - include_option=--include; \ - empty_fix=; \ - fi; \ - list='$(SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test ! -f $$subdir/TAGS || \ - tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \ - fi; \ - done; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done - list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ - if test "$$subdir" = .; then :; else \ - test -d "$(distdir)/$$subdir" \ - || mkdir "$(distdir)/$$subdir" \ - || exit 1; \ - (cd $$subdir && \ - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="../$(top_distdir)" \ - distdir="../$(distdir)/$$subdir" \ - distdir) \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-recursive -all-am: Makefile -installdirs: installdirs-recursive -installdirs-am: -install: install-recursive -install-exec: install-exec-recursive -install-data: install-data-recursive -uninstall: uninstall-recursive - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-recursive -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-recursive - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-recursive - -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-libtool \ - distclean-tags - -dvi: dvi-recursive - -dvi-am: - -html: html-recursive - -info: info-recursive - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-recursive - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-recursive - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-recursive - -mostlyclean-am: mostlyclean-generic mostlyclean-libtool - -pdf: pdf-recursive - -pdf-am: - -ps: ps-recursive - -ps-am: - -uninstall-am: uninstall-info-am - -uninstall-info: uninstall-info-recursive - -.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \ - clean clean-generic clean-libtool clean-recursive ctags \ - ctags-recursive distclean distclean-generic distclean-libtool \ - distclean-recursive distclean-tags distdir dvi dvi-am html \ - html-am info info-am install install-am install-data \ - install-data-am install-exec install-exec-am install-info \ - install-info-am install-man install-strip installcheck \ - installcheck-am installdirs installdirs-am maintainer-clean \ - maintainer-clean-generic maintainer-clean-recursive \ - mostlyclean mostlyclean-generic mostlyclean-libtool \ - mostlyclean-recursive pdf pdf-am ps ps-am tags tags-recursive \ - uninstall uninstall-am uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/au/Makefile.in
Deleted
@@ -1,1168 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(nodist_libpluginau_a_SOURCES) $(LinuxSamplerAU_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -@HAVE_AU_TRUE@bin_PROGRAMS = LinuxSamplerAU$(EXEEXT) -subdir = src/hostplugins/au -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LIBRARIES = $(noinst_LIBRARIES) -ARFLAGS = cru -libpluginau_a_AR = $(AR) $(ARFLAGS) -libpluginau_a_LIBADD = -@HAVE_AU_TRUE@nodist_libpluginau_a_OBJECTS = \ -@HAVE_AU_TRUE@ libpluginau_a-CAHostTimeBase.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAAUMIDIMap.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAAUMIDIMapManager.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAAUParameter.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAAudioChannelLayout.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAMutex.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAStreamBasicDescription.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-CAVectorUnit.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUBuffer.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUDebugDispatcher.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUBase.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUDispatch.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUInputElement.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUOutputElement.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUScopeElement.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-ComponentBase.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-AUMIDIBase.$(OBJEXT) \ -@HAVE_AU_TRUE@ libpluginau_a-MusicDeviceBase.$(OBJEXT) -libpluginau_a_OBJECTS = $(nodist_libpluginau_a_OBJECTS) -am__installdirs = "$(DESTDIR)$(bindir)" -binPROGRAMS_INSTALL = $(INSTALL_PROGRAM) -PROGRAMS = $(bin_PROGRAMS) -am__LinuxSamplerAU_SOURCES_DIST = PluginAU.cpp -@HAVE_AU_TRUE@am_LinuxSamplerAU_OBJECTS = \ -@HAVE_AU_TRUE@ LinuxSamplerAU-PluginAU.$(OBJEXT) -LinuxSamplerAU_OBJECTS = $(am_LinuxSamplerAU_OBJECTS) -@HAVE_AU_TRUE@LinuxSamplerAU_DEPENDENCIES = \ -@HAVE_AU_TRUE@ $(top_builddir)/src/.libs/liblinuxsampler.a \ -@HAVE_AU_TRUE@ libpluginau.a -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/LinuxSamplerAU-PluginAU.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUBase.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUBuffer.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUDispatch.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUInputElement.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUMIDIBase.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUOutputElement.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-AUScopeElement.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAAUParameter.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAMutex.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-CAVectorUnit.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-ComponentBase.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(nodist_libpluginau_a_SOURCES) $(LinuxSamplerAU_SOURCES) -DIST_SOURCES = $(am__LinuxSamplerAU_SOURCES_DIST) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_AU_TRUE@plugindir = $(libdir)/au -@HAVE_AU_TRUE@examples_dir = /Developer/Examples -@HAVE_AU_TRUE@au_public_dir = $(examples_dir)/CoreAudio/AudioUnits/AUPublic -@HAVE_AU_TRUE@ca_public_dir = $(examples_dir)/CoreAudio/PublicUtility -@HAVE_AU_TRUE@INCLUDES = -I$(au_public_dir)/AUBase -I$(au_public_dir)/OtherBases \ -@HAVE_AU_TRUE@ -I$(au_public_dir)/Utility -I$(ca_public_dir) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) - -@HAVE_AU_TRUE@noinst_LIBRARIES = libpluginau.a - -# Uncomment for debug messages. -#debug_messages = -DAU_DEBUG_DISPATCHER=1 -@HAVE_AU_TRUE@libpluginau_a_CXXFLAGS = $(debug_messages) -@HAVE_AU_TRUE@nodist_libpluginau_a_SOURCES = $(ca_public_dir)/CAHostTimeBase.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAHostTimeBase.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUMIDIMap.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUMIDIMap.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUMIDIMapManager.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUMIDIMapManager.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUParameter.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAUParameter.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAudioChannelLayout.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAAudioChannelLayout.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAMutex.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAMutex.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAStreamBasicDescription.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAStreamBasicDescription.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAVectorUnitTypes.h \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAVectorUnit.cpp \ -@HAVE_AU_TRUE@ $(ca_public_dir)/CAVectorUnit.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUBuffer.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUBuffer.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUDebugDispatcher.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUDebugDispatcher.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUInputFormatConverter.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUSilentTimeout.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/Utility/AUTimestampGenerator.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUBase.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUBase.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUDispatch.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUDispatch.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUInputElement.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUInputElement.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUOutputElement.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUOutputElement.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUScopeElement.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/AUScopeElement.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/ComponentBase.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/AUBase/ComponentBase.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/OtherBases/AUMIDIBase.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/OtherBases/AUMIDIBase.h \ -@HAVE_AU_TRUE@ $(au_public_dir)/OtherBases/MusicDeviceBase.cpp \ -@HAVE_AU_TRUE@ $(au_public_dir)/OtherBases/MusicDeviceBase.h - -@HAVE_AU_TRUE@LinuxSamplerAU_SOURCES = PluginAU.cpp -@HAVE_AU_TRUE@LinuxSamplerAU_LDADD = $(top_builddir)/src/.libs/liblinuxsampler.a libpluginau.a -@HAVE_AUFLAGS_FALSE@@HAVE_AU_TRUE@AUFLAGS = $(GIG_LIBS) $(JACK_LIBS) $(SQLITE3_LIBS) -@HAVE_AU_TRUE@LinuxSamplerAU_CXXFLAGS = -bundle $(debug_messages) -@HAVE_AU_TRUE@LinuxSamplerAU_LDFLAGS = -static $(AUFLAGS) \ -@HAVE_AU_TRUE@ -exported_symbols_list PluginAU.exp \ -@HAVE_AU_TRUE@ -framework CoreServices -framework CoreMIDI -framework CoreAudio \ -@HAVE_AU_TRUE@ -framework CoreFoundation -framework AudioToolbox -framework AudioUnit - -@HAVE_AU_TRUE@COMPONENT_DIR = LinuxSamplerAU.component -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/hostplugins/au/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/hostplugins/au/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLIBRARIES: - -test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES) -libpluginau.a: $(libpluginau_a_OBJECTS) $(libpluginau_a_DEPENDENCIES) - -rm -f libpluginau.a - $(libpluginau_a_AR) libpluginau.a $(libpluginau_a_OBJECTS) $(libpluginau_a_LIBADD) - $(RANLIB) libpluginau.a -install-binPROGRAMS: $(bin_PROGRAMS) - @$(NORMAL_INSTALL) - test -z "$(bindir)" || $(mkdir_p) "$(DESTDIR)$(bindir)" - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ - if test -f $$p \ - || test -f $$p1 \ - ; then \ - f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \ - echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) '$$p' '$(DESTDIR)$(bindir)/$$f'"; \ - $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) "$$p" "$(DESTDIR)$(bindir)/$$f" || exit 1; \ - else :; fi; \ - done - -uninstall-binPROGRAMS: - @$(NORMAL_UNINSTALL) - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \ - echo " rm -f '$(DESTDIR)$(bindir)/$$f'"; \ - rm -f "$(DESTDIR)$(bindir)/$$f"; \ - done - -clean-binPROGRAMS: - @list='$(bin_PROGRAMS)'; for p in $$list; do \ - f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ - echo " rm -f $$p $$f"; \ - rm -f $$p $$f ; \ - done -LinuxSamplerAU$(EXEEXT): $(LinuxSamplerAU_OBJECTS) $(LinuxSamplerAU_DEPENDENCIES) - @rm -f LinuxSamplerAU$(EXEEXT) - $(CXXLINK) $(LinuxSamplerAU_LDFLAGS) $(LinuxSamplerAU_OBJECTS) $(LinuxSamplerAU_LDADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LinuxSamplerAU-PluginAU.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUBase.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUBuffer.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUDispatch.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUInputElement.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUMIDIBase.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUOutputElement.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-AUScopeElement.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAAUParameter.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAMutex.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-CAVectorUnit.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-ComponentBase.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -libpluginau_a-CAHostTimeBase.o: $(ca_public_dir)/CAHostTimeBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAHostTimeBase.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" -c -o libpluginau_a-CAHostTimeBase.o `test -f '$(ca_public_dir)/CAHostTimeBase.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAHostTimeBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAHostTimeBase.cpp' object='libpluginau_a-CAHostTimeBase.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAHostTimeBase.o `test -f '$(ca_public_dir)/CAHostTimeBase.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAHostTimeBase.cpp - -libpluginau_a-CAHostTimeBase.obj: $(ca_public_dir)/CAHostTimeBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAHostTimeBase.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" -c -o libpluginau_a-CAHostTimeBase.obj `if test -f '$(ca_public_dir)/CAHostTimeBase.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAHostTimeBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAHostTimeBase.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAHostTimeBase.cpp' object='libpluginau_a-CAHostTimeBase.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAHostTimeBase.obj `if test -f '$(ca_public_dir)/CAHostTimeBase.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAHostTimeBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAHostTimeBase.cpp'; fi` - -libpluginau_a-CAHostTimeBase.lo: $(ca_public_dir)/CAHostTimeBase.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAHostTimeBase.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" -c -o libpluginau_a-CAHostTimeBase.lo `test -f '$(ca_public_dir)/CAHostTimeBase.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAHostTimeBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo" "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAHostTimeBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAHostTimeBase.cpp' object='libpluginau_a-CAHostTimeBase.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAHostTimeBase.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAHostTimeBase.lo `test -f '$(ca_public_dir)/CAHostTimeBase.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAHostTimeBase.cpp - -libpluginau_a-CAAUMIDIMap.o: $(ca_public_dir)/CAAUMIDIMap.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMap.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" -c -o libpluginau_a-CAAUMIDIMap.o `test -f '$(ca_public_dir)/CAAUMIDIMap.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMap.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMap.cpp' object='libpluginau_a-CAAUMIDIMap.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMap.o `test -f '$(ca_public_dir)/CAAUMIDIMap.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMap.cpp - -libpluginau_a-CAAUMIDIMap.obj: $(ca_public_dir)/CAAUMIDIMap.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMap.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" -c -o libpluginau_a-CAAUMIDIMap.obj `if test -f '$(ca_public_dir)/CAAUMIDIMap.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUMIDIMap.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUMIDIMap.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMap.cpp' object='libpluginau_a-CAAUMIDIMap.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMap.obj `if test -f '$(ca_public_dir)/CAAUMIDIMap.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUMIDIMap.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUMIDIMap.cpp'; fi` - -libpluginau_a-CAAUMIDIMap.lo: $(ca_public_dir)/CAAUMIDIMap.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMap.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" -c -o libpluginau_a-CAAUMIDIMap.lo `test -f '$(ca_public_dir)/CAAUMIDIMap.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMap.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMap.cpp' object='libpluginau_a-CAAUMIDIMap.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMap.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMap.lo `test -f '$(ca_public_dir)/CAAUMIDIMap.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMap.cpp - -libpluginau_a-CAAUMIDIMapManager.o: $(ca_public_dir)/CAAUMIDIMapManager.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMapManager.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" -c -o libpluginau_a-CAAUMIDIMapManager.o `test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMapManager.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMapManager.cpp' object='libpluginau_a-CAAUMIDIMapManager.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMapManager.o `test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMapManager.cpp - -libpluginau_a-CAAUMIDIMapManager.obj: $(ca_public_dir)/CAAUMIDIMapManager.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMapManager.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" -c -o libpluginau_a-CAAUMIDIMapManager.obj `if test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUMIDIMapManager.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUMIDIMapManager.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMapManager.cpp' object='libpluginau_a-CAAUMIDIMapManager.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMapManager.obj `if test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUMIDIMapManager.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUMIDIMapManager.cpp'; fi` - -libpluginau_a-CAAUMIDIMapManager.lo: $(ca_public_dir)/CAAUMIDIMapManager.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUMIDIMapManager.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" -c -o libpluginau_a-CAAUMIDIMapManager.lo `test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMapManager.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo" "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUMIDIMapManager.cpp' object='libpluginau_a-CAAUMIDIMapManager.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUMIDIMapManager.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUMIDIMapManager.lo `test -f '$(ca_public_dir)/CAAUMIDIMapManager.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUMIDIMapManager.cpp - -libpluginau_a-CAAUParameter.o: $(ca_public_dir)/CAAUParameter.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUParameter.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" -c -o libpluginau_a-CAAUParameter.o `test -f '$(ca_public_dir)/CAAUParameter.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUParameter.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" "$(DEPDIR)/libpluginau_a-CAAUParameter.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUParameter.cpp' object='libpluginau_a-CAAUParameter.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUParameter.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUParameter.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUParameter.o `test -f '$(ca_public_dir)/CAAUParameter.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUParameter.cpp - -libpluginau_a-CAAUParameter.obj: $(ca_public_dir)/CAAUParameter.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUParameter.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" -c -o libpluginau_a-CAAUParameter.obj `if test -f '$(ca_public_dir)/CAAUParameter.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUParameter.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUParameter.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" "$(DEPDIR)/libpluginau_a-CAAUParameter.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUParameter.cpp' object='libpluginau_a-CAAUParameter.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUParameter.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUParameter.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUParameter.obj `if test -f '$(ca_public_dir)/CAAUParameter.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAUParameter.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAUParameter.cpp'; fi` - -libpluginau_a-CAAUParameter.lo: $(ca_public_dir)/CAAUParameter.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAUParameter.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" -c -o libpluginau_a-CAAUParameter.lo `test -f '$(ca_public_dir)/CAAUParameter.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUParameter.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo" "$(DEPDIR)/libpluginau_a-CAAUParameter.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAAUParameter.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAUParameter.cpp' object='libpluginau_a-CAAUParameter.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAUParameter.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAUParameter.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAUParameter.lo `test -f '$(ca_public_dir)/CAAUParameter.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAUParameter.cpp - -libpluginau_a-CAAudioChannelLayout.o: $(ca_public_dir)/CAAudioChannelLayout.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAudioChannelLayout.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" -c -o libpluginau_a-CAAudioChannelLayout.o `test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAudioChannelLayout.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAudioChannelLayout.cpp' object='libpluginau_a-CAAudioChannelLayout.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAudioChannelLayout.o `test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAudioChannelLayout.cpp - -libpluginau_a-CAAudioChannelLayout.obj: $(ca_public_dir)/CAAudioChannelLayout.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAudioChannelLayout.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" -c -o libpluginau_a-CAAudioChannelLayout.obj `if test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAudioChannelLayout.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAudioChannelLayout.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAudioChannelLayout.cpp' object='libpluginau_a-CAAudioChannelLayout.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAudioChannelLayout.obj `if test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAAudioChannelLayout.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAAudioChannelLayout.cpp'; fi` - -libpluginau_a-CAAudioChannelLayout.lo: $(ca_public_dir)/CAAudioChannelLayout.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAAudioChannelLayout.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" -c -o libpluginau_a-CAAudioChannelLayout.lo `test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAudioChannelLayout.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo" "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAAudioChannelLayout.cpp' object='libpluginau_a-CAAudioChannelLayout.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAAudioChannelLayout.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAAudioChannelLayout.lo `test -f '$(ca_public_dir)/CAAudioChannelLayout.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAAudioChannelLayout.cpp - -libpluginau_a-CAMutex.o: $(ca_public_dir)/CAMutex.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAMutex.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" -c -o libpluginau_a-CAMutex.o `test -f '$(ca_public_dir)/CAMutex.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAMutex.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" "$(DEPDIR)/libpluginau_a-CAMutex.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAMutex.cpp' object='libpluginau_a-CAMutex.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAMutex.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAMutex.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAMutex.o `test -f '$(ca_public_dir)/CAMutex.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAMutex.cpp - -libpluginau_a-CAMutex.obj: $(ca_public_dir)/CAMutex.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAMutex.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" -c -o libpluginau_a-CAMutex.obj `if test -f '$(ca_public_dir)/CAMutex.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAMutex.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAMutex.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" "$(DEPDIR)/libpluginau_a-CAMutex.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAMutex.cpp' object='libpluginau_a-CAMutex.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAMutex.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAMutex.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAMutex.obj `if test -f '$(ca_public_dir)/CAMutex.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAMutex.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAMutex.cpp'; fi` - -libpluginau_a-CAMutex.lo: $(ca_public_dir)/CAMutex.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAMutex.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" -c -o libpluginau_a-CAMutex.lo `test -f '$(ca_public_dir)/CAMutex.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAMutex.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo" "$(DEPDIR)/libpluginau_a-CAMutex.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAMutex.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAMutex.cpp' object='libpluginau_a-CAMutex.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAMutex.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAMutex.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAMutex.lo `test -f '$(ca_public_dir)/CAMutex.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAMutex.cpp - -libpluginau_a-CAStreamBasicDescription.o: $(ca_public_dir)/CAStreamBasicDescription.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAStreamBasicDescription.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" -c -o libpluginau_a-CAStreamBasicDescription.o `test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAStreamBasicDescription.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAStreamBasicDescription.cpp' object='libpluginau_a-CAStreamBasicDescription.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAStreamBasicDescription.o `test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAStreamBasicDescription.cpp - -libpluginau_a-CAStreamBasicDescription.obj: $(ca_public_dir)/CAStreamBasicDescription.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAStreamBasicDescription.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" -c -o libpluginau_a-CAStreamBasicDescription.obj `if test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAStreamBasicDescription.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAStreamBasicDescription.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAStreamBasicDescription.cpp' object='libpluginau_a-CAStreamBasicDescription.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAStreamBasicDescription.obj `if test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAStreamBasicDescription.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAStreamBasicDescription.cpp'; fi` - -libpluginau_a-CAStreamBasicDescription.lo: $(ca_public_dir)/CAStreamBasicDescription.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAStreamBasicDescription.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" -c -o libpluginau_a-CAStreamBasicDescription.lo `test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAStreamBasicDescription.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo" "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAStreamBasicDescription.cpp' object='libpluginau_a-CAStreamBasicDescription.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAStreamBasicDescription.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAStreamBasicDescription.lo `test -f '$(ca_public_dir)/CAStreamBasicDescription.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAStreamBasicDescription.cpp - -libpluginau_a-CAVectorUnit.o: $(ca_public_dir)/CAVectorUnit.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAVectorUnit.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" -c -o libpluginau_a-CAVectorUnit.o `test -f '$(ca_public_dir)/CAVectorUnit.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAVectorUnit.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" "$(DEPDIR)/libpluginau_a-CAVectorUnit.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAVectorUnit.cpp' object='libpluginau_a-CAVectorUnit.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAVectorUnit.o `test -f '$(ca_public_dir)/CAVectorUnit.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAVectorUnit.cpp - -libpluginau_a-CAVectorUnit.obj: $(ca_public_dir)/CAVectorUnit.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAVectorUnit.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" -c -o libpluginau_a-CAVectorUnit.obj `if test -f '$(ca_public_dir)/CAVectorUnit.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAVectorUnit.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAVectorUnit.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" "$(DEPDIR)/libpluginau_a-CAVectorUnit.Po"; else rm -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAVectorUnit.cpp' object='libpluginau_a-CAVectorUnit.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAVectorUnit.obj `if test -f '$(ca_public_dir)/CAVectorUnit.cpp'; then $(CYGPATH_W) '$(ca_public_dir)/CAVectorUnit.cpp'; else $(CYGPATH_W) '$(srcdir)/$(ca_public_dir)/CAVectorUnit.cpp'; fi` - -libpluginau_a-CAVectorUnit.lo: $(ca_public_dir)/CAVectorUnit.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-CAVectorUnit.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" -c -o libpluginau_a-CAVectorUnit.lo `test -f '$(ca_public_dir)/CAVectorUnit.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAVectorUnit.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo" "$(DEPDIR)/libpluginau_a-CAVectorUnit.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-CAVectorUnit.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(ca_public_dir)/CAVectorUnit.cpp' object='libpluginau_a-CAVectorUnit.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-CAVectorUnit.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-CAVectorUnit.lo `test -f '$(ca_public_dir)/CAVectorUnit.cpp' || echo '$(srcdir)/'`$(ca_public_dir)/CAVectorUnit.cpp - -libpluginau_a-AUBuffer.o: $(au_public_dir)/Utility/AUBuffer.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBuffer.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" -c -o libpluginau_a-AUBuffer.o `test -f '$(au_public_dir)/Utility/AUBuffer.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUBuffer.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" "$(DEPDIR)/libpluginau_a-AUBuffer.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUBuffer.cpp' object='libpluginau_a-AUBuffer.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBuffer.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBuffer.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBuffer.o `test -f '$(au_public_dir)/Utility/AUBuffer.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUBuffer.cpp - -libpluginau_a-AUBuffer.obj: $(au_public_dir)/Utility/AUBuffer.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBuffer.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" -c -o libpluginau_a-AUBuffer.obj `if test -f '$(au_public_dir)/Utility/AUBuffer.cpp'; then $(CYGPATH_W) '$(au_public_dir)/Utility/AUBuffer.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/Utility/AUBuffer.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" "$(DEPDIR)/libpluginau_a-AUBuffer.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUBuffer.cpp' object='libpluginau_a-AUBuffer.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBuffer.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBuffer.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBuffer.obj `if test -f '$(au_public_dir)/Utility/AUBuffer.cpp'; then $(CYGPATH_W) '$(au_public_dir)/Utility/AUBuffer.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/Utility/AUBuffer.cpp'; fi` - -libpluginau_a-AUBuffer.lo: $(au_public_dir)/Utility/AUBuffer.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBuffer.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" -c -o libpluginau_a-AUBuffer.lo `test -f '$(au_public_dir)/Utility/AUBuffer.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUBuffer.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo" "$(DEPDIR)/libpluginau_a-AUBuffer.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUBuffer.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUBuffer.cpp' object='libpluginau_a-AUBuffer.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBuffer.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBuffer.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBuffer.lo `test -f '$(au_public_dir)/Utility/AUBuffer.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUBuffer.cpp - -libpluginau_a-AUDebugDispatcher.o: $(au_public_dir)/Utility/AUDebugDispatcher.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDebugDispatcher.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" -c -o libpluginau_a-AUDebugDispatcher.o `test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUDebugDispatcher.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUDebugDispatcher.cpp' object='libpluginau_a-AUDebugDispatcher.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDebugDispatcher.o `test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUDebugDispatcher.cpp - -libpluginau_a-AUDebugDispatcher.obj: $(au_public_dir)/Utility/AUDebugDispatcher.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDebugDispatcher.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" -c -o libpluginau_a-AUDebugDispatcher.obj `if test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; then $(CYGPATH_W) '$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUDebugDispatcher.cpp' object='libpluginau_a-AUDebugDispatcher.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDebugDispatcher.obj `if test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; then $(CYGPATH_W) '$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/Utility/AUDebugDispatcher.cpp'; fi` - -libpluginau_a-AUDebugDispatcher.lo: $(au_public_dir)/Utility/AUDebugDispatcher.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDebugDispatcher.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" -c -o libpluginau_a-AUDebugDispatcher.lo `test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUDebugDispatcher.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo" "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/Utility/AUDebugDispatcher.cpp' object='libpluginau_a-AUDebugDispatcher.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDebugDispatcher.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDebugDispatcher.lo `test -f '$(au_public_dir)/Utility/AUDebugDispatcher.cpp' || echo '$(srcdir)/'`$(au_public_dir)/Utility/AUDebugDispatcher.cpp - -libpluginau_a-AUBase.o: $(au_public_dir)/AUBase/AUBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBase.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBase.Tpo" -c -o libpluginau_a-AUBase.o `test -f '$(au_public_dir)/AUBase/AUBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo" "$(DEPDIR)/libpluginau_a-AUBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUBase.cpp' object='libpluginau_a-AUBase.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBase.o `test -f '$(au_public_dir)/AUBase/AUBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUBase.cpp - -libpluginau_a-AUBase.obj: $(au_public_dir)/AUBase/AUBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBase.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBase.Tpo" -c -o libpluginau_a-AUBase.obj `if test -f '$(au_public_dir)/AUBase/AUBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUBase.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo" "$(DEPDIR)/libpluginau_a-AUBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUBase.cpp' object='libpluginau_a-AUBase.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBase.obj `if test -f '$(au_public_dir)/AUBase/AUBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUBase.cpp'; fi` - -libpluginau_a-AUBase.lo: $(au_public_dir)/AUBase/AUBase.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUBase.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUBase.Tpo" -c -o libpluginau_a-AUBase.lo `test -f '$(au_public_dir)/AUBase/AUBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo" "$(DEPDIR)/libpluginau_a-AUBase.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUBase.cpp' object='libpluginau_a-AUBase.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUBase.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUBase.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUBase.lo `test -f '$(au_public_dir)/AUBase/AUBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUBase.cpp - -libpluginau_a-AUDispatch.o: $(au_public_dir)/AUBase/AUDispatch.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDispatch.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" -c -o libpluginau_a-AUDispatch.o `test -f '$(au_public_dir)/AUBase/AUDispatch.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUDispatch.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" "$(DEPDIR)/libpluginau_a-AUDispatch.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUDispatch.cpp' object='libpluginau_a-AUDispatch.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDispatch.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDispatch.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDispatch.o `test -f '$(au_public_dir)/AUBase/AUDispatch.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUDispatch.cpp - -libpluginau_a-AUDispatch.obj: $(au_public_dir)/AUBase/AUDispatch.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDispatch.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" -c -o libpluginau_a-AUDispatch.obj `if test -f '$(au_public_dir)/AUBase/AUDispatch.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUDispatch.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUDispatch.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" "$(DEPDIR)/libpluginau_a-AUDispatch.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUDispatch.cpp' object='libpluginau_a-AUDispatch.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDispatch.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDispatch.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDispatch.obj `if test -f '$(au_public_dir)/AUBase/AUDispatch.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUDispatch.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUDispatch.cpp'; fi` - -libpluginau_a-AUDispatch.lo: $(au_public_dir)/AUBase/AUDispatch.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUDispatch.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" -c -o libpluginau_a-AUDispatch.lo `test -f '$(au_public_dir)/AUBase/AUDispatch.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUDispatch.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo" "$(DEPDIR)/libpluginau_a-AUDispatch.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUDispatch.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUDispatch.cpp' object='libpluginau_a-AUDispatch.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUDispatch.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUDispatch.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUDispatch.lo `test -f '$(au_public_dir)/AUBase/AUDispatch.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUDispatch.cpp - -libpluginau_a-AUInputElement.o: $(au_public_dir)/AUBase/AUInputElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUInputElement.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" -c -o libpluginau_a-AUInputElement.o `test -f '$(au_public_dir)/AUBase/AUInputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUInputElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUInputElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUInputElement.cpp' object='libpluginau_a-AUInputElement.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUInputElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUInputElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUInputElement.o `test -f '$(au_public_dir)/AUBase/AUInputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUInputElement.cpp - -libpluginau_a-AUInputElement.obj: $(au_public_dir)/AUBase/AUInputElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUInputElement.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" -c -o libpluginau_a-AUInputElement.obj `if test -f '$(au_public_dir)/AUBase/AUInputElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUInputElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUInputElement.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUInputElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUInputElement.cpp' object='libpluginau_a-AUInputElement.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUInputElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUInputElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUInputElement.obj `if test -f '$(au_public_dir)/AUBase/AUInputElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUInputElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUInputElement.cpp'; fi` - -libpluginau_a-AUInputElement.lo: $(au_public_dir)/AUBase/AUInputElement.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUInputElement.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" -c -o libpluginau_a-AUInputElement.lo `test -f '$(au_public_dir)/AUBase/AUInputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUInputElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUInputElement.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUInputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUInputElement.cpp' object='libpluginau_a-AUInputElement.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUInputElement.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUInputElement.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUInputElement.lo `test -f '$(au_public_dir)/AUBase/AUInputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUInputElement.cpp - -libpluginau_a-AUOutputElement.o: $(au_public_dir)/AUBase/AUOutputElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUOutputElement.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" -c -o libpluginau_a-AUOutputElement.o `test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUOutputElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUOutputElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUOutputElement.cpp' object='libpluginau_a-AUOutputElement.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUOutputElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUOutputElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUOutputElement.o `test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUOutputElement.cpp - -libpluginau_a-AUOutputElement.obj: $(au_public_dir)/AUBase/AUOutputElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUOutputElement.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" -c -o libpluginau_a-AUOutputElement.obj `if test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUOutputElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUOutputElement.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUOutputElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUOutputElement.cpp' object='libpluginau_a-AUOutputElement.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUOutputElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUOutputElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUOutputElement.obj `if test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUOutputElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUOutputElement.cpp'; fi` - -libpluginau_a-AUOutputElement.lo: $(au_public_dir)/AUBase/AUOutputElement.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUOutputElement.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" -c -o libpluginau_a-AUOutputElement.lo `test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUOutputElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo" "$(DEPDIR)/libpluginau_a-AUOutputElement.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUOutputElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUOutputElement.cpp' object='libpluginau_a-AUOutputElement.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUOutputElement.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUOutputElement.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUOutputElement.lo `test -f '$(au_public_dir)/AUBase/AUOutputElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUOutputElement.cpp - -libpluginau_a-AUScopeElement.o: $(au_public_dir)/AUBase/AUScopeElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUScopeElement.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" -c -o libpluginau_a-AUScopeElement.o `test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUScopeElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" "$(DEPDIR)/libpluginau_a-AUScopeElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUScopeElement.cpp' object='libpluginau_a-AUScopeElement.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUScopeElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUScopeElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUScopeElement.o `test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUScopeElement.cpp - -libpluginau_a-AUScopeElement.obj: $(au_public_dir)/AUBase/AUScopeElement.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUScopeElement.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" -c -o libpluginau_a-AUScopeElement.obj `if test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUScopeElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUScopeElement.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" "$(DEPDIR)/libpluginau_a-AUScopeElement.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUScopeElement.cpp' object='libpluginau_a-AUScopeElement.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUScopeElement.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUScopeElement.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUScopeElement.obj `if test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/AUScopeElement.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/AUScopeElement.cpp'; fi` - -libpluginau_a-AUScopeElement.lo: $(au_public_dir)/AUBase/AUScopeElement.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUScopeElement.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" -c -o libpluginau_a-AUScopeElement.lo `test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUScopeElement.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo" "$(DEPDIR)/libpluginau_a-AUScopeElement.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUScopeElement.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/AUScopeElement.cpp' object='libpluginau_a-AUScopeElement.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUScopeElement.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUScopeElement.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUScopeElement.lo `test -f '$(au_public_dir)/AUBase/AUScopeElement.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/AUScopeElement.cpp - -libpluginau_a-ComponentBase.o: $(au_public_dir)/AUBase/ComponentBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-ComponentBase.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" -c -o libpluginau_a-ComponentBase.o `test -f '$(au_public_dir)/AUBase/ComponentBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/ComponentBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" "$(DEPDIR)/libpluginau_a-ComponentBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/ComponentBase.cpp' object='libpluginau_a-ComponentBase.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-ComponentBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-ComponentBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-ComponentBase.o `test -f '$(au_public_dir)/AUBase/ComponentBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/ComponentBase.cpp - -libpluginau_a-ComponentBase.obj: $(au_public_dir)/AUBase/ComponentBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-ComponentBase.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" -c -o libpluginau_a-ComponentBase.obj `if test -f '$(au_public_dir)/AUBase/ComponentBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/ComponentBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/ComponentBase.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" "$(DEPDIR)/libpluginau_a-ComponentBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/ComponentBase.cpp' object='libpluginau_a-ComponentBase.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-ComponentBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-ComponentBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-ComponentBase.obj `if test -f '$(au_public_dir)/AUBase/ComponentBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/AUBase/ComponentBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/AUBase/ComponentBase.cpp'; fi` - -libpluginau_a-ComponentBase.lo: $(au_public_dir)/AUBase/ComponentBase.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-ComponentBase.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" -c -o libpluginau_a-ComponentBase.lo `test -f '$(au_public_dir)/AUBase/ComponentBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/ComponentBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo" "$(DEPDIR)/libpluginau_a-ComponentBase.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-ComponentBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/AUBase/ComponentBase.cpp' object='libpluginau_a-ComponentBase.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-ComponentBase.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-ComponentBase.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-ComponentBase.lo `test -f '$(au_public_dir)/AUBase/ComponentBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/AUBase/ComponentBase.cpp - -libpluginau_a-AUMIDIBase.o: $(au_public_dir)/OtherBases/AUMIDIBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUMIDIBase.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" -c -o libpluginau_a-AUMIDIBase.o `test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/AUMIDIBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" "$(DEPDIR)/libpluginau_a-AUMIDIBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/AUMIDIBase.cpp' object='libpluginau_a-AUMIDIBase.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUMIDIBase.o `test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/AUMIDIBase.cpp - -libpluginau_a-AUMIDIBase.obj: $(au_public_dir)/OtherBases/AUMIDIBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUMIDIBase.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" -c -o libpluginau_a-AUMIDIBase.obj `if test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" "$(DEPDIR)/libpluginau_a-AUMIDIBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/AUMIDIBase.cpp' object='libpluginau_a-AUMIDIBase.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUMIDIBase.obj `if test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/OtherBases/AUMIDIBase.cpp'; fi` - -libpluginau_a-AUMIDIBase.lo: $(au_public_dir)/OtherBases/AUMIDIBase.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-AUMIDIBase.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" -c -o libpluginau_a-AUMIDIBase.lo `test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/AUMIDIBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo" "$(DEPDIR)/libpluginau_a-AUMIDIBase.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-AUMIDIBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/AUMIDIBase.cpp' object='libpluginau_a-AUMIDIBase.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-AUMIDIBase.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-AUMIDIBase.lo `test -f '$(au_public_dir)/OtherBases/AUMIDIBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/AUMIDIBase.cpp - -libpluginau_a-MusicDeviceBase.o: $(au_public_dir)/OtherBases/MusicDeviceBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-MusicDeviceBase.o -MD -MP -MF "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" -c -o libpluginau_a-MusicDeviceBase.o `test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/MusicDeviceBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' object='libpluginau_a-MusicDeviceBase.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-MusicDeviceBase.o `test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/MusicDeviceBase.cpp - -libpluginau_a-MusicDeviceBase.obj: $(au_public_dir)/OtherBases/MusicDeviceBase.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-MusicDeviceBase.obj -MD -MP -MF "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" -c -o libpluginau_a-MusicDeviceBase.obj `if test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po"; else rm -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' object='libpluginau_a-MusicDeviceBase.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.Po' tmpdepfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-MusicDeviceBase.obj `if test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; then $(CYGPATH_W) '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; else $(CYGPATH_W) '$(srcdir)/$(au_public_dir)/OtherBases/MusicDeviceBase.cpp'; fi` - -libpluginau_a-MusicDeviceBase.lo: $(au_public_dir)/OtherBases/MusicDeviceBase.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -MT libpluginau_a-MusicDeviceBase.lo -MD -MP -MF "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" -c -o libpluginau_a-MusicDeviceBase.lo `test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/MusicDeviceBase.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo" "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Plo"; else rm -f "$(DEPDIR)/libpluginau_a-MusicDeviceBase.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' object='libpluginau_a-MusicDeviceBase.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.Plo' tmpdepfile='$(DEPDIR)/libpluginau_a-MusicDeviceBase.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libpluginau_a_CXXFLAGS) $(CXXFLAGS) -c -o libpluginau_a-MusicDeviceBase.lo `test -f '$(au_public_dir)/OtherBases/MusicDeviceBase.cpp' || echo '$(srcdir)/'`$(au_public_dir)/OtherBases/MusicDeviceBase.cpp - -LinuxSamplerAU-PluginAU.o: PluginAU.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -MT LinuxSamplerAU-PluginAU.o -MD -MP -MF "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" -c -o LinuxSamplerAU-PluginAU.o `test -f 'PluginAU.cpp' || echo '$(srcdir)/'`PluginAU.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" "$(DEPDIR)/LinuxSamplerAU-PluginAU.Po"; else rm -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginAU.cpp' object='LinuxSamplerAU-PluginAU.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.Po' tmpdepfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSamplerAU-PluginAU.o `test -f 'PluginAU.cpp' || echo '$(srcdir)/'`PluginAU.cpp - -LinuxSamplerAU-PluginAU.obj: PluginAU.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -MT LinuxSamplerAU-PluginAU.obj -MD -MP -MF "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" -c -o LinuxSamplerAU-PluginAU.obj `if test -f 'PluginAU.cpp'; then $(CYGPATH_W) 'PluginAU.cpp'; else $(CYGPATH_W) '$(srcdir)/PluginAU.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" "$(DEPDIR)/LinuxSamplerAU-PluginAU.Po"; else rm -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginAU.cpp' object='LinuxSamplerAU-PluginAU.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.Po' tmpdepfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSamplerAU-PluginAU.obj `if test -f 'PluginAU.cpp'; then $(CYGPATH_W) 'PluginAU.cpp'; else $(CYGPATH_W) '$(srcdir)/PluginAU.cpp'; fi` - -LinuxSamplerAU-PluginAU.lo: PluginAU.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -MT LinuxSamplerAU-PluginAU.lo -MD -MP -MF "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" -c -o LinuxSamplerAU-PluginAU.lo `test -f 'PluginAU.cpp' || echo '$(srcdir)/'`PluginAU.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo" "$(DEPDIR)/LinuxSamplerAU-PluginAU.Plo"; else rm -f "$(DEPDIR)/LinuxSamplerAU-PluginAU.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginAU.cpp' object='LinuxSamplerAU-PluginAU.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.Plo' tmpdepfile='$(DEPDIR)/LinuxSamplerAU-PluginAU.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(LinuxSamplerAU_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSamplerAU-PluginAU.lo `test -f 'PluginAU.cpp' || echo '$(srcdir)/'`PluginAU.cpp - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LIBRARIES) $(PROGRAMS) all-local -installdirs: - for dir in "$(DESTDIR)$(bindir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-binPROGRAMS clean-generic clean-libtool clean-local \ - clean-noinstLIBRARIES mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: install-binPROGRAMS - @$(NORMAL_INSTALL) - $(MAKE) $(AM_MAKEFLAGS) install-exec-hook - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-binPROGRAMS uninstall-info-am - @$(NORMAL_INSTALL) - $(MAKE) $(AM_MAKEFLAGS) uninstall-hook - -.PHONY: CTAGS GTAGS all all-am all-local check check-am clean \ - clean-binPROGRAMS clean-generic clean-libtool clean-local \ - clean-noinstLIBRARIES ctags distclean distclean-compile \ - distclean-generic distclean-libtool distclean-tags distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-binPROGRAMS install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-binPROGRAMS uninstall-info-am - - -@HAVE_AU_TRUE@all-local: -@HAVE_AU_TRUE@ Rez PluginAU.r -d SystemSevenOrLater=1 -useDF -script Roman -d ppc_YES -d i386_YES -d x86_64_YES \ -@HAVE_AU_TRUE@ -I /System/Library/Frameworks/CoreServices.framework/Frameworks/CarbonCore.framework/Versions/Current/Headers \ -@HAVE_AU_TRUE@ -I $(au_public_dir)/AUBase/ -arch i386 -arch x86_64 -arch ppc -o LinuxSamplerAU.rsrc - -@HAVE_AU_TRUE@ if test ! -d "$(COMPONENT_DIR)/Contents/Frameworks"; then mkdir -p "$(COMPONENT_DIR)/Contents/Frameworks"; fi -@HAVE_AU_TRUE@ if test ! -d "$(COMPONENT_DIR)/Contents/MacOS"; then mkdir -p "$(COMPONENT_DIR)/Contents/MacOS"; fi -@HAVE_AU_TRUE@ if test ! -d "$(COMPONENT_DIR)/Contents/Resources"; then mkdir -p "$(COMPONENT_DIR)/Contents/Resources"; fi - -@HAVE_AU_TRUE@ cp PkgInfo "$(COMPONENT_DIR)/Contents" -@HAVE_AU_TRUE@ cp Info.plist "$(COMPONENT_DIR)/Contents" -@HAVE_AU_TRUE@ cp LinuxSamplerAU "$(COMPONENT_DIR)/Contents/MacOS" -@HAVE_AU_TRUE@ cp LinuxSamplerAU.rsrc "$(COMPONENT_DIR)/Contents/Resources" - -# cp "`pkg-config --variable=libdir gig`/libgig.6.dylib" "$(COMPONENT_DIR)/Contents/Frameworks/"; \ -# install_name_tool -id @executable_path/../Frameworks/libgig.6.dylib \ -# "$(COMPONENT_DIR)/Contents/Frameworks/libgig.6.dylib"; \ -# install_name_tool -change "`pkg-config --variable=libdir gig`/libgig.6.dylib" \ -# @executable_path/../Frameworks/libgig.6.dylib \ -# "$(COMPONENT_DIR)/Contents/MacOS/LinuxSamplerAU" -# -#if HAVE_SQLITE3 -# cp "`pkg-config --variable=libdir sqlite3`/libsqlite3.dylib" "$(COMPONENT_DIR)/Contents/Frameworks/"; \ -# install_name_tool -id @executable_path/../Frameworks/libsqlite3.dylib \; \ -# "$(COMPONENT_DIR)/Contents/Frameworks/libsqlite3.dylib"; \ -# install_name_tool -change "`pkg-config --variable=libdir sqlite3`/libsqlite3.dylib" \ -# @executable_path/../Frameworks/libsqlite3.dylib \ -# "$(COMPONENT_DIR)/Contents/MacOS/LinuxSamplerAU" -#endif -# -#if HAVE_JACK -# cp "`pkg-config --variable=libdir jack`/libjack.dylib" "$(COMPONENT_DIR)/Contents/Frameworks/"; \ -# install_name_tool -id @executable_path/../Frameworks/libjack.dylib \ -# "$(COMPONENT_DIR)/Contents/Frameworks/libjack.dylib"; \ -# install_name_tool -change "`pkg-config --variable=libdir jack`/libjack.dylib" \ -# @executable_path/../Frameworks/libjack.dylib \ -# "$(COMPONENT_DIR)/Contents/MacOS/LinuxSamplerAU" -#endif - -@HAVE_AU_TRUE@clean-local: -@HAVE_AU_TRUE@ rm -f LinuxSamplerAU.rsrc -@HAVE_AU_TRUE@ rm -rf $(COMPONENT_DIR) - -@HAVE_AU_TRUE@install-exec-hook: -@HAVE_AU_TRUE@ cp -r $(COMPONENT_DIR) /Library/Audio/Plug-Ins/Components/ -@HAVE_AU_TRUE@uninstall-hook: -@HAVE_AU_TRUE@ rm -rf /Library/Audio/Plug-Ins/Components/$(COMPONENT_DIR) -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/dssi/Makefile.in
Deleted
@@ -1,530 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(linuxsampler_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/hostplugins/dssi -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am__installdirs = "$(DESTDIR)$(plugindir)" -pluginLTLIBRARIES_INSTALL = $(INSTALL) -LTLIBRARIES = $(plugin_LTLIBRARIES) -@HAVE_DSSI_TRUE@linuxsampler_la_DEPENDENCIES = \ -@HAVE_DSSI_TRUE@ $(top_builddir)/src/liblinuxsampler.la -am__linuxsampler_la_SOURCES_DIST = PluginDssi.cpp PluginDssi.h -@HAVE_DSSI_TRUE@am_linuxsampler_la_OBJECTS = PluginDssi.lo -linuxsampler_la_OBJECTS = $(am_linuxsampler_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/PluginDssi.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(linuxsampler_la_SOURCES) -DIST_SOURCES = $(am__linuxsampler_la_SOURCES_DIST) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_DSSI_TRUE@INCLUDES = $(GIG_CFLAGS) $(SQLITE3_CFLAGS) -@HAVE_DSSI_TRUE@plugindir = $(libdir)/dssi -@HAVE_DSSI_TRUE@plugin_LTLIBRARIES = linuxsampler.la -@HAVE_DSSI_TRUE@linuxsampler_la_SOURCES = PluginDssi.cpp PluginDssi.h -@HAVE_DSSI_TRUE@linuxsampler_la_LDFLAGS = -module -avoid-version -@HAVE_DSSI_TRUE@linuxsampler_la_LIBADD = $(top_builddir)/src/liblinuxsampler.la -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/hostplugins/dssi/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/hostplugins/dssi/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -install-pluginLTLIBRARIES: $(plugin_LTLIBRARIES) - @$(NORMAL_INSTALL) - test -z "$(plugindir)" || $(mkdir_p) "$(DESTDIR)$(plugindir)" - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - if test -f $$p; then \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) '$$p' '$(DESTDIR)$(plugindir)/$$f'"; \ - $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) "$$p" "$(DESTDIR)$(plugindir)/$$f"; \ - else :; fi; \ - done - -uninstall-pluginLTLIBRARIES: - @$(NORMAL_UNINSTALL) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - p="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=uninstall rm -f '$(DESTDIR)$(plugindir)/$$p'"; \ - $(LIBTOOL) --mode=uninstall rm -f "$(DESTDIR)$(plugindir)/$$p"; \ - done - -clean-pluginLTLIBRARIES: - -test -z "$(plugin_LTLIBRARIES)" || rm -f $(plugin_LTLIBRARIES) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -linuxsampler.la: $(linuxsampler_la_OBJECTS) $(linuxsampler_la_DEPENDENCIES) - $(CXXLINK) -rpath $(plugindir) $(linuxsampler_la_LDFLAGS) $(linuxsampler_la_OBJECTS) $(linuxsampler_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/PluginDssi.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: - for dir in "$(DESTDIR)$(plugindir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-pluginLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-pluginLTLIBRARIES - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am uninstall-pluginLTLIBRARIES - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-pluginLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-pluginLTLIBRARIES install-strip installcheck \ - installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-compile \ - mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - tags uninstall uninstall-am uninstall-info-am \ - uninstall-pluginLTLIBRARIES - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/Makefile.in
Deleted
@@ -1,556 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(linuxsampler_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/hostplugins/lv2 -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am__installdirs = "$(DESTDIR)$(plugindir)" "$(DESTDIR)$(plugindir)" -pluginLTLIBRARIES_INSTALL = $(INSTALL) -LTLIBRARIES = $(plugin_LTLIBRARIES) -@HAVE_LV2_TRUE@linuxsampler_la_DEPENDENCIES = \ -@HAVE_LV2_TRUE@ $(top_builddir)/src/liblinuxsampler.la -am__linuxsampler_la_SOURCES_DIST = PluginLv2.cpp PluginLv2.h \ - lv2_event.h lv2-saverestore.h -@HAVE_LV2_TRUE@am_linuxsampler_la_OBJECTS = PluginLv2.lo -linuxsampler_la_OBJECTS = $(am_linuxsampler_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/PluginLv2.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(linuxsampler_la_SOURCES) -DIST_SOURCES = $(am__linuxsampler_la_SOURCES_DIST) -pluginDATA_INSTALL = $(INSTALL_DATA) -DATA = $(plugin_DATA) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_LV2_TRUE@INCLUDES = $(LV2_CFLAGS) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) -@HAVE_LV2_TRUE@plugindir = $(libdir)/lv2/linuxsampler.lv2 -@HAVE_LV2_TRUE@plugin_LTLIBRARIES = linuxsampler.la -@HAVE_LV2_TRUE@plugin_DATA = manifest.ttl linuxsampler.ttl -@HAVE_LV2_TRUE@EXTRA_DIST = $(plugin_DATA) -@HAVE_LV2_TRUE@linuxsampler_la_SOURCES = PluginLv2.cpp PluginLv2.h \ -@HAVE_LV2_TRUE@ lv2_event.h lv2-saverestore.h - -@HAVE_LV2_TRUE@linuxsampler_la_LDFLAGS = -module -avoid-version -@HAVE_LV2_TRUE@linuxsampler_la_LIBADD = $(top_builddir)/src/liblinuxsampler.la -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/hostplugins/lv2/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/hostplugins/lv2/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -install-pluginLTLIBRARIES: $(plugin_LTLIBRARIES) - @$(NORMAL_INSTALL) - test -z "$(plugindir)" || $(mkdir_p) "$(DESTDIR)$(plugindir)" - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - if test -f $$p; then \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) '$$p' '$(DESTDIR)$(plugindir)/$$f'"; \ - $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) "$$p" "$(DESTDIR)$(plugindir)/$$f"; \ - else :; fi; \ - done - -uninstall-pluginLTLIBRARIES: - @$(NORMAL_UNINSTALL) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - p="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=uninstall rm -f '$(DESTDIR)$(plugindir)/$$p'"; \ - $(LIBTOOL) --mode=uninstall rm -f "$(DESTDIR)$(plugindir)/$$p"; \ - done - -clean-pluginLTLIBRARIES: - -test -z "$(plugin_LTLIBRARIES)" || rm -f $(plugin_LTLIBRARIES) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -linuxsampler.la: $(linuxsampler_la_OBJECTS) $(linuxsampler_la_DEPENDENCIES) - $(CXXLINK) -rpath $(plugindir) $(linuxsampler_la_LDFLAGS) $(linuxsampler_la_OBJECTS) $(linuxsampler_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/PluginLv2.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-pluginDATA: $(plugin_DATA) - @$(NORMAL_INSTALL) - test -z "$(plugindir)" || $(mkdir_p) "$(DESTDIR)$(plugindir)" - @list='$(plugin_DATA)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(pluginDATA_INSTALL) '$$d$$p' '$(DESTDIR)$(plugindir)/$$f'"; \ - $(pluginDATA_INSTALL) "$$d$$p" "$(DESTDIR)$(plugindir)/$$f"; \ - done - -uninstall-pluginDATA: - @$(NORMAL_UNINSTALL) - @list='$(plugin_DATA)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(plugindir)/$$f'"; \ - rm -f "$(DESTDIR)$(plugindir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(DATA) -installdirs: - for dir in "$(DESTDIR)$(plugindir)" "$(DESTDIR)$(plugindir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-pluginLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-pluginDATA install-pluginLTLIBRARIES - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am uninstall-pluginDATA \ - uninstall-pluginLTLIBRARIES - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-pluginLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-pluginDATA install-pluginLTLIBRARIES install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-compile \ - mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - tags uninstall uninstall-am uninstall-info-am \ - uninstall-pluginDATA uninstall-pluginLTLIBRARIES - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/lv2-saverestore.h
Deleted
@@ -1,190 +0,0 @@ -/************************************************************************ - * - * Save/Restore extension for LV2 - * - * Copyright (C) 2007-2008 Lars Luthman <lars.luthman@gmail.com> - * - * This header is free software; you can redistribute it and/or modify it - * under the terms of the GNU Lesser General Public License as published - * by the Free Software Foundation; either version 2.1 of the License, - * or (at your option) any later version. - * - * This header is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 - * USA. - * - ***********************************************************************/ - -#ifndef LV2_SAVERESTORE -#define LV2_SAVERESTORE - -#include <lv2.h> - -#define LV2_SAVERESTORE_URI "http://ll-plugins.nongnu.org/lv2/ext/saverestore" - -#ifdef __cplusplus -extern "C" { -#endif - - /** @file - - This extension defines a way to save and restore the internal state - of an LV2 plugin instance. The internal state does not include input - port values, which are visible to the host, but rather things that - the host has no way of knowing, such as loaded sample buffers that have - been modified using GUI commands, or internal variables that have been - updated and modified as a reaction to the input streams. A plugin that - implements this extension must list - <http://ll-plugins.nongnu.org/lv2/ext/saverestore> as an optional - or required Feature in its RDF data, and it must have an - extension_data() function pointer in its descriptor that returns a - pointer to a LV2SR_Descriptor, defined below, when called with the same - URI. The data pointer for the host feature passed to the plugin's - instantiate() function should be NULL. - - The function pointer members in the LV2SR_Descriptor struct belong to the - Instantiation class, and they must not be NULL. - - For the host, the typical use of this extension would go like this: - - * To save a plugin instance that has not been saved previously: - - Create a directory /home/foo/mysession/myplugininstance - - LV2SR_File* files; - lv2srdesc->save(myplugin_handle, - "/home/foo/mysession/myplugininstance", - &files); - - for each element in 'files' that has the 'must_copy' flag set, copy - that file into /home/foo/mysession/myplugininstance if isn't already - there and change the 'path' member to reflect the new location - - save the names and paths for all elements in 'files' somewhere as - part of the session - - * To restore a plugin instance that has been saved: - - instantiate a new instance of that plugin - - load the file paths and names from your session, allocate an array of - LV2SR_File pointers, allocate the LV2SR_File objects and fill in the - 'name' and 'path' members - - lv2srdesc->restore(myplugin_handle, files); - - * To save a plugin instance that already has been saved earlier: - - LV2SR_File* files; - lv2srdesc->save(myplugin_handle, - "/home/foo/mysession/myplugininstance", - &files); - - erase all files in /home/foo/mysession/myplugininstance that aren't - listed in the new 'files' array - - for each element in 'files' that has the 'must_copy' flag set, copy - that file into /home/foo/mysession/myplugininstance if isn't already - there and change the 'path' member to reflect the new location - - save the names and paths for all elements in 'files' somewhere as - part of the session - - This extension allows for two "levels" of saving a plugin's state - - the host can either just copy the files with the 'must_copy' flag set - into its session directory and rely on the other files staying at the - same paths in the filesystem (a "shallow" save) or it can copy every - mentioned file into its session directory (a "deep" save). The latter - may be useful when moving sessions between machines. - - Most simple plugins whose behaviour is completely defined by the current - values in its control input ports should not need to implement this - extension. - - */ - - - /** A simple struct that represents a file used by a plugin instance. */ - typedef struct _LV2SR_File { - - /** A '\0'-terminated string that the plugin uses to identify the file (it - can't use the file path since the host may move the file). The host - should copy this verbatim and not try to interpret it in any way. */ - char* name; - - /** The absolute path to the file. */ - char* path; - - /** This is set to 1 by the plugin in the save() callback if this file must - be copied by the host into persistent storage, 0 otherwise. Its value - is not significant in the restore() callback. */ - uint32_t must_copy; - - } LV2SR_File; - - - /** A pointer to an object of this type is returned by extension_data() when - called with the URI for this host feature. */ - typedef struct _LV2SR_Descriptor { - - /** This function tells the plugin instance to save its current state. - - The files parameter should be a pointer to a valid LV2SR_File**. After - the call to save() has returned, files MUST point to the start of - a NULL-terminated array of LV2SR_File pointers allocated by - the plugin, that the host should store as part of the plugin's saved - state. The path members of the elements of this array MUST all be - valid filesystem paths. If the member must_copy of an element of this - array is nonzero, the host MUST copy the file at the associated path - into some sort of persistant storage as a part of the plugin's state. - If must_copy is zero, the host is free to choose whether to copy the - file, or rely on the file staying in the same place until the plugin - state is restored again. This array as well as all the name and path - members of its elements should be deallocated by the host. - - The parameter directory MUST be a path to an existing directory. If - the plugin creates any new must_copy files as a part of its save - process it SHOULD create the new files in that directory. This is to - help the host avoid unnecessary copying of files. - - A plugin that creates new files as a part of its save process must NOT - overwrite or delete existing files in that directory, even if it knows - that it created them itself for an earlier save. The host may want to - keep them around for reverting back to an earlier state. - - This function should return NULL if the plugin has successfully saved - its state and a dynamically allocated error message if not (e.g. not - enough room on the disk). Any returned error message should be - deallocated by the host using free(). If NULL is returned the host - should not try to access or deallocate the array pointed to by the - files parameter, or it's elements. - - This function pointer must not be set to NULL. - */ - char* (*save)(LV2_Handle handle, - const char* directory, - LV2SR_File*** files); - - /** This function tells the plugin instance to restore to a saved state. - - The files parameter must be a pointer to a NULL-terminated array of - LV2SR_File pointers, which should be identical to an array produced by - an instance of the same plugin in an earlier call to save(), with the - exception that the file paths may be changed to reflect the new - locations of the files (the session may have been moved to some other - part of the filesystem, the host may have reorganised its file - hierarchy etc). - - This function should return NULL if it successfully restores a state - from the given parameters and an error message otherwise. Any returned - error message should be deallocated by the host. - - This function pointer must not be set to NULL. - */ - char* (*restore)(LV2_Handle handle, - const LV2SR_File** files); - - } LV2SR_Descriptor; - - -#ifdef __cplusplus -} -#endif - - -#endif
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/vst/Makefile.in
Deleted
@@ -1,652 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(LinuxSampler_la_SOURCES) $(nodist_LinuxSampler_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -@HAVE_VST_TRUE@@HAVE_WINDOWS_TRUE@am__append_1 = -Wl,$(srcdir)/PluginVst.def -@HAVE_VST_TRUE@@HAVE_WINDOWS_TRUE@am__append_2 = -lws2_32 -@HAVE_VST_TRUE@@HAVE_WINDOWS_FALSE@am__append_3 = -Wl,--defsym -Wl,main=VSTPluginMain -subdir = src/hostplugins/vst -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am__installdirs = "$(DESTDIR)$(plugindir)" -pluginLTLIBRARIES_INSTALL = $(INSTALL) -LTLIBRARIES = $(plugin_LTLIBRARIES) -am__DEPENDENCIES_1 = -@HAVE_VST_TRUE@LinuxSampler_la_DEPENDENCIES = \ -@HAVE_VST_TRUE@ $(top_builddir)/src/liblinuxsampler.la \ -@HAVE_VST_TRUE@ $(am__DEPENDENCIES_1) -am__LinuxSampler_la_SOURCES_DIST = PluginVst.cpp PluginVst.h -@HAVE_VST_TRUE@am_LinuxSampler_la_OBJECTS = \ -@HAVE_VST_TRUE@ LinuxSampler_la-PluginVst.lo -@HAVE_VST_TRUE@nodist_LinuxSampler_la_OBJECTS = \ -@HAVE_VST_TRUE@ LinuxSampler_la-audioeffectx.lo \ -@HAVE_VST_TRUE@ LinuxSampler_la-audioeffect.lo \ -@HAVE_VST_TRUE@ LinuxSampler_la-vstplugmain.lo -LinuxSampler_la_OBJECTS = $(am_LinuxSampler_la_OBJECTS) \ - $(nodist_LinuxSampler_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/LinuxSampler_la-PluginVst.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/LinuxSampler_la-audioeffect.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/LinuxSampler_la-audioeffectx.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/LinuxSampler_la-vstplugmain.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(LinuxSampler_la_SOURCES) $(nodist_LinuxSampler_la_SOURCES) -DIST_SOURCES = $(am__LinuxSampler_la_SOURCES_DIST) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -@HAVE_VST_TRUE@plugindir = $(libdir)/vst -@HAVE_VST_TRUE@plugin_LTLIBRARIES = LinuxSampler.la -@HAVE_VST_TRUE@INCLUDES = -I@VSTSDK_DIR@ -I@VSTSDK_DIR@/public.sdk/source/vst2.x \ -@HAVE_VST_TRUE@ $(GIG_CFLAGS) $(SQLITE3_CFLAGS) - -@HAVE_VST_TRUE@LinuxSampler_la_SOURCES = PluginVst.cpp PluginVst.h -@HAVE_VST_TRUE@nodist_LinuxSampler_la_SOURCES = \ -@HAVE_VST_TRUE@ @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp \ -@HAVE_VST_TRUE@ @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp \ -@HAVE_VST_TRUE@ @VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp - -@HAVE_VST_TRUE@LinuxSampler_la_LDFLAGS = -module -avoid-version -no-undefined -Wl,-s $(am__append_1) $(am__append_3) -@HAVE_VST_TRUE@LinuxSampler_la_LIBADD = $(top_builddir)/src/liblinuxsampler.la $(am__append_2) -@HAVE_VST_TRUE@EXTRA_DIST = PluginVst.def -@HAVE_VST_TRUE@@HAVE_WINDOWS_FALSE@LinuxSampler_la_CPPFLAGS = -D__cdecl= -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/hostplugins/vst/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/hostplugins/vst/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -install-pluginLTLIBRARIES: $(plugin_LTLIBRARIES) - @$(NORMAL_INSTALL) - test -z "$(plugindir)" || $(mkdir_p) "$(DESTDIR)$(plugindir)" - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - if test -f $$p; then \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) '$$p' '$(DESTDIR)$(plugindir)/$$f'"; \ - $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) "$$p" "$(DESTDIR)$(plugindir)/$$f"; \ - else :; fi; \ - done - -uninstall-pluginLTLIBRARIES: - @$(NORMAL_UNINSTALL) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - p="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(LIBTOOL) --mode=uninstall rm -f '$(DESTDIR)$(plugindir)/$$p'"; \ - $(LIBTOOL) --mode=uninstall rm -f "$(DESTDIR)$(plugindir)/$$p"; \ - done - -clean-pluginLTLIBRARIES: - -test -z "$(plugin_LTLIBRARIES)" || rm -f $(plugin_LTLIBRARIES) - @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -LinuxSampler.la: $(LinuxSampler_la_OBJECTS) $(LinuxSampler_la_DEPENDENCIES) - $(CXXLINK) -rpath $(plugindir) $(LinuxSampler_la_LDFLAGS) $(LinuxSampler_la_OBJECTS) $(LinuxSampler_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LinuxSampler_la-PluginVst.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LinuxSampler_la-audioeffect.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LinuxSampler_la-audioeffectx.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LinuxSampler_la-vstplugmain.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -LinuxSampler_la-PluginVst.o: PluginVst.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-PluginVst.o -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" -c -o LinuxSampler_la-PluginVst.o `test -f 'PluginVst.cpp' || echo '$(srcdir)/'`PluginVst.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" "$(DEPDIR)/LinuxSampler_la-PluginVst.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginVst.cpp' object='LinuxSampler_la-PluginVst.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-PluginVst.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-PluginVst.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-PluginVst.o `test -f 'PluginVst.cpp' || echo '$(srcdir)/'`PluginVst.cpp - -LinuxSampler_la-PluginVst.obj: PluginVst.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-PluginVst.obj -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" -c -o LinuxSampler_la-PluginVst.obj `if test -f 'PluginVst.cpp'; then $(CYGPATH_W) 'PluginVst.cpp'; else $(CYGPATH_W) '$(srcdir)/PluginVst.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" "$(DEPDIR)/LinuxSampler_la-PluginVst.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginVst.cpp' object='LinuxSampler_la-PluginVst.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-PluginVst.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-PluginVst.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-PluginVst.obj `if test -f 'PluginVst.cpp'; then $(CYGPATH_W) 'PluginVst.cpp'; else $(CYGPATH_W) '$(srcdir)/PluginVst.cpp'; fi` - -LinuxSampler_la-PluginVst.lo: PluginVst.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-PluginVst.lo -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" -c -o LinuxSampler_la-PluginVst.lo `test -f 'PluginVst.cpp' || echo '$(srcdir)/'`PluginVst.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo" "$(DEPDIR)/LinuxSampler_la-PluginVst.Plo"; else rm -f "$(DEPDIR)/LinuxSampler_la-PluginVst.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='PluginVst.cpp' object='LinuxSampler_la-PluginVst.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-PluginVst.Plo' tmpdepfile='$(DEPDIR)/LinuxSampler_la-PluginVst.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-PluginVst.lo `test -f 'PluginVst.cpp' || echo '$(srcdir)/'`PluginVst.cpp - -LinuxSampler_la-audioeffectx.o: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffectx.o -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" -c -o LinuxSampler_la-audioeffectx.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffectx.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' object='LinuxSampler_la-audioeffectx.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffectx.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp - -LinuxSampler_la-audioeffectx.obj: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffectx.obj -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" -c -o LinuxSampler_la-audioeffectx.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffectx.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' object='LinuxSampler_la-audioeffectx.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffectx.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp'; fi` - -LinuxSampler_la-audioeffectx.lo: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffectx.lo -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" -c -o LinuxSampler_la-audioeffectx.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffectx.Plo"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffectx.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' object='LinuxSampler_la-audioeffectx.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.Plo' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffectx.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffectx.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp - -LinuxSampler_la-audioeffect.o: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffect.o -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" -c -o LinuxSampler_la-audioeffect.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffect.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' object='LinuxSampler_la-audioeffect.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffect.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffect.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffect.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp - -LinuxSampler_la-audioeffect.obj: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffect.obj -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" -c -o LinuxSampler_la-audioeffect.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffect.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' object='LinuxSampler_la-audioeffect.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffect.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffect.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffect.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp'; fi` - -LinuxSampler_la-audioeffect.lo: @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-audioeffect.lo -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" -c -o LinuxSampler_la-audioeffect.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo" "$(DEPDIR)/LinuxSampler_la-audioeffect.Plo"; else rm -f "$(DEPDIR)/LinuxSampler_la-audioeffect.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' object='LinuxSampler_la-audioeffect.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-audioeffect.Plo' tmpdepfile='$(DEPDIR)/LinuxSampler_la-audioeffect.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-audioeffect.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp - -LinuxSampler_la-vstplugmain.o: @VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-vstplugmain.o -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" -c -o LinuxSampler_la-vstplugmain.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" "$(DEPDIR)/LinuxSampler_la-vstplugmain.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' object='LinuxSampler_la-vstplugmain.o' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-vstplugmain.o `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp - -LinuxSampler_la-vstplugmain.obj: @VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp -@am__fastdepCXX_TRUE@ if $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-vstplugmain.obj -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" -c -o LinuxSampler_la-vstplugmain.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; fi`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" "$(DEPDIR)/LinuxSampler_la-vstplugmain.Po"; else rm -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' object='LinuxSampler_la-vstplugmain.obj' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.Po' tmpdepfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-vstplugmain.obj `if test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; then $(CYGPATH_W) '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; else $(CYGPATH_W) '$(srcdir)/@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp'; fi` - -LinuxSampler_la-vstplugmain.lo: @VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp -@am__fastdepCXX_TRUE@ if $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT LinuxSampler_la-vstplugmain.lo -MD -MP -MF "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" -c -o LinuxSampler_la-vstplugmain.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo" "$(DEPDIR)/LinuxSampler_la-vstplugmain.Plo"; else rm -f "$(DEPDIR)/LinuxSampler_la-vstplugmain.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' object='LinuxSampler_la-vstplugmain.lo' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.Plo' tmpdepfile='$(DEPDIR)/LinuxSampler_la-vstplugmain.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(LinuxSampler_la_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o LinuxSampler_la-vstplugmain.lo `test -f '@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp' || echo '$(srcdir)/'`@VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: - for dir in "$(DESTDIR)$(plugindir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-pluginLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-pluginLTLIBRARIES - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am uninstall-pluginLTLIBRARIES - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-pluginLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-pluginLTLIBRARIES install-strip installcheck \ - installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-compile \ - mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - tags uninstall uninstall-am uninstall-info-am \ - uninstall-pluginLTLIBRARIES - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/network/Makefile.in
Deleted
@@ -1,540 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -SOURCES = $(liblinuxsamplernetwork_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/network -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -am__DEPENDENCIES_1 = -liblinuxsamplernetwork_la_DEPENDENCIES = $(am__DEPENDENCIES_1) -am_liblinuxsamplernetwork_la_OBJECTS = lscpparser.lo lscpserver.lo \ - lscpresultset.lo lscpevent.lo -liblinuxsamplernetwork_la_OBJECTS = \ - $(am_liblinuxsamplernetwork_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/lscpevent.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/lscpparser.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/lscpresultset.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/lscpserver.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplernetwork_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplernetwork_la_SOURCES) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) -METASOURCES = AUTO -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -@HAVE_WINDOWS_FALSE@winsocket_ldflags = -@HAVE_WINDOWS_TRUE@winsocket_ldflags = -lws2_32 -lole32 -noinst_LTLIBRARIES = liblinuxsamplernetwork.la -liblinuxsamplernetwork_la_SOURCES = \ - lscp.h \ - lscpparser.cpp lscpparser.h \ - lscpserver.cpp lscpserver.h \ - lscpsymbols.h \ - lscpresultset.cpp lscpresultset.h \ - lscpevent.cpp lscpevent.h - -liblinuxsamplernetwork_la_LIBADD = $(winsocket_ldflags) -yacc_sources = lscp.y -EXTRA_DIST = $(yacc_sources) -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/network/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/network/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplernetwork.la: $(liblinuxsamplernetwork_la_OBJECTS) $(liblinuxsamplernetwork_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplernetwork_la_LDFLAGS) $(liblinuxsamplernetwork_la_OBJECTS) $(liblinuxsamplernetwork_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lscpevent.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lscpparser.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lscpresultset.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lscpserver.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am - - -# automatically (re)generate lscpsymbols.h with bison / yacc if the -# yacc source file(s) have been changed -lscpsymbols.h: $(yacc_sources) - $(top_builddir)/scripts/generate_parser.sh - -# automatically (re)generate lscpparser.cpp with bison / yacc if the -# yacc source file(s) have been changed -lscpparser.cpp: $(yacc_sources) - $(top_builddir)/scripts/generate_parser.sh - -.PHONY: parser - -# "make parser" was explicitly requested -parser: - $(top_builddir)/scripts/generate_parser.sh -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpparser.cpp
Deleted
@@ -1,6078 +0,0 @@ -/* A Bison parser, made by GNU Bison 2.3. */ - -/* Skeleton implementation for Bison's Yacc-like parsers in C - - Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - Free Software Foundation, Inc. - - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, - Boston, MA 02110-1301, USA. */ - -/* As a special exception, you may create a larger work that contains - part or all of the Bison parser skeleton and distribute that work - under terms of your choice, so long as that work isn't itself a - parser generator using the skeleton or a modified version thereof - as a parser skeleton. Alternatively, if you modify or redistribute - the parser skeleton itself, you may (at your option) remove this - special exception, which will cause the skeleton and the resulting - Bison output files to be licensed under the GNU General Public - License without this special exception. - - This special exception was added by the Free Software Foundation in - version 2.2 of Bison. */ - -/* C LALR(1) parser skeleton written by Richard Stallman, by - simplifying the original so-called "semantic" parser. */ - -/* All symbols defined below should begin with yy or YY, to avoid - infringing on user name space. This should be done even for local - variables, as they might otherwise be expanded by user macros. - There are some unavoidable exceptions within include files to - define necessary library symbols; they are noted "INFRINGES ON - USER NAME SPACE" below. */ - -/* Identify Bison output. */ -#define YYBISON 1 - -/* Bison version. */ -#define YYBISON_VERSION "2.3" - -/* Skeleton name. */ -#define YYSKELETON_NAME "yacc.c" - -/* Pure parsers. */ -#define YYPURE 1 - -/* Using locations. */ -#define YYLSP_NEEDED 0 - - - -/* Tokens. */ -#ifndef YYTOKENTYPE -# define YYTOKENTYPE - /* Put the tokens into the symbol table, so that GDB and other debuggers - know about them. */ - enum yytokentype { - EXT_ASCII_CHAR = 258 - }; -#endif -/* Tokens. */ -#define EXT_ASCII_CHAR 258 - - - - -/* Copy the first part of user declarations. */ -#line 32 "lscp.y" - - -#include "lscpparser.h" -#include "lscpserver.h" -#include "lscpevent.h" -#include "lscpsymbols.h" - -namespace LinuxSampler { - -// to save us typing work in the rules action definitions -#define LSCPSERVER ((yyparse_param_t*) yyparse_param)->pServer -#define SESSION_PARAM ((yyparse_param_t*) yyparse_param) -#define INCREMENT_LINE { SESSION_PARAM->iLine++; SESSION_PARAM->iColumn = 0; } - -// clears input buffer -void restart(yyparse_param_t* pparam, int& yychar); -#define RESTART restart((yyparse_param_t*) YYPARSE_PARAM, yychar) - -static char buf1024; // input buffer to feed the parser with new characters -static int bytes = 0; // current number of characters in the input buffer -static int ptr = 0; // current position in the input buffer -static String sLastError; // error message of the last error occured - -// external reference to the function which actually reads from the socket -extern int GetLSCPCommand( void *buf, int max_size); - -// external reference to the function in lscpserver.cpp which returns the -// current session (only works because the server runs as singleton) -extern yyparse_param_t* GetCurrentYaccSession(); - -// returns true if supplied characters has an ASCII code of 128 or higher -inline bool isExtendedAsciiChar(const char c) { - return (c < 0); -} - -// custom scanner function which reads from the socket -// (bison expects it to return the numerical ID of the next -// "recognized token" from the input stream) -int yylex(YYSTYPE* yylval) { - // check if we have to read new characters - if (ptr >= bytes) { - bytes = GetLSCPCommand(buf, 1023); - ptr = 0; - if (bytes < 0) { - bytes = 0; - return 0; - } - } - // this is the next character in the input stream - const char c = bufptr++; - // increment current reading position (just for verbosity / messages) - GetCurrentYaccSession()->iColumn++; - // we have to handle "normal" and "extended" ASCII characters separately - if (isExtendedAsciiChar(c)) { - // workaround for characters with ASCII code higher than 127 - yylval->Char = c; - return EXT_ASCII_CHAR; - } else { - // simply return the ASCII code as terminal symbol ID - return (int) c; - } -} - -// parser helper functions - -int octalsToNumber(char oct_digit0, char oct_digit1 = '0', char oct_digit2 = '0') { - const char d0 = { oct_digit0, '\0' }; - const char d1 = { oct_digit1, '\0' }; - const char d2 = { oct_digit2, '\0' }; - return atoi(d2)*8*8 + atoi(d1)*8 + atoi(d0); -} - -} - -// we provide our own version of yyerror() so we don't have to link against the yacc library -void yyerror(const char* s); - -using namespace LinuxSampler; - - - -/* Enabling traces. */ -#ifndef YYDEBUG -# define YYDEBUG 0 -#endif - -/* Enabling verbose error messages. */ -#ifdef YYERROR_VERBOSE -# undef YYERROR_VERBOSE -# define YYERROR_VERBOSE 1 -#else -# define YYERROR_VERBOSE 1 -#endif - -/* Enabling the token table. */ -#ifndef YYTOKEN_TABLE -# define YYTOKEN_TABLE 0 -#endif - -#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED -typedef int YYSTYPE; -# define yystype YYSTYPE /* obsolescent; will be withdrawn */ -# define YYSTYPE_IS_DECLARED 1 -# define YYSTYPE_IS_TRIVIAL 1 -#endif - - - -/* Copy the second part of user declarations. */ - - -/* Line 216 of yacc.c. */ -#line 193 "y.tab.c" - -#ifdef short -# undef short -#endif - -#ifdef YYTYPE_UINT8 -typedef YYTYPE_UINT8 yytype_uint8; -#else -typedef unsigned char yytype_uint8; -#endif - -#ifdef YYTYPE_INT8 -typedef YYTYPE_INT8 yytype_int8; -#elif (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -typedef signed char yytype_int8; -#else -typedef short int yytype_int8; -#endif - -#ifdef YYTYPE_UINT16 -typedef YYTYPE_UINT16 yytype_uint16; -#else -typedef unsigned short int yytype_uint16; -#endif - -#ifdef YYTYPE_INT16 -typedef YYTYPE_INT16 yytype_int16; -#else -typedef short int yytype_int16; -#endif - -#ifndef YYSIZE_T -# ifdef __SIZE_TYPE__ -# define YYSIZE_T __SIZE_TYPE__ -# elif defined size_t -# define YYSIZE_T size_t -# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -# include <stddef.h> /* INFRINGES ON USER NAME SPACE */ -# define YYSIZE_T size_t -# else -# define YYSIZE_T unsigned int -# endif -#endif - -#define YYSIZE_MAXIMUM ((YYSIZE_T) -1) - -#ifndef YY_ -# if YYENABLE_NLS -# if ENABLE_NLS -# include <libintl.h> /* INFRINGES ON USER NAME SPACE */ -# define YY_(msgid) dgettext ("bison-runtime", msgid) -# endif -# endif -# ifndef YY_ -# define YY_(msgid) msgid -# endif -#endif - -/* Suppress unused-variable warnings by "using" E. */ -#if ! defined lint || defined __GNUC__ -# define YYUSE(e) ((void) (e)) -#else -# define YYUSE(e) /* empty */ -#endif - -/* Identity function, used to suppress warnings about constant conditions. */ -#ifndef lint -# define YYID(n) (n) -#else -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static int -YYID (int i) -#else -static int -YYID (i) - int i; -#endif -{ - return i; -} -#endif - -#if ! defined yyoverflow || YYERROR_VERBOSE - -/* The parser invokes alloca or malloc; define the necessary symbols. */ - -# ifdef YYSTACK_USE_ALLOCA -# if YYSTACK_USE_ALLOCA -# ifdef __GNUC__ -# define YYSTACK_ALLOC __builtin_alloca -# elif defined __BUILTIN_VA_ARG_INCR -# include <alloca.h> /* INFRINGES ON USER NAME SPACE */ -# elif defined _AIX -# define YYSTACK_ALLOC __alloca -# elif defined _MSC_VER -# include <malloc.h> /* INFRINGES ON USER NAME SPACE */ -# define alloca _alloca -# else -# define YYSTACK_ALLOC alloca -# if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ -# ifndef _STDLIB_H -# define _STDLIB_H 1 -# endif -# endif -# endif -# endif -# endif - -# ifdef YYSTACK_ALLOC - /* Pacify GCC's `empty if-body' warning. */ -# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0)) -# ifndef YYSTACK_ALLOC_MAXIMUM - /* The OS might guarantee only one guard page at the bottom of the stack, - and a page size can be as small as 4096 bytes. So we cannot safely - invoke alloca (N) if N exceeds 4096. Use a slightly smaller number - to allow for a few compiler-allocated temporary stack slots. */ -# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */ -# endif -# else -# define YYSTACK_ALLOC YYMALLOC -# define YYSTACK_FREE YYFREE -# ifndef YYSTACK_ALLOC_MAXIMUM -# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM -# endif -# if (defined __cplusplus && ! defined _STDLIB_H \ - && ! ((defined YYMALLOC || defined malloc) \ - && (defined YYFREE || defined free))) -# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ -# ifndef _STDLIB_H -# define _STDLIB_H 1 -# endif -# endif -# ifndef YYMALLOC -# define YYMALLOC malloc -# if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ -# endif -# endif -# ifndef YYFREE -# define YYFREE free -# if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -void free (void *); /* INFRINGES ON USER NAME SPACE */ -# endif -# endif -# endif -#endif /* ! defined yyoverflow || YYERROR_VERBOSE */ - - -#if (! defined yyoverflow \ - && (! defined __cplusplus \ - || (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL))) - -/* A type that is properly aligned for any stack member. */ -union yyalloc -{ - yytype_int16 yyss; - YYSTYPE yyvs; - }; - -/* The size of the maximum gap between one aligned stack and the next. */ -# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) - -/* The size of an array large to enough to hold all stacks, each with - N elements. */ -# define YYSTACK_BYTES(N) \ - ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \ - + YYSTACK_GAP_MAXIMUM) - -/* Copy COUNT objects from FROM to TO. The source and destination do - not overlap. */ -# ifndef YYCOPY -# if defined __GNUC__ && 1 < __GNUC__ -# define YYCOPY(To, From, Count) \ - __builtin_memcpy (To, From, (Count) * sizeof (*(From))) -# else -# define YYCOPY(To, From, Count) \ - do \ - { \ - YYSIZE_T yyi; \ - for (yyi = 0; yyi < (Count); yyi++) \ - (To)yyi = (From)yyi; \ - } \ - while (YYID (0)) -# endif -# endif - -/* Relocate STACK from its old location to the new one. The - local variables YYSIZE and YYSTACKSIZE give the old and new number of - elements in the stack, and YYPTR gives the new location of the - stack. Advance YYPTR to a properly aligned location for the next - stack. */ -# define YYSTACK_RELOCATE(Stack) \ - do \ - { \ - YYSIZE_T yynewbytes; \ - YYCOPY (&yyptr->Stack, Stack, yysize); \ - Stack = &yyptr->Stack; \ - yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ - yyptr += yynewbytes / sizeof (*yyptr); \ - } \ - while (YYID (0)) - -#endif - -/* YYFINAL -- State number of the termination state. */ -#define YYFINAL 58 -/* YYLAST -- Last index in YYTABLE. */ -#define YYLAST 4635 - -/* YYNTOKENS -- Number of terminals. */ -#define YYNTOKENS 100 -/* YYNNTS -- Number of nonterminals. */ -#define YYNNTS 201 -/* YYNRULES -- Number of rules. */ -#define YYNRULES 594 -/* YYNRULES -- Number of states. */ -#define YYNSTATES 2246 - -/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ -#define YYUNDEFTOK 2 -#define YYMAXUTOK 258 - -#define YYTRANSLATE(YYX) \ - ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslateYYX : YYUNDEFTOK) - -/* YYTRANSLATEYYLEX -- Bison symbol number corresponding to YYLEX. */ -static const yytype_uint8 yytranslate = -{ - 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 98, 2, 2, 99, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 97, 77, 33, 4, 78, 79, 80, 32, - 81, 82, 83, 8, 6, 9, 7, 34, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 35, 84, - 85, 5, 86, 87, 88, 26, 27, 28, 29, 30, - 31, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 89, 36, 90, 91, 92, 2, 20, 21, 22, - 23, 24, 25, 57, 58, 59, 60, 61, 62, 63, - 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, - 74, 75, 76, 93, 94, 95, 96, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 1, 2, 3 -}; - -#if YYDEBUG -/* YYPRHSYYN -- Index of the first RHS symbol of rule number YYN in - YYRHS. */ -static const yytype_uint16 yyprhs = -{ - 0, 0, 3, 6, 10, 11, 13, 15, 17, 19, - 22, 25, 28, 31, 35, 39, 43, 47, 51, 55, - 59, 63, 67, 71, 75, 79, 83, 87, 91, 95, - 99, 103, 107, 111, 113, 115, 117, 121, 131, 143, - 151, 161, 169, 179, 185, 193, 195, 199, 201, 203, - 205, 207, 209, 211, 213, 215, 217, 219, 221, 223, - 225, 227, 229, 231, 233, 235, 237, 239, 241, 243, - 245, 247, 249, 251, 253, 255, 257, 259, 261, 263, - 265, 267, 269, 271, 273, 275, 277, 279, 281, 283, - 285, 287, 289, 291, 293, 295, 297, 299, 301, 303, - 320, 339, 358, 379, 387, 391, 395, 399, 405, 409, - 413, 415, 417, 423, 431, 441, 443, 449, 457, 467, - 469, 471, 477, 483, 491, 501, 509, 519, 521, 527, - 535, 541, 547, 553, 557, 559, 561, 563, 567, 571, - 581, 583, 589, 593, 601, 607, 611, 617, 623, 627, - 633, 639, 641, 643, 645, 651, 661, 669, 679, 687, - 697, 707, 711, 719, 729, 741, 751, 761, 769, 777, - 785, 793, 801, 805, 809, 813, 817, 823, 827, 833, - 837, 843, 851, 855, 859, 863, 871, 877, 885, 891, - 895, 901, 907, 913, 919, 923, 927, 933, 937, 941, - 947, 955, 961, 971, 977, 983, 989, 995, 1001, 1007, - 1013, 1019, 1025, 1031, 1037, 1039, 1040, 1043, 1047, 1053, - 1055, 1057, 1059, 1061, 1063, 1065, 1067, 1069, 1073, 1077, - 1079, 1083, 1089, 1093, 1099, 1103, 1109, 1121, 1127, 1135, - 1139, 1141, 1143, 1145, 1147, 1149, 1151, 1153, 1155, 1157, - 1159, 1161, 1163, 1165, 1167, 1169, 1171, 1173, 1175, 1177, - 1179, 1181, 1183, 1185, 1187, 1189, 1191, 1195, 1197, 1199, - 1201, 1203, 1207, 1213, 1215, 1217, 1219, 1221, 1223, 1225, - 1227, 1231, 1236, 1241, 1243, 1246, 1248, 1250, 1252, 1254, - 1256, 1258, 1260, 1262, 1264, 1266, 1268, 1270, 1272, 1274, - 1276, 1278, 1280, 1282, 1284, 1286, 1288, 1290, 1292, 1294, - 1296, 1298, 1300, 1302, 1304, 1306, 1308, 1310, 1312, 1314, - 1316, 1318, 1320, 1322, 1324, 1326, 1328, 1331, 1334, 1337, - 1340, 1343, 1346, 1349, 1352, 1355, 1359, 1363, 1366, 1368, - 1372, 1373, 1376, 1379, 1383, 1387, 1391, 1395, 1397, 1399, - 1402, 1405, 1407, 1409, 1412, 1415, 1417, 1419, 1422, 1425, - 1427, 1430, 1432, 1434, 1437, 1440, 1442, 1444, 1446, 1448, - 1450, 1452, 1454, 1456, 1458, 1460, 1462, 1464, 1466, 1468, - 1470, 1472, 1474, 1476, 1478, 1480, 1482, 1484, 1486, 1488, - 1490, 1492, 1494, 1496, 1498, 1500, 1502, 1504, 1506, 1508, - 1510, 1512, 1514, 1516, 1518, 1520, 1522, 1524, 1526, 1528, - 1530, 1532, 1534, 1536, 1538, 1540, 1542, 1544, 1546, 1548, - 1550, 1552, 1554, 1556, 1558, 1560, 1562, 1564, 1566, 1568, - 1570, 1572, 1574, 1576, 1578, 1580, 1582, 1584, 1586, 1588, - 1590, 1592, 1594, 1596, 1598, 1600, 1602, 1604, 1606, 1608, - 1610, 1612, 1614, 1616, 1618, 1620, 1622, 1624, 1626, 1628, - 1631, 1634, 1637, 1640, 1643, 1646, 1649, 1652, 1655, 1657, - 1659, 1662, 1666, 1671, 1675, 1680, 1682, 1684, 1686, 1690, - 1694, 1698, 1704, 1710, 1715, 1727, 1732, 1737, 1744, 1752, - 1757, 1762, 1766, 1771, 1779, 1789, 1796, 1800, 1810, 1822, - 1830, 1848, 1879, 1888, 1893, 1919, 1944, 1968, 1991, 2017, - 2042, 2064, 2085, 2115, 2144, 2164, 2183, 2203, 2227, 2241, - 2254, 2266, 2279, 2293, 2306, 2318, 2331, 2343, 2362, 2380, - 2402, 2414, 2425, 2437, 2444, 2454, 2469, 2480, 2510, 2531, - 2551, 2581, 2601, 2632, 2653, 2671, 2700, 2728, 2754, 2773, - 2791, 2819, 2835, 2852, 2872, 2893, 2911, 2927, 2946, 2962, - 2973, 2989, 2994, 3002, 3011, 3035, 3061, 3076, 3090, 3109, - 3124, 3136, 3142, 3147, 3157, 3171, 3176, 3186, 3193, 3200, - 3206, 3211, 3216, 3223, 3231, 3237, 3248, 3253, 3258, 3265, - 3275, 3281, 3295, 3300, 3305 -}; - -/* YYRHS -- A `-1'-separated list of the rules' RHS. */ -static const yytype_int16 yyrhs = -{ - 101, 0, -1, 102, 182, -1, 102, 183, 182, -1, - -1, 103, -1, 104, -1, 1, -1, 4, -1, 103, - 4, -1, 103, 181, -1, 103, 163, -1, 103, 173, - -1, 184, 181, 105, -1, 186, 181, 108, -1, 187, - 181, 109, -1, 185, 181, 111, -1, 193, 181, 113, - -1, 194, 181, 119, -1, 195, 181, 127, -1, 196, - 181, 120, -1, 201, 181, 110, -1, 202, 181, 112, - -1, 203, 181, 106, -1, 204, 181, 107, -1, 296, - 181, 114, -1, 188, 181, 115, -1, 189, 181, 116, - -1, 191, 181, 117, -1, 192, 181, 118, -1, 293, - 181, 122, -1, 294, 181, 123, -1, 267, 181, 128, - -1, 296, -1, 300, -1, 205, -1, 270, 181, 148, - -1, 272, 181, 200, 181, 156, 181, 148, 181, 147, - -1, 272, 181, 200, 181, 156, 181, 190, 181, 148, - 181, 147, -1, 272, 181, 156, 181, 148, 181, 147, - -1, 272, 181, 156, 181, 190, 181, 148, 181, 147, - -1, 272, 181, 200, 181, 148, 181, 147, -1, 272, - 181, 200, 181, 148, 181, 147, 181, 144, -1, 272, - 181, 148, 181, 147, -1, 272, 181, 148, 181, 147, - 181, 144, -1, 259, -1, 259, 181, 149, -1, 210, - -1, 211, -1, 212, -1, 213, -1, 224, -1, 225, - -1, 226, -1, 232, -1, 231, -1, 230, -1, 227, - -1, 228, -1, 229, -1, 214, -1, 215, -1, 216, - -1, 217, -1, 218, -1, 219, -1, 220, -1, 221, - -1, 223, -1, 297, -1, 233, -1, 234, -1, 236, - -1, 210, -1, 211, -1, 212, -1, 213, -1, 224, - -1, 225, -1, 226, -1, 232, -1, 231, -1, 230, - -1, 227, -1, 228, -1, 229, -1, 214, -1, 215, - -1, 216, -1, 217, -1, 218, -1, 219, -1, 220, - -1, 221, -1, 223, -1, 297, -1, 233, -1, 234, - -1, 236, -1, 257, 181, 124, 138, 181, 139, 181, - 140, 181, 146, 181, 147, 181, 144, 181, 142, -1, - 257, 181, 124, 138, 181, 139, 181, 140, 181, 146, - 181, 147, 181, 144, 181, 142, 181, 131, -1, 257, - 181, 124, 138, 181, 139, 181, 140, 181, 146, 181, - 147, 181, 144, 181, 142, 181, 150, -1, 257, 181, - 124, 138, 181, 139, 181, 140, 181, 146, 181, 147, - 181, 144, 181, 142, 181, 131, 181, 150, -1, 257, - 181, 138, 181, 139, 181, 140, -1, 205, 181, 143, - -1, 259, 181, 138, -1, 259, 181, 197, -1, 270, - 181, 277, 181, 148, -1, 270, 181, 148, -1, 273, - 181, 148, -1, 206, -1, 251, -1, 261, 181, 209, - 181, 173, -1, 256, 181, 209, 181, 173, 181, 173, - -1, 256, 181, 209, 181, 173, 181, 173, 181, 125, - -1, 207, -1, 247, 181, 209, 181, 173, -1, 246, - 181, 209, 181, 173, 181, 173, -1, 246, 181, 209, - 181, 173, 181, 173, 181, 125, -1, 244, -1, 254, - -1, 245, 181, 209, 181, 163, -1, 255, 181, 209, - 181, 163, -1, 262, 181, 209, 181, 163, 181, 163, - -1, 253, 181, 209, 181, 163, 181, 163, 181, 173, - -1, 249, 181, 209, 181, 163, 181, 163, -1, 248, - 181, 209, 181, 163, 181, 163, 181, 173, -1, 208, - -1, 205, 181, 209, 181, 143, -1, 205, 181, 230, - 181, 126, 181, 143, -1, 205, 181, 231, 181, 143, - -1, 205, 181, 232, 181, 143, -1, 239, 181, 209, - 181, 146, -1, 283, 181, 209, -1, 233, -1, 234, - -1, 235, -1, 258, 181, 138, -1, 258, 181, 197, - -1, 257, 181, 209, 181, 138, 181, 139, 181, 140, - -1, 260, -1, 259, 181, 209, 181, 138, -1, 269, - 181, 143, -1, 268, 181, 209, 181, 143, 181, 145, - -1, 271, 181, 279, 181, 148, -1, 271, 181, 148, - -1, 270, 181, 209, 181, 148, -1, 272, 181, 279, - 181, 148, -1, 272, 181, 148, -1, 273, 181, 209, - 181, 148, -1, 274, 181, 209, 181, 163, -1, 284, - -1, 288, -1, 289, -1, 292, 181, 238, 181, 147, - -1, 292, 181, 237, 181, 209, 181, 147, 181, 144, - -1, 243, 181, 163, 181, 173, 5, 152, -1, 248, - 181, 163, 181, 163, 181, 173, 5, 152, -1, 252, - 181, 163, 181, 173, 5, 152, -1, 253, 181, 163, - 181, 163, 181, 173, 5, 198, -1, 253, 181, 163, - 181, 163, 181, 173, 5, 152, -1, 205, 181, 121, - -1, 259, 181, 298, 181, 138, 181, 149, -1, 268, - 181, 298, 181, 143, 181, 145, 181, 151, -1, 268, - 181, 249, 181, 143, 181, 145, 181, 133, 181, 133, - -1, 268, 181, 266, 181, 143, 181, 145, 181, 141, - -1, 268, 181, 285, 181, 143, 181, 145, 181, 142, - -1, 270, 181, 298, 181, 148, 181, 169, -1, 270, - 181, 276, 181, 148, 181, 169, -1, 273, 181, 298, - 181, 148, 181, 169, -1, 273, 181, 276, 181, 148, - 181, 169, -1, 273, 181, 282, 181, 147, 181, 147, - -1, 299, 181, 157, -1, 284, 181, 142, -1, 288, - 181, 163, -1, 289, 181, 163, -1, 245, 181, 173, - 181, 125, -1, 245, 181, 173, -1, 255, 181, 173, - 181, 125, -1, 255, 181, 173, -1, 268, 181, 143, - 181, 141, -1, 268, 181, 143, 181, 141, 181, 151, - -1, 205, 181, 143, -1, 258, 181, 138, -1, 258, - 181, 197, -1, 272, 181, 280, 181, 148, 181, 154, - -1, 272, 181, 148, 181, 154, -1, 271, 181, 280, - 181, 148, 181, 154, -1, 271, 181, 148, 181, 154, - -1, 281, 181, 222, -1, 270, 181, 148, 181, 148, - -1, 273, 181, 148, 181, 148, -1, 270, 181, 148, - 181, 148, -1, 273, 181, 148, 181, 148, -1, 245, - 181, 163, -1, 255, 181, 163, -1, 268, 181, 143, - 181, 145, -1, 237, 181, 129, -1, 239, 181, 130, - -1, 245, 181, 143, 181, 132, -1, 249, 181, 143, - 181, 133, 181, 133, -1, 250, 181, 143, 181, 134, - -1, 265, 181, 143, 181, 132, 181, 135, 181, 136, - -1, 255, 181, 143, 181, 132, -1, 262, 181, 143, - 181, 135, -1, 263, 181, 143, 181, 136, -1, 264, - 181, 143, 181, 137, -1, 284, 181, 143, 181, 142, - -1, 286, 181, 143, 181, 157, -1, 287, 181, 143, - 181, 157, -1, 259, 181, 143, 181, 138, -1, 259, - 181, 143, 181, 198, -1, 259, 181, 143, 181, 199, - -1, 205, 181, 237, 181, 143, -1, 275, -1, -1, - 200, 181, -1, 173, 5, 152, -1, 125, 181, 173, - 5, 152, -1, 290, -1, 291, -1, 244, -1, 254, - -1, 208, -1, 206, -1, 251, -1, 207, -1, 258, - 181, 138, -1, 258, 181, 197, -1, 260, -1, 269, - 181, 143, -1, 271, 181, 279, 181, 148, -1, 271, - 181, 148, -1, 272, 181, 279, 181, 148, -1, 272, - 181, 148, -1, 292, 181, 238, 181, 147, -1, 205, - 181, 295, 181, 173, 181, 143, 181, 163, 181, 163, - -1, 147, 181, 144, 181, 143, -1, 200, 181, 147, - 181, 144, 181, 143, -1, 146, 181, 143, -1, 240, - -1, 241, -1, 242, -1, 163, -1, 163, -1, 173, - -1, 163, -1, 163, -1, 197, -1, 173, -1, 163, - -1, 163, -1, 163, -1, 163, -1, 158, -1, 163, - -1, 163, -1, 163, -1, 163, -1, 173, -1, 164, - -1, 164, -1, 169, -1, 169, -1, 169, -1, 153, - -1, 152, 6, 153, -1, 173, -1, 168, -1, 163, - -1, 158, -1, 173, 5, 155, -1, 154, 181, 173, - 5, 155, -1, 172, -1, 169, -1, 279, -1, 280, - -1, 278, -1, 163, -1, 173, -1, 159, 7, 159, - -1, 8, 159, 7, 159, -1, 9, 159, 7, 159, - -1, 160, -1, 159, 160, -1, 10, -1, 11, -1, - 12, -1, 13, -1, 14, -1, 15, -1, 16, -1, - 17, -1, 18, -1, 19, -1, 10, -1, 11, -1, - 12, -1, 13, -1, 14, -1, 15, -1, 16, -1, - 17, -1, 10, -1, 11, -1, 12, -1, 13, -1, - 14, -1, 15, -1, 16, -1, 17, -1, 18, -1, - 19, -1, 20, -1, 21, -1, 22, -1, 23, -1, - 24, -1, 25, -1, 26, -1, 27, -1, 28, -1, - 29, -1, 30, -1, 31, -1, 160, -1, 11, 159, - -1, 12, 159, -1, 13, 159, -1, 14, 159, -1, - 15, 159, -1, 16, 159, -1, 17, 159, -1, 18, - 159, -1, 19, 159, -1, 32, 165, 32, -1, 33, - 165, 33, -1, 166, 167, -1, 34, -1, 176, 35, - 34, -1, -1, 167, 34, -1, 167, 171, -1, 32, - 170, 32, -1, 33, 170, 33, -1, 32, 172, 32, - -1, 33, 172, 33, -1, 181, -1, 173, -1, 170, - 181, -1, 170, 173, -1, 181, -1, 174, -1, 171, - 181, -1, 171, 174, -1, 34, -1, 171, -1, 172, - 34, -1, 172, 171, -1, 175, -1, 173, 175, -1, - 177, -1, 178, -1, 174, 177, -1, 174, 178, -1, - 177, -1, 36, -1, 34, -1, 26, -1, 27, -1, - 28, -1, 29, -1, 30, -1, 31, -1, 37, -1, - 38, -1, 39, -1, 40, -1, 41, -1, 42, -1, - 43, -1, 44, -1, 45, -1, 46, -1, 47, -1, - 48, -1, 49, -1, 50, -1, 51, -1, 52, -1, - 53, -1, 54, -1, 55, -1, 56, -1, 20, -1, - 21, -1, 22, -1, 23, -1, 24, -1, 25, -1, - 57, -1, 58, -1, 59, -1, 60, -1, 61, -1, - 62, -1, 63, -1, 64, -1, 65, -1, 66, -1, - 67, -1, 68, -1, 69, -1, 70, -1, 71, -1, - 72, -1, 73, -1, 74, -1, 75, -1, 76, -1, - 176, -1, 10, -1, 11, -1, 12, -1, 13, -1, - 14, -1, 15, -1, 16, -1, 17, -1, 18, -1, - 19, -1, 77, -1, 4, -1, 78, -1, 79, -1, - 80, -1, 81, -1, 82, -1, 83, -1, 8, -1, - 9, -1, 7, -1, 6, -1, 35, -1, 84, -1, - 85, -1, 5, -1, 86, -1, 87, -1, 88, -1, - 89, -1, 90, -1, 91, -1, 92, -1, 93, -1, - 94, -1, 95, -1, 96, -1, 3, -1, 36, 32, - -1, 36, 33, -1, 36, 36, -1, 36, 34, -1, - 36, 64, -1, 36, 68, -1, 36, 25, -1, 36, - 70, -1, 36, 72, -1, 179, -1, 180, -1, 36, - 161, -1, 36, 161, 161, -1, 36, 161, 161, 161, - -1, 36, 74, 162, -1, 36, 74, 162, 162, -1, - 97, -1, 98, -1, 99, -1, 26, 29, 29, -1, - 37, 30, 50, -1, 43, 26, 46, -1, 51, 44, - 43, 26, 46, -1, 28, 42, 30, 26, 48, -1, - 31, 39, 44, 29, -1, 31, 39, 42, 30, 92, - 26, 49, 92, 29, 39, 48, -1, 43, 45, 52, - 30, -1, 28, 45, 46, 55, -1, 28, 48, 30, - 26, 50, 30, -1, 29, 30, 49, 50, 48, 45, - 55, -1, 42, 39, 49, 50, -1, 42, 45, 26, - 29, -1, 26, 42, 42, -1, 44, 45, 44, 30, - -1, 29, 30, 31, 26, 51, 42, 50, -1, 44, - 45, 44, 92, 43, 45, 29, 26, 42, -1, 48, - 30, 43, 45, 52, 30, -1, 49, 30, 50, -1, - 49, 51, 27, 49, 28, 48, 39, 27, 30, -1, - 51, 44, 49, 51, 27, 49, 28, 48, 39, 27, - 30, -1, 28, 38, 26, 44, 44, 30, 42, -1, - 26, 52, 26, 39, 42, 26, 27, 42, 30, 92, - 30, 44, 37, 39, 44, 30, 49, -1, 26, 52, - 26, 39, 42, 26, 27, 42, 30, 92, 26, 51, - 29, 39, 45, 92, 45, 51, 50, 46, 51, 50, - 92, 29, 48, 39, 52, 30, 48, 49, -1, 28, - 38, 26, 44, 44, 30, 42, 49, -1, 39, 44, - 31, 45, -1, 26, 51, 29, 39, 45, 92, 45, - 51, 50, 46, 51, 50, 92, 29, 30, 52, 39, - 28, 30, 92, 28, 45, 51, 44, 50, -1, 26, - 51, 29, 39, 45, 92, 45, 51, 50, 46, 51, - 50, 92, 29, 30, 52, 39, 28, 30, 92, 39, - 44, 31, 45, -1, 43, 39, 29, 39, 92, 39, - 44, 46, 51, 50, 92, 29, 30, 52, 39, 28, - 30, 92, 28, 45, 51, 44, 50, -1, 43, 39, - 29, 39, 92, 39, 44, 46, 51, 50, 92, 29, - 30, 52, 39, 28, 30, 92, 39, 44, 31, 45, - -1, 43, 39, 29, 39, 92, 39, 44, 49, 50, - 48, 51, 43, 30, 44, 50, 92, 43, 26, 46, - 92, 28, 45, 51, 44, 50, -1, 43, 39, 29, - 39, 92, 39, 44, 49, 50, 48, 51, 43, 30, - 44, 50, 92, 43, 26, 46, 92, 39, 44, 31, - 45, -1, 43, 39, 29, 39, 92, 39, 44, 49, - 50, 48, 51, 43, 30, 44, 50, 92, 28, 45, - 51, 44, 50, -1, 43, 39, 29, 39, 92, 39, - 44, 49, 50, 48, 51, 43, 30, 44, 50, 92, - 39, 44, 31, 45, -1, 29, 27, 92, 39, 44, - 49, 50, 48, 51, 43, 30, 44, 50, 92, 29, - 39, 48, 30, 28, 50, 45, 48, 55, 92, 28, - 45, 51, 44, 50, -1, 29, 27, 92, 39, 44, - 49, 50, 48, 51, 43, 30, 44, 50, 92, 29, - 39, 48, 30, 28, 50, 45, 48, 55, 92, 39, - 44, 31, 45, -1, 29, 27, 92, 39, 44, 49, - 50, 48, 51, 43, 30, 44, 50, 92, 28, 45, - 51, 44, 50, -1, 29, 27, 92, 39, 44, 49, - 50, 48, 51, 43, 30, 44, 50, 92, 39, 44, - 31, 45, -1, 29, 27, 92, 39, 44, 49, 50, - 48, 51, 43, 30, 44, 50, 92, 31, 39, 42, - 30, 49, -1, 29, 27, 92, 39, 44, 49, 50, - 48, 51, 43, 30, 44, 50, 49, 92, 40, 45, - 27, 92, 39, 44, 31, 45, -1, 28, 38, 26, - 44, 44, 30, 42, 92, 28, 45, 51, 44, 50, - -1, 28, 38, 26, 44, 44, 30, 42, 92, 43, - 39, 29, 39, -1, 29, 30, 52, 39, 28, 30, - 92, 43, 39, 29, 39, -1, 28, 38, 26, 44, - 44, 30, 42, 92, 39, 44, 31, 45, -1, 31, - 54, 92, 49, 30, 44, 29, 92, 28, 45, 51, - 44, 50, -1, 31, 54, 92, 49, 30, 44, 29, - 92, 39, 44, 31, 45, -1, 27, 51, 31, 31, - 30, 48, 92, 31, 39, 42, 42, -1, 49, 50, - 48, 30, 26, 43, 92, 28, 45, 51, 44, 50, - -1, 52, 45, 39, 28, 30, 92, 28, 45, 51, - 44, 50, -1, 50, 45, 50, 26, 42, 92, 49, - 50, 48, 30, 26, 43, 92, 28, 45, 51, 44, - 50, -1, 50, 45, 50, 26, 42, 92, 52, 45, - 39, 28, 30, 92, 28, 45, 51, 44, 50, -1, - 50, 45, 50, 26, 42, 92, 52, 45, 39, 28, - 30, 92, 28, 45, 51, 44, 50, 92, 43, 26, - 54, -1, 37, 42, 45, 27, 26, 42, 92, 39, - 44, 31, 45, -1, 39, 44, 49, 50, 48, 51, - 43, 30, 44, 50, -1, 39, 44, 49, 50, 48, - 51, 43, 30, 44, 50, 49, -1, 30, 44, 37, - 39, 44, 30, -1, 45, 44, 92, 29, 30, 43, - 26, 44, 29, -1, 45, 44, 92, 29, 30, 43, - 26, 44, 29, 92, 38, 45, 42, 29, -1, 46, - 30, 48, 49, 39, 49, 50, 30, 44, 50, -1, - 26, 51, 29, 39, 45, 92, 45, 51, 50, 46, - 51, 50, 92, 29, 30, 52, 39, 28, 30, 92, - 46, 26, 48, 26, 43, 30, 50, 30, 48, -1, - 26, 51, 29, 39, 45, 92, 45, 51, 50, 46, - 51, 50, 92, 29, 30, 52, 39, 28, 30, 49, - -1, 26, 51, 29, 39, 45, 92, 45, 51, 50, - 46, 51, 50, 92, 29, 30, 52, 39, 28, 30, - -1, 26, 51, 29, 39, 45, 92, 45, 51, 50, - 46, 51, 50, 92, 29, 48, 39, 52, 30, 48, - 92, 46, 26, 48, 26, 43, 30, 50, 30, 48, - -1, 26, 51, 29, 39, 45, 92, 45, 51, 50, - 46, 51, 50, 92, 29, 48, 39, 52, 30, 48, - -1, 26, 51, 29, 39, 45, 92, 45, 51, 50, - 46, 51, 50, 92, 28, 38, 26, 44, 44, 30, - 42, 92, 46, 26, 48, 26, 43, 30, 50, 30, - 48, -1, 26, 51, 29, 39, 45, 92, 45, 51, - 50, 46, 51, 50, 92, 28, 38, 26, 44, 44, - 30, 42, -1, 26, 51, 29, 39, 45, 92, 45, - 51, 50, 46, 51, 50, 92, 50, 55, 46, 30, - -1, 26, 52, 26, 39, 42, 26, 27, 42, 30, - 92, 43, 39, 29, 39, 92, 39, 44, 46, 51, - 50, 92, 29, 48, 39, 52, 30, 48, 49, -1, - 43, 39, 29, 39, 92, 39, 44, 46, 51, 50, - 92, 29, 30, 52, 39, 28, 30, 92, 46, 26, - 48, 26, 43, 30, 50, 30, 48, -1, 43, 39, - 29, 39, 92, 39, 44, 46, 51, 50, 92, 46, - 45, 48, 50, 92, 46, 26, 48, 26, 43, 30, - 50, 30, 48, -1, 43, 39, 29, 39, 92, 39, - 44, 46, 51, 50, 92, 29, 30, 52, 39, 28, - 30, 49, -1, 43, 39, 29, 39, 92, 39, 44, - 46, 51, 50, 92, 29, 30, 52, 39, 28, 30, - -1, 43, 39, 29, 39, 92, 39, 44, 46, 51, - 50, 92, 29, 48, 39, 52, 30, 48, 92, 46, - 26, 48, 26, 43, 30, 50, 30, 48, -1, 43, - 39, 29, 39, 92, 39, 44, 49, 50, 48, 51, - 43, 30, 44, 50, -1, 43, 39, 29, 39, 92, - 39, 44, 49, 50, 48, 51, 43, 30, 44, 50, - 49, -1, 43, 39, 29, 39, 92, 39, 44, 49, - 50, 48, 51, 43, 30, 44, 50, 92, 43, 26, - 46, -1, 43, 39, 29, 39, 92, 39, 44, 49, - 50, 48, 51, 43, 30, 44, 50, 92, 43, 26, - 46, 49, -1, 43, 39, 29, 39, 92, 39, 44, - 46, 51, 50, 92, 29, 48, 39, 52, 30, 48, - -1, 43, 39, 29, 39, 92, 39, 44, 46, 51, - 50, 92, 46, 45, 48, 50, -1, 43, 39, 29, - 39, 92, 39, 44, 46, 51, 50, 92, 28, 38, - 26, 44, 44, 30, 42, -1, 43, 39, 29, 39, - 92, 39, 44, 46, 51, 50, 92, 50, 55, 46, - 30, -1, 43, 39, 29, 39, 92, 39, 44, 46, - 51, 50, -1, 43, 39, 29, 39, 92, 28, 45, - 44, 50, 48, 45, 42, 42, 30, 48, -1, 49, - 30, 44, 29, -1, 31, 54, 92, 49, 30, 44, - 29, -1, 31, 54, 92, 49, 30, 44, 29, 49, - -1, 29, 27, 92, 39, 44, 49, 50, 48, 51, - 43, 30, 44, 50, 92, 29, 39, 48, 30, 28, - 50, 45, 48, 55, -1, 29, 27, 92, 39, 44, - 49, 50, 48, 51, 43, 30, 44, 50, 92, 29, - 39, 48, 30, 28, 50, 45, 48, 39, 30, 49, - -1, 29, 27, 92, 39, 44, 49, 50, 48, 51, - 43, 30, 44, 50, 49, -1, 29, 27, 92, 39, - 44, 49, 50, 48, 51, 43, 30, 44, 50, -1, - 29, 27, 92, 39, 44, 49, 50, 48, 51, 43, - 30, 44, 50, 49, 92, 40, 45, 27, -1, 39, - 44, 49, 50, 48, 51, 43, 30, 44, 50, 49, - 92, 29, 27, -1, 29, 30, 49, 28, 48, 39, - 46, 50, 39, 45, 44, -1, 31, 45, 48, 28, - 30, -1, 31, 42, 26, 50, -1, 48, 30, 28, - 51, 48, 49, 39, 52, 30, -1, 44, 45, 44, - 92, 48, 30, 28, 51, 48, 49, 39, 52, 30, - -1, 42, 45, 49, 50, -1, 31, 39, 42, 30, - 92, 46, 26, 50, 38, -1, 49, 30, 48, 52, - 30, 48, -1, 52, 45, 42, 51, 43, 30, -1, - 42, 30, 52, 30, 42, -1, 43, 51, 50, 30, - -1, 49, 45, 42, 45, -1, 52, 45, 39, 28, - 30, 49, -1, 49, 50, 48, 30, 26, 43, 49, - -1, 27, 55, 50, 30, 49, -1, 46, 30, 48, - 28, 30, 44, 50, 26, 37, 30, -1, 31, 39, - 42, 30, -1, 30, 29, 39, 50, -1, 31, 45, - 48, 43, 26, 50, -1, 43, 39, 29, 39, 92, - 29, 26, 50, 26, -1, 48, 30, 49, 30, 50, - -1, 43, 39, 49, 28, 30, 42, 42, 26, 44, - 30, 45, 51, 49, -1, 44, 26, 43, 30, -1, - 30, 28, 38, 45, -1, 47, 51, 39, 50, -1 -}; - -/* YYRLINEYYN -- source line where rule number YYN was defined. */ -static const yytype_uint16 yyrline = -{ - 0, 146, 146, 147, 150, 151, 152, 153, 156, 157, - 158, 159, 160, 163, 164, 165, 166, 167, 168, 169, - 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, - 180, 181, 182, 183, 184, 187, 188, 189, 190, 191, - 192, 193, 194, 195, 196, 197, 198, 201, 202, 203, - 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, - 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, - 224, 225, 226, 229, 230, 231, 232, 233, 234, 235, - 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, - 246, 247, 248, 249, 250, 251, 252, 253, 254, 257, - 258, 259, 260, 263, 266, 267, 268, 269, 270, 271, - 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, - 284, 285, 286, 287, 288, 289, 290, 291, 292, 293, - 294, 295, 296, 297, 298, 299, 300, 301, 302, 303, - 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 315, 316, 317, 318, 319, 322, 323, 324, 325, - 326, 327, 328, 329, 330, 331, 332, 333, 334, 335, - 336, 337, 338, 339, 340, 341, 344, 345, 346, 347, - 348, 349, 352, 355, 356, 359, 360, 361, 362, 363, - 366, 367, 370, 371, 374, 375, 376, 379, 380, 383, - 384, 385, 386, 387, 388, 389, 390, 391, 392, 393, - 394, 395, 396, 399, 402, 405, 406, 409, 410, 413, - 414, 417, 418, 419, 420, 421, 422, 423, 424, 425, - 426, 427, 428, 429, 430, 431, 434, 437, 438, 441, - 444, 445, 446, 449, 452, 455, 458, 461, 462, 465, - 468, 471, 474, 477, 480, 481, 484, 487, 490, 493, - 496, 506, 509, 512, 515, 518, 519, 523, 524, 525, - 526, 529, 530, 533, 534, 537, 538, 539, 547, 548, - 551, 552, 553, 557, 558, 561, 562, 563, 564, 565, - 566, 567, 568, 569, 570, 573, 574, 575, 576, 577, - 578, 579, 580, 583, 584, 585, 586, 587, 588, 589, - 590, 591, 592, 593, 594, 595, 596, 597, 598, 599, - 600, 601, 602, 603, 604, 607, 608, 609, 610, 611, - 612, 613, 614, 615, 616, 619, 620, 623, 626, 627, - 630, 631, 632, 635, 636, 639, 640, 643, 644, 645, - 646, 650, 651, 652, 653, 656, 657, 658, 659, 662, - 663, 666, 667, 668, 669, 673, 674, 675, 679, 679, - 679, 679, 679, 679, 679, 679, 679, 679, 679, 679, - 679, 679, 679, 679, 679, 679, 679, 679, 679, 679, - 679, 679, 679, 679, 680, 680, 680, 680, 680, 680, - 680, 680, 680, 680, 680, 680, 680, 680, 680, 680, - 680, 680, 680, 680, 680, 680, 680, 680, 680, 680, - 684, 685, 685, 685, 685, 685, 685, 685, 685, 685, - 685, 686, 686, 686, 686, 686, 686, 686, 686, 686, - 686, 686, 686, 687, 687, 687, 687, 687, 687, 687, - 688, 688, 688, 688, 689, 689, 689, 689, 690, 693, - 694, 695, 696, 697, 698, 699, 700, 701, 702, 703, - 706, 707, 708, 711, 712, 717, 720, 723, 726, 729, - 732, 735, 738, 741, 744, 747, 750, 753, 756, 759, - 762, 765, 768, 771, 774, 777, 780, 783, 786, 789, - 792, 795, 798, 801, 804, 807, 810, 813, 816, 819, - 822, 825, 828, 831, 834, 837, 840, 843, 846, 849, - 852, 855, 858, 861, 864, 867, 870, 873, 876, 879, - 882, 885, 888, 891, 894, 897, 900, 903, 906, 909, - 912, 915, 918, 921, 924, 927, 930, 933, 936, 939, - 942, 945, 948, 951, 954, 957, 960, 963, 966, 969, - 972, 975, 978, 981, 984, 987, 990, 993, 996, 999, - 1002, 1005, 1008, 1011, 1014, 1017, 1020, 1023, 1026, 1029, - 1032, 1035, 1038, 1041, 1044, 1047, 1050, 1053, 1056, 1059, - 1062, 1065, 1068, 1071, 1074 -}; -#endif - -#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE -/* YYTNAMESYMBOL-NUM -- String name of the symbol SYMBOL-NUM. - First, the terminals, then, starting at YYNTOKENS, nonterminals. */ -static const char *const yytname = -{ - "$end", "error", "$undefined", "EXT_ASCII_CHAR", "'#'", "'='", "','", - "'.'", "'+'", "'-'", "'0'", "'1'", "'2'", "'3'", "'4'", "'5'", "'6'", - "'7'", "'8'", "'9'", "'a'", "'b'", "'c'", "'d'", "'e'", "'f'", "'A'", - "'B'", "'C'", "'D'", "'E'", "'F'", "'''", "'\"'", "'/'", "':'", "'\\\\'", - "'G'", "'H'", "'I'", "'J'", "'K'", "'L'", "'M'", "'N'", "'O'", "'P'", - "'Q'", "'R'", "'S'", "'T'", "'U'", "'V'", "'W'", "'X'", "'Y'", "'Z'", - "'g'", "'h'", "'i'", "'j'", "'k'", "'l'", "'m'", "'n'", "'o'", "'p'", - "'q'", "'r'", "'s'", "'t'", "'u'", "'v'", "'w'", "'x'", "'y'", "'z'", - "'!'", "'$'", "'%'", "'&'", "'('", "')'", "'*'", "';'", "'<'", "'>'", - "'?'", "'@'", "''", "''", "'^'", "'_'", "'{'", "'|'", "'}'", "'~'", - "' '", "'\\n'", "'\\r'", "$accept", "input", "line", "comment", - "command", "add_instruction", "subscribe_event", "unsubscribe_event", - "map_instruction", "unmap_instruction", "remove_instruction", - "get_instruction", "set_instruction", "create_instruction", - "reset_instruction", "clear_instruction", "find_instruction", - "move_instruction", "copy_instruction", "destroy_instruction", - "load_instruction", "set_chan_instruction", "edit_instruction", - "format_instruction", "modal_arg", "key_val_list", "buffer_size_type", - "list_instruction", "send_instruction", "load_instr_args", - "load_engine_args", "instr_load_mode", "device_index", - "audio_channel_index", "audio_output_type_name", "midi_input_port_index", - "midi_input_channel_index", "midi_input_type_name", "midi_map", - "midi_bank", "midi_prog", "midi_ctrl", "volume_value", "sampler_channel", - "instrument_index", "fx_send_id", "engine_name", "filename", "db_path", - "map_name", "entry_name", "fx_send_name", "param_val_list", "param_val", - "query_val_list", "query_val", "scan_mode", "boolean", "dotnum", - "digits", "digit", "digit_oct", "digit_hex", "number", "path", - "path_base", "path_prefix", "path_body", "stringval", - "stringval_escaped", "text", "text_escaped_base", "text_escaped", - "string", "string_escaped", "char", "alpha_char", "char_base", - "escape_seq", "escape_seq_octal", "escape_seq_hex", "SP", "LF", "CR", - "ADD", "GET", "MAP", "UNMAP", "CLEAR", "FIND", "FILE_AS_DIR", "MOVE", - "COPY", "CREATE", "DESTROY", "LIST", "LOAD", "ALL", "NONE", "DEFAULT", - "NON_MODAL", "REMOVE", "SET", "SUBSCRIBE", "UNSUBSCRIBE", "CHANNEL", - "AVAILABLE_ENGINES", "AVAILABLE_AUDIO_OUTPUT_DRIVERS", "CHANNELS", - "INFO", "AUDIO_OUTPUT_DEVICE_COUNT", "AUDIO_OUTPUT_DEVICE_INFO", - "MIDI_INPUT_DEVICE_COUNT", "MIDI_INPUT_DEVICE_INFO", - "MIDI_INSTRUMENT_MAP_COUNT", "MIDI_INSTRUMENT_MAP_INFO", - "MIDI_INSTRUMENT_COUNT", "MIDI_INSTRUMENT_INFO", - "DB_INSTRUMENT_DIRECTORY_COUNT", "DB_INSTRUMENT_DIRECTORY_INFO", - "DB_INSTRUMENT_COUNT", "DB_INSTRUMENT_INFO", "DB_INSTRUMENT_FILES", - "DB_INSTRUMENTS_JOB_INFO", "CHANNEL_COUNT", "CHANNEL_MIDI", - "DEVICE_MIDI", "CHANNEL_INFO", "FX_SEND_COUNT", "FX_SEND_INFO", - "BUFFER_FILL", "STREAM_COUNT", "VOICE_COUNT", "TOTAL_STREAM_COUNT", - "TOTAL_VOICE_COUNT", "TOTAL_VOICE_COUNT_MAX", "GLOBAL_INFO", - "INSTRUMENT", "INSTRUMENTS", "ENGINE", "ON_DEMAND", "ON_DEMAND_HOLD", - "PERSISTENT", "AUDIO_OUTPUT_DEVICE_PARAMETER", "AUDIO_OUTPUT_DEVICES", - "AUDIO_OUTPUT_DEVICE", "AUDIO_OUTPUT_DRIVER_PARAMETER", - "AUDIO_OUTPUT_DRIVER", "AUDIO_OUTPUT_CHANNEL_PARAMETER", - "AUDIO_OUTPUT_CHANNEL", "AUDIO_OUTPUT_TYPE", - "AVAILABLE_MIDI_INPUT_DRIVERS", "MIDI_INPUT_DEVICE_PARAMETER", - "MIDI_INPUT_PORT_PARAMETER", "MIDI_INPUT_DEVICES", "MIDI_INPUT_DEVICE", - "MIDI_INPUT_DRIVER_PARAMETER", "MIDI_INSTRUMENT", "MIDI_INSTRUMENTS", - "MIDI_INSTRUMENT_MAP", "MIDI_INSTRUMENT_MAPS", "MIDI_INPUT_DRIVER", - "MIDI_INPUT_PORT", "MIDI_INPUT_CHANNEL", "MIDI_INPUT_TYPE", "MIDI_INPUT", - "MIDI_CONTROLLER", "SEND", "FX_SEND", "FX_SENDS", - "DB_INSTRUMENT_DIRECTORY", "DB_INSTRUMENT_DIRECTORIES", "DB_INSTRUMENTS", - "DB_INSTRUMENT", "DB_INSTRUMENTS_JOB", "INSTRUMENTS_DB", "DESCRIPTION", - "FORCE", "FLAT", "RECURSIVE", "NON_RECURSIVE", "LOST", "FILE_PATH", - "SERVER", "VOLUME", "LEVEL", "MUTE", "SOLO", "VOICES", "STREAMS", - "BYTES", "PERCENTAGE", "FILE", "EDIT", "FORMAT", "MIDI_DATA", "RESET", - "MISCELLANEOUS", "NAME", "ECHO", "QUIT", 0 -}; -#endif - -# ifdef YYPRINT -/* YYTOKNUMYYLEX-NUM -- Internal token number corresponding to - token YYLEX-NUM. */ -static const yytype_uint16 yytoknum = -{ - 0, 256, 257, 258, 35, 61, 44, 46, 43, 45, - 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, - 97, 98, 99, 100, 101, 102, 65, 66, 67, 68, - 69, 70, 39, 34, 47, 58, 92, 71, 72, 73, - 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, - 84, 85, 86, 87, 88, 89, 90, 103, 104, 105, - 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, - 116, 117, 118, 119, 120, 121, 122, 33, 36, 37, - 38, 40, 41, 42, 59, 60, 62, 63, 64, 91, - 93, 94, 95, 123, 124, 125, 126, 32, 10, 13 -}; -# endif - -/* YYR1YYN -- Symbol number of symbol that rule YYN derives. */ -static const yytype_uint16 yyr1 = -{ - 0, 100, 101, 101, 102, 102, 102, 102, 103, 103, - 103, 103, 103, 104, 104, 104, 104, 104, 104, 104, - 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, - 104, 104, 104, 104, 104, 105, 105, 105, 105, 105, - 105, 105, 105, 105, 105, 105, 105, 106, 106, 106, - 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, - 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, - 106, 106, 106, 107, 107, 107, 107, 107, 107, 107, - 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, - 107, 107, 107, 107, 107, 107, 107, 107, 107, 108, - 108, 108, 108, 109, 110, 110, 110, 110, 110, 110, - 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, - 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, - 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, - 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, - 111, 111, 111, 111, 111, 111, 112, 112, 112, 112, - 112, 112, 112, 112, 112, 112, 112, 112, 112, 112, - 112, 112, 112, 112, 112, 112, 113, 113, 113, 113, - 113, 113, 114, 115, 115, 116, 116, 116, 116, 116, - 117, 117, 118, 118, 119, 119, 119, 120, 120, 121, - 121, 121, 121, 121, 121, 121, 121, 121, 121, 121, - 121, 121, 121, 122, 123, 124, 124, 125, 125, 126, - 126, 127, 127, 127, 127, 127, 127, 127, 127, 127, - 127, 127, 127, 127, 127, 127, 128, 129, 129, 130, - 131, 131, 131, 132, 133, 134, 135, 136, 136, 137, - 138, 139, 140, 141, 142, 142, 143, 144, 145, 146, - 147, 148, 149, 150, 151, 152, 152, 153, 153, 153, - 153, 154, 154, 155, 155, 156, 156, 156, 157, 157, - 158, 158, 158, 159, 159, 160, 160, 160, 160, 160, - 160, 160, 160, 160, 160, 161, 161, 161, 161, 161, - 161, 161, 161, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 162, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 162, 162, 162, 163, 163, 163, 163, 163, - 163, 163, 163, 163, 163, 164, 164, 165, 166, 166, - 167, 167, 167, 168, 168, 169, 169, 170, 170, 170, - 170, 171, 171, 171, 171, 172, 172, 172, 172, 173, - 173, 174, 174, 174, 174, 175, 175, 175, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 176, 176, 176, 176, 176, 176, 176, 176, 176, 176, - 177, 177, 177, 177, 177, 177, 177, 177, 177, 177, - 177, 177, 177, 177, 177, 177, 177, 177, 177, 177, - 177, 177, 177, 177, 177, 177, 177, 177, 177, 177, - 177, 177, 177, 177, 177, 177, 177, 177, 177, 178, - 178, 178, 178, 178, 178, 178, 178, 178, 178, 178, - 179, 179, 179, 180, 180, 181, 182, 183, 184, 185, - 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, - 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, - 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, - 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, - 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, - 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, - 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, - 256, 257, 258, 259, 260, 261, 262, 263, 264, 265, - 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, - 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, - 286, 287, 288, 289, 290, 291, 292, 293, 294, 295, - 296, 297, 298, 299, 300 -}; - -/* YYR2YYN -- Number of symbols composing right hand side of rule YYN. */ -static const yytype_uint8 yyr2 = -{ - 0, 2, 2, 3, 0, 1, 1, 1, 1, 2, - 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 1, 1, 1, 3, 9, 11, 7, - 9, 7, 9, 5, 7, 1, 3, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 16, - 18, 18, 20, 7, 3, 3, 3, 5, 3, 3, - 1, 1, 5, 7, 9, 1, 5, 7, 9, 1, - 1, 5, 5, 7, 9, 7, 9, 1, 5, 7, - 5, 5, 5, 3, 1, 1, 1, 3, 3, 9, - 1, 5, 3, 7, 5, 3, 5, 5, 3, 5, - 5, 1, 1, 1, 5, 9, 7, 9, 7, 9, - 9, 3, 7, 9, 11, 9, 9, 7, 7, 7, - 7, 7, 3, 3, 3, 3, 5, 3, 5, 3, - 5, 7, 3, 3, 3, 7, 5, 7, 5, 3, - 5, 5, 5, 5, 3, 3, 5, 3, 3, 5, - 7, 5, 9, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 1, 0, 2, 3, 5, 1, - 1, 1, 1, 1, 1, 1, 1, 3, 3, 1, - 3, 5, 3, 5, 3, 5, 11, 5, 7, 3, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 3, 1, 1, 1, - 1, 3, 5, 1, 1, 1, 1, 1, 1, 1, - 3, 4, 4, 1, 2, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 3, 3, 2, 1, 3, - 0, 2, 2, 3, 3, 3, 3, 1, 1, 2, - 2, 1, 1, 2, 2, 1, 1, 2, 2, 1, - 2, 1, 1, 2, 2, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, - 2, 3, 4, 3, 4, 1, 1, 1, 3, 3, - 3, 5, 5, 4, 11, 4, 4, 6, 7, 4, - 4, 3, 4, 7, 9, 6, 3, 9, 11, 7, - 17, 30, 8, 4, 25, 24, 23, 22, 25, 24, - 21, 20, 29, 28, 19, 18, 19, 23, 13, 12, - 11, 12, 13, 12, 11, 12, 11, 18, 17, 21, - 11, 10, 11, 6, 9, 14, 10, 29, 20, 19, - 29, 19, 30, 20, 17, 28, 27, 25, 18, 17, - 27, 15, 16, 19, 20, 17, 15, 18, 15, 10, - 15, 4, 7, 8, 23, 25, 14, 13, 18, 14, - 11, 5, 4, 9, 13, 4, 9, 6, 6, 5, - 4, 4, 6, 7, 5, 10, 4, 4, 6, 9, - 5, 13, 4, 4, 4 -}; - -/* YYDEFACTSTATE-NAME -- Default rule to reduce with in state - STATE-NUM when YYTABLE doesn't specify something else to do. Zero - means the default is an error. */ -static const yytype_uint16 yydefact = -{ - 0, 7, 8, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 5, 6, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 33, 34, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1, 476, - 477, 2, 0, 458, 9, 446, 442, 441, 439, 440, - 285, 286, 287, 288, 289, 290, 291, 292, 293, 294, - 394, 395, 396, 397, 398, 399, 368, 369, 370, 371, - 372, 373, 367, 443, 366, 374, 375, 376, 377, 378, - 379, 380, 381, 382, 383, 384, 385, 386, 387, 388, - 389, 390, 391, 392, 393, 400, 401, 402, 403, 404, - 405, 406, 407, 408, 409, 410, 411, 412, 413, 414, - 415, 416, 417, 418, 419, 431, 433, 434, 435, 436, - 437, 438, 444, 445, 447, 448, 449, 450, 451, 452, - 453, 454, 455, 456, 457, 475, 325, 11, 12, 359, - 420, 365, 10, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 478, 0, 0, 0, 0, 0, 0, - 0, 479, 0, 0, 480, 0, 0, 0, 0, 0, - 496, 0, 0, 0, 3, 285, 286, 287, 288, 289, - 290, 291, 292, 293, 294, 326, 283, 327, 328, 329, - 330, 331, 332, 333, 334, 432, 421, 422, 423, 424, - 425, 426, 427, 428, 429, 430, 360, 0, 0, 0, - 13, 35, 45, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 16, 0, 110, 115, 127, 134, - 135, 136, 0, 119, 0, 0, 0, 0, 0, 111, - 0, 120, 0, 0, 0, 0, 0, 140, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 151, 152, - 153, 0, 0, 14, 0, 15, 0, 0, 26, 0, - 0, 0, 27, 0, 0, 0, 0, 28, 0, 0, - 29, 0, 0, 0, 0, 0, 17, 0, 0, 0, - 18, 0, 0, 0, 0, 0, 0, 0, 19, 224, - 226, 223, 221, 225, 222, 0, 229, 0, 0, 0, - 0, 0, 20, 0, 0, 21, 0, 0, 0, 0, - 0, 0, 0, 0, 22, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 23, 47, - 48, 49, 50, 60, 61, 62, 63, 64, 65, 66, - 67, 68, 51, 52, 53, 57, 58, 59, 56, 55, - 54, 70, 71, 72, 69, 24, 73, 74, 75, 76, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 77, - 78, 79, 83, 84, 85, 82, 81, 80, 96, 97, - 98, 95, 32, 0, 30, 0, 0, 31, 214, 25, - 0, 0, 486, 0, 0, 587, 483, 0, 489, 490, - 485, 594, 0, 0, 561, 0, 0, 0, 284, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 215, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 482, 0, 0, 0, 0, 590, 0, 481, - 0, 0, 0, 0, 0, 0, 46, 262, 0, 0, - 36, 261, 0, 0, 0, 0, 0, 0, 277, 275, - 276, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 286, - 287, 288, 289, 290, 291, 292, 293, 294, 0, 137, - 250, 138, 0, 0, 0, 0, 142, 256, 0, 145, - 0, 148, 0, 0, 0, 133, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 183, 184, 0, 0, 0, - 0, 0, 0, 0, 0, 189, 0, 0, 0, 0, - 0, 0, 0, 0, 177, 179, 0, 194, 195, 0, - 0, 0, 0, 0, 227, 228, 230, 232, 0, 234, - 0, 0, 0, 0, 197, 0, 260, 0, 198, 0, - 259, 104, 105, 106, 0, 108, 0, 109, 0, 0, - 0, 0, 0, 0, 0, 161, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 173, 254, 0, 283, 255, 174, 175, 172, 278, 279, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 182, 487, 0, 588, - 495, 0, 0, 0, 0, 0, 355, 0, 356, 0, - 352, 361, 362, 468, 469, 351, 0, 338, 0, 340, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 586, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 216, 0, 0, 0, 575, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 593, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 488, 0, - 0, 0, 0, 0, 295, 296, 297, 298, 299, 300, - 301, 302, 465, 459, 460, 462, 461, 463, 464, 466, - 467, 0, 470, 354, 353, 345, 357, 358, 363, 364, - 346, 335, 337, 0, 336, 0, 0, 0, 43, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 128, 0, 0, - 0, 219, 220, 130, 131, 132, 121, 0, 116, 0, - 0, 0, 122, 0, 0, 491, 141, 112, 0, 0, - 146, 144, 147, 149, 150, 0, 0, 154, 0, 0, - 0, 0, 251, 0, 0, 0, 188, 0, 0, 186, - 0, 0, 0, 190, 191, 192, 193, 0, 0, 0, - 176, 0, 178, 180, 253, 196, 258, 0, 0, 0, - 0, 231, 233, 0, 235, 0, 0, 257, 0, 239, - 0, 107, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 213, 0, 0, - 0, 0, 0, 0, 303, 304, 305, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 315, 316, 317, 318, - 319, 320, 321, 322, 323, 324, 473, 471, 341, 342, - 339, 572, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 533, 0, 0, 577, 0, 0, - 582, 578, 503, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 580, 581, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 592, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 281, 282, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 497, - 0, 499, 0, 0, 474, 472, 0, 0, 0, 44, - 0, 39, 0, 41, 0, 0, 0, 0, 499, 0, - 562, 0, 583, 0, 0, 0, 0, 129, 117, 0, - 125, 0, 113, 0, 123, 143, 0, 0, 0, 0, - 103, 252, 0, 0, 0, 271, 274, 273, 187, 185, - 0, 0, 0, 562, 0, 0, 439, 440, 0, 0, - 217, 265, 270, 269, 268, 267, 181, 264, 0, 0, - 0, 0, 0, 0, 237, 0, 571, 0, 0, 0, - 0, 199, 243, 0, 244, 201, 245, 203, 0, 0, - 210, 211, 212, 204, 246, 205, 247, 248, 206, 249, - 0, 207, 208, 209, 156, 0, 158, 0, 162, 0, - 579, 0, 0, 0, 0, 0, 0, 168, 167, 0, - 170, 171, 169, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 502, 0, 563, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 348, 347, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 498, 0, 0, 0, 0, 0, 0, 40, - 42, 37, 0, 0, 0, 0, 0, 0, 0, 0, - 584, 0, 118, 126, 124, 114, 139, 0, 155, 0, - 0, 0, 0, 272, 0, 0, 0, 0, 218, 343, - 350, 349, 344, 266, 0, 0, 0, 0, 0, 238, - 0, 0, 0, 0, 200, 0, 0, 0, 157, 381, - 160, 159, 0, 0, 0, 165, 166, 163, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 531, 0, 0, - 0, 0, 0, 492, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 494, 0, 573, 0, 38, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 202, 0, 0, 164, 0, 576, - 0, 524, 0, 0, 0, 0, 520, 0, 0, 530, - 0, 0, 0, 0, 0, 526, 589, 236, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 531, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 559, 0, 0, 0, 0, 0, 0, 521, 519, - 0, 0, 523, 0, 0, 0, 525, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 567, 0, 0, - 0, 0, 0, 0, 0, 532, 0, 0, 0, 0, - 0, 567, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 493, 0, 0, 570, 0, 518, 0, 522, - 0, 0, 591, 0, 0, 566, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 566, 0, 0, 0, 0, - 0, 0, 0, 585, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 569, 0, 0, 574, 484, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 556, 551, 0, 0, 551, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 552, 0, 0, 0, 99, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 500, 0, 0, 0, 549, - 555, 0, 0, 0, 528, 0, 0, 0, 0, 549, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 556, - 558, 560, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 528, 0, 0, 0, 0, 0, 0, 0, 568, - 0, 548, 0, 0, 0, 527, 0, 0, 0, 100, - 101, 263, 240, 241, 242, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 515, 0, 0, 0, 0, 0, 553, 0, 539, 541, - 0, 0, 0, 0, 0, 553, 0, 0, 0, 0, - 0, 0, 539, 0, 0, 0, 0, 0, 0, 544, - 0, 0, 0, 514, 0, 0, 0, 0, 0, 0, - 0, 543, 538, 0, 0, 0, 0, 0, 0, 554, - 0, 0, 0, 102, 0, 0, 0, 0, 0, 0, - 557, 0, 0, 0, 0, 0, 0, 511, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 529, 0, 0, - 0, 516, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 510, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 543, 0, 0, - 0, 0, 0, 507, 0, 0, 564, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 517, 0, 506, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 505, 0, 0, - 509, 0, 0, 0, 0, 565, 0, 547, 0, 0, - 0, 0, 504, 0, 0, 508, 0, 0, 0, 0, - 0, 534, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 550, 0, 536, 0, 546, 0, 0, 0, 0, - 0, 545, 0, 0, 0, 513, 0, 540, 0, 0, - 537, 512, 542, 501, 0, 535 -}; - -/* YYDEFGOTONTERM-NUM. */ -static const yytype_int16 yydefgoto = -{ - -1, 15, 16, 17, 18, 240, 378, 405, 293, 295, - 345, 254, 354, 316, 439, 298, 302, 307, 310, 320, - 342, 725, 434, 437, 661, 1070, 1020, 328, 432, 704, - 708, 2019, 1381, 1383, 1385, 1393, 1395, 1398, 639, 1051, - 1340, 1073, 760, 646, 1086, 1075, 709, 705, 590, 586, - 2020, 1366, 1360, 1361, 1056, 1345, 596, 767, 1362, 762, - 156, 982, 1176, 647, 591, 808, 809, 992, 1364, 587, - 1477, 798, 1347, 1365, 800, 159, 160, 161, 802, 803, - 804, 805, 61, 62, 19, 20, 21, 22, 23, 24, - 1001, 25, 26, 27, 28, 29, 30, 1397, 1391, 1392, - 597, 31, 32, 33, 34, 241, 256, 257, 258, 615, - 379, 380, 381, 382, 383, 384, 385, 386, 387, 388, - 389, 390, 675, 391, 392, 393, 394, 395, 396, 397, - 398, 399, 400, 259, 260, 261, 403, 343, 658, 262, - 2022, 2023, 2024, 356, 263, 264, 265, 266, 267, 268, - 728, 269, 358, 270, 271, 272, 273, 274, 275, 242, - 277, 278, 279, 732, 733, 734, 748, 35, 280, 281, - 243, 283, 244, 285, 286, 438, 752, 716, 598, 599, - 600, 305, 756, 287, 288, 749, 736, 737, 289, 290, - 1021, 1022, 291, 36, 37, 783, 38, 404, 743, 367, - 39 -}; - -/* YYPACTSTATE-NUM -- Index in YYTABLE of the portion describing - STATE-NUM. */ -#define YYPACT_NINF -1411 -static const yytype_int16 yypact = -{ - 133, -1411, -1411, 28, 380, 37, 68, 239, 216, 381, - 188, 20, 241, 102, 264, 312, 461, 2554, -1411, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 257, -1411, - 363, 326, 392, 342, 393, 414, 435, 443, 470, 462, - 503, 490, 515, 506, 108, 347, 549, 402, -1411, -1411, - -1411, -1411, 498, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, 894, 894, 894, 894, 894, 894, 894, 894, 894, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, 3312, -1411, - -1411, -1411, -1411, 211, 172, 591, 591, 615, 123, 635, - 635, 343, 343, 378, 348, 351, 426, 726, 726, 643, - 643, 645, 643, -1411, 656, 636, 667, 647, 652, 698, - 685, -1411, 684, 708, -1411, 711, 692, 699, 718, 721, - -1411, 702, 730, 707, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, 894, -1411, 894, 894, 894, - 894, 894, 894, 894, 894, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, 722, 732, 725, - -1411, -1411, 257, 257, 257, 543, 723, 738, 724, 270, - 731, 76, 727, 728, -1411, 257, -1411, -1411, -1411, -1411, - -1411, -1411, 257, -1411, 257, 257, 257, 257, 257, -1411, - 257, -1411, 257, 257, 257, 257, 257, -1411, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, -1411, -1411, - -1411, 257, 735, -1411, 257, -1411, 257, 741, -1411, 257, - 744, 737, -1411, 257, 257, 257, 750, -1411, 257, 257, - -1411, 257, 257, 733, 729, 746, -1411, 257, 257, 257, - -1411, 257, 257, 257, 562, 748, 298, 762, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, 257, -1411, 257, 257, 257, - 257, 743, -1411, 257, 257, -1411, 257, 257, 257, 257, - 752, 761, 765, 756, -1411, 257, 257, 257, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 767, 768, - 782, 440, 769, 779, 783, 774, 793, 795, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, 257, -1411, 257, 797, -1411, -1411, -1411, - 257, 778, -1411, 792, 799, -1411, -1411, 817, -1411, -1411, - -1411, -1411, 796, 803, -1411, 827, 811, 832, -1411, 819, - 770, 831, 597, 606, 493, 836, 835, 840, 775, 833, - 826, 777, 842, 837, 838, 839, 429, 158, 848, 848, - 848, 848, 848, 848, 848, 848, 848, 848, 571, 848, - 848, 848, 848, 924, 848, 248, 248, 848, 848, 848, - 849, 861, 847, 924, 866, 571, 802, 850, 284, 284, - 867, 805, 606, 606, 606, 606, 869, 809, 873, 3312, - 3312, 924, 924, 924, 924, 885, 898, 834, 896, 571, - 924, 248, 248, 888, 883, 352, 3312, 924, 571, 302, - 606, 915, 907, 917, 53, 924, 924, 924, 924, 903, - 186, 346, 386, 865, 924, 924, 3406, 919, 918, 926, - 862, 901, 864, 913, 150, 911, 910, 922, 920, 923, - 916, 924, -1411, 934, 921, 925, 937, -1411, 929, -1411, - 930, 927, 935, 939, 2649, 2649, -1411, -1411, 1885, 1885, - -1411, -1411, 931, 942, 938, 257, 257, 257, -1411, -1411, - -1411, 941, 943, 944, 950, 951, 961, 945, 953, 946, - 963, 969, 968, 948, 956, 257, 257, 257, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 257, 894, - 894, 894, 894, 894, 894, 894, 894, 894, 955, -1411, - -1411, -1411, 257, 257, 257, 257, -1411, -1411, 257, -1411, - 257, -1411, 257, 257, 257, -1411, 957, 257, 257, 965, - 960, 924, 257, 257, 967, -1411, -1411, 970, 952, 962, - 257, 257, 257, 257, 984, -1411, 976, 257, 257, 257, - 257, 979, 971, 980, 2744, 2744, 257, -1411, -1411, 257, - 985, 981, 974, 987, -1411, -1411, -1411, -1411, 257, -1411, - 257, 983, 257, 978, -1411, 257, -1411, 257, -1411, 257, - 3312, -1411, -1411, -1411, 988, -1411, 257, -1411, 993, 991, - 998, 989, 234, 1001, 1004, -1411, 257, 257, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 257, 257, - 257, 257, 1012, 257, 999, 1021, 1013, 257, 257, 257, - 257, 1027, 257, 257, 1019, 257, 257, 257, 894, 894, - -1411, -1411, 781, 42, -1411, -1411, -1411, -1411, -1411, 3312, - 1022, 1029, 1018, 1024, 1025, 1016, 1039, 1031, 1040, 1042, - 1047, 1046, 1036, 257, 257, 1026, -1411, -1411, 914, -1411, - -1411, 1038, 1050, 1035, 1049, 1003, -1411, 449, 3029, 2078, - 4252, -1411, -1411, -1411, -1411, -1411, 2269, -1411, 1048, -1411, - 1062, 1066, 1074, 1057, 1078, 606, 520, 502, 1064, 1071, - 1070, 1072, 1075, -1411, 1085, 1028, 1091, 1096, 1081, 1094, - 1083, 1097, 924, 189, 924, 924, 3312, 924, 3312, 3312, - 924, 924, 924, 924, 3312, 924, 1088, 924, 3312, 924, - 924, 606, 606, 606, 606, 924, 1082, 848, 606, 1041, - 1090, 257, -1411, 924, 1043, 1092, -1411, 1093, 3312, 606, - 3312, 606, 1051, 1095, 606, 606, 606, 606, 1087, 1108, - 1052, 3312, 3312, 924, 924, 1101, 1098, 1110, 1055, 606, - 606, 1100, 606, 1079, 924, 606, 924, 1102, 606, 1106, - -1411, 1060, 1112, 1124, 1105, 1114, 1115, 924, 924, 924, - 924, 924, 924, 924, 924, 924, 924, 924, 924, 3312, - 924, 3312, 924, 1116, 924, 1129, 1133, 1131, 924, 924, - 924, 924, 1137, 606, 606, 1145, 606, 606, 606, 798, - 818, 894, 1143, 1159, 1146, 1147, 1164, 1166, 1168, 1107, - 1167, 1174, 1160, 1173, 1175, 3312, 924, 1157, -1411, 1179, - 1161, 1177, 1162, 1169, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, 1153, 663, 4252, -1411, -1411, -1411, 3029, -1411, -1411, - -1411, -1411, 2839, 1176, -1411, 1163, 1120, 1172, 257, 1180, - 257, 257, 257, 257, 1122, 1189, 1194, 1181, 1199, 1187, - 1193, 1185, 1191, 1144, 1186, 1207, 1195, -1411, 1183, 1209, - 257, -1411, -1411, -1411, -1411, -1411, -1411, 2744, 3312, 257, - 257, 257, -1411, 2744, 257, -1411, -1411, 3312, 257, 257, - -1411, -1411, -1411, -1411, -1411, 1196, 257, -1411, 1202, 1151, - 924, 257, -1411, 1205, 1198, 1156, 257, 3500, 257, 257, - 257, 1206, 1200, -1411, -1411, -1411, -1411, 1158, 1208, 1214, - 257, 3594, 257, 257, -1411, -1411, -1411, 1165, 1224, 1211, - 1217, -1411, -1411, 1216, -1411, 1210, 257, -1411, 257, -1411, - 1230, -1411, 1182, 1233, 1236, 1237, 1247, 1234, 257, 257, - 257, 257, 257, 257, 257, 257, 257, 257, 257, 257, - 3688, 257, 3782, 257, 1248, 257, 1245, 1255, 1249, 257, - 257, 257, 257, 1258, 257, 257, 1257, 257, 257, 257, - 894, 894, 894, 1197, 1242, 1261, 1243, 1270, 1260, 1259, - 1263, 1264, 1262, 1215, 1218, 1269, 2744, -1411, 1266, 1279, - 1274, 1276, 1271, 1275, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, 1153, 663, -1411, 3029, - -1411, -1411, 165, 1277, 924, 1280, 606, 606, 606, 520, - 1281, 1297, 1285, 1278, -1411, 1300, 1286, -1411, 1284, 450, - -1411, -1411, -1411, 1288, 1287, 924, 3312, 924, 924, 924, - 3312, 924, 924, 924, 1291, 606, 1290, 1293, 257, 924, - 1296, 1295, 1298, 3312, 2174, 3312, 3312, 1307, 1302, 1308, - 1325, 1312, 3312, 3124, 597, 1316, 1315, 1333, 1319, 1317, - 1321, 924, 924, 1337, 1323, 1326, 1324, 1282, -1411, -1411, - 924, 924, 3312, 924, 176, 924, 571, 3312, 924, 865, - 3406, 3406, 3124, 3312, 3124, 3312, -1411, 597, 1327, 1329, - 1283, 924, 924, 924, 924, 1332, 597, 597, 1292, 597, - 606, 597, 894, 894, 1328, 1294, 1335, 1338, 1299, 1353, - 1309, 1341, 1345, 1310, 466, 1361, 1311, 924, 1347, -1411, - 1367, -1411, 1351, 1355, -1411, -1411, 1360, 1370, 1357, -1411, - 1377, -1411, 257, 257, 257, 257, 1358, 1366, 1362, 1365, - 1371, 481, -1411, 1364, 1376, 1380, 1387, -1411, 2744, 257, - -1411, 257, 2744, 257, -1411, -1411, 1372, 257, 1373, 924, - -1411, -1411, 1375, 1378, 3876, -1411, -1411, 2934, 257, 257, - 1379, 1381, 1374, -1411, 1385, 3970, 894, 894, 2744, 2744, - 1421, -1411, -1411, -1411, -1411, 3312, -1411, -1411, 1382, 1362, - 1371, 512, 1383, 1405, -1411, 257, -1411, 1386, 522, 1344, - 1399, -1411, -1411, 257, -1411, -1411, 3312, -1411, 1409, 1395, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, 3312, - 257, -1411, -1411, -1411, 1421, 4064, 1421, 4158, -1411, 1349, - -1411, 1414, 257, 257, 257, 257, 1404, -1411, -1411, 1398, - -1411, -1411, -1411, 1394, 1415, 1356, 1401, 1407, 1369, 1408, - 523, 1426, 1425, 1412, 1417, 1435, 257, 1424, 1437, 1418, - 1420, 1436, 1440, 1432, 1384, 606, 924, 606, 606, 1422, - 1447, -1411, 1427, -1411, 1428, 1430, 1433, 1443, 1434, 1454, - 3312, 3312, 3312, 3312, 924, 1444, 924, 1438, 257, 1439, - 1441, 2174, 1445, 1442, 1446, 1448, 3124, 2364, 3312, -1411, - 2459, 3124, 1450, 1451, 1453, 1455, 1463, 924, 1458, 1461, - 1449, 1469, 924, 1460, 1470, 924, 3124, 3218, 1452, 1471, - 924, 924, 865, 597, 1472, 1491, 1473, 1482, 405, 1475, - 1483, 115, 1480, 1476, 1493, 1486, 1499, 1507, 1496, 1523, - 924, 1512, -1411, 1508, 1509, 1532, 1510, 1511, 1533, -1411, - -1411, -1411, 257, 1516, 1474, 1521, 1515, 1522, 1456, 1543, - -1411, 1528, 257, 3312, 3312, 257, -1411, 1544, -1411, 1525, - 3312, 1527, 1534, -1411, 1530, 1536, 1535, 1526, 1421, -1411, - 3312, -1411, -1411, -1411, 1537, 1538, 1539, 1552, 1541, -1411, - 1540, 1542, 1545, 528, -1411, 1558, 1555, 257, 1421, 1395, - 1421, -1411, 1546, 1549, 257, -1411, -1411, -1411, 1550, 1551, - 1553, 1547, 1557, 1559, 1556, 1561, 1576, 1562, 1564, 1575, - 1563, 1566, 1581, 1565, 1584, 1571, 1567, 257, 1568, 1589, - 1569, 1580, 1577, 1593, 1578, 606, 1573, 246, 1596, 1548, - 1579, 1602, 1599, 1582, 1590, 1585, 257, 1586, 1603, 1587, - 1605, 1588, 1554, 1594, 1570, 1597, 1600, -1411, 1598, 1572, - 1591, 1604, 1606, -1411, 571, 1601, 1608, 924, 1611, 1609, - 1610, 1612, 1615, 1628, 1631, 1633, 1629, 1616, 1638, 1625, - 1583, 1621, 1632, 1630, 1648, 1634, 1653, 924, 1636, 1637, - 1639, -1411, 1640, -1411, 1595, -1411, 1641, 1635, 1644, 1651, - 1649, 190, 1652, 1654, 1607, 1657, 1642, 1655, 606, 1658, - 1650, 1659, 1656, 1646, 1674, 1660, 1675, 1662, 1661, 1663, - 214, 1666, 1664, 1665, -1411, 1669, 1668, -1411, 1673, -1411, - 1670, -1411, 1678, 1679, 1667, 1681, -1411, 1682, 1683, -1411, - 1680, 1676, 1672, 1677, 1643, -1411, -1411, -1411, 1647, 1688, - 1700, 1692, 1703, 1685, 1704, 1671, 1711, 1691, 112, 1697, - 1715, 1686, 1718, 1710, 1699, 1719, 257, 1720, 1701, 1722, - 1705, 1687, 1723, 1689, 1724, 1726, 1699, 1693, 1727, 1713, - 1708, 1694, 1714, 1709, 1716, 1721, 1695, 1725, -1411, -1411, - 1730, 1734, -1411, 1736, 1739, 1740, -1411, 1742, 1744, 1, - 1746, 1741, 1752, 614, 1753, 1755, 1756, 39, 1745, 1757, - 1750, 1758, 1771, 1759, 1770, -1411, 1761, 924, 1763, 46, - 1764, 1728, 1772, 1751, 1782, 1760, 1769, 619, 1762, 1767, - 1766, 269, -1411, 1768, 1775, -1411, 1790, -1411, 52, -1411, - 1773, 1777, -1411, 1778, 1795, -1411, 1798, 1774, 1800, 1783, - 1794, 148, 1788, 1791, 1747, 1748, 1805, 1797, 1785, 1792, - 1793, 1796, 1787, -1411, 1799, 257, 1801, 1815, 1802, 1816, - 1806, 1817, 1809, 1803, 1812, 1824, 1818, 1808, 1776, 1821, - 1810, 1807, 1779, 1814, 1830, 1780, 213, 1822, 1813, 1823, - -1411, 1825, 1781, -1411, -1411, 1840, 1826, 1828, 1784, 1845, - 1838, 1839, 1841, 1853, 1852, 1804, 74, 1832, 1842, -1411, - 865, 1835, 1846, 1811, 1836, 1859, 1837, 1862, 81, 1865, - 1843, 1864, 1804, 127, 1867, 1849, 1848, 1870, 1871, 1850, - 1860, 1873, 1881, 1918, 1876, 1872, 1919, 1917, 1923, 1924, - 1928, 1925, 1930, 1920, 1926, 1931, 1932, 1948, 1933, 1936, - -1411, 1940, 1935, 1934, 257, 1937, 1955, 1950, 1957, 1951, - 1962, 1952, 1949, 1958, 1964, 1960, 1941, 1956, 1953, 1969, - 1959, 1965, 1961, 1954, 1963, 1970, 1978, 445, 1966, 1979, - 1984, 1968, 1985, 1987, 1967, -1411, 1973, 1988, 1990, 1972, - 1922, 1996, 1997, 1974, 1938, 444, 1995, 1989, 1998, -1411, - 1999, 1972, 2003, 1991, 2004, 1939, 2007, 1992, 1993, -1411, - -1411, -1411, 2006, 2009, 2000, 2010, 1994, 1971, 2001, 2005, - 2015, -1411, 2014, 2002, 2013, 2017, 2008, 2012, 2016, -1411, - 2022, -1411, 2011, 2018, 2019, -1411, 2021, 2024, 2023, 257, - -1411, -1411, -1411, -1411, -1411, 2026, 2027, 2025, 2028, 2029, - 2030, 2040, 2031, 2032, 2041, 2042, 2043, 1982, 2251, 2050, - -1411, 178, 2346, 2020, 2033, 2441, -1411, 2038, 2537, 2495, - 2635, 2632, 2726, 2751, 2845, 2823, 2940, 2875, 3013, 597, - 3012, 3033, -1411, 2537, 2823, 3302, 3253, 3412, 3395, -1411, - 3490, 3441, 3587, -1411, 3577, 3675, 3677, 3770, 3863, 3723, - 3864, 3910, -1411, 3957, 4045, 4005, 4145, 4143, 4241, -1411, - 1626, 4256, 4237, -1411, 4304, 4301, 3910, 4305, 4306, 4322, - -1411, 275, 4309, 4310, 4307, 4325, 4311, -1411, 360, 4312, - 4313, 4331, 4314, 4333, 4315, 4339, 4336, -1411, 4337, 4329, - 4321, -1411, 4344, 4345, 4330, 4328, 4332, 4343, 4327, 4334, - 4335, -1411, 4338, 4340, 4324, 4351, 4341, 4289, 4342, 244, - 4348, 4346, 4349, 4350, 4347, 4352, 4354, -1411, 4353, 4356, - 4357, 4355, 4358, -1411, 4360, 4362, -1411, 4359, 4368, 4366, - 4364, 4371, 4375, 4376, 4372, 4363, 4383, 4382, 4370, 4373, - -1411, 4290, -1411, 4377, 4374, 4389, 4379, 4369, 4378, 4367, - 4381, 4380, 4385, 4390, 4384, 4386, 4387, -1411, 404, 4388, - -1411, 4391, 4393, 4394, 4395, -1411, 4396, -1411, 4403, 4397, - 4405, 4409, -1411, 4398, 4400, -1411, 4410, 4392, 4399, 4401, - 4402, 4293, 4404, 4406, 4407, 4408, 4414, 4411, 4416, 4417, - 4413, -1411, 4415, -1411, 4418, -1411, 4419, 4412, 4422, 4420, - 4421, -1411, 4425, 4423, 4424, -1411, 4427, -1411, 4428, 4430, - -1411, -1411, -1411, -1411, 4429, -1411 -}; - -/* YYPGOTONTERM-NUM. */ -static const yytype_int16 yypgoto = -{ - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - -1411, -1411, -1411, -1411, -1411, -848, -1411, -1411, -1411, -1411, - -1411, -1411, -812, -1410, -1411, 550, 408, -1411, -452, -1007, - -1295, 558, -1258, 624, -1153, -1126, -807, -788, -440, 3121, - 2365, 2957, -1186, 2983, -786, 2994, 3649, -611, -530, -13, - 286, -943, 3291, 9, -490, 3884, -1411, -1411, -1411, -1196, - 3117, -774, 67, 511, -776, 266, 77, -417, -760, -1411, - -1411, -17, 4426, -1411, -1411, -1411, -1411, -1411, -1411, -1411, - 3289, -1411, -1411, -1411, -1411, -1411, -1411, -355, 2982, -1411, - -377, -1411, -1411, -1411, -1411, 191, 4308, 4316, 4317, -370, - 4302, 4318, 4319, 4320, 4323, 4326, 4361, 4365, 4431, 4432, - 4433, 4434, -1411, 4435, 4436, 4437, 4438, 4439, 4440, 4441, - -141, -126, -124, 509, 526, -1411, 4442, -451, 3949, 4447, - -1411, -1411, -1411, -1411, 4449, -136, -1411, -1411, 4448, -64, - -1411, 4450, -1411, 4451, 4452, -125, -1411, 540, 349, -134, - 4453, -1411, 3939, -1411, -1411, -1411, -1411, -1411, 368, 4455, - 525, 327, -70, 373, -1411, -1411, 3932, -1411, -1411, -360, - 199, -1411, -1411, -1411, -143, -1411, -1411, -1411, 4454, 4456, - -1411, -1411, 4458, -1411, -1411, -1411, -1411, 4457, 41, -1411, - -1411 -}; - -/* YYTABLEYYPACTSTATE-NUM. What to do in state STATE-NUM. If - positive, shift that token. If negative, reduce the rule which - number is the opposite. If zero, do what YYDEFACT says. - If YYTABLE_NINF, syntax error. */ -#define YYTABLE_NINF -326 -static const yytype_int16 yytable = -{ - 162, 1401, 163, 164, 165, 166, 167, 168, 169, 170, - 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, - 181, 182, 983, 761, 595, 987, 157, 998, 1346, 1025, - 276, 1309, 987, 364, 1072, 317, 321, 425, 1367, 1177, - 989, 347, 360, 1218, 1468, 706, 318, 322, -325, 657, - 1825, 663, 426, 665, 427, 649, 651, 40, 215, 217, - 218, 219, 220, 221, 222, 223, 224, 44, 670, 672, - 1047, 53, 677, 678, 679, 680, 1404, 694, 1406, 721, - 1417, 1418, 1574, 1420, 1059, 1422, 712, 1335, 1835, 1375, - 1584, 697, 699, 1826, 284, 1825, 722, 45, 304, 715, - 717, 1865, 723, 339, 1084, 724, 473, 1088, 619, 620, - 621, 622, 623, 624, 625, 626, 627, 628, 784, 642, - 643, 644, 645, 1930, 648, 662, 474, 653, 654, 655, - 1930, 1836, 55, 641, 1, 650, 652, 2, 1847, -325, - -325, -325, 1788, 1597, 1866, 1412, 1413, 1414, 1415, 1128, - 666, 197, 300, 56, 1598, 1945, 1849, 198, 707, 3, - 1789, 4, 5, 6, 7, 301, 1931, 801, 801, 1546, - 8, 698, 700, 1941, 695, 9, 10, 1946, 1876, 777, - 11, 12, 13, 713, 14, 369, 205, 629, 630, 631, - 632, 633, 634, 635, 636, 637, 1877, 614, 245, 778, - 246, 247, 248, 249, 1333, 1388, 2075, 375, 1306, 861, - 377, 983, 744, 1307, 51, 250, 1018, 2076, 1179, 1738, - 1389, 251, 252, 989, 253, 462, 463, 464, 745, 746, - 742, -4, -4, 52, 1305, 1019, 1739, 1707, 477, 237, - 238, 1911, 1912, 1758, 1586, 478, 48, 479, 480, 481, - 482, 483, 1913, 484, 239, 485, 486, 487, 488, 489, - 1759, 490, 491, 492, 493, 494, 495, 496, 497, 498, - 499, 54, 1677, 903, 500, 1346, 1678, 502, 46, 503, - 588, 589, 505, 2161, 47, 904, 508, 509, 510, 1679, - 1558, 512, 513, 1530, 514, 515, 594, 1859, 1752, 2156, - 519, 520, 521, 2125, 522, 523, 524, 1367, 57, 470, - 1578, 1580, 58, 1548, 2126, 1860, 588, 589, 529, 1861, - 530, 531, 532, 533, 471, 706, 535, 536, 669, 537, - 538, 539, 540, 714, 588, 589, 616, 470, 544, 545, - 546, 547, 548, 549, 550, 551, 552, 553, 554, 555, - 556, 617, 527, 618, 155, 255, 184, 216, 216, 216, - 216, 216, 216, 216, 216, 216, 346, 355, 706, 313, - 433, 435, 186, 440, 314, 751, 1000, 1002, 248, 237, - 306, 801, 801, 988, 588, 589, 315, 341, 2132, 801, - 742, 199, 183, 1034, 239, 1036, 660, 200, 1311, 2133, - 1313, 735, 706, 983, 324, 706, 325, 300, 726, 326, - 730, 1040, 1041, 1042, 1043, 751, 568, 754, 569, 729, - 49, 327, 41, 571, 236, 42, 50, 1337, 43, 1058, - 742, 1060, 2203, 1592, 1063, 1064, 1065, 1066, 185, 1348, - 1349, 1387, 187, 2204, 1593, 202, 1400, 706, 1594, 1081, - 1082, 203, 350, 188, 237, 306, 351, 314, 1091, 964, - 965, 966, 967, 968, 969, 970, 971, 560, 612, 352, - 561, 613, 1115, 1998, 972, 353, 584, 585, 253, 189, - 727, 973, 974, 975, 1999, 976, 747, 1046, 2000, 2017, - 2018, 190, 1421, 1124, 1125, 303, 1127, 640, 1129, 1323, - 338, 458, 1324, 458, 458, 458, 458, 458, 458, 458, - 458, 192, 640, 977, 640, 1323, 299, 978, 1433, 979, - 191, 980, 335, 981, 592, 588, 589, 1454, 158, 193, - 1455, 687, 688, 592, 588, 589, 194, 593, 640, 319, - 323, 594, 309, 312, 361, 196, 669, 640, 349, 363, - 594, 999, 588, 589, 738, 739, 740, 741, 1483, 59, - 60, 1484, 764, 765, 766, 768, 988, 195, 1489, 1513, - 801, 1440, 1514, 987, 1641, 801, 201, 1440, 815, 816, - 817, 205, 629, 630, 631, 632, 633, 634, 635, 636, - 637, 750, 753, 757, 465, 466, 59, 638, 832, 833, - 834, 835, 836, 837, 838, 839, 840, 841, 842, 843, - 844, 845, 1542, 525, 466, 1545, 215, 217, 218, 219, - 220, 221, 222, 223, 224, 847, 848, 849, 850, 584, - 585, 851, 1934, 852, 292, 853, 854, 855, 588, 589, - 857, 858, 1830, 1831, 1845, 862, 863, 1854, 1855, 1402, - 1403, 799, 806, 868, 869, 870, 871, 1529, 297, 1531, - 874, 875, 876, 877, 306, 810, 810, 881, 882, 883, - 640, 237, 884, 964, 965, 966, 967, 968, 969, 970, - 971, 889, 441, 890, 436, 892, 401, 428, 894, 282, - 895, 442, 896, 443, 308, 311, 706, 444, 706, 898, - 348, 362, 445, 402, 429, 294, 296, 671, 673, 907, - 908, 909, 910, 911, 912, 913, 914, 915, 916, 917, - 918, 919, 920, 921, 922, 706, 924, 446, 447, 761, - 928, 929, 930, 931, 448, 933, 934, 449, 936, 937, - 938, 450, 451, 1626, 452, 939, 940, 1312, 453, 1314, - 454, 455, 368, 369, 370, 371, 456, 372, 457, 460, - 459, 467, 801, 373, 461, 468, 955, 956, 469, 374, - 472, 506, 475, 476, 501, 375, 376, 511, 377, 2021, - 504, 984, 507, 517, 516, 518, 526, 534, 941, 542, - 706, 205, 206, 207, 208, 209, 210, 211, 212, 213, - 214, 528, 1390, 541, 543, 1130, 474, 801, 205, 206, - 207, 208, 209, 210, 211, 212, 213, 214, 557, 558, - 559, 563, 564, 562, 565, 1131, 572, 1675, 205, 206, - 207, 208, 209, 210, 211, 212, 213, 214, 566, 763, - 567, 570, 573, 575, 1050, 581, 1026, 574, 576, 1029, - 1030, 1031, 1032, 577, 640, 578, 640, 579, 1038, 580, - 583, 602, 582, 2021, 1044, 601, 603, 604, 606, 607, - 605, 608, 1052, 758, 759, 205, 629, 630, 631, 632, - 633, 634, 635, 636, 637, 609, 610, 614, 656, 611, - 659, 660, 1074, 1076, 667, 664, 674, 676, 681, 668, - 1746, 682, 683, 1087, 205, 206, 207, 208, 209, 210, - 211, 212, 213, 214, 690, 216, 216, 216, 216, 216, - 216, 216, 216, 216, 691, 693, 692, 701, 1132, 1111, - 801, 1113, 703, 640, 205, 629, 630, 631, 632, 633, - 634, 635, 636, 637, 718, 719, 720, 742, 770, 771, - 236, 236, 772, 774, 773, 706, 775, 706, 776, 779, - 780, 781, 341, 782, 787, 785, 788, 790, 814, 958, - 984, 793, 761, 812, 794, 789, 236, 791, 795, 792, - 818, 1184, 819, 1186, 1187, 1188, 1189, 813, 820, 821, - 822, 823, 825, 827, 824, 828, 829, 846, 826, 830, - 831, 856, 866, 1205, 859, 860, 864, 867, 1532, 865, - 1206, 872, 1207, 1208, 1209, 873, 1210, 1211, 878, 880, - 879, 1212, 1213, 887, 885, 886, 888, 891, 893, 1215, - 684, 685, 899, 897, 1219, 236, 900, 901, 923, 1223, - 902, 1225, 1223, 1226, 216, 216, 905, 710, 458, 906, - 925, 926, 927, 1232, 801, 1232, 1234, 932, 935, 1052, - 943, 942, 944, 945, 946, 947, 948, 769, 950, 1241, - 949, 1242, 951, 952, 953, 954, 957, 959, 960, 961, - 991, 1250, 1251, 1252, 1253, 1254, 1255, 1256, 1257, 1258, - 1259, 1260, 1261, 962, 1263, 963, 1265, 993, 1267, 994, - 995, 996, 1271, 1272, 1273, 1274, 997, 1276, 1277, 1004, - 1279, 1280, 1281, 1005, 1006, 1009, 1007, 1282, 1283, 1008, - 1010, 1011, 1012, 1013, 1014, 706, 1015, 1085, 1016, 1297, - 1035, 1045, 1067, 1048, 1049, 1053, 1054, 1055, 1068, 1062, - 1079, 1094, 1078, 1061, 1069, 686, 1077, 1080, 689, 1083, - 1090, 1092, 1093, 1095, 696, 1096, 1097, 613, 1116, 1114, - 1118, 711, 984, 1154, 1155, 1156, 1157, 1158, 1159, 1160, - 1161, 1162, 1163, 1164, 1165, 1166, 1167, 1168, 1169, 1170, - 1171, 1172, 1173, 1174, 1175, 1117, 1123, 1126, 1133, 1134, - 1135, 1136, 1137, 1087, 1139, 786, 1138, 1141, 706, 1140, - 1142, 1339, 1143, 1144, 1145, 1148, 1149, 1151, 1153, 1150, - 1180, 1152, 1182, 1181, 1190, 1191, 1329, 1330, 1331, 1185, - 1052, 1334, 1076, 1183, 1192, 458, 458, 216, 1341, 1194, - 1193, 1195, 1196, 1197, 1198, 1200, 1199, 1201, 1203, 1204, - 1202, 1216, 1363, 1217, 1220, 1227, 1214, 1221, 1222, 1228, - 1229, 1087, 1230, 1231, 1236, 1237, 1238, 1235, 1243, 1382, - 1384, 1240, 1382, 640, 1394, 1396, 1239, 1382, 764, 768, - 768, 1363, 1245, 1363, 1244, 1246, 1247, 1248, 1266, 1249, - 1076, 1076, 1076, 1076, 1268, 1269, 1275, 1278, 1270, 1284, - 1285, 1286, 1287, 236, 236, 1445, 1446, 1447, 1448, 236, - 1288, 1290, 1291, 236, 1289, 1293, 1292, 1294, 1296, 1299, - 1295, 1460, 1461, 1300, 1462, 1463, 1464, 1298, 1301, 1303, - 1466, 1302, 1310, 236, 1317, 1308, 1316, 1318, 1319, 1320, - 1321, 1223, 1223, 1322, 1338, 1326, 1306, 236, 1325, 1336, - 1342, 1479, 1479, 939, 940, 1343, 1307, 710, 1341, 1027, - 1028, 1350, 1351, 1352, 1353, 1033, 1354, 1369, 1487, 1037, - 761, 1368, 1370, 1371, 1373, 1372, 1492, 1376, 1377, 1379, - 1378, 1410, 1409, 1423, 1380, 1411, 236, 1425, 236, 1057, - 1416, 1057, 1428, 1495, 1419, 1430, 1424, 1431, 1426, 1434, - 1437, 1427, 1071, 1071, 1438, 1500, 1501, 1502, 1503, 1439, - 1442, 1429, 1432, 1435, 1440, 1441, 1443, 1444, 1450, 1449, - 1458, 1451, 236, 1452, 1456, 1459, 216, 216, 458, 1520, - 1453, 1457, 1467, 1465, 1469, 1474, 1470, 1481, 1472, 1473, - 1110, 1475, 1112, 1482, 1485, 1486, 1490, 1488, 1491, 1493, - 1494, 1498, 1499, 1504, 1505, 1506, 1507, 1512, 1508, 1509, - 1510, 1550, 1515, 1516, 1521, 1087, 1017, 1517, 1023, 1024, - 1561, 1511, 1518, 1561, 1519, 1525, 1146, 1522, 1526, 1523, - 1524, 1527, 1533, 1341, 1039, 1087, 1528, 1534, 1535, 1536, - 1537, 1538, 1539, 1540, 1541, 1363, 1621, 1547, 1549, 1551, - 1363, 1575, 1552, 1555, 1572, 1554, 1556, 1582, 1567, 1557, - 1564, 1384, 1565, 1566, 1394, 1363, 1363, 1568, 1570, 1384, - 1074, 764, 1571, 1573, 1576, 1615, 1583, 1589, 1588, 763, - 1089, 1591, 1596, 1590, 1599, 1232, 1595, 1600, 1232, 1607, - 1602, 1098, 1099, 1100, 1101, 1102, 1103, 1104, 1105, 1106, - 1107, 1108, 1109, 1601, 1603, 763, 1604, 1605, 763, 1606, - 763, 1609, 1119, 1120, 1121, 1122, 1608, 1610, 1611, 1614, - 1644, 1612, 1616, 1613, 1618, 1619, 1617, 1647, 458, 458, - 1620, 1622, 1623, 1625, 1624, 1627, 1632, 1628, 1629, 1630, - 1147, 1631, 1636, 1633, 1642, 1643, 1638, 1635, 1634, 1651, - 1667, 1637, 1639, 1646, 236, 1654, 1640, 1645, 236, 1650, - 1648, 1649, 1652, 1653, 1655, 1656, 1659, 1657, 1658, 1688, - 236, 1662, 1664, 1660, 1661, 1665, 1663, 1666, 1668, 1669, - 1670, 236, 1671, 1673, 1676, 1672, 1680, 1674, 1683, 1684, - 1682, 236, 1685, 1690, 1686, 1692, 1687, 1689, 1691, 1693, - 1681, 1701, 216, 216, 1698, 1695, 1694, 1709, 1697, 1699, - 1708, 1705, 236, 1396, 1711, 1702, 1384, 1703, 1706, 1713, - 1714, 1710, 1696, 1715, 1700, 236, 1712, 1717, 1716, 1718, - 1719, 236, 1721, 236, 1723, 1720, 1727, 1722, 1724, 1726, - 2117, 1729, 1730, 1743, 1725, 1728, 1734, 1732, 1735, 1731, - 1736, 1733, 1744, 1737, 1748, 1740, 1751, 1741, 1745, 1742, - 1750, 1747, 1749, 1752, 1754, 1755, 1769, 1762, 1785, 1773, - 1753, 1756, 1760, 1757, 1761, 1763, 1764, 1328, 1765, 1774, - 1766, 1332, 1767, 1775, 1768, 1770, 1771, 1776, 1772, 1797, - 1780, 1781, 1782, 1784, 1344, 1777, 1057, 1057, 1779, 1778, - 1786, 1787, 1790, 1355, 236, 1791, 1793, 1794, 1795, 1796, - 1798, 1799, 1800, 1803, 1805, 1801, 1806, 1808, 1809, 1810, - 1813, 1814, 763, 1386, 1812, 1815, 1820, 763, 1399, 1821, - 1823, 769, 769, 1824, 1405, 1817, 1407, 1783, 1792, 1802, - 1818, 1804, 763, 763, 1819, 1807, 1811, 1816, 763, 1822, - 1827, 1829, 1832, 1828, 1833, 1834, 1838, 1837, 1839, 1841, - 1843, 1849, 1840, 1850, 1842, 1844, 1087, 1846, 1848, 236, - 236, 1851, 1852, 1853, 1856, 1857, 1858, 1863, 1862, 1864, - 1826, 1868, 1870, 1869, 1872, 1867, 236, 1871, 1890, 1327, - 1873, 1874, 1875, 1878, 1882, 1879, 1883, 1884, 1888, 1880, - 1881, 1887, 1885, 1886, 1892, 1895, 1894, 1896, 1897, 1889, - 1899, 1891, 1893, 1898, 1900, 1905, 1908, 1901, 1902, 1904, - 1909, 1914, 1906, 1915, 1917, 1374, 1919, 1921, 1903, 1478, - 1478, 1907, 1910, 1918, 1916, 1923, 1922, 1924, 1920, 1925, - 1926, 1927, 1928, 1932, 1930, 1935, 1933, 1938, 1937, 1939, - 1940, 1942, 1944, 1947, 1949, 1943, 1929, 1948, 1945, 764, - 1952, 1950, 1951, 1936, 1956, 80, 81, 82, 83, 84, - 85, 86, 87, 88, 89, 90, 91, 1975, 1953, 807, - 1954, 1436, 95, 96, 97, 98, 99, 100, 101, 102, - 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, - 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, - 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, - 133, 134, 1955, 1958, 1957, 1959, 1960, 1962, 1961, 1965, - 1966, 1071, 1543, 1544, 1071, 1964, 1967, 1963, 1969, 1973, - 1968, 1970, 1971, 1972, 1974, 1976, 1977, 1979, 1560, 1978, - 1980, 1560, 1981, 1983, 1985, 1982, 1987, 1984, 1986, 1990, - 1988, 1996, 2059, 1989, 1992, 1994, 1993, 1991, 1997, 2002, - 2003, 1995, 2004, 2005, 2012, 2009, 2001, 2006, 2007, 2008, - 2010, 2011, 2013, 2014, 2015, 2025, 2027, 2028, 2026, 2029, - 2016, 2032, 2031, 2033, 2036, 2030, 2037, 2035, 2034, 2040, - 2039, 2044, 2045, 2047, 2038, 1577, 2042, 2048, 2046, 2043, - 2052, 2078, 1704, 2058, 2060, 2062, 2049, 2053, 2063, 1585, - 2065, 710, 2050, 2041, 2056, 2055, 2054, 2051, 2057, 2061, - 2066, 2069, 2070, 2071, 2072, 2064, 2068, 2067, 2074, 2079, - 2081, 63, 225, 65, 66, 67, 68, 69, 226, 227, - 228, 229, 230, 231, 232, 233, 234, 235, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 985, 1569, 986, 93, 797, 95, 96, 97, 98, 99, - 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, - 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, - 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, - 150, 151, 152, 153, 154, 155, 763, 63, 225, 65, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 584, 585, 796, 93, - 797, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 155, 63, 225, 65, 66, 67, 68, 69, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 2073, 990, 986, 93, 797, 95, 96, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, - 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, - 149, 150, 151, 152, 153, 154, 155, 63, 225, 65, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 1559, 2077, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 155, 63, 225, 65, 66, 67, 68, 69, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 2080, 1562, 92, 93, 94, 95, 96, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, - 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, - 149, 150, 151, 152, 153, 154, 155, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 2082, 2083, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 155, 63, 225, 65, 66, 67, 68, 69, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 2084, 2085, 796, 93, 797, 95, 96, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, - 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, - 149, 150, 151, 152, 153, 154, 155, 63, 225, 65, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 2086, 2087, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 155, 63, 225, 65, 66, 67, 68, 69, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 2088, 2089, 1178, 93, 797, 95, 96, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, - 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, - 149, 150, 151, 152, 153, 154, 155, 63, 225, 65, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 2090, 2091, 986, 93, - 797, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 155, 63, 225, 65, 66, 67, 68, 69, 226, - 227, 228, 229, 230, 231, 232, 233, 234, 235, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 2092, 2094, 2095, 93, 797, 95, 96, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 121, 122, 123, 124, 125, 126, 127, 128, - 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, - 139, 140, 141, 142, 143, 144, 145, 146, 147, 148, - 149, 150, 151, 152, 153, 154, 155, 63, 225, 65, - 66, 67, 1356, 1357, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 1358, 1359, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 63, 225, 65, 66, 67, 1356, 1357, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 1358, 1359, 92, 93, 94, 95, 96, 97, 98, 99, - 100, 101, 1579, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, - 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, - 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, - 150, 151, 152, 153, 154, 63, 225, 65, 66, 67, - 68, 69, 226, 227, 228, 229, 230, 231, 232, 233, - 234, 235, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 2096, 2097, 92, 93, 94, 95, - 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, - 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, - 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, - 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, - 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, - 146, 147, 148, 149, 150, 151, 152, 153, 154, 63, - 225, 65, 66, 67, 68, 69, 70, 71, 72, 73, - 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, - 84, 85, 86, 87, 88, 89, 90, 91, 2098, 2099, - 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, - 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, - 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, - 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, - 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, - 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, - 152, 153, 154, 63, 225, 1224, 66, 67, 68, 69, - 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, - 90, 91, 2100, 2101, 92, 93, 94, 95, 96, 97, - 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, - 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, - 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, - 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, - 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, - 148, 149, 150, 151, 152, 153, 154, 63, 225, 1233, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 2102, 2103, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 63, 225, 1262, 66, 67, 68, 69, 226, 227, - 228, 229, 230, 231, 232, 233, 234, 235, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 2104, 2105, 92, 93, 94, 95, 96, 97, 98, 99, - 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, - 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, - 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, - 150, 151, 152, 153, 154, 63, 225, 1264, 66, 67, - 68, 69, 226, 227, 228, 229, 230, 231, 232, 233, - 234, 235, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 2106, 2108, 92, 93, 94, 95, - 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, - 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, - 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, - 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, - 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, - 146, 147, 148, 149, 150, 151, 152, 153, 154, 63, - 225, 1471, 66, 67, 68, 69, 226, 227, 228, 229, - 230, 231, 232, 233, 234, 235, 80, 81, 82, 83, - 84, 85, 86, 87, 88, 89, 90, 91, 2107, 2109, - 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, - 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, - 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, - 122, 123, 124, 125, 126, 127, 128, 129, 130, 131, - 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, - 142, 143, 144, 145, 146, 147, 148, 149, 150, 151, - 152, 153, 154, 63, 225, 1476, 66, 67, 68, 69, - 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, - 90, 91, 2110, 2111, 92, 93, 94, 95, 96, 97, - 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, - 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, - 118, 119, 120, 121, 122, 123, 124, 125, 126, 127, - 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, - 138, 139, 140, 141, 142, 143, 144, 145, 146, 147, - 148, 149, 150, 151, 152, 153, 154, 63, 225, 1496, - 66, 67, 68, 69, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 235, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 2112, 2113, 92, 93, - 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, - 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, - 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, - 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, - 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, - 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, - 154, 63, 225, 1497, 66, 67, 68, 69, 226, 227, - 228, 229, 230, 231, 232, 233, 234, 235, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 2114, 2115, 92, 93, 94, 95, 96, 97, 98, 99, - 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 121, 122, 123, 124, 125, 126, 127, 128, 129, - 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, - 140, 141, 142, 143, 144, 145, 146, 147, 148, 149, - 150, 151, 152, 153, 154, 63, 225, 65, 66, 67, - 68, 69, 226, 227, 228, 229, 230, 231, 232, 233, - 234, 235, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 2116, 2118, 2119, 93, 797, 95, - 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, - 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, - 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, - 126, 127, 128, 129, 130, 131, 132, 133, 134, 135, - 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, - 146, 147, 148, 149, 150, 151, 152, 153, 154, 2120, - 2121, 2122, 2124, 2127, 2123, 2128, 2130, 2136, 2129, 2135, - 2134, 2131, 2138, 2139, 2137, 2140, 2141, 2142, 2143, 2144, - 2145, 2146, 2147, 2148, 2150, 2151, 2149, 2157, 2152, 2156, - 2153, 2159, 2188, 2154, 2155, 2222, 2161, 2169, 1408, 2158, - 2160, 2162, 2164, 2174, 2176, 2177, 2163, 2167, 2182, 2165, - 2166, 2179, 2170, 2178, 2168, 2180, 2181, 2175, 2172, 2184, - 2171, 2173, 2185, 2183, 2186, 2191, 2195, 2193, 2187, 2190, - 2199, 2189, 2192, 2207, 2093, 2209, 2210, 2200, 2197, 2198, - 2194, 2196, 2211, 2208, 2206, 2213, 2201, 2202, 2205, 2214, - 2217, 2212, 2218, 2215, 2216, 2227, 2229, 2230, 2233, 2220, - 2221, 2219, 2236, 2232, 2223, 2225, 2224, 2235, 2245, 2226, - 1587, 2228, 2231, 2234, 1563, 1553, 1003, 1304, 2237, 2238, - 2239, 2240, 2244, 811, 2241, 2242, 1480, 2243, 1315, 1581, - 406, 329, 702, 731, 755, 0, 0, 0, 204, 330, - 331, 0, 0, 0, 0, 0, 407, 408, 409, 0, - 0, 410, 0, 0, 411, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 412, - 0, 0, 0, 413, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 414, - 415, 416, 417, 418, 419, 420, 421, 422, 423, 424, - 430, 344, 332, 333, 357, 334, 336, 359, 337, 0, - 365, 340, 366, 0, 0, 431 -}; - -static const yytype_int16 yycheck = -{ - 17, 1259, 19, 20, 21, 22, 23, 24, 25, 26, - 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, - 37, 38, 798, 553, 464, 799, 17, 815, 1224, 836, - 164, 1184, 806, 176, 882, 171, 172, 178, 1234, 982, - 800, 175, 176, 1050, 1339, 535, 171, 172, 6, 500, - 49, 503, 178, 505, 178, 495, 496, 29, 71, 72, - 73, 74, 75, 76, 77, 78, 79, 30, 508, 509, - 858, 51, 512, 513, 514, 515, 1262, 529, 1264, 26, - 1276, 1277, 1492, 1279, 870, 1281, 538, 1213, 49, 1242, - 1500, 531, 532, 92, 164, 49, 43, 29, 168, 539, - 540, 49, 49, 173, 892, 52, 30, 895, 478, 479, - 480, 481, 482, 483, 484, 485, 486, 487, 569, 489, - 490, 491, 492, 49, 494, 502, 50, 497, 498, 499, - 49, 92, 30, 488, 1, 495, 496, 4, 92, 97, - 98, 99, 30, 28, 92, 1271, 1272, 1273, 1274, 937, - 505, 43, 29, 51, 39, 28, 29, 49, 535, 26, - 48, 28, 29, 30, 31, 42, 92, 584, 585, 1464, - 37, 531, 532, 92, 529, 42, 43, 50, 30, 29, - 47, 48, 49, 538, 51, 27, 10, 11, 12, 13, - 14, 15, 16, 17, 18, 19, 48, 39, 26, 49, - 28, 29, 30, 31, 1211, 29, 28, 49, 43, 661, - 52, 987, 26, 48, 26, 43, 27, 39, 992, 29, - 44, 49, 50, 983, 52, 242, 243, 244, 42, 43, - 44, 98, 99, 45, 1177, 46, 46, 1647, 255, 28, - 29, 28, 29, 29, 1502, 262, 30, 264, 265, 266, - 267, 268, 39, 270, 43, 272, 273, 274, 275, 276, - 46, 278, 279, 280, 281, 282, 283, 284, 285, 286, - 287, 30, 26, 39, 291, 1471, 30, 294, 39, 296, - 32, 33, 299, 39, 45, 51, 303, 304, 305, 43, - 1476, 308, 309, 1446, 311, 312, 48, 28, 29, 55, - 317, 318, 319, 28, 321, 322, 323, 1503, 44, 39, - 1496, 1497, 0, 1466, 39, 46, 32, 33, 335, 50, - 337, 338, 339, 340, 54, 815, 343, 344, 44, 346, - 347, 348, 349, 31, 32, 33, 477, 39, 355, 356, - 357, 358, 359, 360, 361, 362, 363, 364, 365, 366, - 367, 477, 54, 477, 97, 164, 30, 71, 72, 73, - 74, 75, 76, 77, 78, 79, 175, 176, 858, 26, - 179, 180, 30, 182, 31, 29, 816, 817, 30, 28, - 29, 798, 799, 800, 32, 33, 43, 39, 28, 806, - 44, 44, 29, 845, 43, 847, 44, 50, 1186, 39, - 1188, 544, 892, 1179, 26, 895, 28, 29, 544, 31, - 544, 851, 852, 853, 854, 29, 433, 31, 435, 544, - 39, 43, 42, 440, 158, 45, 45, 1215, 48, 869, - 44, 871, 28, 28, 874, 875, 876, 877, 46, 1225, - 1226, 1253, 49, 39, 39, 43, 1258, 937, 43, 889, - 890, 49, 26, 39, 28, 29, 30, 31, 898, 10, - 11, 12, 13, 14, 15, 16, 17, 27, 39, 43, - 30, 42, 924, 28, 25, 49, 32, 33, 52, 44, - 544, 32, 33, 34, 39, 36, 550, 857, 43, 45, - 46, 48, 1280, 933, 934, 168, 936, 488, 938, 49, - 173, 215, 52, 217, 218, 219, 220, 221, 222, 223, - 224, 49, 503, 64, 505, 49, 167, 68, 52, 70, - 50, 72, 173, 74, 31, 32, 33, 46, 17, 26, - 49, 522, 523, 31, 32, 33, 46, 44, 529, 171, - 172, 48, 169, 170, 176, 39, 44, 538, 175, 176, - 48, 31, 32, 33, 545, 546, 547, 548, 46, 98, - 99, 49, 553, 554, 555, 556, 983, 52, 46, 46, - 987, 49, 49, 1347, 46, 992, 27, 49, 595, 596, - 597, 10, 11, 12, 13, 14, 15, 16, 17, 18, - 19, 550, 551, 552, 51, 52, 98, 26, 615, 616, - 617, 618, 619, 620, 621, 622, 623, 624, 625, 626, - 627, 628, 1460, 51, 52, 1463, 629, 630, 631, 632, - 633, 634, 635, 636, 637, 642, 643, 644, 645, 32, - 33, 648, 1890, 650, 43, 652, 653, 654, 32, 33, - 657, 658, 28, 29, 1797, 662, 663, 28, 29, 1260, - 1261, 584, 585, 670, 671, 672, 673, 1445, 43, 1447, - 677, 678, 679, 680, 29, 588, 589, 684, 685, 686, - 661, 28, 689, 10, 11, 12, 13, 14, 15, 16, - 17, 698, 26, 700, 39, 702, 177, 178, 705, 164, - 707, 55, 709, 26, 169, 170, 1186, 50, 1188, 716, - 175, 176, 50, 177, 178, 165, 166, 508, 509, 726, - 727, 728, 729, 730, 731, 732, 733, 734, 735, 736, - 737, 738, 739, 740, 741, 1215, 743, 29, 43, 1259, - 747, 748, 749, 750, 50, 752, 753, 29, 755, 756, - 757, 30, 50, 1550, 45, 758, 759, 1187, 30, 1189, - 29, 49, 26, 27, 28, 29, 26, 31, 51, 27, - 38, 38, 1179, 37, 39, 27, 783, 784, 44, 43, - 39, 27, 45, 45, 39, 49, 50, 27, 52, 1975, - 39, 798, 45, 54, 51, 39, 38, 44, 7, 28, - 1280, 10, 11, 12, 13, 14, 15, 16, 17, 18, - 19, 39, 1254, 51, 39, 7, 50, 1224, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 51, 51, - 38, 42, 39, 54, 50, 7, 48, 1615, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 45, 553, - 45, 44, 50, 26, 861, 26, 837, 48, 52, 840, - 841, 842, 843, 50, 845, 28, 847, 46, 849, 27, - 29, 26, 92, 2059, 855, 29, 26, 92, 42, 92, - 37, 29, 863, 8, 9, 10, 11, 12, 13, 14, - 15, 16, 17, 18, 19, 48, 48, 39, 39, 50, - 29, 44, 883, 884, 92, 29, 29, 92, 29, 49, - 1688, 92, 29, 894, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 29, 629, 630, 631, 632, 633, - 634, 635, 636, 637, 26, 29, 92, 39, 941, 920, - 1347, 922, 49, 924, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 29, 38, 29, 44, 29, 31, - 684, 685, 26, 52, 92, 1445, 92, 1447, 45, 48, - 50, 39, 39, 43, 30, 49, 45, 30, 30, 55, - 987, 44, 1502, 42, 39, 50, 710, 48, 39, 49, - 39, 998, 39, 1000, 1001, 1002, 1003, 45, 44, 39, - 39, 30, 39, 30, 49, 26, 28, 42, 52, 51, - 44, 44, 50, 1020, 39, 45, 39, 45, 1448, 39, - 1027, 27, 1029, 1030, 1031, 39, 1033, 1034, 39, 39, - 49, 1038, 1039, 49, 39, 44, 39, 44, 50, 1046, - 519, 520, 39, 45, 1051, 769, 45, 39, 26, 1056, - 51, 1058, 1059, 1060, 758, 759, 45, 536, 762, 45, - 51, 30, 39, 1070, 1471, 1072, 1073, 30, 39, 1050, - 31, 39, 44, 39, 39, 49, 27, 556, 28, 1086, - 39, 1088, 30, 26, 28, 39, 50, 39, 28, 44, - 32, 1098, 1099, 1100, 1101, 1102, 1103, 1104, 1105, 1106, - 1107, 1108, 1109, 44, 1111, 92, 1113, 35, 1115, 33, - 26, 44, 1119, 1120, 1121, 1122, 28, 1124, 1125, 45, - 1127, 1128, 1129, 42, 44, 30, 44, 1130, 1131, 44, - 92, 30, 26, 42, 30, 1615, 43, 48, 31, 1146, - 42, 49, 45, 92, 44, 92, 44, 44, 30, 44, - 30, 29, 44, 92, 92, 521, 45, 92, 524, 49, - 48, 45, 92, 29, 530, 50, 42, 42, 29, 43, - 29, 537, 1179, 10, 11, 12, 13, 14, 15, 16, - 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, - 27, 28, 29, 30, 31, 52, 49, 42, 45, 30, - 44, 44, 28, 1184, 26, 571, 30, 30, 1688, 92, - 26, 1218, 42, 30, 29, 48, 27, 30, 39, 48, - 34, 49, 92, 50, 92, 26, 1207, 1208, 1209, 39, - 1211, 1212, 1213, 51, 30, 939, 940, 941, 1219, 30, - 49, 44, 39, 48, 43, 49, 92, 30, 55, 30, - 45, 39, 1233, 92, 39, 39, 50, 49, 92, 49, - 92, 1242, 44, 39, 30, 44, 39, 92, 28, 1250, - 1251, 51, 1253, 1254, 1255, 1256, 50, 1258, 1259, 1260, - 1261, 1262, 39, 1264, 92, 39, 39, 30, 30, 45, - 1271, 1272, 1273, 1274, 39, 30, 28, 30, 39, 92, - 48, 30, 49, 1027, 1028, 1312, 1313, 1314, 1315, 1033, - 30, 42, 39, 1037, 44, 43, 42, 92, 39, 30, - 92, 1328, 1329, 39, 1331, 1332, 1333, 51, 42, 44, - 1337, 50, 42, 1057, 27, 48, 45, 42, 50, 29, - 44, 1348, 1349, 49, 44, 48, 43, 1071, 50, 48, - 44, 1358, 1359, 1356, 1357, 50, 48, 836, 1339, 838, - 839, 44, 50, 45, 29, 844, 44, 42, 1375, 848, - 1890, 45, 29, 44, 43, 48, 1383, 30, 45, 45, - 44, 42, 45, 45, 92, 92, 1110, 42, 1112, 868, - 48, 870, 29, 1400, 92, 44, 92, 42, 50, 28, - 43, 92, 881, 882, 27, 1412, 1413, 1414, 1415, 48, - 30, 92, 92, 92, 49, 45, 49, 30, 42, 51, - 30, 49, 1146, 48, 50, 28, 1130, 1131, 1132, 1436, - 49, 45, 49, 51, 49, 51, 48, 6, 49, 48, - 919, 46, 921, 51, 51, 30, 92, 51, 39, 30, - 45, 92, 28, 39, 46, 51, 31, 39, 92, 48, - 43, 1468, 26, 28, 30, 1446, 832, 45, 834, 835, - 1477, 92, 45, 1480, 29, 29, 955, 30, 28, 51, - 50, 39, 50, 1464, 850, 1466, 92, 30, 51, 51, - 50, 48, 39, 49, 30, 1476, 30, 43, 50, 50, - 1481, 31, 51, 51, 45, 50, 50, 45, 43, 51, - 50, 1492, 51, 50, 1495, 1496, 1497, 44, 50, 1500, - 1501, 1502, 51, 44, 44, 1532, 45, 26, 46, 1233, - 896, 39, 39, 50, 44, 1542, 51, 51, 1545, 1520, - 44, 907, 908, 909, 910, 911, 912, 913, 914, 915, - 916, 917, 918, 50, 45, 1259, 39, 51, 1262, 26, - 1264, 43, 928, 929, 930, 931, 44, 48, 26, 26, - 1577, 51, 46, 52, 43, 50, 92, 1584, 1282, 1283, - 48, 28, 44, 48, 30, 48, 50, 43, 48, 43, - 956, 46, 30, 46, 26, 30, 46, 48, 50, 42, - 1607, 50, 50, 44, 1328, 39, 51, 51, 1332, 46, - 50, 50, 45, 44, 43, 29, 31, 45, 44, 1626, - 1344, 30, 28, 50, 48, 44, 51, 50, 50, 30, - 51, 1355, 42, 30, 51, 48, 30, 49, 26, 30, - 51, 1365, 50, 30, 44, 30, 51, 51, 51, 51, - 92, 50, 1356, 1357, 44, 51, 92, 38, 51, 51, - 39, 50, 1386, 1644, 42, 51, 1647, 51, 50, 31, - 29, 51, 92, 30, 92, 1399, 51, 51, 39, 31, - 45, 1405, 51, 1407, 44, 92, 1667, 45, 30, 26, - 54, 44, 43, 26, 50, 49, 51, 92, 44, 49, - 39, 50, 50, 44, 44, 43, 50, 43, 43, 92, - 44, 43, 43, 29, 29, 43, 39, 42, 37, 29, - 50, 50, 46, 50, 50, 46, 48, 1206, 45, 43, - 50, 1210, 44, 51, 45, 44, 44, 50, 45, 1746, - 30, 39, 29, 29, 1223, 92, 1225, 1226, 50, 92, - 29, 50, 45, 1232, 1478, 30, 28, 37, 49, 30, - 30, 50, 30, 30, 30, 50, 30, 30, 45, 51, - 51, 45, 1476, 1252, 50, 44, 30, 1481, 1257, 30, - 28, 1260, 1261, 29, 1263, 50, 1265, 92, 92, 92, - 50, 92, 1496, 1497, 50, 92, 92, 92, 1502, 49, - 44, 39, 39, 52, 39, 39, 39, 52, 48, 28, - 30, 29, 44, 52, 45, 44, 1797, 44, 44, 1543, - 1544, 29, 52, 44, 52, 48, 50, 42, 50, 29, - 92, 44, 27, 45, 50, 52, 1560, 29, 1845, 1205, - 30, 48, 38, 45, 29, 44, 39, 52, 51, 92, - 92, 45, 50, 50, 29, 39, 30, 30, 39, 50, - 38, 50, 50, 50, 30, 45, 42, 39, 50, 38, - 30, 39, 55, 50, 39, 1241, 26, 39, 92, 1358, - 1359, 92, 92, 92, 51, 30, 92, 39, 52, 40, - 39, 28, 30, 51, 49, 39, 44, 28, 52, 52, - 28, 26, 28, 26, 46, 52, 92, 48, 28, 1890, - 40, 30, 52, 92, 28, 20, 21, 22, 23, 24, - 25, 26, 27, 28, 29, 30, 31, 1934, 45, 34, - 39, 1297, 37, 38, 39, 40, 41, 42, 43, 44, - 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, - 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, - 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, - 75, 76, 44, 44, 92, 48, 43, 39, 44, 49, - 44, 1460, 1461, 1462, 1463, 45, 45, 52, 30, 44, - 48, 48, 46, 43, 50, 48, 31, 30, 1477, 39, - 39, 1480, 30, 44, 30, 43, 55, 39, 38, 30, - 44, 31, 2019, 50, 39, 51, 45, 48, 30, 30, - 26, 48, 44, 28, 92, 27, 50, 30, 51, 46, - 30, 49, 26, 26, 50, 30, 28, 28, 39, 26, - 92, 92, 28, 26, 28, 44, 27, 44, 46, 45, - 30, 26, 28, 30, 44, 1495, 45, 30, 46, 44, - 28, 31, 1644, 30, 28, 30, 48, 46, 30, 1501, - 30, 1550, 50, 92, 43, 46, 48, 51, 44, 42, - 30, 30, 30, 30, 92, 46, 44, 46, 28, 46, - 42, 3, 4, 5, 6, 7, 8, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 32, 1487, 34, 35, 36, 37, 38, 39, 40, 41, - 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 92, 93, 94, 95, 96, 97, 1890, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 97, 3, 4, 5, 6, 7, 8, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 50, 33, 34, 35, 36, 37, 38, 39, 40, - 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 32, 51, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 97, 3, 4, 5, 6, 7, 8, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 50, 33, 34, 35, 36, 37, 38, 39, 40, - 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 49, 92, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 97, 3, 4, 5, 6, 7, 8, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 46, 50, 34, 35, 36, 37, 38, 39, 40, - 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 50, 26, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 97, 3, 4, 5, 6, 7, 8, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 26, 49, 34, 35, 36, 37, 38, 39, 40, - 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 26, 92, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 97, 3, 4, 5, 6, 7, 8, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 48, 50, 30, 35, 36, 37, 38, 39, 40, - 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, - 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, - 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 3, 4, 5, 6, 7, 8, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, - 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 92, 93, 94, 95, 96, 3, 4, 5, 6, 7, - 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, - 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, - 28, 29, 30, 31, 42, 92, 34, 35, 36, 37, - 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, - 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, - 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, - 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 92, 93, 94, 95, 96, 3, - 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, - 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, - 24, 25, 26, 27, 28, 29, 30, 31, 26, 44, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, - 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, - 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, - 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, - 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, - 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, - 94, 95, 96, 3, 4, 5, 6, 7, 8, 9, - 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, - 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 42, 92, 34, 35, 36, 37, 38, 39, - 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, - 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, - 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, - 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, - 90, 91, 92, 93, 94, 95, 96, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 39, 50, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 3, 4, 5, 6, 7, 8, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 45, 44, 34, 35, 36, 37, 38, 39, 40, 41, - 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 92, 93, 94, 95, 96, 3, 4, 5, 6, 7, - 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, - 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, - 28, 29, 30, 31, 44, 92, 34, 35, 36, 37, - 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, - 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, - 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, - 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 92, 93, 94, 95, 96, 3, - 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, - 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, - 24, 25, 26, 27, 28, 29, 30, 31, 45, 45, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, - 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, - 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, - 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, - 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, - 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, - 94, 95, 96, 3, 4, 5, 6, 7, 8, 9, - 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, - 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 92, 46, 34, 35, 36, 37, 38, 39, - 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, - 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, - 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, - 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, - 90, 91, 92, 93, 94, 95, 96, 3, 4, 5, - 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 51, 92, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, - 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, - 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, - 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, - 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, - 96, 3, 4, 5, 6, 7, 8, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 45, 48, 34, 35, 36, 37, 38, 39, 40, 41, - 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 92, 93, 94, 95, 96, 3, 4, 5, 6, 7, - 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, - 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, - 28, 29, 30, 31, 43, 29, 49, 35, 36, 37, - 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, - 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, - 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, - 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, - 88, 89, 90, 91, 92, 93, 94, 95, 96, 45, - 49, 46, 30, 44, 48, 45, 31, 26, 51, 46, - 48, 50, 29, 48, 50, 26, 30, 30, 39, 48, - 26, 26, 42, 45, 31, 48, 44, 26, 44, 55, - 45, 92, 92, 45, 44, 92, 39, 31, 1267, 48, - 48, 43, 43, 31, 26, 29, 50, 43, 26, 49, - 48, 30, 45, 39, 51, 30, 30, 48, 50, 26, - 55, 51, 30, 50, 44, 26, 49, 48, 45, 45, - 30, 44, 43, 30, 2059, 30, 30, 43, 48, 44, - 52, 50, 29, 39, 43, 30, 50, 50, 50, 30, - 30, 44, 50, 45, 44, 31, 30, 30, 30, 48, - 48, 52, 30, 38, 50, 48, 50, 45, 29, 51, - 1503, 50, 49, 44, 1481, 1471, 817, 1176, 48, 48, - 45, 48, 42, 589, 50, 48, 1359, 49, 1189, 1497, - 178, 173, 533, 544, 552, -1, -1, -1, 62, 173, - 173, -1, -1, -1, -1, -1, 178, 178, 178, -1, - -1, 178, -1, -1, 178, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 178, - -1, -1, -1, 178, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 178, - 178, 178, 178, 178, 178, 178, 178, 178, 178, 178, - 178, 174, 173, 173, 176, 173, 173, 176, 173, -1, - 176, 173, 176, -1, -1, 178 -}; - -/* YYSTOSSTATE-NUM -- The (internal number of the) accessing - symbol of state STATE-NUM. */ -static const yytype_uint16 yystos = -{ - 0, 1, 4, 26, 28, 29, 30, 31, 37, 42, - 43, 47, 48, 49, 51, 101, 102, 103, 104, 184, - 185, 186, 187, 188, 189, 191, 192, 193, 194, 195, - 196, 201, 202, 203, 204, 267, 293, 294, 296, 300, - 29, 42, 45, 48, 30, 29, 39, 45, 30, 39, - 45, 26, 45, 51, 30, 30, 51, 44, 0, 98, - 99, 182, 183, 3, 4, 5, 6, 7, 8, 9, - 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, - 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 34, 35, 36, 37, 38, 39, 40, 41, - 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, - 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, - 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, - 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, - 92, 93, 94, 95, 96, 97, 160, 163, 173, 175, - 176, 177, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 29, 30, 46, 30, 49, 39, 44, - 48, 50, 49, 26, 46, 52, 39, 43, 49, 44, - 50, 27, 43, 49, 182, 10, 11, 12, 13, 14, - 15, 16, 17, 18, 19, 159, 160, 159, 159, 159, - 159, 159, 159, 159, 159, 4, 10, 11, 12, 13, - 14, 15, 16, 17, 18, 19, 175, 28, 29, 43, - 105, 205, 259, 270, 272, 26, 28, 29, 30, 31, - 43, 49, 50, 52, 111, 205, 206, 207, 208, 233, - 234, 235, 239, 244, 245, 246, 247, 248, 249, 251, - 253, 254, 255, 256, 257, 258, 259, 260, 261, 262, - 268, 269, 270, 271, 272, 273, 274, 283, 284, 288, - 289, 292, 43, 108, 257, 109, 257, 43, 115, 258, - 29, 42, 116, 271, 272, 281, 29, 117, 270, 273, - 118, 270, 273, 26, 31, 43, 113, 245, 255, 268, - 119, 245, 255, 268, 26, 28, 31, 43, 127, 206, - 207, 208, 244, 251, 254, 258, 260, 269, 271, 272, - 292, 39, 120, 237, 239, 110, 205, 259, 270, 273, - 26, 30, 43, 49, 112, 205, 243, 248, 252, 253, - 259, 268, 270, 273, 284, 288, 289, 299, 26, 27, - 28, 29, 31, 37, 43, 49, 50, 52, 106, 210, - 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, - 221, 223, 224, 225, 226, 227, 228, 229, 230, 231, - 232, 233, 234, 236, 297, 107, 210, 211, 212, 213, - 214, 215, 216, 217, 218, 219, 220, 221, 223, 224, - 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, - 236, 297, 128, 205, 122, 205, 39, 123, 275, 114, - 205, 26, 55, 26, 50, 50, 29, 43, 50, 29, - 30, 50, 45, 30, 29, 49, 26, 51, 160, 38, - 27, 39, 181, 181, 181, 51, 52, 38, 27, 44, - 39, 54, 39, 30, 50, 45, 45, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 39, 181, 181, 39, 181, 27, 45, 181, 181, - 181, 27, 181, 181, 181, 181, 51, 54, 39, 181, - 181, 181, 181, 181, 181, 51, 38, 54, 39, 181, - 181, 181, 181, 181, 44, 181, 181, 181, 181, 181, - 181, 51, 28, 39, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 181, 51, 51, 38, - 27, 30, 54, 42, 39, 50, 45, 45, 181, 181, - 44, 181, 48, 50, 48, 26, 52, 50, 28, 46, - 27, 26, 92, 29, 32, 33, 149, 169, 32, 33, - 148, 164, 31, 44, 48, 148, 156, 200, 278, 279, - 280, 29, 26, 26, 92, 37, 42, 92, 29, 48, - 48, 50, 39, 42, 39, 209, 230, 231, 232, 209, - 209, 209, 209, 209, 209, 209, 209, 209, 209, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 26, 138, - 163, 197, 209, 209, 209, 209, 143, 163, 209, 148, - 279, 148, 279, 209, 209, 209, 39, 237, 238, 29, - 44, 124, 200, 138, 29, 138, 197, 92, 49, 44, - 148, 280, 148, 280, 29, 222, 92, 148, 148, 148, - 148, 29, 92, 29, 173, 173, 143, 163, 163, 143, - 29, 26, 92, 29, 138, 197, 143, 148, 279, 148, - 279, 39, 238, 49, 129, 147, 164, 200, 130, 146, - 173, 143, 138, 197, 31, 148, 277, 148, 29, 38, - 29, 26, 43, 49, 52, 121, 245, 249, 250, 255, - 259, 262, 263, 264, 265, 284, 286, 287, 163, 163, - 163, 163, 44, 298, 26, 42, 43, 249, 266, 285, - 298, 29, 276, 298, 31, 276, 282, 298, 8, 9, - 142, 158, 159, 160, 163, 163, 163, 157, 163, 173, - 29, 31, 26, 92, 52, 92, 45, 29, 49, 48, - 50, 39, 43, 295, 237, 49, 143, 30, 45, 50, - 30, 48, 49, 44, 39, 39, 34, 36, 171, 172, - 174, 177, 178, 179, 180, 181, 172, 34, 165, 166, - 176, 165, 42, 45, 30, 181, 181, 181, 39, 39, - 44, 39, 39, 30, 49, 39, 52, 30, 26, 28, - 51, 44, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 42, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 44, 181, 181, 39, - 45, 138, 181, 181, 39, 39, 50, 45, 181, 181, - 181, 181, 27, 39, 181, 181, 181, 181, 39, 49, - 39, 181, 181, 181, 181, 39, 44, 49, 39, 181, - 181, 44, 181, 50, 181, 181, 181, 45, 181, 39, - 45, 39, 51, 39, 51, 45, 45, 181, 181, 181, - 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 181, 26, 181, 51, 30, 39, 181, 181, - 181, 181, 30, 181, 181, 39, 181, 181, 181, 159, - 159, 7, 39, 31, 44, 39, 39, 49, 27, 39, - 28, 30, 26, 28, 39, 181, 181, 50, 55, 39, - 28, 44, 44, 92, 10, 11, 12, 13, 14, 15, - 16, 17, 25, 32, 33, 34, 36, 64, 68, 70, - 72, 74, 161, 174, 181, 32, 34, 171, 177, 178, - 33, 32, 167, 35, 33, 26, 44, 28, 147, 31, - 148, 190, 148, 156, 45, 42, 44, 44, 44, 30, - 92, 30, 26, 42, 30, 43, 31, 143, 27, 46, - 126, 290, 291, 143, 143, 146, 163, 173, 173, 163, - 163, 163, 163, 173, 138, 42, 138, 173, 163, 143, - 148, 148, 148, 148, 163, 49, 209, 147, 92, 44, - 181, 139, 163, 92, 44, 44, 154, 173, 148, 154, - 148, 92, 44, 148, 148, 148, 148, 45, 30, 92, - 125, 173, 125, 141, 163, 145, 163, 45, 44, 30, - 92, 148, 148, 49, 147, 48, 144, 163, 147, 143, - 48, 148, 45, 92, 29, 29, 50, 42, 143, 143, - 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, - 173, 163, 173, 163, 43, 138, 29, 52, 29, 143, - 143, 143, 143, 49, 148, 148, 42, 148, 147, 148, - 7, 7, 159, 45, 30, 44, 44, 28, 30, 26, - 92, 30, 26, 42, 30, 29, 173, 143, 48, 27, - 48, 30, 49, 39, 10, 11, 12, 13, 14, 15, - 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 162, 161, 34, 171, - 34, 50, 92, 51, 181, 39, 181, 181, 181, 181, - 92, 26, 30, 49, 30, 44, 39, 48, 43, 92, - 49, 30, 45, 55, 30, 181, 181, 181, 181, 181, - 181, 181, 181, 181, 50, 181, 39, 92, 139, 181, - 39, 49, 92, 181, 5, 181, 181, 39, 49, 92, - 44, 39, 181, 5, 181, 92, 30, 44, 39, 50, - 51, 181, 181, 28, 92, 39, 39, 39, 30, 45, - 181, 181, 181, 181, 181, 181, 181, 181, 181, 181, - 181, 181, 5, 181, 5, 181, 30, 181, 39, 30, - 39, 181, 181, 181, 181, 28, 181, 181, 30, 181, - 181, 181, 159, 159, 92, 48, 30, 49, 30, 44, - 42, 39, 42, 43, 92, 92, 39, 181, 51, 30, - 39, 42, 50, 44, 162, 161, 43, 48, 48, 144, - 42, 147, 148, 147, 148, 190, 45, 27, 42, 50, - 29, 44, 49, 49, 52, 50, 48, 143, 173, 163, - 163, 163, 173, 139, 163, 145, 48, 147, 44, 181, - 140, 163, 44, 50, 173, 155, 169, 172, 154, 154, - 44, 50, 45, 29, 44, 173, 8, 9, 32, 33, - 152, 153, 158, 163, 168, 173, 151, 169, 45, 42, - 29, 44, 48, 43, 143, 144, 30, 45, 44, 45, - 92, 132, 163, 133, 163, 134, 173, 132, 29, 44, - 138, 198, 199, 135, 163, 136, 163, 197, 137, 173, - 132, 142, 157, 157, 152, 173, 152, 173, 149, 45, - 42, 92, 145, 145, 145, 145, 48, 169, 169, 92, - 169, 147, 169, 45, 92, 42, 50, 92, 29, 92, - 44, 42, 92, 52, 28, 92, 143, 43, 27, 48, - 49, 45, 30, 49, 30, 181, 181, 181, 181, 51, - 42, 49, 48, 49, 46, 49, 50, 45, 30, 28, - 181, 181, 181, 181, 181, 51, 181, 49, 140, 49, - 48, 5, 49, 48, 51, 46, 5, 170, 173, 181, - 170, 6, 51, 46, 49, 51, 30, 181, 51, 46, - 92, 39, 181, 30, 45, 181, 5, 5, 92, 28, - 181, 181, 181, 181, 39, 46, 51, 31, 92, 48, - 43, 92, 39, 46, 49, 26, 28, 45, 45, 29, - 181, 30, 30, 51, 50, 29, 28, 39, 92, 147, - 144, 147, 148, 50, 30, 51, 51, 50, 48, 39, - 49, 30, 125, 173, 173, 125, 140, 43, 144, 50, - 181, 50, 51, 155, 50, 51, 50, 51, 152, 32, - 173, 181, 33, 153, 50, 51, 50, 43, 44, 143, - 50, 51, 45, 44, 133, 31, 44, 135, 152, 44, - 152, 198, 45, 45, 133, 141, 142, 151, 46, 26, - 50, 39, 28, 39, 43, 51, 39, 28, 39, 44, - 51, 50, 44, 45, 39, 51, 26, 163, 44, 43, - 48, 26, 51, 52, 26, 181, 46, 92, 43, 50, - 48, 30, 28, 44, 30, 48, 146, 48, 43, 48, - 43, 46, 50, 46, 50, 48, 30, 50, 46, 50, - 51, 46, 26, 30, 181, 51, 44, 181, 50, 50, - 46, 42, 45, 44, 39, 43, 29, 45, 44, 31, - 50, 48, 30, 51, 28, 44, 50, 181, 50, 30, - 51, 42, 48, 30, 49, 147, 51, 26, 30, 43, - 30, 92, 51, 26, 30, 50, 44, 51, 181, 51, - 30, 51, 30, 51, 92, 51, 92, 51, 44, 51, - 92, 50, 51, 51, 136, 50, 50, 133, 39, 38, - 51, 42, 51, 31, 29, 30, 39, 51, 31, 45, - 92, 51, 45, 44, 30, 50, 26, 163, 49, 44, - 43, 49, 92, 50, 51, 44, 39, 44, 29, 46, - 43, 43, 92, 26, 50, 43, 147, 43, 44, 43, - 44, 50, 29, 50, 29, 43, 50, 50, 29, 46, - 46, 50, 42, 46, 48, 45, 50, 44, 45, 39, - 44, 44, 45, 29, 43, 51, 50, 92, 92, 50, - 30, 39, 29, 92, 29, 37, 29, 50, 30, 48, - 45, 30, 92, 28, 37, 49, 30, 181, 30, 50, - 30, 50, 92, 30, 92, 30, 30, 92, 30, 45, - 51, 92, 50, 51, 45, 44, 92, 50, 50, 50, - 30, 30, 49, 28, 29, 49, 92, 44, 52, 39, - 28, 29, 39, 39, 39, 49, 92, 52, 39, 48, - 44, 28, 45, 30, 44, 144, 44, 92, 44, 29, - 52, 29, 52, 44, 28, 29, 52, 48, 50, 28, - 46, 50, 50, 42, 29, 49, 92, 52, 44, 45, - 27, 29, 50, 30, 48, 38, 30, 48, 45, 44, - 92, 92, 29, 39, 52, 50, 50, 45, 51, 50, - 181, 50, 29, 50, 30, 39, 30, 39, 50, 38, - 30, 39, 50, 92, 38, 45, 55, 92, 42, 30, - 92, 28, 29, 39, 39, 50, 51, 39, 92, 26, - 52, 39, 92, 30, 39, 40, 39, 28, 30, 92, - 49, 92, 51, 44, 142, 39, 92, 52, 28, 52, - 28, 92, 26, 52, 28, 28, 50, 26, 48, 46, - 30, 52, 40, 45, 39, 44, 28, 92, 44, 48, - 43, 44, 39, 52, 45, 49, 44, 45, 48, 30, - 48, 46, 43, 44, 50, 181, 48, 31, 39, 30, - 39, 30, 43, 44, 39, 30, 38, 55, 44, 50, - 30, 48, 39, 45, 51, 48, 31, 30, 28, 39, - 43, 50, 30, 26, 44, 28, 30, 51, 46, 27, - 30, 49, 92, 26, 26, 50, 92, 45, 46, 131, - 150, 169, 240, 241, 242, 30, 39, 28, 28, 26, - 44, 28, 92, 26, 46, 44, 28, 27, 44, 30, - 45, 92, 45, 44, 26, 28, 46, 30, 30, 48, - 50, 51, 28, 46, 48, 46, 43, 44, 30, 181, - 28, 42, 30, 30, 46, 30, 30, 46, 44, 30, - 30, 30, 92, 50, 28, 28, 39, 51, 31, 46, - 50, 42, 49, 92, 46, 50, 50, 26, 26, 49, - 26, 92, 48, 150, 50, 30, 42, 92, 26, 44, - 42, 92, 39, 50, 45, 44, 44, 45, 92, 45, - 92, 46, 51, 92, 45, 48, 43, 54, 29, 49, - 45, 49, 46, 48, 30, 28, 39, 44, 45, 51, - 31, 50, 28, 39, 48, 46, 26, 50, 29, 48, - 26, 30, 30, 39, 48, 26, 26, 42, 45, 44, - 31, 48, 44, 45, 45, 44, 55, 26, 48, 92, - 48, 39, 43, 50, 43, 49, 48, 43, 51, 31, - 45, 55, 50, 51, 31, 48, 26, 29, 39, 30, - 30, 30, 26, 50, 26, 30, 44, 45, 92, 44, - 45, 26, 43, 48, 52, 49, 50, 48, 44, 30, - 43, 50, 50, 28, 39, 50, 43, 30, 39, 30, - 30, 29, 44, 30, 30, 45, 44, 30, 50, 52, - 48, 48, 92, 50, 50, 48, 51, 31, 50, 30, - 30, 49, 38, 30, 44, 45, 30, 48, 48, 45, - 48, 50, 48, 49, 42, 29 -}; - -#define yyerrok (yyerrstatus = 0) -#define yyclearin (yychar = YYEMPTY) -#define YYEMPTY (-2) -#define YYEOF 0 - -#define YYACCEPT goto yyacceptlab -#define YYABORT goto yyabortlab -#define YYERROR goto yyerrorlab - - -/* Like YYERROR except do call yyerror. This remains here temporarily - to ease the transition to the new meaning of YYERROR, for GCC. - Once GCC version 2 has supplanted version 1, this can go. */ - -#define YYFAIL goto yyerrlab - -#define YYRECOVERING() (!!yyerrstatus) - -#define YYBACKUP(Token, Value) \ -do \ - if (yychar == YYEMPTY && yylen == 1) \ - { \ - yychar = (Token); \ - yylval = (Value); \ - yytoken = YYTRANSLATE (yychar); \ - YYPOPSTACK (1); \ - goto yybackup; \ - } \ - else \ - { \ - yyerror (YY_("syntax error: cannot back up")); \ - YYERROR; \ - } \ -while (YYID (0)) - - -#define YYTERROR 1 -#define YYERRCODE 256 - - -/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS1 to RHSN. - If N is 0, then set CURRENT to the empty location which ends - the previous symbol: RHS0 (always defined). */ - -#define YYRHSLOC(Rhs, K) ((Rhs)K) -#ifndef YYLLOC_DEFAULT -# define YYLLOC_DEFAULT(Current, Rhs, N) \ - do \ - if (YYID (N)) \ - { \ - (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \ - (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \ - (Current).last_line = YYRHSLOC (Rhs, N).last_line; \ - (Current).last_column = YYRHSLOC (Rhs, N).last_column; \ - } \ - else \ - { \ - (Current).first_line = (Current).last_line = \ - YYRHSLOC (Rhs, 0).last_line; \ - (Current).first_column = (Current).last_column = \ - YYRHSLOC (Rhs, 0).last_column; \ - } \ - while (YYID (0)) -#endif - - -/* YY_LOCATION_PRINT -- Print the location on the stream. - This macro was not mandated originally: define only if we know - we won't break user code: when these are the locations we know. */ - -#ifndef YY_LOCATION_PRINT -# if YYLTYPE_IS_TRIVIAL -# define YY_LOCATION_PRINT(File, Loc) \ - fprintf (File, "%d.%d-%d.%d", \ - (Loc).first_line, (Loc).first_column, \ - (Loc).last_line, (Loc).last_column) -# else -# define YY_LOCATION_PRINT(File, Loc) ((void) 0) -# endif -#endif - - -/* YYLEX -- calling `yylex' with the right arguments. */ - -#ifdef YYLEX_PARAM -# define YYLEX yylex (&yylval, YYLEX_PARAM) -#else -# define YYLEX yylex (&yylval) -#endif - -/* Enable debugging if requested. */ -#if YYDEBUG - -# ifndef YYFPRINTF -# include <stdio.h> /* INFRINGES ON USER NAME SPACE */ -# define YYFPRINTF fprintf -# endif - -# define YYDPRINTF(Args) \ -do { \ - if (yydebug) \ - YYFPRINTF Args; \ -} while (YYID (0)) - -# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \ -do { \ - if (yydebug) \ - { \ - YYFPRINTF (stderr, "%s ", Title); \ - yy_symbol_print (stderr, \ - Type, Value); \ - YYFPRINTF (stderr, "\n"); \ - } \ -} while (YYID (0)) - - -/*--------------------------------. -| Print this symbol on YYOUTPUT. | -`--------------------------------*/ - -/*ARGSUSED*/ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep) -#else -static void -yy_symbol_value_print (yyoutput, yytype, yyvaluep) - FILE *yyoutput; - int yytype; - YYSTYPE const * const yyvaluep; -#endif -{ - if (!yyvaluep) - return; -# ifdef YYPRINT - if (yytype < YYNTOKENS) - YYPRINT (yyoutput, yytoknumyytype, *yyvaluep); -# else - YYUSE (yyoutput); -# endif - switch (yytype) - { - default: - break; - } -} - - -/*--------------------------------. -| Print this symbol on YYOUTPUT. | -`--------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep) -#else -static void -yy_symbol_print (yyoutput, yytype, yyvaluep) - FILE *yyoutput; - int yytype; - YYSTYPE const * const yyvaluep; -#endif -{ - if (yytype < YYNTOKENS) - YYFPRINTF (yyoutput, "token %s (", yytnameyytype); - else - YYFPRINTF (yyoutput, "nterm %s (", yytnameyytype); - - yy_symbol_value_print (yyoutput, yytype, yyvaluep); - YYFPRINTF (yyoutput, ")"); -} - -/*------------------------------------------------------------------. -| yy_stack_print -- Print the state stack from its BOTTOM up to its | -| TOP (included). | -`------------------------------------------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_stack_print (yytype_int16 *bottom, yytype_int16 *top) -#else -static void -yy_stack_print (bottom, top) - yytype_int16 *bottom; - yytype_int16 *top; -#endif -{ - YYFPRINTF (stderr, "Stack now"); - for (; bottom <= top; ++bottom) - YYFPRINTF (stderr, " %d", *bottom); - YYFPRINTF (stderr, "\n"); -} - -# define YY_STACK_PRINT(Bottom, Top) \ -do { \ - if (yydebug) \ - yy_stack_print ((Bottom), (Top)); \ -} while (YYID (0)) - - -/*------------------------------------------------. -| Report that the YYRULE is going to be reduced. | -`------------------------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_reduce_print (YYSTYPE *yyvsp, int yyrule) -#else -static void -yy_reduce_print (yyvsp, yyrule) - YYSTYPE *yyvsp; - int yyrule; -#endif -{ - int yynrhs = yyr2yyrule; - int yyi; - unsigned long int yylno = yyrlineyyrule; - YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n", - yyrule - 1, yylno); - /* The symbols being reduced. */ - for (yyi = 0; yyi < yynrhs; yyi++) - { - fprintf (stderr, " $%d = ", yyi + 1); - yy_symbol_print (stderr, yyrhsyyprhsyyrule + yyi, - &(yyvsp(yyi + 1) - (yynrhs)) - ); - fprintf (stderr, "\n"); - } -} - -# define YY_REDUCE_PRINT(Rule) \ -do { \ - if (yydebug) \ - yy_reduce_print (yyvsp, Rule); \ -} while (YYID (0)) - -/* Nonzero means print parse trace. It is left uninitialized so that - multiple parsers can coexist. */ -int yydebug; -#else /* !YYDEBUG */ -# define YYDPRINTF(Args) -# define YY_SYMBOL_PRINT(Title, Type, Value, Location) -# define YY_STACK_PRINT(Bottom, Top) -# define YY_REDUCE_PRINT(Rule) -#endif /* !YYDEBUG */ - - -/* YYINITDEPTH -- initial size of the parser's stacks. */ -#ifndef YYINITDEPTH -# define YYINITDEPTH 200 -#endif - -/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only - if the built-in stack extension method is used). - - Do not make this value too large; the results are undefined if - YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH) - evaluated with infinite-precision integer arithmetic. */ - -#ifndef YYMAXDEPTH -# define YYMAXDEPTH 10000 -#endif - - - -#if YYERROR_VERBOSE - -# ifndef yystrlen -# if defined __GLIBC__ && defined _STRING_H -# define yystrlen strlen -# else -/* Return the length of YYSTR. */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static YYSIZE_T -yystrlen (const char *yystr) -#else -static YYSIZE_T -yystrlen (yystr) - const char *yystr; -#endif -{ - YYSIZE_T yylen; - for (yylen = 0; yystryylen; yylen++) - continue; - return yylen; -} -# endif -# endif - -# ifndef yystpcpy -# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE -# define yystpcpy stpcpy -# else -/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in - YYDEST. */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static char * -yystpcpy (char *yydest, const char *yysrc) -#else -static char * -yystpcpy (yydest, yysrc) - char *yydest; - const char *yysrc; -#endif -{ - char *yyd = yydest; - const char *yys = yysrc; - - while ((*yyd++ = *yys++) != '\0') - continue; - - return yyd - 1; -} -# endif -# endif - -# ifndef yytnamerr -/* Copy to YYRES the contents of YYSTR after stripping away unnecessary - quotes and backslashes, so that it's suitable for yyerror. The - heuristic is that double-quoting is unnecessary unless the string - contains an apostrophe, a comma, or backslash (other than - backslash-backslash). YYSTR is taken from yytname. If YYRES is - null, do not copy; instead, return the length of what the result - would have been. */ -static YYSIZE_T -yytnamerr (char *yyres, const char *yystr) -{ - if (*yystr == '"') - { - YYSIZE_T yyn = 0; - char const *yyp = yystr; - - for (;;) - switch (*++yyp) - { - case '\'': - case ',': - goto do_not_strip_quotes; - - case '\\': - if (*++yyp != '\\') - goto do_not_strip_quotes; - /* Fall through. */ - default: - if (yyres) - yyresyyn = *yyp; - yyn++; - break; - - case '"': - if (yyres) - yyresyyn = '\0'; - return yyn; - } - do_not_strip_quotes: ; - } - - if (! yyres) - return yystrlen (yystr); - - return yystpcpy (yyres, yystr) - yyres; -} -# endif - -/* Copy into YYRESULT an error message about the unexpected token - YYCHAR while in state YYSTATE. Return the number of bytes copied, - including the terminating null byte. If YYRESULT is null, do not - copy anything; just return the number of bytes that would be - copied. As a special case, return 0 if an ordinary "syntax error" - message will do. Return YYSIZE_MAXIMUM if overflow occurs during - size calculation. */ -static YYSIZE_T -yysyntax_error (char *yyresult, int yystate, int yychar) -{ - int yyn = yypactyystate; - - if (! (YYPACT_NINF < yyn && yyn <= YYLAST)) - return 0; - else - { - int yytype = YYTRANSLATE (yychar); - YYSIZE_T yysize0 = yytnamerr (0, yytnameyytype); - YYSIZE_T yysize = yysize0; - YYSIZE_T yysize1; - int yysize_overflow = 0; - enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; - char const *yyargYYERROR_VERBOSE_ARGS_MAXIMUM; - int yyx; - -# if 0 - /* This is so xgettext sees the translatable formats that are - constructed on the fly. */ - YY_("syntax error, unexpected %s"); - YY_("syntax error, unexpected %s, expecting %s"); - YY_("syntax error, unexpected %s, expecting %s or %s"); - YY_("syntax error, unexpected %s, expecting %s or %s or %s"); - YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); -# endif - char *yyfmt; - char const *yyf; - static char const yyunexpected = "syntax error, unexpected %s"; - static char const yyexpecting = ", expecting %s"; - static char const yyor = " or %s"; - char yyformatsizeof yyunexpected - + sizeof yyexpecting - 1 - + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) - * (sizeof yyor - 1)); - char const *yyprefix = yyexpecting; - - /* Start YYX at -YYN if negative to avoid negative indexes in - YYCHECK. */ - int yyxbegin = yyn < 0 ? -yyn : 0; - - /* Stay within bounds of both yycheck and yytname. */ - int yychecklim = YYLAST - yyn + 1; - int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; - int yycount = 1; - - yyarg0 = yytnameyytype; - yyfmt = yystpcpy (yyformat, yyunexpected); - - for (yyx = yyxbegin; yyx < yyxend; ++yyx) - if (yycheckyyx + yyn == yyx && yyx != YYTERROR) - { - if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) - { - yycount = 1; - yysize = yysize0; - yyformatsizeof yyunexpected - 1 = '\0'; - break; - } - yyargyycount++ = yytnameyyx; - yysize1 = yysize + yytnamerr (0, yytnameyyx); - yysize_overflow |= (yysize1 < yysize); - yysize = yysize1; - yyfmt = yystpcpy (yyfmt, yyprefix); - yyprefix = yyor; - } - - yyf = YY_(yyformat); - yysize1 = yysize + yystrlen (yyf); - yysize_overflow |= (yysize1 < yysize); - yysize = yysize1; - - if (yysize_overflow) - return YYSIZE_MAXIMUM; - - if (yyresult) - { - /* Avoid sprintf, as that infringes on the user's name space. - Don't have undefined behavior even if the translation - produced a string with the wrong number of "%s"s. */ - char *yyp = yyresult; - int yyi = 0; - while ((*yyp = *yyf) != '\0') - { - if (*yyp == '%' && yyf1 == 's' && yyi < yycount) - { - yyp += yytnamerr (yyp, yyargyyi++); - yyf += 2; - } - else - { - yyp++; - yyf++; - } - } - } - return yysize; - } -} -#endif /* YYERROR_VERBOSE */ - - -/*-----------------------------------------------. -| Release the memory associated to this symbol. | -`-----------------------------------------------*/ - -/*ARGSUSED*/ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep) -#else -static void -yydestruct (yymsg, yytype, yyvaluep) - const char *yymsg; - int yytype; - YYSTYPE *yyvaluep; -#endif -{ - YYUSE (yyvaluep); - - if (!yymsg) - yymsg = "Deleting"; - YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp); - - switch (yytype) - { - - default: - break; - } -} - - -/* Prevent warnings from -Wmissing-prototypes. */ - -#ifdef YYPARSE_PARAM -#if defined __STDC__ || defined __cplusplus -int yyparse (void *YYPARSE_PARAM); -#else -int yyparse (); -#endif -#else /* ! YYPARSE_PARAM */ -#if defined __STDC__ || defined __cplusplus -int yyparse (void); -#else -int yyparse (); -#endif -#endif /* ! YYPARSE_PARAM */ - - - - - - -/*----------. -| yyparse. | -`----------*/ - -#ifdef YYPARSE_PARAM -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -int -yyparse (void *YYPARSE_PARAM) -#else -int -yyparse (YYPARSE_PARAM) - void *YYPARSE_PARAM; -#endif -#else /* ! YYPARSE_PARAM */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -int -yyparse (void) -#else -int -yyparse () - -#endif -#endif -{ - /* The look-ahead symbol. */ -int yychar; - -/* The semantic value of the look-ahead symbol. */ -YYSTYPE yylval; - -/* Number of syntax errors so far. */ -int yynerrs; - - int yystate; - int yyn; - int yyresult; - /* Number of tokens to shift before error messages enabled. */ - int yyerrstatus; - /* Look-ahead token as an internal (translated) token number. */ - int yytoken = 0; -#if YYERROR_VERBOSE - /* Buffer for error messages, and its allocated size. */ - char yymsgbuf128; - char *yymsg = yymsgbuf; - YYSIZE_T yymsg_alloc = sizeof yymsgbuf; -#endif - - /* Three stacks and their tools: - `yyss': related to states, - `yyvs': related to semantic values, - `yyls': related to locations. - - Refer to the stacks thru separate pointers, to allow yyoverflow - to reallocate them elsewhere. */ - - /* The state stack. */ - yytype_int16 yyssaYYINITDEPTH; - yytype_int16 *yyss = yyssa; - yytype_int16 *yyssp; - - /* The semantic value stack. */ - YYSTYPE yyvsaYYINITDEPTH; - YYSTYPE *yyvs = yyvsa; - YYSTYPE *yyvsp; - - - -#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N)) - - YYSIZE_T yystacksize = YYINITDEPTH; - - /* The variables used to return semantic value and location from the - action routines. */ - YYSTYPE yyval; - - - /* The number of symbols on the RHS of the reduced rule. - Keep to zero when no symbol should be popped. */ - int yylen = 0; - - YYDPRINTF ((stderr, "Starting parse\n")); - - yystate = 0; - yyerrstatus = 0; - yynerrs = 0; - yychar = YYEMPTY; /* Cause a token to be read. */ - - /* Initialize stack pointers. - Waste one element of value and location stack - so that they stay on the same level as the state stack. - The wasted elements are never initialized. */ - - yyssp = yyss; - yyvsp = yyvs; - - goto yysetstate; - -/*------------------------------------------------------------. -| yynewstate -- Push a new state, which is found in yystate. | -`------------------------------------------------------------*/ - yynewstate: - /* In all cases, when you get here, the value and location stacks - have just been pushed. So pushing a state here evens the stacks. */ - yyssp++; - - yysetstate: - *yyssp = yystate; - - if (yyss + yystacksize - 1 <= yyssp) - { - /* Get the current used size of the three stacks, in elements. */ - YYSIZE_T yysize = yyssp - yyss + 1; - -#ifdef yyoverflow - { - /* Give user a chance to reallocate the stack. Use copies of - these so that the &'s don't force the real ones into - memory. */ - YYSTYPE *yyvs1 = yyvs; - yytype_int16 *yyss1 = yyss; - - - /* Each stack pointer address is followed by the size of the - data in use in that stack, in bytes. This used to be a - conditional around just the two extra args, but that might - be undefined if yyoverflow is a macro. */ - yyoverflow (YY_("memory exhausted"), - &yyss1, yysize * sizeof (*yyssp), - &yyvs1, yysize * sizeof (*yyvsp), - - &yystacksize); - - yyss = yyss1; - yyvs = yyvs1; - } -#else /* no yyoverflow */ -# ifndef YYSTACK_RELOCATE - goto yyexhaustedlab; -# else - /* Extend the stack our own way. */ - if (YYMAXDEPTH <= yystacksize) - goto yyexhaustedlab; - yystacksize *= 2; - if (YYMAXDEPTH < yystacksize) - yystacksize = YYMAXDEPTH; - - { - yytype_int16 *yyss1 = yyss; - union yyalloc *yyptr = - (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize)); - if (! yyptr) - goto yyexhaustedlab; - YYSTACK_RELOCATE (yyss); - YYSTACK_RELOCATE (yyvs); - -# undef YYSTACK_RELOCATE - if (yyss1 != yyssa) - YYSTACK_FREE (yyss1); - } -# endif -#endif /* no yyoverflow */ - - yyssp = yyss + yysize - 1; - yyvsp = yyvs + yysize - 1; - - - YYDPRINTF ((stderr, "Stack size increased to %lu\n", - (unsigned long int) yystacksize)); - - if (yyss + yystacksize - 1 <= yyssp) - YYABORT; - } - - YYDPRINTF ((stderr, "Entering state %d\n", yystate)); - - goto yybackup; - -/*-----------. -| yybackup. | -`-----------*/ -yybackup: - - /* Do appropriate processing given the current state. Read a - look-ahead token if we need one and don't already have one. */ - - /* First try to decide what to do without reference to look-ahead token. */ - yyn = yypactyystate; - if (yyn == YYPACT_NINF) - goto yydefault; - - /* Not known => get a look-ahead token if don't already have one. */ - - /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol. */ - if (yychar == YYEMPTY) - { - YYDPRINTF ((stderr, "Reading a token: ")); - yychar = YYLEX; - } - - if (yychar <= YYEOF) - { - yychar = yytoken = YYEOF; - YYDPRINTF ((stderr, "Now at end of input.\n")); - } - else - { - yytoken = YYTRANSLATE (yychar); - YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc); - } - - /* If the proper action on seeing token YYTOKEN is to reduce or to - detect an error, take that action. */ - yyn += yytoken; - if (yyn < 0 || YYLAST < yyn || yycheckyyn != yytoken) - goto yydefault; - yyn = yytableyyn; - if (yyn <= 0) - { - if (yyn == 0 || yyn == YYTABLE_NINF) - goto yyerrlab; - yyn = -yyn; - goto yyreduce; - } - - if (yyn == YYFINAL) - YYACCEPT; - - /* Count tokens shifted since error; after three, turn off error - status. */ - if (yyerrstatus) - yyerrstatus--; - - /* Shift the look-ahead token. */ - YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc); - - /* Discard the shifted token unless it is eof. */ - if (yychar != YYEOF) - yychar = YYEMPTY; - - yystate = yyn; - *++yyvsp = yylval; - - goto yynewstate; - - -/*-----------------------------------------------------------. -| yydefault -- do the default action for the current state. | -`-----------------------------------------------------------*/ -yydefault: - yyn = yydefactyystate; - if (yyn == 0) - goto yyerrlab; - goto yyreduce; - - -/*-----------------------------. -| yyreduce -- Do a reduction. | -`-----------------------------*/ -yyreduce: - /* yyn is the number of a rule to reduce with. */ - yylen = yyr2yyn; - - /* If YYLEN is nonzero, implement the default value of the action: - `$$ = $1'. - - Otherwise, the following line sets YYVAL to garbage. - This behavior is undocumented and Bison - users should not rely upon it. Assigning to YYVAL - unconditionally makes the parser a bit smaller, and it avoids a - GCC warning that YYVAL may be used uninitialized. */ - yyval = yyvsp1-yylen; - - - YY_REDUCE_PRINT (yyn); - switch (yyn) - { - case 4: -#line 150 "lscp.y" - { INCREMENT_LINE; return LSCP_DONE; } - break; - - case 5: -#line 151 "lscp.y" - { INCREMENT_LINE; return LSCP_DONE; } - break; - - case 6: -#line 152 "lscp.y" - { INCREMENT_LINE; LSCPSERVER->AnswerClient((yyvsp(1) - (1).String)); return LSCP_DONE; } - break; - - case 7: -#line 153 "lscp.y" - { INCREMENT_LINE; LSCPSERVER->AnswerClient("ERR:0:" + sLastError + "\r\n"); RESTART; return LSCP_SYNTAX_ERROR; } - break; - - case 13: -#line 163 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 14: -#line 164 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 15: -#line 165 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 16: -#line 166 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 17: -#line 167 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 18: -#line 168 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 19: -#line 169 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 20: -#line 170 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 21: -#line 171 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 22: -#line 172 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 23: -#line 173 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 24: -#line 174 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 25: -#line 175 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 26: -#line 176 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 27: -#line 177 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 28: -#line 178 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 29: -#line 179 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 30: -#line 180 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 31: -#line 181 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 32: -#line 182 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 33: -#line 183 "lscp.y" - { (yyval.String) = LSCPSERVER->ResetSampler(); } - break; - - case 34: -#line 184 "lscp.y" - { LSCPSERVER->AnswerClient("Bye!\r\n"); return LSCP_QUIT; } - break; - - case 35: -#line 187 "lscp.y" - { (yyval.String) = LSCPSERVER->AddChannel(); } - break; - - case 36: -#line 188 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstrumentDirectory((yyvsp(3) - (3).String)); } - break; - - case 37: -#line 189 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(5) - (9).String),(yyvsp(7) - (9).String),(yyvsp(9) - (9).String), true); } - break; - - case 38: -#line 190 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(5) - (11).String),(yyvsp(9) - (11).String),(yyvsp(11) - (11).String), true, true); } - break; - - case 39: -#line 191 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(3) - (7).String),(yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 40: -#line 192 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(3) - (9).String),(yyvsp(7) - (9).String),(yyvsp(9) - (9).String), false, true); } - break; - - case 41: -#line 193 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(5) - (7).String),(yyvsp(7) - (7).String), -1, true); } - break; - - case 42: -#line 194 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(5) - (9).String),(yyvsp(7) - (9).String),(yyvsp(9) - (9).Number), true); } - break; - - case 43: -#line 195 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(3) - (5).String),(yyvsp(5) - (5).String)); } - break; - - case 44: -#line 196 "lscp.y" - { (yyval.String) = LSCPSERVER->AddDbInstruments((yyvsp(3) - (7).String),(yyvsp(5) - (7).String),(yyvsp(7) - (7).Number)); } - break; - - case 45: -#line 197 "lscp.y" - { (yyval.String) = LSCPSERVER->AddMidiInstrumentMap(); } - break; - - case 46: -#line 198 "lscp.y" - { (yyval.String) = LSCPSERVER->AddMidiInstrumentMap((yyvsp(3) - (3).String)); } - break; - - case 47: -#line 201 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_audio_device_count); } - break; - - case 48: -#line 202 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_audio_device_info); } - break; - - case 49: -#line 203 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_device_count); } - break; - - case 50: -#line 204 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_device_info); } - break; - - case 51: -#line 205 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_channel_count); } - break; - - case 52: -#line 206 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_channel_midi); } - break; - - case 53: -#line 207 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_device_midi); } - break; - - case 54: -#line 208 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_voice_count); } - break; - - case 55: -#line 209 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_stream_count); } - break; - - case 56: -#line 210 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_buffer_fill); } - break; - - case 57: -#line 211 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_channel_info); } - break; - - case 58: -#line 212 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_fx_send_count); } - break; - - case 59: -#line 213 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_fx_send_info); } - break; - - case 60: -#line 214 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_instr_map_count); } - break; - - case 61: -#line 215 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_instr_map_info); } - break; - - case 62: -#line 216 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_instr_count); } - break; - - case 63: -#line 217 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_midi_instr_info); } - break; - - case 64: -#line 218 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_db_instr_dir_count); } - break; - - case 65: -#line 219 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_db_instr_dir_info); } - break; - - case 66: -#line 220 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_db_instr_count); } - break; - - case 67: -#line 221 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_db_instr_info); } - break; - - case 68: -#line 222 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_db_instrs_job_info); } - break; - - case 69: -#line 223 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_misc); } - break; - - case 70: -#line 224 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_total_stream_count); } - break; - - case 71: -#line 225 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_total_voice_count); } - break; - - case 72: -#line 226 "lscp.y" - { (yyval.String) = LSCPSERVER->SubscribeNotification(LSCPEvent::event_global_info); } - break; - - case 73: -#line 229 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_audio_device_count); } - break; - - case 74: -#line 230 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_audio_device_info); } - break; - - case 75: -#line 231 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_device_count); } - break; - - case 76: -#line 232 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_device_info); } - break; - - case 77: -#line 233 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_channel_count); } - break; - - case 78: -#line 234 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_channel_midi); } - break; - - case 79: -#line 235 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_device_midi); } - break; - - case 80: -#line 236 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_voice_count); } - break; - - case 81: -#line 237 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_stream_count); } - break; - - case 82: -#line 238 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_buffer_fill); } - break; - - case 83: -#line 239 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_channel_info); } - break; - - case 84: -#line 240 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_fx_send_count); } - break; - - case 85: -#line 241 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_fx_send_info); } - break; - - case 86: -#line 242 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_instr_map_count); } - break; - - case 87: -#line 243 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_instr_map_info); } - break; - - case 88: -#line 244 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_instr_count); } - break; - - case 89: -#line 245 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_midi_instr_info); } - break; - - case 90: -#line 246 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_db_instr_dir_count); } - break; - - case 91: -#line 247 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_db_instr_dir_info); } - break; - - case 92: -#line 248 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_db_instr_count); } - break; - - case 93: -#line 249 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_db_instr_info); } - break; - - case 94: -#line 250 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_db_instrs_job_info); } - break; - - case 95: -#line 251 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_misc); } - break; - - case 96: -#line 252 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_total_stream_count); } - break; - - case 97: -#line 253 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_total_voice_count); } - break; - - case 98: -#line 254 "lscp.y" - { (yyval.String) = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_global_info); } - break; - - case 99: -#line 257 "lscp.y" - { (yyval.String) = LSCPSERVER->AddOrReplaceMIDIInstrumentMapping((yyvsp(4) - (16).Number),(yyvsp(6) - (16).Number),(yyvsp(8) - (16).Number),(yyvsp(10) - (16).String),(yyvsp(12) - (16).String),(yyvsp(14) - (16).Number),(yyvsp(16) - (16).Dotnum),MidiInstrumentMapper::DONTCARE,"",(yyvsp(3) - (16).Bool)); } - break; - - case 100: -#line 258 "lscp.y" - { (yyval.String) = LSCPSERVER->AddOrReplaceMIDIInstrumentMapping((yyvsp(4) - (18).Number),(yyvsp(6) - (18).Number),(yyvsp(8) - (18).Number),(yyvsp(10) - (18).String),(yyvsp(12) - (18).String),(yyvsp(14) - (18).Number),(yyvsp(16) - (18).Dotnum),(yyvsp(18) - (18).LoadMode),"",(yyvsp(3) - (18).Bool)); } - break; - - case 101: -#line 259 "lscp.y" - { (yyval.String) = LSCPSERVER->AddOrReplaceMIDIInstrumentMapping((yyvsp(4) - (18).Number),(yyvsp(6) - (18).Number),(yyvsp(8) - (18).Number),(yyvsp(10) - (18).String),(yyvsp(12) - (18).String),(yyvsp(14) - (18).Number),(yyvsp(16) - (18).Dotnum),MidiInstrumentMapper::DONTCARE,(yyvsp(18) - (18).String),(yyvsp(3) - (18).Bool)); } - break; - - case 102: -#line 260 "lscp.y" - { (yyval.String) = LSCPSERVER->AddOrReplaceMIDIInstrumentMapping((yyvsp(4) - (20).Number),(yyvsp(6) - (20).Number),(yyvsp(8) - (20).Number),(yyvsp(10) - (20).String),(yyvsp(12) - (20).String),(yyvsp(14) - (20).Number),(yyvsp(16) - (20).Dotnum),(yyvsp(18) - (20).LoadMode),(yyvsp(20) - (20).String),(yyvsp(3) - (20).Bool)); } - break; - - case 103: -#line 263 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveMIDIInstrumentMapping((yyvsp(3) - (7).Number),(yyvsp(5) - (7).Number),(yyvsp(7) - (7).Number)); } - break; - - case 104: -#line 266 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveChannel((yyvsp(3) - (3).Number)); } - break; - - case 105: -#line 267 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveMidiInstrumentMap((yyvsp(3) - (3).Number)); } - break; - - case 106: -#line 268 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveAllMidiInstrumentMaps(); } - break; - - case 107: -#line 269 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveDbInstrumentDirectory((yyvsp(5) - (5).String), true); } - break; - - case 108: -#line 270 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveDbInstrumentDirectory((yyvsp(3) - (3).String)); } - break; - - case 109: -#line 271 "lscp.y" - { (yyval.String) = LSCPSERVER->RemoveDbInstrument((yyvsp(3) - (3).String)); } - break; - - case 110: -#line 274 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAvailableEngines(); } - break; - - case 111: -#line 275 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAvailableMidiInputDrivers(); } - break; - - case 112: -#line 276 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDriverInfo((yyvsp(5) - (5).String)); } - break; - - case 113: -#line 277 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDriverParameterInfo((yyvsp(5) - (7).String), (yyvsp(7) - (7).String)); } - break; - - case 114: -#line 278 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDriverParameterInfo((yyvsp(5) - (9).String), (yyvsp(7) - (9).String), (yyvsp(9) - (9).KeyValList)); } - break; - - case 115: -#line 279 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAvailableAudioOutputDrivers(); } - break; - - case 116: -#line 280 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDriverInfo((yyvsp(5) - (5).String)); } - break; - - case 117: -#line 281 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDriverParameterInfo((yyvsp(5) - (7).String), (yyvsp(7) - (7).String)); } - break; - - case 118: -#line 282 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDriverParameterInfo((yyvsp(5) - (9).String), (yyvsp(7) - (9).String), (yyvsp(9) - (9).KeyValList)); } - break; - - case 119: -#line 283 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDeviceCount(); } - break; - - case 120: -#line 284 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDeviceCount(); } - break; - - case 121: -#line 285 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDeviceInfo((yyvsp(5) - (5).Number)); } - break; - - case 122: -#line 286 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDeviceInfo((yyvsp(5) - (5).Number)); } - break; - - case 123: -#line 287 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputPortInfo((yyvsp(5) - (7).Number), (yyvsp(7) - (7).Number)); } - break; - - case 124: -#line 288 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputPortParameterInfo((yyvsp(5) - (9).Number), (yyvsp(7) - (9).Number), (yyvsp(9) - (9).String)); } - break; - - case 125: -#line 289 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputChannelInfo((yyvsp(5) - (7).Number), (yyvsp(7) - (7).Number)); } - break; - - case 126: -#line 290 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputChannelParameterInfo((yyvsp(5) - (9).Number), (yyvsp(7) - (9).Number), (yyvsp(9) - (9).String)); } - break; - - case 127: -#line 291 "lscp.y" - { (yyval.String) = LSCPSERVER->GetChannels(); } - break; - - case 128: -#line 292 "lscp.y" - { (yyval.String) = LSCPSERVER->GetChannelInfo((yyvsp(5) - (5).Number)); } - break; - - case 129: -#line 293 "lscp.y" - { (yyval.String) = LSCPSERVER->GetBufferFill((yyvsp(5) - (7).FillResponse), (yyvsp(7) - (7).Number)); } - break; - - case 130: -#line 294 "lscp.y" - { (yyval.String) = LSCPSERVER->GetStreamCount((yyvsp(5) - (5).Number)); } - break; - - case 131: -#line 295 "lscp.y" - { (yyval.String) = LSCPSERVER->GetVoiceCount((yyvsp(5) - (5).Number)); } - break; - - case 132: -#line 296 "lscp.y" - { (yyval.String) = LSCPSERVER->GetEngineInfo((yyvsp(5) - (5).String)); } - break; - - case 133: -#line 297 "lscp.y" - { (yyval.String) = LSCPSERVER->GetServerInfo(); } - break; - - case 134: -#line 298 "lscp.y" - { (yyval.String) = LSCPSERVER->GetTotalStreamCount(); } - break; - - case 135: -#line 299 "lscp.y" - { (yyval.String) = LSCPSERVER->GetTotalVoiceCount(); } - break; - - case 136: -#line 300 "lscp.y" - { (yyval.String) = LSCPSERVER->GetTotalVoiceCountMax(); } - break; - - case 137: -#line 301 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInstrumentMappings((yyvsp(3) - (3).Number)); } - break; - - case 138: -#line 302 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAllMidiInstrumentMappings(); } - break; - - case 139: -#line 303 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInstrumentMapping((yyvsp(5) - (9).Number),(yyvsp(7) - (9).Number),(yyvsp(9) - (9).Number)); } - break; - - case 140: -#line 304 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInstrumentMaps(); } - break; - - case 141: -#line 305 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInstrumentMap((yyvsp(5) - (5).Number)); } - break; - - case 142: -#line 306 "lscp.y" - { (yyval.String) = LSCPSERVER->GetFxSends((yyvsp(3) - (3).Number)); } - break; - - case 143: -#line 307 "lscp.y" - { (yyval.String) = LSCPSERVER->GetFxSendInfo((yyvsp(5) - (7).Number),(yyvsp(7) - (7).Number)); } - break; - - case 144: -#line 308 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentDirectoryCount((yyvsp(5) - (5).String), true); } - break; - - case 145: -#line 309 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentDirectoryCount((yyvsp(3) - (3).String), false); } - break; - - case 146: -#line 310 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentDirectoryInfo((yyvsp(5) - (5).String)); } - break; - - case 147: -#line 311 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentCount((yyvsp(5) - (5).String), true); } - break; - - case 148: -#line 312 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentCount((yyvsp(3) - (3).String), false); } - break; - - case 149: -#line 313 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentInfo((yyvsp(5) - (5).String)); } - break; - - case 150: -#line 314 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentsJobInfo((yyvsp(5) - (5).Number)); } - break; - - case 151: -#line 315 "lscp.y" - { (yyval.String) = LSCPSERVER->GetGlobalVolume(); } - break; - - case 152: -#line 316 "lscp.y" - { (yyval.String) = LSCPSERVER->GetGlobalMaxVoices(); } - break; - - case 153: -#line 317 "lscp.y" - { (yyval.String) = LSCPSERVER->GetGlobalMaxStreams(); } - break; - - case 154: -#line 318 "lscp.y" - { (yyval.String) = LSCPSERVER->GetFileInstruments((yyvsp(5) - (5).String)); } - break; - - case 155: -#line 319 "lscp.y" - { (yyval.String) = LSCPSERVER->GetFileInstrumentInfo((yyvsp(7) - (9).String),(yyvsp(9) - (9).Number)); } - break; - - case 156: -#line 322 "lscp.y" - { (yyval.String) = LSCPSERVER->SetAudioOutputDeviceParameter((yyvsp(3) - (7).Number), (yyvsp(5) - (7).String), (yyvsp(7) - (7).String)); } - break; - - case 157: -#line 323 "lscp.y" - { (yyval.String) = LSCPSERVER->SetAudioOutputChannelParameter((yyvsp(3) - (9).Number), (yyvsp(5) - (9).Number), (yyvsp(7) - (9).String), (yyvsp(9) - (9).String)); } - break; - - case 158: -#line 324 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMidiInputDeviceParameter((yyvsp(3) - (7).Number), (yyvsp(5) - (7).String), (yyvsp(7) - (7).String)); } - break; - - case 159: -#line 325 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMidiInputPortParameter((yyvsp(3) - (9).Number), (yyvsp(5) - (9).Number), (yyvsp(7) - (9).String), ""); } - break; - - case 160: -#line 326 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMidiInputPortParameter((yyvsp(3) - (9).Number), (yyvsp(5) - (9).Number), (yyvsp(7) - (9).String), (yyvsp(9) - (9).String)); } - break; - - case 161: -#line 327 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 162: -#line 328 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMidiInstrumentMapName((yyvsp(5) - (7).Number), (yyvsp(7) - (7).String)); } - break; - - case 163: -#line 329 "lscp.y" - { (yyval.String) = LSCPSERVER->SetFxSendName((yyvsp(5) - (9).Number),(yyvsp(7) - (9).Number),(yyvsp(9) - (9).String)); } - break; - - case 164: -#line 330 "lscp.y" - { (yyval.String) = LSCPSERVER->SetFxSendAudioOutputChannel((yyvsp(5) - (11).Number),(yyvsp(7) - (11).Number),(yyvsp(9) - (11).Number),(yyvsp(11) - (11).Number)); } - break; - - case 165: -#line 331 "lscp.y" - { (yyval.String) = LSCPSERVER->SetFxSendMidiController((yyvsp(5) - (9).Number),(yyvsp(7) - (9).Number),(yyvsp(9) - (9).Number)); } - break; - - case 166: -#line 332 "lscp.y" - { (yyval.String) = LSCPSERVER->SetFxSendLevel((yyvsp(5) - (9).Number),(yyvsp(7) - (9).Number),(yyvsp(9) - (9).Dotnum)); } - break; - - case 167: -#line 333 "lscp.y" - { (yyval.String) = LSCPSERVER->SetDbInstrumentDirectoryName((yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 168: -#line 334 "lscp.y" - { (yyval.String) = LSCPSERVER->SetDbInstrumentDirectoryDescription((yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 169: -#line 335 "lscp.y" - { (yyval.String) = LSCPSERVER->SetDbInstrumentName((yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 170: -#line 336 "lscp.y" - { (yyval.String) = LSCPSERVER->SetDbInstrumentDescription((yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 171: -#line 337 "lscp.y" - { (yyval.String) = LSCPSERVER->SetDbInstrumentFilePath((yyvsp(5) - (7).String),(yyvsp(7) - (7).String)); } - break; - - case 172: -#line 338 "lscp.y" - { (yyval.String) = LSCPSERVER->SetEcho((yyparse_param_t*) yyparse_param, (yyvsp(3) - (3).Dotnum)); } - break; - - case 173: -#line 339 "lscp.y" - { (yyval.String) = LSCPSERVER->SetGlobalVolume((yyvsp(3) - (3).Dotnum)); } - break; - - case 174: -#line 340 "lscp.y" - { (yyval.String) = LSCPSERVER->SetGlobalMaxVoices((yyvsp(3) - (3).Number)); } - break; - - case 175: -#line 341 "lscp.y" - { (yyval.String) = LSCPSERVER->SetGlobalMaxStreams((yyvsp(3) - (3).Number)); } - break; - - case 176: -#line 344 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateAudioOutputDevice((yyvsp(3) - (5).String),(yyvsp(5) - (5).KeyValList)); } - break; - - case 177: -#line 345 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateAudioOutputDevice((yyvsp(3) - (3).String)); } - break; - - case 178: -#line 346 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateMidiInputDevice((yyvsp(3) - (5).String),(yyvsp(5) - (5).KeyValList)); } - break; - - case 179: -#line 347 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateMidiInputDevice((yyvsp(3) - (3).String)); } - break; - - case 180: -#line 348 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateFxSend((yyvsp(3) - (5).Number),(yyvsp(5) - (5).Number)); } - break; - - case 181: -#line 349 "lscp.y" - { (yyval.String) = LSCPSERVER->CreateFxSend((yyvsp(3) - (7).Number),(yyvsp(5) - (7).Number),(yyvsp(7) - (7).String)); } - break; - - case 182: -#line 352 "lscp.y" - { (yyval.String) = LSCPSERVER->ResetChannel((yyvsp(3) - (3).Number)); } - break; - - case 183: -#line 355 "lscp.y" - { (yyval.String) = LSCPSERVER->ClearMidiInstrumentMappings((yyvsp(3) - (3).Number)); } - break; - - case 184: -#line 356 "lscp.y" - { (yyval.String) = LSCPSERVER->ClearAllMidiInstrumentMappings(); } - break; - - case 185: -#line 359 "lscp.y" - { (yyval.String) = LSCPSERVER->FindDbInstruments((yyvsp(5) - (7).String),(yyvsp(7) - (7).KeyValList), false); } - break; - - case 186: -#line 360 "lscp.y" - { (yyval.String) = LSCPSERVER->FindDbInstruments((yyvsp(3) - (5).String),(yyvsp(5) - (5).KeyValList), true); } - break; - - case 187: -#line 361 "lscp.y" - { (yyval.String) = LSCPSERVER->FindDbInstrumentDirectories((yyvsp(5) - (7).String),(yyvsp(7) - (7).KeyValList), false); } - break; - - case 188: -#line 362 "lscp.y" - { (yyval.String) = LSCPSERVER->FindDbInstrumentDirectories((yyvsp(3) - (5).String),(yyvsp(5) - (5).KeyValList), true); } - break; - - case 189: -#line 363 "lscp.y" - { (yyval.String) = LSCPSERVER->FindLostDbInstrumentFiles(); } - break; - - case 190: -#line 366 "lscp.y" - { (yyval.String) = LSCPSERVER->MoveDbInstrumentDirectory((yyvsp(3) - (5).String),(yyvsp(5) - (5).String)); } - break; - - case 191: -#line 367 "lscp.y" - { (yyval.String) = LSCPSERVER->MoveDbInstrument((yyvsp(3) - (5).String),(yyvsp(5) - (5).String)); } - break; - - case 192: -#line 370 "lscp.y" - { (yyval.String) = LSCPSERVER->CopyDbInstrumentDirectory((yyvsp(3) - (5).String),(yyvsp(5) - (5).String)); } - break; - - case 193: -#line 371 "lscp.y" - { (yyval.String) = LSCPSERVER->CopyDbInstrument((yyvsp(3) - (5).String),(yyvsp(5) - (5).String)); } - break; - - case 194: -#line 374 "lscp.y" - { (yyval.String) = LSCPSERVER->DestroyAudioOutputDevice((yyvsp(3) - (3).Number)); } - break; - - case 195: -#line 375 "lscp.y" - { (yyval.String) = LSCPSERVER->DestroyMidiInputDevice((yyvsp(3) - (3).Number)); } - break; - - case 196: -#line 376 "lscp.y" - { (yyval.String) = LSCPSERVER->DestroyFxSend((yyvsp(3) - (5).Number),(yyvsp(5) - (5).Number)); } - break; - - case 197: -#line 379 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 198: -#line 380 "lscp.y" - { (yyval.String) = (yyvsp(3) - (3).String); } - break; - - case 199: -#line 383 "lscp.y" - { (yyval.String) = LSCPSERVER->SetAudioOutputDevice((yyvsp(5) - (5).Number), (yyvsp(3) - (5).Number)); } - break; - - case 200: -#line 384 "lscp.y" - { (yyval.String) = LSCPSERVER->SetAudioOutputChannel((yyvsp(5) - (7).Number), (yyvsp(7) - (7).Number), (yyvsp(3) - (7).Number)); } - break; - - case 201: -#line 385 "lscp.y" - { (yyval.String) = LSCPSERVER->SetAudioOutputType((yyvsp(5) - (5).String), (yyvsp(3) - (5).Number)); } - break; - - case 202: -#line 386 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMIDIInput((yyvsp(5) - (9).Number), (yyvsp(7) - (9).Number), (yyvsp(9) - (9).Number), (yyvsp(3) - (9).Number)); } - break; - - case 203: -#line 387 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMIDIInputDevice((yyvsp(5) - (5).Number), (yyvsp(3) - (5).Number)); } - break; - - case 204: -#line 388 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMIDIInputPort((yyvsp(5) - (5).Number), (yyvsp(3) - (5).Number)); } - break; - - case 205: -#line 389 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMIDIInputChannel((yyvsp(5) - (5).Number), (yyvsp(3) - (5).Number)); } - break; - - case 206: -#line 390 "lscp.y" - { (yyval.String) = LSCPSERVER->SetMIDIInputType((yyvsp(5) - (5).String), (yyvsp(3) - (5).Number)); } - break; - - case 207: -#line 391 "lscp.y" - { (yyval.String) = LSCPSERVER->SetVolume((yyvsp(5) - (5).Dotnum), (yyvsp(3) - (5).Number)); } - break; - - case 208: -#line 392 "lscp.y" - { (yyval.String) = LSCPSERVER->SetChannelMute((yyvsp(5) - (5).Dotnum), (yyvsp(3) - (5).Number)); } - break; - - case 209: -#line 393 "lscp.y" - { (yyval.String) = LSCPSERVER->SetChannelSolo((yyvsp(5) - (5).Dotnum), (yyvsp(3) - (5).Number)); } - break; - - case 210: -#line 394 "lscp.y" - { (yyval.String) = LSCPSERVER->SetChannelMap((yyvsp(3) - (5).Number), (yyvsp(5) - (5).Number)); } - break; - - case 211: -#line 395 "lscp.y" - { (yyval.String) = LSCPSERVER->SetChannelMap((yyvsp(3) - (5).Number), -1); } - break; - - case 212: -#line 396 "lscp.y" - { (yyval.String) = LSCPSERVER->SetChannelMap((yyvsp(3) - (5).Number), -2); } - break; - - case 213: -#line 399 "lscp.y" - { (yyval.String) = LSCPSERVER->EditSamplerChannelInstrument((yyvsp(5) - (5).Number)); } - break; - - case 214: -#line 402 "lscp.y" - { (yyval.String) = LSCPSERVER->FormatInstrumentsDb(); } - break; - - case 215: -#line 405 "lscp.y" - { (yyval.Bool) = true; } - break; - - case 216: -#line 406 "lscp.y" - { (yyval.Bool) = false; } - break; - - case 217: -#line 409 "lscp.y" - { (yyval.KeyValList)(yyvsp(1) - (3).String) = (yyvsp(3) - (3).String); } - break; - - case 218: -#line 410 "lscp.y" - { (yyval.KeyValList) = (yyvsp(1) - (5).KeyValList); (yyval.KeyValList)(yyvsp(3) - (5).String) = (yyvsp(5) - (5).String); } - break; - - case 219: -#line 413 "lscp.y" - { (yyval.FillResponse) = fill_response_bytes; } - break; - - case 220: -#line 414 "lscp.y" - { (yyval.FillResponse) = fill_response_percentage; } - break; - - case 221: -#line 417 "lscp.y" - { (yyval.String) = LSCPSERVER->GetAudioOutputDevices(); } - break; - - case 222: -#line 418 "lscp.y" - { (yyval.String) = LSCPSERVER->GetMidiInputDevices(); } - break; - - case 223: -#line 419 "lscp.y" - { (yyval.String) = LSCPSERVER->ListChannels(); } - break; - - case 224: -#line 420 "lscp.y" - { (yyval.String) = LSCPSERVER->ListAvailableEngines(); } - break; - - case 225: -#line 421 "lscp.y" - { (yyval.String) = LSCPSERVER->ListAvailableMidiInputDrivers(); } - break; - - case 226: -#line 422 "lscp.y" - { (yyval.String) = LSCPSERVER->ListAvailableAudioOutputDrivers(); } - break; - - case 227: -#line 423 "lscp.y" - { (yyval.String) = LSCPSERVER->ListMidiInstrumentMappings((yyvsp(3) - (3).Number)); } - break; - - case 228: -#line 424 "lscp.y" - { (yyval.String) = LSCPSERVER->ListAllMidiInstrumentMappings(); } - break; - - case 229: -#line 425 "lscp.y" - { (yyval.String) = LSCPSERVER->ListMidiInstrumentMaps(); } - break; - - case 230: -#line 426 "lscp.y" - { (yyval.String) = LSCPSERVER->ListFxSends((yyvsp(3) - (3).Number)); } - break; - - case 231: -#line 427 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentDirectories((yyvsp(5) - (5).String), true); } - break; - - case 232: -#line 428 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstrumentDirectories((yyvsp(3) - (3).String)); } - break; - - case 233: -#line 429 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstruments((yyvsp(5) - (5).String), true); } - break; - - case 234: -#line 430 "lscp.y" - { (yyval.String) = LSCPSERVER->GetDbInstruments((yyvsp(3) - (3).String)); } - break; - - case 235: -#line 431 "lscp.y" - { (yyval.String) = LSCPSERVER->ListFileInstruments((yyvsp(5) - (5).String)); } - break; - - case 236: -#line 434 "lscp.y" - { (yyval.String) = LSCPSERVER->SendChannelMidiData((yyvsp(5) - (11).String), (yyvsp(7) - (11).Number), (yyvsp(9) - (11).Number), (yyvsp(11) - (11).Number)); } - break; - - case 237: -#line 437 "lscp.y" - { (yyval.String) = LSCPSERVER->LoadInstrument((yyvsp(1) - (5).String), (yyvsp(3) - (5).Number), (yyvsp(5) - (5).Number)); } - break; - - case 238: -#line 438 "lscp.y" - { (yyval.String) = LSCPSERVER->LoadInstrument((yyvsp(3) - (7).String), (yyvsp(5) - (7).Number), (yyvsp(7) - (7).Number), true); } - break; - - case 239: -#line 441 "lscp.y" - { (yyval.String) = LSCPSERVER->SetEngineType((yyvsp(1) - (3).String), (yyvsp(3) - (3).Number)); } - break; - - case 240: -#line 444 "lscp.y" - { (yyval.LoadMode) = MidiInstrumentMapper::ON_DEMAND; } - break; - - case 241: -#line 445 "lscp.y" - { (yyval.LoadMode) = MidiInstrumentMapper::ON_DEMAND_HOLD; } - break; - - case 242: -#line 446 "lscp.y" - { (yyval.LoadMode) = MidiInstrumentMapper::PERSISTENT; } - break; - - case 248: -#line 462 "lscp.y" - { (yyval.Number) = 16; } - break; - - case 255: -#line 481 "lscp.y" - { (yyval.Dotnum) = (yyvsp(1) - (1).Number); } - break; - - case 260: -#line 496 "lscp.y" - { - #if WIN32 - (yyval.String) = (yyvsp(1) - (1).UniversalPath).toWindows(); - #else - // assuming POSIX - (yyval.String) = (yyvsp(1) - (1).UniversalPath).toPosix(); - #endif - } - break; - - case 261: -#line 506 "lscp.y" - { (yyval.String) = (yyvsp(1) - (1).UniversalPath).toDbPath(); } - break; - - case 266: -#line 519 "lscp.y" - { (yyval.String) = (yyvsp(1) - (3).String) + "," + (yyvsp(3) - (3).String); } - break; - - case 267: -#line 523 "lscp.y" - { (yyval.String) = "\'" + (yyvsp(1) - (1).String) + "\'"; } - break; - - case 268: -#line 524 "lscp.y" - { (yyval.String) = "\'" + (yyvsp(1) - (1).String) + "\'"; } - break; - - case 269: -#line 525 "lscp.y" - { std::stringstream ss; ss << "\'" << (yyvsp(1) - (1).Number) << "\'"; (yyval.String) = ss.str(); } - break; - - case 270: -#line 526 "lscp.y" - { std::stringstream ss; ss << "\'" << (yyvsp(1) - (1).Dotnum) << "\'"; (yyval.String) = ss.str(); } - break; - - case 271: -#line 529 "lscp.y" - { (yyval.KeyValList)(yyvsp(1) - (3).String) = (yyvsp(3) - (3).String); } - break; - - case 272: -#line 530 "lscp.y" - { (yyval.KeyValList) = (yyvsp(1) - (5).KeyValList); (yyval.KeyValList)(yyvsp(3) - (5).String) = (yyvsp(5) - (5).String); } - break; - - case 275: -#line 537 "lscp.y" - { (yyval.String) = "RECURSIVE"; } - break; - - case 276: -#line 538 "lscp.y" - { (yyval.String) = "NON_RECURSIVE"; } - break; - - case 277: -#line 539 "lscp.y" - { (yyval.String) = "FLAT"; } - break; - - case 278: -#line 547 "lscp.y" - { (yyval.Dotnum) = (yyvsp(1) - (1).Number); } - break; - - case 279: -#line 548 "lscp.y" - { (yyval.Dotnum) = -1; } - break; - - case 280: -#line 551 "lscp.y" - { std::stringstream ss((yyvsp(1) - (3).String) + "." + (yyvsp(3) - (3).String)); ss.imbue(std::locale::classic()); ss >> (yyval.Dotnum); } - break; - - case 281: -#line 552 "lscp.y" - { std::stringstream ss((yyvsp(2) - (4).String) + "." + (yyvsp(4) - (4).String)); ss.imbue(std::locale::classic()); ss >> (yyval.Dotnum); } - break; - - case 282: -#line 553 "lscp.y" - { std::stringstream ss("-" + (yyvsp(2) - (4).String) + "." + (yyvsp(4) - (4).String)); ss.imbue(std::locale::classic()); ss >> (yyval.Dotnum); } - break; - - case 283: -#line 557 "lscp.y" - { (yyval.String) = (yyvsp(1) - (1).Char); } - break; - - case 284: -#line 558 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).Char); } - break; - - case 285: -#line 561 "lscp.y" - { (yyval.Char) = '0'; } - break; - - case 286: -#line 562 "lscp.y" - { (yyval.Char) = '1'; } - break; - - case 287: -#line 563 "lscp.y" - { (yyval.Char) = '2'; } - break; - - case 288: -#line 564 "lscp.y" - { (yyval.Char) = '3'; } - break; - - case 289: -#line 565 "lscp.y" - { (yyval.Char) = '4'; } - break; - - case 290: -#line 566 "lscp.y" - { (yyval.Char) = '5'; } - break; - - case 291: -#line 567 "lscp.y" - { (yyval.Char) = '6'; } - break; - - case 292: -#line 568 "lscp.y" - { (yyval.Char) = '7'; } - break; - - case 293: -#line 569 "lscp.y" - { (yyval.Char) = '8'; } - break; - - case 294: -#line 570 "lscp.y" - { (yyval.Char) = '9'; } - break; - - case 295: -#line 573 "lscp.y" - { (yyval.Char) = '0'; } - break; - - case 296: -#line 574 "lscp.y" - { (yyval.Char) = '1'; } - break; - - case 297: -#line 575 "lscp.y" - { (yyval.Char) = '2'; } - break; - - case 298: -#line 576 "lscp.y" - { (yyval.Char) = '3'; } - break; - - case 299: -#line 577 "lscp.y" - { (yyval.Char) = '4'; } - break; - - case 300: -#line 578 "lscp.y" - { (yyval.Char) = '5'; } - break; - - case 301: -#line 579 "lscp.y" - { (yyval.Char) = '6'; } - break; - - case 302: -#line 580 "lscp.y" - { (yyval.Char) = '7'; } - break; - - case 303: -#line 583 "lscp.y" - { (yyval.Char) = '0'; } - break; - - case 304: -#line 584 "lscp.y" - { (yyval.Char) = '1'; } - break; - - case 305: -#line 585 "lscp.y" - { (yyval.Char) = '2'; } - break; - - case 306: -#line 586 "lscp.y" - { (yyval.Char) = '3'; } - break; - - case 307: -#line 587 "lscp.y" - { (yyval.Char) = '4'; } - break; - - case 308: -#line 588 "lscp.y" - { (yyval.Char) = '5'; } - break; - - case 309: -#line 589 "lscp.y" - { (yyval.Char) = '6'; } - break; - - case 310: -#line 590 "lscp.y" - { (yyval.Char) = '7'; } - break; - - case 311: -#line 591 "lscp.y" - { (yyval.Char) = '8'; } - break; - - case 312: -#line 592 "lscp.y" - { (yyval.Char) = '9'; } - break; - - case 313: -#line 593 "lscp.y" - { (yyval.Char) = 'a'; } - break; - - case 314: -#line 594 "lscp.y" - { (yyval.Char) = 'b'; } - break; - - case 315: -#line 595 "lscp.y" - { (yyval.Char) = 'c'; } - break; - - case 316: -#line 596 "lscp.y" - { (yyval.Char) = 'd'; } - break; - - case 317: -#line 597 "lscp.y" - { (yyval.Char) = 'e'; } - break; - - case 318: -#line 598 "lscp.y" - { (yyval.Char) = 'f'; } - break; - - case 319: -#line 599 "lscp.y" - { (yyval.Char) = 'a'; } - break; - - case 320: -#line 600 "lscp.y" - { (yyval.Char) = 'b'; } - break; - - case 321: -#line 601 "lscp.y" - { (yyval.Char) = 'c'; } - break; - - case 322: -#line 602 "lscp.y" - { (yyval.Char) = 'd'; } - break; - - case 323: -#line 603 "lscp.y" - { (yyval.Char) = 'e'; } - break; - - case 324: -#line 604 "lscp.y" - { (yyval.Char) = 'f'; } - break; - - case 325: -#line 607 "lscp.y" - { (yyval.Number) = atoi(String(1, (yyvsp(1) - (1).Char)).c_str()); } - break; - - case 326: -#line 608 "lscp.y" - { (yyval.Number) = atoi(String(String("1") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 327: -#line 609 "lscp.y" - { (yyval.Number) = atoi(String(String("2") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 328: -#line 610 "lscp.y" - { (yyval.Number) = atoi(String(String("3") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 329: -#line 611 "lscp.y" - { (yyval.Number) = atoi(String(String("4") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 330: -#line 612 "lscp.y" - { (yyval.Number) = atoi(String(String("5") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 331: -#line 613 "lscp.y" - { (yyval.Number) = atoi(String(String("6") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 332: -#line 614 "lscp.y" - { (yyval.Number) = atoi(String(String("7") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 333: -#line 615 "lscp.y" - { (yyval.Number) = atoi(String(String("8") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 334: -#line 616 "lscp.y" - { (yyval.Number) = atoi(String(String("9") + (yyvsp(2) - (2).String)).c_str()); } - break; - - case 335: -#line 619 "lscp.y" - { (yyval.UniversalPath) = (yyvsp(2) - (3).UniversalPath); } - break; - - case 336: -#line 620 "lscp.y" - { (yyval.UniversalPath) = (yyvsp(2) - (3).UniversalPath); } - break; - - case 337: -#line 623 "lscp.y" - { (yyval.UniversalPath) = (yyvsp(1) - (2).UniversalPath) + (yyvsp(2) - (2).UniversalPath); } - break; - - case 338: -#line 626 "lscp.y" - { (yyval.UniversalPath) = Path(); } - break; - - case 339: -#line 627 "lscp.y" - { Path p; p.setDrive((yyvsp(1) - (3).Char)); (yyval.UniversalPath) = p; } - break; - - case 340: -#line 630 "lscp.y" - { (yyval.UniversalPath) = Path(); } - break; - - case 341: -#line 631 "lscp.y" - { (yyval.UniversalPath) = (yyvsp(1) - (2).UniversalPath); } - break; - - case 342: -#line 632 "lscp.y" - { Path p; p.appendNode((yyvsp(2) - (2).String)); (yyval.UniversalPath) = (yyvsp(1) - (2).UniversalPath) + p; } - break; - - case 343: -#line 635 "lscp.y" - { (yyval.String) = (yyvsp(2) - (3).String); } - break; - - case 344: -#line 636 "lscp.y" - { (yyval.String) = (yyvsp(2) - (3).String); } - break; - - case 345: -#line 639 "lscp.y" - { (yyval.String) = (yyvsp(2) - (3).String); } - break; - - case 346: -#line 640 "lscp.y" - { (yyval.String) = (yyvsp(2) - (3).String); } - break; - - case 347: -#line 643 "lscp.y" - { (yyval.String) = " "; } - break; - - case 349: -#line 645 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + " "; } - break; - - case 350: -#line 646 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).String); } - break; - - case 351: -#line 650 "lscp.y" - { (yyval.String) = " "; } - break; - - case 353: -#line 652 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + " "; } - break; - - case 354: -#line 653 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).String); } - break; - - case 355: -#line 656 "lscp.y" - { (yyval.String) = "/"; } - break; - - case 357: -#line 658 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + "/"; } - break; - - case 358: -#line 659 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).String); } - break; - - case 359: -#line 662 "lscp.y" - { std::string s; s = (yyvsp(1) - (1).Char); (yyval.String) = s; } - break; - - case 360: -#line 663 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).Char); } - break; - - case 361: -#line 666 "lscp.y" - { std::string s; s = (yyvsp(1) - (1).Char); (yyval.String) = s; } - break; - - case 362: -#line 667 "lscp.y" - { std::string s; s = (yyvsp(1) - (1).Char); (yyval.String) = s; } - break; - - case 363: -#line 668 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).Char); } - break; - - case 364: -#line 669 "lscp.y" - { (yyval.String) = (yyvsp(1) - (2).String) + (yyvsp(2) - (2).Char); } - break; - - case 366: -#line 674 "lscp.y" - { (yyval.Char) = '\\'; } - break; - - case 367: -#line 675 "lscp.y" - { (yyval.Char) = '/'; } - break; - - case 368: -#line 679 "lscp.y" - { (yyval.Char) = 'A'; } - break; - - case 369: -#line 679 "lscp.y" - { (yyval.Char) = 'B'; } - break; - - case 370: -#line 679 "lscp.y" - { (yyval.Char) = 'C'; } - break; - - case 371: -#line 679 "lscp.y" - { (yyval.Char) = 'D'; } - break; - - case 372: -#line 679 "lscp.y" - { (yyval.Char) = 'E'; } - break; - - case 373: -#line 679 "lscp.y" - { (yyval.Char) = 'F'; } - break; - - case 374: -#line 679 "lscp.y" - { (yyval.Char) = 'G'; } - break; - - case 375: -#line 679 "lscp.y" - { (yyval.Char) = 'H'; } - break; - - case 376: -#line 679 "lscp.y" - { (yyval.Char) = 'I'; } - break; - - case 377: -#line 679 "lscp.y" - { (yyval.Char) = 'J'; } - break; - - case 378: -#line 679 "lscp.y" - { (yyval.Char) = 'K'; } - break; - - case 379: -#line 679 "lscp.y" - { (yyval.Char) = 'L'; } - break; - - case 380: -#line 679 "lscp.y" - { (yyval.Char) = 'M'; } - break; - - case 381: -#line 679 "lscp.y" - { (yyval.Char) = 'N'; } - break; - - case 382: -#line 679 "lscp.y" - { (yyval.Char) = 'O'; } - break; - - case 383: -#line 679 "lscp.y" - { (yyval.Char) = 'P'; } - break; - - case 384: -#line 679 "lscp.y" - { (yyval.Char) = 'Q'; } - break; - - case 385: -#line 679 "lscp.y" - { (yyval.Char) = 'R'; } - break; - - case 386: -#line 679 "lscp.y" - { (yyval.Char) = 'S'; } - break; - - case 387: -#line 679 "lscp.y" - { (yyval.Char) = 'T'; } - break; - - case 388: -#line 679 "lscp.y" - { (yyval.Char) = 'U'; } - break; - - case 389: -#line 679 "lscp.y" - { (yyval.Char) = 'V'; } - break; - - case 390: -#line 679 "lscp.y" - { (yyval.Char) = 'W'; } - break; - - case 391: -#line 679 "lscp.y" - { (yyval.Char) = 'X'; } - break; - - case 392: -#line 679 "lscp.y" - { (yyval.Char) = 'Y'; } - break; - - case 393: -#line 679 "lscp.y" - { (yyval.Char) = 'Z'; } - break; - - case 394: -#line 680 "lscp.y" - { (yyval.Char) = 'a'; } - break; - - case 395: -#line 680 "lscp.y" - { (yyval.Char) = 'b'; } - break; - - case 396: -#line 680 "lscp.y" - { (yyval.Char) = 'c'; } - break; - - case 397: -#line 680 "lscp.y" - { (yyval.Char) = 'd'; } - break; - - case 398: -#line 680 "lscp.y" - { (yyval.Char) = 'e'; } - break; - - case 399: -#line 680 "lscp.y" - { (yyval.Char) = 'f'; } - break; - - case 400: -#line 680 "lscp.y" - { (yyval.Char) = 'g'; } - break; - - case 401: -#line 680 "lscp.y" - { (yyval.Char) = 'h'; } - break; - - case 402: -#line 680 "lscp.y" - { (yyval.Char) = 'i'; } - break; - - case 403: -#line 680 "lscp.y" - { (yyval.Char) = 'j'; } - break; - - case 404: -#line 680 "lscp.y" - { (yyval.Char) = 'k'; } - break; - - case 405: -#line 680 "lscp.y" - { (yyval.Char) = 'l'; } - break; - - case 406: -#line 680 "lscp.y" - { (yyval.Char) = 'm'; } - break; - - case 407: -#line 680 "lscp.y" - { (yyval.Char) = 'n'; } - break; - - case 408: -#line 680 "lscp.y" - { (yyval.Char) = 'o'; } - break; - - case 409: -#line 680 "lscp.y" - { (yyval.Char) = 'p'; } - break; - - case 410: -#line 680 "lscp.y" - { (yyval.Char) = 'q'; } - break; - - case 411: -#line 680 "lscp.y" - { (yyval.Char) = 'r'; } - break; - - case 412: -#line 680 "lscp.y" - { (yyval.Char) = 's'; } - break; - - case 413: -#line 680 "lscp.y" - { (yyval.Char) = 't'; } - break; - - case 414: -#line 680 "lscp.y" - { (yyval.Char) = 'u'; } - break; - - case 415: -#line 680 "lscp.y" - { (yyval.Char) = 'v'; } - break; - - case 416: -#line 680 "lscp.y" - { (yyval.Char) = 'w'; } - break; - - case 417: -#line 680 "lscp.y" - { (yyval.Char) = 'x'; } - break; - - case 418: -#line 680 "lscp.y" - { (yyval.Char) = 'y'; } - break; - - case 419: -#line 680 "lscp.y" - { (yyval.Char) = 'z'; } - break; - - case 421: -#line 685 "lscp.y" - { (yyval.Char) = '0'; } - break; - - case 422: -#line 685 "lscp.y" - { (yyval.Char) = '1'; } - break; - - case 423: -#line 685 "lscp.y" - { (yyval.Char) = '2'; } - break; - - case 424: -#line 685 "lscp.y" - { (yyval.Char) = '3'; } - break; - - case 425: -#line 685 "lscp.y" - { (yyval.Char) = '4'; } - break; - - case 426: -#line 685 "lscp.y" - { (yyval.Char) = '5'; } - break; - - case 427: -#line 685 "lscp.y" - { (yyval.Char) = '6'; } - break; - - case 428: -#line 685 "lscp.y" - { (yyval.Char) = '7'; } - break; - - case 429: -#line 685 "lscp.y" - { (yyval.Char) = '8'; } - break; - - case 430: -#line 685 "lscp.y" - { (yyval.Char) = '9'; } - break; - - case 431: -#line 686 "lscp.y" - { (yyval.Char) = '!'; } - break; - - case 432: -#line 686 "lscp.y" - { (yyval.Char) = '#'; } - break; - - case 433: -#line 686 "lscp.y" - { (yyval.Char) = '$'; } - break; - - case 434: -#line 686 "lscp.y" - { (yyval.Char) = '%'; } - break; - - case 435: -#line 686 "lscp.y" - { (yyval.Char) = '&'; } - break; - - case 436: -#line 686 "lscp.y" - { (yyval.Char) = '('; } - break; - - case 437: -#line 686 "lscp.y" - { (yyval.Char) = ')'; } - break; - - case 438: -#line 686 "lscp.y" - { (yyval.Char) = '*'; } - break; - - case 439: -#line 686 "lscp.y" - { (yyval.Char) = '+'; } - break; - - case 440: -#line 686 "lscp.y" - { (yyval.Char) = '-'; } - break; - - case 441: -#line 686 "lscp.y" - { (yyval.Char) = '.'; } - break; - - case 442: -#line 686 "lscp.y" - { (yyval.Char) = ','; } - break; - - case 443: -#line 687 "lscp.y" - { (yyval.Char) = ':'; } - break; - - case 444: -#line 687 "lscp.y" - { (yyval.Char) = ';'; } - break; - - case 445: -#line 687 "lscp.y" - { (yyval.Char) = '<'; } - break; - - case 446: -#line 687 "lscp.y" - { (yyval.Char) = '='; } - break; - - case 447: -#line 687 "lscp.y" - { (yyval.Char) = '>'; } - break; - - case 448: -#line 687 "lscp.y" - { (yyval.Char) = '?'; } - break; - - case 449: -#line 687 "lscp.y" - { (yyval.Char) = '@'; } - break; - - case 450: -#line 688 "lscp.y" - { (yyval.Char) = ''; } - break; - - case 451: -#line 688 "lscp.y" - { (yyval.Char) = ''; } - break; - - case 452: -#line 688 "lscp.y" - { (yyval.Char) = '^'; } - break; - - case 453: -#line 688 "lscp.y" - { (yyval.Char) = '_'; } - break; - - case 454: -#line 689 "lscp.y" - { (yyval.Char) = '{'; } - break; - - case 455: -#line 689 "lscp.y" - { (yyval.Char) = '|'; } - break; - - case 456: -#line 689 "lscp.y" - { (yyval.Char) = '}'; } - break; - - case 457: -#line 689 "lscp.y" - { (yyval.Char) = '~'; } - break; - - case 459: -#line 693 "lscp.y" - { (yyval.Char) = '\''; } - break; - - case 460: -#line 694 "lscp.y" - { (yyval.Char) = '\"'; } - break; - - case 461: -#line 695 "lscp.y" - { (yyval.Char) = '\\'; } - break; - - case 462: -#line 696 "lscp.y" - { (yyval.Char) = '/'; } - break; - - case 463: -#line 697 "lscp.y" - { (yyval.Char) = '\n'; } - break; - - case 464: -#line 698 "lscp.y" - { (yyval.Char) = '\r'; } - break; - - case 465: -#line 699 "lscp.y" - { (yyval.Char) = '\f'; } - break; - - case 466: -#line 700 "lscp.y" - { (yyval.Char) = '\t'; } - break; - - case 467: -#line 701 "lscp.y" - { (yyval.Char) = '\v'; } - break; - - case 470: -#line 706 "lscp.y" - { (yyval.Char) = (char) octalsToNumber((yyvsp(2) - (2).Char)); } - break; - - case 471: -#line 707 "lscp.y" - { (yyval.Char) = (char) octalsToNumber((yyvsp(3) - (3).Char),(yyvsp(2) - (3).Char)); } - break; - - case 472: -#line 708 "lscp.y" - { (yyval.Char) = (char) octalsToNumber((yyvsp(4) - (4).Char),(yyvsp(3) - (4).Char),(yyvsp(2) - (4).Char)); } - break; - - case 473: -#line 711 "lscp.y" - { (yyval.Char) = (char) hexsToNumber((yyvsp(3) - (3).Char)); } - break; - - case 474: -#line 712 "lscp.y" - { (yyval.Char) = (char) hexsToNumber((yyvsp(4) - (4).Char),(yyvsp(3) - (4).Char)); } - break; - - -/* Line 1267 of yacc.c. */ -#line 5837 "y.tab.c" - default: break; - } - YY_SYMBOL_PRINT ("-> $$ =", yyr1yyn, &yyval, &yyloc); - - YYPOPSTACK (yylen); - yylen = 0; - YY_STACK_PRINT (yyss, yyssp); - - *++yyvsp = yyval; - - - /* Now `shift' the result of the reduction. Determine what state - that goes to, based on the state we popped back to and the rule - number reduced by. */ - - yyn = yyr1yyn; - - yystate = yypgotoyyn - YYNTOKENS + *yyssp; - if (0 <= yystate && yystate <= YYLAST && yycheckyystate == *yyssp) - yystate = yytableyystate; - else - yystate = yydefgotoyyn - YYNTOKENS; - - goto yynewstate; - - -/*------------------------------------. -| yyerrlab -- here on detecting error | -`------------------------------------*/ -yyerrlab: - /* If not already recovering from an error, report this error. */ - if (!yyerrstatus) - { - ++yynerrs; -#if ! YYERROR_VERBOSE - yyerror (YY_("syntax error")); -#else - { - YYSIZE_T yysize = yysyntax_error (0, yystate, yychar); - if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM) - { - YYSIZE_T yyalloc = 2 * yysize; - if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM)) - yyalloc = YYSTACK_ALLOC_MAXIMUM; - if (yymsg != yymsgbuf) - YYSTACK_FREE (yymsg); - yymsg = (char *) YYSTACK_ALLOC (yyalloc); - if (yymsg) - yymsg_alloc = yyalloc; - else - { - yymsg = yymsgbuf; - yymsg_alloc = sizeof yymsgbuf; - } - } - - if (0 < yysize && yysize <= yymsg_alloc) - { - (void) yysyntax_error (yymsg, yystate, yychar); - yyerror (yymsg); - } - else - { - yyerror (YY_("syntax error")); - if (yysize != 0) - goto yyexhaustedlab; - } - } -#endif - } - - - - if (yyerrstatus == 3) - { - /* If just tried and failed to reuse look-ahead token after an - error, discard it. */ - - if (yychar <= YYEOF) - { - /* Return failure if at end of input. */ - if (yychar == YYEOF) - YYABORT; - } - else - { - yydestruct ("Error: discarding", - yytoken, &yylval); - yychar = YYEMPTY; - } - } - - /* Else will try to reuse look-ahead token after shifting the error - token. */ - goto yyerrlab1; - - -/*---------------------------------------------------. -| yyerrorlab -- error raised explicitly by YYERROR. | -`---------------------------------------------------*/ -yyerrorlab: - - /* Pacify compilers like GCC when the user code never invokes - YYERROR and the label yyerrorlab therefore never appears in user - code. */ - if (/*CONSTCOND*/ 0) - goto yyerrorlab; - - /* Do not reclaim the symbols of the rule which action triggered - this YYERROR. */ - YYPOPSTACK (yylen); - yylen = 0; - YY_STACK_PRINT (yyss, yyssp); - yystate = *yyssp; - goto yyerrlab1; - - -/*-------------------------------------------------------------. -| yyerrlab1 -- common code for both syntax error and YYERROR. | -`-------------------------------------------------------------*/ -yyerrlab1: - yyerrstatus = 3; /* Each real token shifted decrements this. */ - - for (;;) - { - yyn = yypactyystate; - if (yyn != YYPACT_NINF) - { - yyn += YYTERROR; - if (0 <= yyn && yyn <= YYLAST && yycheckyyn == YYTERROR) - { - yyn = yytableyyn; - if (0 < yyn) - break; - } - } - - /* Pop the current state because it cannot handle the error token. */ - if (yyssp == yyss) - YYABORT; - - - yydestruct ("Error: popping", - yystosyystate, yyvsp); - YYPOPSTACK (1); - yystate = *yyssp; - YY_STACK_PRINT (yyss, yyssp); - } - - if (yyn == YYFINAL) - YYACCEPT; - - *++yyvsp = yylval; - - - /* Shift the error token. */ - YY_SYMBOL_PRINT ("Shifting", yystosyyn, yyvsp, yylsp); - - yystate = yyn; - goto yynewstate; - - -/*-------------------------------------. -| yyacceptlab -- YYACCEPT comes here. | -`-------------------------------------*/ -yyacceptlab: - yyresult = 0; - goto yyreturn; - -/*-----------------------------------. -| yyabortlab -- YYABORT comes here. | -`-----------------------------------*/ -yyabortlab: - yyresult = 1; - goto yyreturn; - -#ifndef yyoverflow -/*-------------------------------------------------. -| yyexhaustedlab -- memory exhaustion comes here. | -`-------------------------------------------------*/ -yyexhaustedlab: - yyerror (YY_("memory exhausted")); - yyresult = 2; - /* Fall through. */ -#endif - -yyreturn: - if (yychar != YYEOF && yychar != YYEMPTY) - yydestruct ("Cleanup: discarding lookahead", - yytoken, &yylval); - /* Do not reclaim the symbols of the rule which action triggered - this YYABORT or YYACCEPT. */ - YYPOPSTACK (yylen); - YY_STACK_PRINT (yyss, yyssp); - while (yyssp != yyss) - { - yydestruct ("Cleanup: popping", - yystos*yyssp, yyvsp); - YYPOPSTACK (1); - } -#ifndef yyoverflow - if (yyss != yyssa) - YYSTACK_FREE (yyss); -#endif -#if YYERROR_VERBOSE - if (yymsg != yymsgbuf) - YYSTACK_FREE (yymsg); -#endif - /* Make sure YYID is used. */ - return YYID (yyresult); -} - - -#line 1077 "lscp.y" - - -/** - * Will be called when an error occured (usually syntax error). - */ -void yyerror(const char* s) { - yyparse_param_t* param = GetCurrentYaccSession(); - String msg = s - + (" (line:" + ToString(param->iLine+1)) - + ( ",column:" + ToString(param->iColumn)) - + ")"; - dmsg(2,("LSCPParser: %s\n", msg.c_str())); - sLastError = msg; -} - -namespace LinuxSampler { - -/** - * Clears input buffer. - */ -void restart(yyparse_param_t* pparam, int& yychar) { - bytes = 0; - ptr = 0; - sLastError = ""; -} - -} -
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpsymbols.h
Deleted
@@ -1,59 +0,0 @@ -/* A Bison parser, made by GNU Bison 2.3. */ - -/* Skeleton interface for Bison's Yacc-like parsers in C - - Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - Free Software Foundation, Inc. - - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2, or (at your option) - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, - Boston, MA 02110-1301, USA. */ - -/* As a special exception, you may create a larger work that contains - part or all of the Bison parser skeleton and distribute that work - under terms of your choice, so long as that work isn't itself a - parser generator using the skeleton or a modified version thereof - as a parser skeleton. Alternatively, if you modify or redistribute - the parser skeleton itself, you may (at your option) remove this - special exception, which will cause the skeleton and the resulting - Bison output files to be licensed under the GNU General Public - License without this special exception. - - This special exception was added by the Free Software Foundation in - version 2.2 of Bison. */ - -/* Tokens. */ -#ifndef YYTOKENTYPE -# define YYTOKENTYPE - /* Put the tokens into the symbol table, so that GDB and other debuggers - know about them. */ - enum yytokentype { - EXT_ASCII_CHAR = 258 - }; -#endif -/* Tokens. */ -#define EXT_ASCII_CHAR 258 - - - - -#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED -typedef int YYSTYPE; -# define yystype YYSTYPE /* obsolescent; will be withdrawn */ -# define YYSTYPE_IS_DECLARED 1 -# define YYSTYPE_IS_TRIVIAL 1 -#endif - - -
View file
linuxsampler-1.0.0.tar.bz2/src/plugins/Makefile.in
Deleted
@@ -1,543 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - - -SOURCES = $(liblinuxsamplerplugins_la_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -subdir = src/plugins -DIST_COMMON = $(liblinuxsamplerpluginsinclude_HEADERS) \ - $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -LTLIBRARIES = $(noinst_LTLIBRARIES) -liblinuxsamplerplugins_la_LIBADD = -am_liblinuxsamplerplugins_la_OBJECTS = InstrumentEditor.lo \ - InstrumentEditorFactory.lo -liblinuxsamplerplugins_la_OBJECTS = \ - $(am_liblinuxsamplerplugins_la_OBJECTS) -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/InstrumentEditor.Plo \ -@AMDEP_TRUE@ ./$(DEPDIR)/InstrumentEditorFactory.Plo -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(liblinuxsamplerplugins_la_SOURCES) -DIST_SOURCES = $(liblinuxsamplerplugins_la_SOURCES) -am__installdirs = "$(DESTDIR)$(liblinuxsamplerpluginsincludedir)" -liblinuxsamplerpluginsincludeHEADERS_INSTALL = $(INSTALL_HEADER) -HEADERS = $(liblinuxsamplerpluginsinclude_HEADERS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) -AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -DCONFIG_PLUGIN_DIR=\"$(config_plugin_dir)\" -METASOURCES = AUTO -liblinuxsamplerpluginsincludedir = $(includedir)/linuxsampler/plugins -liblinuxsamplerpluginsinclude_HEADERS = \ - InstrumentEditor.h \ - InstrumentEditorFactory.h - -noinst_LTLIBRARIES = liblinuxsamplerplugins.la -liblinuxsamplerplugins_la_SOURCES = \ - InstrumentEditor.cpp InstrumentEditor.h \ - InstrumentEditorFactory.cpp InstrumentEditorFactory.h - -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/plugins/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/plugins/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -clean-noinstLTLIBRARIES: - -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) - @list='$(noinst_LTLIBRARIES)'; for p in $$list; do \ - dir="`echo $$p | sed -e 's|/^/*$$||'`"; \ - test "$$dir" != "$$p" || dir=.; \ - echo "rm -f \"$${dir}/so_locations\""; \ - rm -f "$${dir}/so_locations"; \ - done -liblinuxsamplerplugins.la: $(liblinuxsamplerplugins_la_OBJECTS) $(liblinuxsamplerplugins_la_DEPENDENCIES) - $(CXXLINK) $(liblinuxsamplerplugins_la_LDFLAGS) $(liblinuxsamplerplugins_la_OBJECTS) $(liblinuxsamplerplugins_la_LIBADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/InstrumentEditor.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/InstrumentEditorFactory.Plo@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: -install-liblinuxsamplerpluginsincludeHEADERS: $(liblinuxsamplerpluginsinclude_HEADERS) - @$(NORMAL_INSTALL) - test -z "$(liblinuxsamplerpluginsincludedir)" || $(mkdir_p) "$(DESTDIR)$(liblinuxsamplerpluginsincludedir)" - @list='$(liblinuxsamplerpluginsinclude_HEADERS)'; for p in $$list; do \ - if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " $(liblinuxsamplerpluginsincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(liblinuxsamplerpluginsincludedir)/$$f'"; \ - $(liblinuxsamplerpluginsincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(liblinuxsamplerpluginsincludedir)/$$f"; \ - done - -uninstall-liblinuxsamplerpluginsincludeHEADERS: - @$(NORMAL_UNINSTALL) - @list='$(liblinuxsamplerpluginsinclude_HEADERS)'; for p in $$list; do \ - f="`echo $$p | sed -e 's|^.*/||'`"; \ - echo " rm -f '$(DESTDIR)$(liblinuxsamplerpluginsincludedir)/$$f'"; \ - rm -f "$(DESTDIR)$(liblinuxsamplerpluginsincludedir)/$$f"; \ - done - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile $(LTLIBRARIES) $(HEADERS) -installdirs: - for dir in "$(DESTDIR)$(liblinuxsamplerpluginsincludedir)"; do \ - test -z "$$dir" || $(mkdir_p) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ - mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: install-liblinuxsamplerpluginsincludeHEADERS - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am \ - uninstall-liblinuxsamplerpluginsincludeHEADERS - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool clean-noinstLTLIBRARIES ctags distclean \ - distclean-compile distclean-generic distclean-libtool \ - distclean-tags distdir dvi dvi-am html html-am info info-am \ - install install-am install-data install-data-am install-exec \ - install-exec-am install-info install-info-am \ - install-liblinuxsamplerpluginsincludeHEADERS install-man \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ - pdf pdf-am ps ps-am tags uninstall uninstall-am \ - uninstall-info-am \ - uninstall-liblinuxsamplerpluginsincludeHEADERS - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/src/testcases/Makefile.in
Deleted
@@ -1,512 +0,0 @@ -# Makefile.in generated by automake 1.8.5 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004 Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ -SOURCES = $(linuxsamplertest_SOURCES) - -srcdir = @srcdir@ -top_srcdir = @top_srcdir@ -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = @INSTALL@ -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -host_triplet = @host@ -EXTRA_PROGRAMS = linuxsamplertest$(EXEEXT) -subdir = src/testcases -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/arts.m4 \ - $(top_srcdir)/m4/nptl_bug.m4 $(top_srcdir)/m4/pthread.m4 \ - $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -mkinstalldirs = $(mkdir_p) -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am_linuxsamplertest_OBJECTS = linuxsamplertest.$(OBJEXT) \ - PoolTest.$(OBJEXT) ThreadTest.$(OBJEXT) MutexTest.$(OBJEXT) \ - ConditionTest.$(OBJEXT) LSCPTest.$(OBJEXT) -linuxsamplertest_OBJECTS = $(am_linuxsamplertest_OBJECTS) -linuxsamplertest_DEPENDENCIES = \ - $(top_builddir)/src/liblinuxsampler.la -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/ConditionTest.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/LSCPTest.Po ./$(DEPDIR)/MutexTest.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/PoolTest.Po ./$(DEPDIR)/ThreadTest.Po \ -@AMDEP_TRUE@ ./$(DEPDIR)/linuxsamplertest.Po -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ - $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) \ - $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ - $(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ - $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(linuxsamplertest_SOURCES) -DIST_SOURCES = $(linuxsamplertest_SOURCES) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = @ACLOCAL@ -AMDEP_FALSE = @AMDEP_FALSE@ -AMDEP_TRUE = @AMDEP_TRUE@ -AMTAR = @AMTAR@ -AR = @AR@ -ARTS_CFLAGS = @ARTS_CFLAGS@ -ARTS_CONFIG = @ARTS_CONFIG@ -ARTS_LIBS = @ARTS_LIBS@ -AS = @AS@ -ASIOSDK_BASEDIR = @ASIOSDK_BASEDIR@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CROSS_COMPILING_FALSE = @CROSS_COMPILING_FALSE@ -CROSS_COMPILING_TRUE = @CROSS_COMPILING_TRUE@ -CXX = @CXX@ -CXXCPP = @CXXCPP@ -CXXDEPMODE = @CXXDEPMODE@ -CXXFLAGS = @CXXFLAGS@ -CXX_CPU_SWITCH = @CXX_CPU_SWITCH@ -CYGPATH_W = @CYGPATH_W@ -DEFS = @DEFS@ -DEPDIR = @DEPDIR@ -DLLTOOL = @DLLTOOL@ -DSYMUTIL = @DSYMUTIL@ -ECHO = @ECHO@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -F77 = @F77@ -FFLAGS = @FFLAGS@ -GIG_CFLAGS = @GIG_CFLAGS@ -GIG_LIBS = @GIG_LIBS@ -GREP = @GREP@ -HAVE_ALSA_FALSE = @HAVE_ALSA_FALSE@ -HAVE_ALSA_TRUE = @HAVE_ALSA_TRUE@ -HAVE_ARTS_FALSE = @HAVE_ARTS_FALSE@ -HAVE_ARTS_TRUE = @HAVE_ARTS_TRUE@ -HAVE_ASIO_FALSE = @HAVE_ASIO_FALSE@ -HAVE_ASIO_TRUE = @HAVE_ASIO_TRUE@ -HAVE_AUFLAGS_FALSE = @HAVE_AUFLAGS_FALSE@ -HAVE_AUFLAGS_TRUE = @HAVE_AUFLAGS_TRUE@ -HAVE_AU_FALSE = @HAVE_AU_FALSE@ -HAVE_AU_TRUE = @HAVE_AU_TRUE@ -HAVE_COREAUDIO_FALSE = @HAVE_COREAUDIO_FALSE@ -HAVE_COREAUDIO_TRUE = @HAVE_COREAUDIO_TRUE@ -HAVE_COREMIDI_FALSE = @HAVE_COREMIDI_FALSE@ -HAVE_COREMIDI_TRUE = @HAVE_COREMIDI_TRUE@ -HAVE_DSSI_FALSE = @HAVE_DSSI_FALSE@ -HAVE_DSSI_TRUE = @HAVE_DSSI_TRUE@ -HAVE_JACK_FALSE = @HAVE_JACK_FALSE@ -HAVE_JACK_MIDI_FALSE = @HAVE_JACK_MIDI_FALSE@ -HAVE_JACK_MIDI_TRUE = @HAVE_JACK_MIDI_TRUE@ -HAVE_JACK_TRUE = @HAVE_JACK_TRUE@ -HAVE_LV2_FALSE = @HAVE_LV2_FALSE@ -HAVE_LV2_TRUE = @HAVE_LV2_TRUE@ -HAVE_MIDISHARE_FALSE = @HAVE_MIDISHARE_FALSE@ -HAVE_MIDISHARE_TRUE = @HAVE_MIDISHARE_TRUE@ -HAVE_MME_MIDI_FALSE = @HAVE_MME_MIDI_FALSE@ -HAVE_MME_MIDI_TRUE = @HAVE_MME_MIDI_TRUE@ -HAVE_SQLITE3_FALSE = @HAVE_SQLITE3_FALSE@ -HAVE_SQLITE3_TRUE = @HAVE_SQLITE3_TRUE@ -HAVE_VST_FALSE = @HAVE_VST_FALSE@ -HAVE_VST_TRUE = @HAVE_VST_TRUE@ -HAVE_WINDOWS_FALSE = @HAVE_WINDOWS_FALSE@ -HAVE_WINDOWS_TRUE = @HAVE_WINDOWS_TRUE@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -JACK_CFLAGS = @JACK_CFLAGS@ -JACK_LIBS = @JACK_LIBS@ -LDFLAGS = @LDFLAGS@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LIBTOOL = @LIBTOOL@ -LN_S = @LN_S@ -LTLIBOBJS = @LTLIBOBJS@ -LV2_CFLAGS = @LV2_CFLAGS@ -LV2_LIBS = @LV2_LIBS@ -MAKEINFO = @MAKEINFO@ -NMEDIT = @NMEDIT@ -OBJDUMP = @OBJDUMP@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -PKG_CONFIG = @PKG_CONFIG@ -PTHREAD_CC = @PTHREAD_CC@ -PTHREAD_CFLAGS = @PTHREAD_CFLAGS@ -PTHREAD_LIBS = @PTHREAD_LIBS@ -RANLIB = @RANLIB@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHARED_VERSION_INFO = @SHARED_VERSION_INFO@ -SHELL = @SHELL@ -SHLIB_VERSION_ARG = @SHLIB_VERSION_ARG@ -SQLITE3_CFLAGS = @SQLITE3_CFLAGS@ -SQLITE3_LIBS = @SQLITE3_LIBS@ -STRIP = @STRIP@ -VERSION = @VERSION@ -VSTSDK_DIR = @VSTSDK_DIR@ -ac_ct_CC = @ac_ct_CC@ -ac_ct_CXX = @ac_ct_CXX@ -ac_ct_F77 = @ac_ct_F77@ -acx_pthread_config = @acx_pthread_config@ -am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@ -am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -config_asiosdk_dir = @config_asiosdk_dir@ -config_default_instruments_db_file = @config_default_instruments_db_file@ -config_plugin_dir = @config_plugin_dir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -sysconfdir = @sysconfdir@ -target_alias = @target_alias@ -INCLUDES = $(all_includes) -METASOURCES = AUTO -@HAVE_COREMIDI_FALSE@coremidi_ldflags = -@HAVE_COREMIDI_TRUE@coremidi_ldflags = -framework CoreFoundation -framework CoreMIDI -linuxsamplertest_SOURCES = \ - linuxsamplertest.cpp \ - PoolTest.cpp PoolTest.h \ - ThreadTest.cpp ThreadTest.h \ - MutexTest.cpp MutexTest.h \ - ConditionTest.cpp ConditionTest.h \ - LSCPTest.cpp LSCPTest.h - -linuxsamplertest_LDFLAGS = $(coremidi_ldflags) -linuxsamplertest_LDADD = $(top_builddir)/src/liblinuxsampler.la -lcppunit -all: all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj -$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) - @for dep in $?; do \ - case '$(am__configure_deps)' in \ - *$$dep*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \ - && exit 0; \ - exit 1;; \ - esac; \ - done; \ - echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/testcases/Makefile'; \ - cd $(top_srcdir) && \ - $(AUTOMAKE) --gnu src/testcases/Makefile -.PRECIOUS: Makefile -Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status - @case '$?' in \ - *config.status*) \ - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ - *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ - esac; - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh - -$(top_srcdir)/configure: $(am__configure_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh -linuxsamplertest$(EXEEXT): $(linuxsamplertest_OBJECTS) $(linuxsamplertest_DEPENDENCIES) - @rm -f linuxsamplertest$(EXEEXT) - $(CXXLINK) $(linuxsamplertest_LDFLAGS) $(linuxsamplertest_OBJECTS) $(linuxsamplertest_LDADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ConditionTest.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LSCPTest.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MutexTest.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/PoolTest.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ThreadTest.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/linuxsamplertest.Po@am__quote@ - -.cpp.o: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -@am__fastdepCXX_TRUE@ if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -@am__fastdepCXX_TRUE@ if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: - -rm -f *.lo - -clean-libtool: - -rm -rf .libs _libs - -distclean-libtool: - -rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$tags $$unique; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - tags=; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) ' { files$$0 = 1; } \ - END { for (i in files) print i; }'`; \ - test -z "$(CTAGS_ARGS)$$tags$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$tags $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && cd $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ - list='$(DISTFILES)'; for file in $$list; do \ - case $$file in \ - $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ - $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ - esac; \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - dir=`echo "$$file" | sed -e 's,/^/*$$,,'`; \ - if test "$$dir" != "$$file" && test "$$dir" != "."; then \ - dir="/$$dir"; \ - $(mkdir_p) "$(distdir)$$dir"; \ - else \ - dir=''; \ - fi; \ - if test -d $$d/$$file; then \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ - fi; \ - cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ - else \ - test -f $(distdir)/$$file \ - || cp -p $$d/$$file $(distdir)/$$file \ - || exit 1; \ - fi; \ - done -check-am: all-am -check: check-am -all-am: Makefile -installdirs: -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: - -rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ - mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-info-am - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \ - clean-libtool ctags distclean distclean-compile \ - distclean-generic distclean-libtool distclean-tags distdir dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-exec install-exec-am \ - install-info install-info-am install-man install-strip \ - installcheck installcheck-am installdirs maintainer-clean \ - maintainer-clean-generic mostlyclean mostlyclean-compile \ - mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ - tags uninstall uninstall-am uninstall-info-am - -# Tell versions 3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT:
View file
linuxsampler-1.0.0.tar.bz2/AUTHORS -> linuxsampler-2342.tar.bz2/AUTHORS
Changed
@@ -46,3 +46,4 @@ Andrew Williams Devin Anderson Chris Cherrett + David Robillard
View file
linuxsampler-1.0.0.tar.bz2/ChangeLog -> linuxsampler-2342.tar.bz2/ChangeLog
Changed
@@ -1,3 +1,338 @@ +Version CVS HEAD (?) + + * plugin changes: + - LV2 "state" extension support (patch by David Robillard) + + * packaging changes: + - fixed building with newer MinGW-w64 + - Mac OS X: support the new dir for Core Audio SDK + - Mac OS X: fixed building outside source directory + - made sure all source files for hostplugins are included when + doing "make dist" + - removed empty directories left from the cvs to svn migration + - fixed compilation with gcc 4.6.1 + - another "make dist" fix, for the LV2 plugin + - made --enable-pthread-testcancel default on Mac OS X + - minor Makefile fix for building lscpparser when build and source + directories are separate + - Mac OS X: made it possible to specify plugin installation dir to + configure + - Mac OS X: Makefile fix for the install-strip target + - fixed compilation with gcc 4.7 + + * general changes: + - Refactoring: moved the independent code from + the Gigasampler format engine to base classes + - command line option '--profile' is currently disabled, since the + respective profiling code is currently broken + - Introduced support for optional environment variable + "LINUXSAMPLER_PLUGIN_DIR" which allows to override the directory + where the sampler shall look for instrument editor plugins + (patch by Luis Garrido, slightly modified). + - implemented Roland GS NRPN 1ArrH which allows to set volume per note + - implemented Roland GS NRPN 1CrrH which allows to set pan per note + - implemented Roland GS NRPN 1DrrH which allows to set reverb send per + note (in this implementation of the sampler its simply hard routed to + the 1st effect send of the sampler channel, no matter what the actual + effect type is) + - implemented Roland GS NRPN 1ErrH which allows to set chorus send per + note (in this implementation of the sampler its simply hard routed to + the 2nd effect send of the sampler channel, no matter what the actual + effect type is) + - implemented support for internal LADSPA effects + - raised limit of program change queue from 100 to 512 + (as suggested by Alex Stone) + - implemented sine LFO, pulse LFO and saw LFO + - experimental support for per voice equalization + - added command line option --exec-after-init + - Introduced new C++ API method: + EngineChannel::InstrumentFileName(int index) + allowing to retrieve the whole list of files used for the loaded + instrument on an engine channel (a.k.a. part). Some GigaStudio + instruments for example are splitted over several files like + "Foo.gig", "Foo.gx01", "Foo.gx02", ... + + * Gigasampler format engine: + - implemented the "round robin keyboard" dimension + - fixed round robin and random dimensions for cases when number of + dimension zones is not a power of two + - made round robin use a counter for each region instead of each + key + + * SFZ format engine: + - Initial implementation (not usable yet) + - added support for v2 multiple stage envelope generators + - added a fine-tuned v1 envelope generator instead of using the + one from the gig engine + - fixed memory leak and memory handling errors + - added support for trigger=first, trigger=legato and sw_previous + - allow non-numerical key values ("C#4" for example) + - "key" opcode now sets pitch_keycenter too + - fixed error when unloading instrument with same sample used by + multiple regions + - added some opcode aliases, like loopmode for loop_mode, to be + more compatible + - added support for trigger=release and rt_decay + - added support for off_mode=normal + - added support for random, seq_position, seq_length and volume + - added v1 LFO opcodes to parser (no support in engine yet) + - added support for amp_veltrack and amp_velcurve_N + - fine-tuned the default velocity curve + - added support for transpose + - fixed crash when using sw_down/up + - improved logic for sw_lokey/hikey/up/down/last + - added more v1 aliases to parser + - reduced memory usage for sfz data + - RT-safeness: avoid malloc in audio thread + - fixed a bug that could cause voice stealing to fail + - optimized sample lookup + - improved support for exclusive groups (group, off_by and + off_mode) + - added support for controller triggered regions (on_locc/on_hicc) + - added support for loop_mode=one_shot + - fixed playback of 16 bit wav files on big endian CPUs + - added support for Ogg Vorbis sample files + - use loop markers from sample file if loop_start and loop_end are + not set in sfz file + - implemeted filters. Filter types: lowpass, bandpass, bandreject + and highpass. 1, 2, 4 and 6 pole filters. Opcodes: fil_type, + cutoff, resonance, fil_veltrack, fil_keytrack, fil_keycenter, + cutoff_cc, cutoff_chanaft. + - bugfix: zero ampeg_sustain didn't work + - added support for velocity effect on amplifier envelope time + (ampeg_vel2attack, ampeg_vel2decay, ampeg_vel2sustain and + ampeg_vel2release) + - added support for EG hold (ampeg_hold) + - added support for sample offset (offset) + - use the newly introduced signal units model + - implemented opcodes lfoN_delay, + lfoN_freq, lfoN_pan, lfoN_cutoff, lfoN_resonance + - implemented opcodes ampeg_delay, ampeg_vel2delay + pitcheg_delay, pitcheg_start, pitcheg_attack, pitcheg_hold, + pitcheg_decay, pitcheg_sustain, pitcheg_release, pitcheg_vel2delay, + pitcheg_vel2attack, pitcheg_vel2hold, pitcheg_vel2decay, + pitcheg_vel2sustain, pitcheg_vel2release, pitcheg_depth + - implemented opcodes pitchlfo_delay, pitchlfo_freq, + pitchlfo_depth, fillfo_delay, fillfo_freq, fillfo_depth, + amplfo_delay, amplfo_freq, amplfo_depth + - implemented opcodes fileg_delay, fileg_start, fileg_attack, + fileg_hold, fileg_decay, fileg_sustain, fileg_release, fileg_vel2delay, + fileg_vel2attack, fileg_vel2hold, fileg_vel2decay, fileg_vel2sustain, + fileg_vel2release + - implemented opcode lfoN_wave + - implemented opcode pitchlfo_depthccN + - implemented opcodes lfoN_phase, lfoN_phase_onccX, + lfoN_pitch, lfoN_pitch_onccX + - implemented opcodes pitchlfo_fade, + fillfo_fade, amplfo_fade, lfoN_fade, lfoN_fade_onccX + - implemented opcodes fillfo_freqccN, + pitchlfo_freqccN, amplfo_freqccN, lfoN_freq_onccX + - implemented opcodes ampeg_delayccN, ampeg_startccN, + ampeg_attackccN, ampeg_holdccN, ampeg_decayccN, ampeg_sustainccN, + ampeg_releaseccN, egN_timeX_onccY, egN_levelX_onccY + - lfoN_* and egN_* opcodes defined in group sections + are now taken into account + - implemented curves + - implemented opcodes volume_onccN, volume_curveccN + - implemented opcode volume_smoothccN + - implemented opcodes fillfo_depthccN, amplfo_depthccN, + lfoN_volume, lfoN_volume_onccX, lfoN_volume_smoothccX, + lfoN_freq_smoothccX, lfoN_pitch_smoothccX, lfoN_pan_onccX, + lfoN_pan_smoothccX, lfoN_cutoff_onccX, lfoN_cutoff_smoothccX, + lfoN_resonance_onccX, lfoN_resonance_smoothccX, lfoN_delay_onccX + - implemented opcode end + - implemented opcodes egN_amplitude_onccX, + egN_volume, egN_volume_onccX, egN_cutoff, egN_cutoff_onccX, + egN_pitch, egN_pitch_onccX, egN_resonance, egN_resonance_onccX + - implemented opcodes xfin_lokey, xfin_hikey, + xfout_lokey, xfout_hikey, xf_keycurve, xfin_lovel, xfin_hivel, + xfout_lovel, xfout_hivel, xf_velcurve, xfin_loccN, xfin_hiccN, + xfout_loccN, xfout_hiccN, xf_cccurve + - implemented opcodes pan_onccN, pan_smoothccN, + pan_curveccN, egN_pan, egN_pan_curve, egN_pan_onccX, + egN_pan_curveccX, pitch_veltrack + - when failed to parse a sfz file + print the line number on which the error occurs + - use common pool of CC objects to minimize RAM usage + - implemented opcodes amplfo_delay_onccN, + amplfo_fade_onccN, fillfo_delay_onccN, fillfo_fade_onccN, + pitchlfo_delay_onccN, pitchlfo_fade_onccN + - implemented opcodes fileg_delay_onccN, + fileg_start_onccN, fileg_attack_onccN, fileg_hold_onccN, + fileg_decay_onccN, fileg_sustain_onccN, fileg_release_onccN, + fileg_depth_onccN, pitcheg_delay_onccN, pitcheg_start_onccN, + pitcheg_attack_onccN, pitcheg_hold_onccN, pitcheg_decay_onccN, + pitcheg_sustain_onccN, pitcheg_release_onccN, pitcheg_depth_onccN + - implemented automatic aliasing *ccN <-> *_onccN + - *lfo_freqccN wasn't working when the respective *lfo_freq + was not set or was set to zero + - lfoN_freq_onccX wasn't working when lfoN_freq + was not set or was set to zero + - implemented opcodes resonance_onccN, resonance_smoothccN, + resonance_curveccN, cutoff_smoothccN, cutoff_curveccN + - implemented opcodes fillfo_depthchanaft, + fillfo_freqchanaft, amplfo_depthchanaft, amplfo_freqchanaft, + pitchlfo_depthchanaft, pitchlfo_freqchanaft + - implemented opcodes pitch_onccN, + pitch_curveccN, pitch_smoothccN, pitch_stepccN + - implemented opcodes volume_stepccN, pan_stepccN, + cutoff_stepccN, resonance_stepccN, lfoN_freq_stepccX, + lfoN_volume_stepccX, lfoN_pitch_stepccX, lfoN_pan_stepccX, + lfoN_cutoff_stepccX, lfoN_resonance_stepccX + - implemented opcodes eq1_freq, eq2_freq, eq3_freq, + eq1_freqccN, eq2_freqccN, eq3_freqccN, eq1_bw, eq2_bw, eq3_bw, + eq1_bwccN, eq2_bwccN, eq3_bwccN, eq1_gain, eq2_gain, eq3_gain, + eq1_gainccN, eq2_gainccN, eq3_gainccN + - implemented opcodes delay, delay_onccN, delay_random, + delay_samples, delay_samples_onccN + - implemented opcodes egN_eq1gain, egN_eq2gain, egN_eq3gain, + egN_eq1gain_onccX, egN_eq2gain_onccX, egN_eq3gain_onccX, egN_eq1freq, + egN_eq2freq, egN_eq3freq, egN_eq1freq_onccX, egN_eq2freq_onccX, + egN_eq3freq_onccX, egN_eq1bw, egN_eq2bw, egN_eq3bw, egN_eq1bw_onccX, + egN_eq2bw_onccX, egN_eq3bw_onccX, lfoN_eq1gain, lfoN_eq2gain, + lfoN_eq3gain, lfoN_eq1gain_onccX, lfoN_eq2gain_onccX, lfoN_eq3gain_onccX, + lfoN_eq1gain_smoothccX, lfoN_eq2gain_smoothccX, lfoN_eq3gain_smoothccX, + lfoN_eq1gain_stepccX, lfoN_eq2gain_stepccX, lfoN_eq3gain_stepccX, + lfoN_eq1freq, lfoN_eq2freq, lfoN_eq3freq, lfoN_eq1freq_onccX, + lfoN_eq2freq_onccX, lfoN_eq3freq_onccX, lfoN_eq1freq_smoothccX, + lfoN_eq2freq_smoothccX, lfoN_eq3freq_smoothccX, lfoN_eq1freq_stepccX, + lfoN_eq2freq_stepccX, lfoN_eq3freq_stepccX, lfoN_eq1bw, lfoN_eq2bw, + lfoN_eq3bw, lfoN_eq1bw_onccX, lfoN_eq2bw_onccX, lfoN_eq3bw_onccX, + lfoN_eq1bw_smoothccX, lfoN_eq2bw_smoothccX, lfoN_eq3bw_smoothccX, + lfoN_eq1bw_stepccX, lfoN_eq2bw_stepccX, lfoN_eq3bw_stepccX + - implemented opcodes eq1_vel2freq, eq2_vel2freq, + eq3_vel2freq, eq1_vel2gain, eq2_vel2gain, eq3_vel2gain + - sfz parser: allow double spaces in sample filenames + - sfz parser: allow absolute paths for sample filenames + - use linear decay and release for filter and pitch EG + - bugfix: only the first amp_veltrack definition in a file was + used + - bugfix: looping was disabled if loop_start was set to 0 + - allow regions with end=-1 to turn off other regions using the + group and off_by opcodes (#168) + - made end=0 play the whole sample + - fixed support for lochan and hichan opcodes (#155) + + * SoundFont format engine: + - Initial implementation (not usable yet) + - RT-safeness: avoid malloc in audio thread + - fixed a bug that could cause voice stealing to fail + - fine-tuned amplitude EG (by switching from gig to sfz EG) + - initial implementation of Vibrato LFO and Modulation LFO + - initial implementation of cutoff filter + - use linear decay and release for filter and pitch EG + + * Gigasampler format engine: + - bugfix: pitch LFO controller "internal+aftertouch" was broken + - bugfix: filter keyboard tracking was broken + - filter performance fix (an unnecessary copy was made of the + filter parameters in each sub fragment) + + * Host plugins: + - AU bugfix: failed to destroy its audio/MIDI devices + - Listen to all interfaces on Mac OS X (INADDR_ANY) + - VST bugfix: If the host called resume() before and after + changing sample rate or block size, the number of channels was + incorrectly set to two. This caused silence in Cubase 5. + - save engine type (gig, sfz or sf2) in plugin state + - VST: when opening Fantasia, look for both 32 and 64 bit Java on + 64 bit Windows + - AU: changed number of output channels from one stereo to 16 + stereo + - VST: made it possible to build the VST plugin for Mac + - AU: link AU plugin dynamically if --disable-shared isn't + specified + - VST bugfix: instrument loading hang and crashed the host when + the plugin was loaded a second time (#174) + - plugin bugfix: instrument loading hang when the plugin was + loaded a second time (this time it's for Linux and Mac, previous + similar fix was for Windows) + - thread safety fixes for the instrument loading thread + + * MIDI driver: + - ALSA MIDI driver supports now "NAME" device parameter, for overriding + the ALSA sequencer client name + - removed limit of maximum amount of MIDI ports per MIDI device, since + there is no reason for this limit + - MME: fixed memory handling bug found with cppcheck + - MME: removed compiler warning + + * audio driver: + - ASIO driver fixes for newer gcc versions (fix from PortAudio) + + * LSCP server: + - added support for sending MIDI CC messages via LSCP command + "SEND CHANNEL MIDI_DATA CC <sampler-chan> <ctrl> <val>" + - added LSCP command "GET AVAILABLE_EFFECTS" + - added LSCP command "LIST AVAILABLE_EFFECTS" + - added LSCP command "GET EFFECT INFO <effect-index>" + - added LSCP command "CREATE EFFECT_INSTANCE <effect-index>" + - added LSCP command + "CREATE EFFECT_INSTANCE <effect-system> <module> <effect-name>" + - added LSCP command "DESTROY EFFECT_INSTANCE <effect-instance>" + - added LSCP command "GET EFFECT_INSTANCES" + - added LSCP command "LIST EFFECT_INSTANCES" + - added LSCP command "GET EFFECT_INSTANCE INFO <effect-instance>" + - added LSCP command + "GET EFFECT_INSTANCE_INPUT_CONTROL INFO <effect-instance> <input-control>" + - added LSCP command "SET EFFECT_INSTANCE_INPUT_CONTROL VALUE + <effect-instance> <input-control> <value>" + - added LSCP command "GET SEND_EFFECT_CHAINS <audio-device>" + - added LSCP command "LIST SEND_EFFECT_CHAINS <audio-device>" + - added LSCP command "ADD SEND_EFFECT_CHAIN <audio-device>" + - added LSCP command + "REMOVE SEND_EFFECT_CHAIN <audio-device> <effect-chain>" + - added LSCP command + "GET SEND_EFFECT_CHAIN INFO <audio-device> <effect-chain>" + - added LSCP command "APPEND SEND_EFFECT_CHAIN EFFECT <audio-device> + <effect-chain> <effect-instance>" + - added LSCP command "INSERT SEND_EFFECT_CHAIN EFFECT <audio-device> + <effect-chain> <effect-chain-pos> <effect-instance>" + - added LSCP command "REMOVE SEND_EFFECT_CHAIN EFFECT <audio-device> + <effect-chain> <chain-pos>" + - added LSCP command "SET FX_SEND EFFECT <sampler_channel> + <fx_send_id> <effect_chain> <chain_pos>" + - added LSCP command "REMOVE FX_SEND EFFECT <sampler_channel> <fx_send_id>" + - added LSCP commands "SUBSCRIBE EFFECT_INSTANCE_COUNT", + "SUBSCRIBE EFFECT_INSTANCE_INFO", "SUBSCRIBE SEND_EFFECT_CHAIN_COUNT", + "SUBSCRIBE SEND_EFFECT_CHAIN_INFO" + + * Bug fixes: + - Fixed crash which may occur when MIDI key + transpose is out of range + - minor valgrind fixes + - fixed crash which occurred when changing an already deployed sampler + channel to a different engine type + - fixed crash when deleting a sampler channel or changing engine + type while an instrument load was in progress + - bugfix: playing a note while changing the instrument could cause + a crash, or give "Handing back unknown region" error messages + - bugfix: calling SET VOICES (which Fantasia does on start and + refresh) could cause instruments to be unloaded + - Mac OS X: fixed name collision of enum in EffectControl and + wrong name of destructor in AudioOutputDeviceCoreAudio.cpp + - Mac OS X: fixed hanging threads + - Windows: disabled the previous thread fix on non-Mac systems, as + it caused hanging threads on Windows + - Fixed possible crashes due to corrupted MIDI/audio device list + after MIDI/audio device creation failure + - When creating MIDI instrument map entries with "PERSISTENT" type, the + instruments were uselessly precached with zero samples, however it still + took the full preloading time and on 1st program change the respective + instrument was completely reloaded again. + - fixed handling of rapid bank select and program change messages + sent to the same sampler channel (patch from the Open Octave + project, slightly adjusted) + - fixed crash when trying to create an effect instance with controls + which min and/or max values depend on the sample rate + - fixed bug #162 + - bugfix: LADSPA_PATH was not evaluated correctly when containing + multiple paths (#165) + - thread safety fixes for the instrument loading thread + - bugfix: instrument loading crashed for sfz and sf2 in Ardour + (#176) + - more thread safety fixes for the instrument loading thread + - sfz/sf2 engine: fixed crash when using small audio fragment size + Version 1.0.0 (31 July 2009) * packaging changes:
View file
linuxsampler-1.0.0.tar.bz2/Documentation/lscp.xml -> linuxsampler-2342.tar.bz2/Documentation/lscp.xml
Changed
@@ -16,7 +16,7 @@ to an annoying "missing Normative/Informative References" error message --> <?rfc strict="no" ?> -<rfc category="std" ipr="full3978" docName="LSCP 1.4"> +<rfc category="std" ipr="full3978" docName="LSCP 1.5"> <front> <title>LinuxSampler Control Protocol</title> <author initials='C.S.' surname="Schoenebeck" fullname='C. @@ -34,7 +34,7 @@ <email>schoenebeck at software minus engineering dot org</email> </address> </author> - <date month="July" year="2009"/> + <date month="June" year="2011"/> <workgroup>LinuxSampler Developers</workgroup> <keyword>LSCP</keyword> <abstract> @@ -3495,7 +3495,21 @@ channel 1 is routed to the channel 3 of the audio output device (see <xref target="SET FX_SEND AUDIO_OUTPUT_CHANNEL">"SET FX_SEND AUDIO_OUTPUT_CHANNEL"</xref> - for details)</t> + for details), if an internal send + effect is assigned to the effect + send, then this setting defines the + audio channel routing to that + effect instance respectively</t> + </list> + </t> + <t>EFFECT - + <list> + <t>destination send effect chain ID + and destination effect chain + position, separated by comma in the + form "<effect-chain>,<chain-pos>" + or "NONE" if there is no send effect + assigned to the effect send</t> </list> </t> </list> @@ -3512,6 +3526,18 @@ <t> "MIDI_CONTROLLER: 91"</t> <t> "LEVEL: 0.3"</t> <t> "AUDIO_OUTPUT_ROUTING: 2,3"</t> + <t> "EFFECT: NONE"</t> + <t> "."</t> + </list> + </t> + <t> + <list> + <t>C: "GET FX_SEND INFO 0 1"</t> + <t>S: "NAME: Delay Send (Internal)"</t> + <t> "MIDI_CONTROLLER: 93"</t> + <t> "LEVEL: 0.51"</t> + <t> "AUDIO_OUTPUT_ROUTING: 1,2"</t> + <t> "EFFECT: 2,0"</t> <t> "."</t> </list> </t> @@ -3578,7 +3604,9 @@ <audio-src> is the numerical ID of the effect send's audio channel which should be rerouted and <audio-dst> is the numerical ID of the audio channel of the selected audio output device where <audio-src> - should be routed to.</t> + should be routed to. If an internal send effect is assigned + to the effect send, then this setting defines the audio + channel routing to that effect instance respectively.</t> <t>Note that effect sends can only route audio to the same audio output device as assigned to the effect send's sampler channel. Also note that an @@ -3621,6 +3649,98 @@ </t> </section> + <section title="Assigning destination effect to an effect send" anchor="SET FX_SEND EFFECT"> + <t>The front-end can (re-)assign a destination effect to an + effect send by sending the following command:</t> + <t> + <list> + <t>SET FX_SEND EFFECT <sampler-chan> <fx-send-id> <effect-chain> <chain-pos></t> + </list> + </t> + <t>Where <sampler-chan> is the sampler channel number + as returned by the <xref target="ADD CHANNEL">"ADD CHANNEL"</xref> + or <xref target="LIST CHANNELS">"LIST CHANNELS"</xref> command, + <fx-send-id> reflects the numerical ID of the effect send entity + as returned by the <xref target="CREATE FX_SEND">"CREATE FX_SEND"</xref> + or <xref target="LIST FX_SENDS">"LIST FX_SENDS"</xref> command, + <effect-chain> by the numerical ID of the destination + effect chain as returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command and <chain-pos> reflects the exact effect + chain position in the effect chain which hosts the actual + destination effect.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>on success</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>in case it failed, providing an appropriate error code and error message</t> + </list> + </t> + </list> + </t> + <t>Example:</t> + <t> + <list> + <t>C: "SET FX_SEND EFFECT 0 0 2 5"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Removing destination effect from an effect send" anchor="REMOVE FX_SEND EFFECT"> + <t>The front-end can (re-)assign a destination effect to an + effect send by sending the following command:</t> + <t> + <list> + <t>REMOVE FX_SEND EFFECT <sampler-chan> <fx-send-id></t> + </list> + </t> + <t>Where <sampler-chan> is the sampler channel number + as returned by the <xref target="ADD CHANNEL">"ADD CHANNEL"</xref> + or <xref target="LIST CHANNELS">"LIST CHANNELS"</xref> command, + <fx-send-id> reflects the numerical ID of the effect send entity + as returned by the <xref target="CREATE FX_SEND">"CREATE FX_SEND"</xref> + or <xref target="LIST FX_SENDS">"LIST FX_SENDS"</xref> command.</t> + + <t>After the destination effect has been removed from the + effect send, the audio signal of the effect send will be + routed directly to the audio output device, according to the + audio channel routing setting of the effect send. + </t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>on success</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>in case it failed, providing an appropriate error code and error message</t> + </list> + </t> + </list> + </t> + <t>Example:</t> + <t> + <list> + <t>C: "REMOVE FX_SEND EFFECT 0 0"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + <section title="Altering effect send's MIDI controller" anchor="SET FX_SEND MIDI_CONTROLLER"> <t>The front-end can alter the MIDI controller of an effect send entity by sending the following command:</t> @@ -3719,7 +3839,7 @@ </section> <section title="Sending MIDI messages to sampler channel" anchor="SEND CHANNEL MIDI_DATA"> - <t>The front-end can send MIDI events to specific sampler channel + <t>The front-end can send MIDI events to a specific sampler channel by sending the following command:</t> <t> <list> @@ -3747,6 +3867,14 @@ as described in the MIDI specification.</t> </list> </t> + <t>"CC" - + <list> + <t>For changing a MIDI controller, where <arg1> + specifies the controller number and <arg2> the + new value of the controller as described in the Control + Change section of the MIDI specification.</t> + </list> + </t> </list> </t> <t>CAUTION: This command is provided for implementations of virtual MIDI keyboards @@ -6546,6 +6674,1024 @@ </t> </section> </section> + <section title="Managing Effects" anchor="effects"> + <t>Audio effects (e.g. reverb, delay, compression) can be + applied to the audio signals generated by the sampler. The + sampler usually provides a set of internal audio effects for + this task. The exact set of effects depends on the availability + of third party effect plugins installed on the system where the + sampler runs on.</t> + <t>At the moment only "send effects" are supported. Support for + "insert effects" and "master effects" is planned to be added at + a later point.</t> + <t>The following commands allow to retrieve the set of internal + effects available to the sampler, detailed informations about + those effects and to create and destroy instances of such + effects. After an instance of an effect is created, the effect + instance can be inserted into the audio signal path of the + sampler, e.g. as send effect.</t> + <t>The sampler allows to create an arbitrary amount of so called + send effect chains. Each effect chain can host an arbitrary + amount of effect instances. The output of the first effect + instance in an effect chain is fed to the input of the second + effect instance of the chain and so on. So effects in one chain + are processed sequentially. Send effect chains however are + processed in parallel to other send effect chains. Audio signals + of sampler channels are fed to send effects by creating FX sends + to the respective sampler channel and assigning a destination + send effect to that FX by using the + <xref target="SET FX_SEND EFFECT">"SET FX_SEND EFFECT"</xref> + command. The latter allows to route the FX send to the beginning + of a send effect chain, as well as directly to any other + position of the send effect chain.</t> + + <section title="Retrieve amount of available effects" anchor="GET AVAILABLE_EFFECTS"> + <t>The front-end can retrieve the amount of internal + effects, available to the sampler by sending + the following command:</t> + <t> + <list> + <t>GET AVAILABLE_EFFECTS</t> + </list> + </t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning the current + number of effects available to the sampler.</t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "GET AVAILABLE_EFFECTS"</t> + <t>S: "129"</t> + </list> + </t> + </section> + + <section title="Get list of available effects" anchor="LIST AVAILABLE_EFFECTS"> + <t>The set of available internal effects can change at + runtime. The front-end can retrieve the list of internal + effects, available to the sampler by sending the following + command:</t> + <t> + <list> + <t>LIST AVAILABLE_EFFECTS</t> + </list> + </t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning a comma + separated list with numerical IDs of effects. Note: + the numercial ID of an effect is generated by the + sampler for the current moment. The numerical ID of + the same effect can change at runtime, e.g. when the + user requests a rescan of available effect plugins. + </t> + </list> + </t> + <t>Example:</t> + <t> + <list> + <t>C: "LIST AVAILABLE_EFFECTS"</t> + <t>S: "5,6,7,120,121,122,123,124"</t> + </list> + </t> + </section> + + <section title="Retrieving general information about an effect" anchor="GET EFFECT INFO"> + <t>The front-end can ask for general informations about an + effect by sending the following command:</t> + <t> + <list> + <t>GET EFFECT INFO <effect-index></t> + </list> + </t> + <t>Where <effect-index> is the numerical ID of an + effect as returned by the + <xref target="LIST AVAILABLE_EFFECTS">"LIST AVAILABLE_EFFECTS"</xref> + command.</t> + <t>Possible Answers:</t> + <t> + <list> + <t>LinuxSampler will answer by sending a <CRLF> separated list. + Each answer line begins with the effect information + category name, followed by a colon and then a space + character <SP> and finally the info character + string to that effect information category. At the + moment the following categories are defined:</t> + <t> + <list> + <t>SYSTEM - + <list> + <t>name of the effect plugin system + the effect is based on + (e.g. "LADSPA")</t> + </list> + </t> + <t>MODULE - + <list> + <t>module of the effect plugin + system that contains this effect, + the module is usually the + dynamic-linked library (DLL) + filename of the effect plugin, + including full path (note that this + filename may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>NAME - + <list> + <t>character string defining the + unique name of the effect within its + module (note that the character + string may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>DESCRIPTION - + <list> + <t>human readable name of the + effect, intended to be displayed in + user interfaces (note that the + character string may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + </list> + </t> + </list> + </t> + <t>The mentioned fields above don't have to be in particular order.</t> + + <t>Example:</t> + <t> + <list> + <t>C: "GET EFFECT INFO 121"</t> + <t>S: "SYSTEM: LADSPA"</t> + <t> "MODULE: /usr/lib/ladspa/lowpass_iir_1891.so"</t> + <t> "NAME: lowpass_iir"</t> + <t> "DESCRIPTION: Glame Lowpass Filter"</t> + <t> "."</t> + </list> + </t> + </section> + + <section title="Creating an instance of an effect by its portable ID" anchor="CREATE EFFECT_INSTANCE"> + <t>The front-end can spawn an instance of the desired + effect by sending the following command:</t> + <t> + <list> + <t>CREATE EFFECT_INSTANCE <effect-system> <module> <effect-name></t> + </list> + </t> + <t>Where <effect-system> is the "SYSTEM" field, + <module> the "MODULE" field and <effect-name> + the "NAME" field as returned by the + <xref target="GET EFFECT INFO">"GET EFFECT INFO"</xref> + command. The filename of argument <module> and the + character string of argument <effect-name> may contain + <xref target="character_set">escape sequences</xref>.</t> + + <t>The sampler will try to load the requested effect and to + create an instance of it. To allow loading the same effect + on a different machine, probably even running a completely + different operating system (e.g. Linux vs. Windows), the + sampler tries to match <module> "softly". That means + it first tries to find an effect that exactly matches the + given <module> argument. If there is no exact match, + the sampler will try to lower the restrictions on matching + the <module> argument more and more, e.g. by ignoring + upper / lower case differences and by ignoring the path of + the DLL filename and file extension. If there is still no + match at the end, the sampler will try to ignore the + <module> argument completely and as a last resort + search for an effect that only matches the given + <effect-system> and <effect-name> arguments.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK<effect-instance>" - + <list> + <t>in case the effect instance was + successfully created, where + <effect-instance> is the numerical ID + of the new effect instance</t> + </list> + </t> + <t>"WRN:<warning-code>:<warning-message>" - + <list> + <t>in case the effect instance was spawned + successfully, but there are noteworthy + issue(s) related, providing an appropriate + warning code and warning message</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the effect could not be instantiated</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "CREATE EFFECT_INSTANCE LADSPA '/usr/lib/ladspa/mod_delay_1419.so' 'modDelay'"</t> + <t>S: "OK0"</t> + </list> + </t> + </section> + + <section title="Creating an instance of an effect by its numerical ID" anchor="CREATE EFFECT_INSTANCE (non-portable)"> + <t>The front-end can spawn an instance of the desired + effect by sending the following command:</t> + <t> + <list> + <t>CREATE EFFECT_INSTANCE <effect-index></t> + </list> + </t> + <t>Where <effect-index> is the numerical ID of the + effect as returned by the + <xref target="LIST AVAILABLE_EFFECTS">"LIST AVAILABLE_EFFECTS"</xref> + command.</t> + + <t>The sampler will try to load the requested effect and to + create an instance of it.</t> + + <t>Note: Since the numerical ID of a certain effect can + change at any time, you should not use this command in + LSCP files to restore a certain effect at a later time! To + store a sampler session including all its effects, use the + <xref target="CREATE EFFECT_INSTANCE">portable text-based + version of "CREATE EFFECT_INSTANCE"</xref> instead! This + allows to restore a sampler session with all its effects + also on other machines, possibly even running a completely + different operating system (e.g. Linux vs. Windows), with + different plugin directories or plugin DLL names.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK<effect-instance>" - + <list> + <t>in case the effect instance was + successfully created, where + <effect-instance> is the numerical ID + of the new effect instance</t> + </list> + </t> + <t>"WRN:<warning-code>:<warning-message>" - + <list> + <t>in case the effect instance was spawned + successfully, but there are noteworthy + issue(s) related, providing an appropriate + warning code and warning message</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the effect could not be instantiated</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "CREATE EFFECT_INSTANCE 72"</t> + <t>S: "OK5"</t> + </list> + </t> + </section> + + <section title="Destroy an effect instance" anchor="DESTROY EFFECT_INSTANCE"> + <t>The front-end can destroy an unusued effect instance and + thus freeing it from memory by sending the following command:</t> + <t> + <list> + <t>DESTROY EFFECT_INSTANCE <effect-instance></t> + </list> + </t> + <t>Where <effect-instance> is the numerical ID of the + effect instance as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command.</t> + + <t>The effect instance can only be destroyed if it's not + used in any part of the sampler's audio signal path anymore. + If the effect instance is still in use somewhere, trying to + destroy the effect instance will result in an error + message.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the effect instance was successfully destroyed</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>in case it failed, providing an appropriate error code and + error message</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "DESTROY EFFECT_INSTANCE 5"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Retrieve amount of effect instances" anchor="GET EFFECT_INSTANCES"> + <t>The front-end can retrieve the current amount of effect + instances by sending the following command:</t> + <t> + <list> + <t>GET EFFECT_INSTANCES</t> + </list> + </t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning the current + number of effect instances created and not yet + destroyed in the current sampler session.</t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "GET EFFECT_INSTANCES"</t> + <t>S: "14"</t> + </list> + </t> + </section> + + <section title="Get list of effect instances" anchor="LIST EFFECT_INSTANCES"> + <t>The front-end can retrieve the current list of effect + instances by sending the following command:</t> + <t> + <list> + <t>LIST EFFECT_INSTANCES</t> + </list> + </t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning a comma + separated list with numerical IDs of effects + instances. + </t> + </list> + </t> + <t>Example:</t> + <t> + <list> + <t>C: "LIST EFFECT_INSTANCES"</t> + <t>S: "9,11,14,15,16,17,25"</t> + </list> + </t> + </section> + + <section title="Retrieving current information about an effect instance" anchor="GET EFFECT_INSTANCE INFO"> + <t>The front-end can ask for the current informations about + a particular effect instance by sending the following command:</t> + <t> + <list> + <t>GET EFFECT_INSTANCE INFO <effect-instance></t> + </list> + </t> + <t>Where <effect-instance> is the numerical ID of an + effect instance as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> + or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>LinuxSampler will answer by sending a <CRLF> separated list. + Each answer line begins with the information + category name, followed by a colon and then a space + character <SP> and finally the info character + string to that information category. At the + moment the following categories are defined:</t> + <t> + <list> + <t>SYSTEM - + <list> + <t>name of the effect plugin system + the effect is based on + (e.g. "LADSPA")</t> + </list> + </t> + <t>MODULE - + <list> + <t>module of the effect plugin + system that contains this effect, + the module is usually the + dynamic-linked library (DLL) + filename of the effect plugin, + including full path (note that this + filename may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>NAME - + <list> + <t>character string defining the + unique name of the effect within its + module (note that the character + string may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>DESCRIPTION - + <list> + <t>human readable name of the + effect, intended to be displayed in + user interfaces (note that the + character string may contain + <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>INPUT_CONTROLS - + <list> + <t>amount of input controls the + effect instance provides, to allow + controlling the effect parameters in + realtime</t> + </list> + </t> + </list> + </t> + </list> + </t> + <t>The mentioned fields above don't have to be in particular order.</t> + + <t>Example:</t> + <t> + <list> + <t>C: "GET EFFECT_INSTANCE INFO 3"</t> + <t>S: "SYSTEM: LADSPA"</t> + <t> "MODULE: /usr/lib/ladspa/mod_delay_1419.so"</t> + <t> "NAME: modDelay"</t> + <t> "DESCRIPTION: Modulatable delay"</t> + <t> "INPUT_CONTROLS: 1"</t> + <t> "."</t> + </list> + </t> + </section> + + <section title="Retrieving information about an effect parameter" anchor="GET EFFECT_INSTANCE_INPUT_CONTROL INFO"> + <t>Effects typically provide a certain set of effect + parameters which can be altered by the user in realtime + (e.g. depth of a reverb effect, duration of a delay effect, + dry / wet signal ratio). Those controllable effect parameters + are called "input controls". The front-end can ask for the + current informations of an effect instance's input control + by sending the following command:</t> + <t> + <list> + <t>GET EFFECT_INSTANCE_INPUT_CONTROL INFO <effect-instance> <input-control></t> + </list> + </t> + <t>Where <effect-instance> is the numerical ID of an + effect instance as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> + or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command and <input-control> is the index of the input + control within the numerical bounds as returned by the + "INPUT_CONTROLS" field of the + <xref target="GET EFFECT_INSTANCE INFO">"GET EFFECT_INSTANCE INFO"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>LinuxSampler will answer by sending a <CRLF> separated list. + Each answer line begins with the information + category name, followed by a colon and then a space + character <SP> and finally the info character + string to that information category. There are + information categories which are always returned, + independent of the respective effect parameter and + there are optional information categories + which are only shown for certain effect parameters. + At the moment the following categories are defined:</t> + <t> + <list> + <t>DESCRIPTION - + <list> + <t>(always returned) + human readable name of the + effect parameter, intended to be + displayed in user interfaces (note + that the character string may + contain <xref target="character_set">escape sequences</xref>)</t> + </list> + </t> + <t>VALUE - + <list> + <t> + (always returned) + current (optional dotted) + floating point value of this effect + parameter</t> + </list> + </t> + <t>RANGE_MIN - + <list> + <t> + (optionally returned) + minimum allowed value for this + effect parameter</t> + </list> + </t> + <t>RANGE_MAX - + <list> + <t> + (optionally returned) + maximum allowed value for this + effect parameter</t> + </list> + </t> + <t>POSSIBILITIES - + <list> + <t> + (optionally returned) + comma separated list of + (optional dotted) floating point + numbers, reflecting the exact set of + possible values for this effect + parameter</t> + </list> + </t> + <t>DEFAULT - + <list> + <t> + (optionally returned) + default value of this effect + parameter</t> + </list> + </t> + </list> + </t> + </list> + </t> + <t>The mentioned fields above don't have to be in particular order.</t> + + <t>Example:</t> + <t> + <list> + <t>C: "GET EFFECT_INSTANCE_INPUT_CONTROL INFO 1 0"</t> + <t>S: "DESCRIPTION: Base delay (s)"</t> + <t> "VALUE: 0.500"</t> + <t> "RANGE_MIN: 0.000"</t> + <t> "."</t> + </list> + </t> + </section> + + <section title="Altering an effect parameter" anchor="SET EFFECT_INSTANCE_INPUT_CONTROL VALUE"> + <t>The front-end can alter the current value of an effect + parameter by sending the following command:</t> + <t> + <list> + <t>SET EFFECT_INSTANCE_INPUT_CONTROL VALUE <effect-instance> <input-control> <value></t> + </list> + </t> + <t>Where <effect-instance> is the numerical ID of the + effect instance as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command, <input-control> is the index of the input + control within the numerical bounds as returned by the + "INPUT_CONTROLS" field of the + <xref target="GET EFFECT_INSTANCE INFO">"GET EFFECT_INSTANCE INFO"</xref> + command and <value> is the new (optional dotted) + floating point value for this effect parameter.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the effect was altered successfully</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>in case it failed, providing an appropriate error code and + error message</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "SET EFFECT_INSTANCE_INPUT_CONTROL VALUE 0 1 0.5"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Retrieve amount of send effect chains" anchor="GET SEND_EFFECT_CHAINS"> + <t>The front-end can retrieve the current amount of send + effect chains of an audio output device by sending the + following command:</t> + <t> + <list> + <t>GET SEND_EFFECT_CHAINS <audio-device></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning the current + number of send effect chains of the supplied audio + output device.</t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "GET SEND_EFFECT_CHAINS 0"</t> + <t>S: "4"</t> + </list> + </t> + </section> + + <section title="Retrieve list of send effect chains" anchor="LIST SEND_EFFECT_CHAINS"> + <t>The front-end can retrieve the current list of send + effect chains of an audio output device by sending the + following command:</t> + <t> + <list> + <t>LIST SEND_EFFECT_CHAINS <audio-device></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>The sampler will answer by returning a comma + separated list with numerical IDs of send effect + chains of the supplied audio output device. + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "LIST SEND_EFFECT_CHAINS 0"</t> + <t>S: "3,4,7"</t> + </list> + </t> + </section> + + <section title="Add send effect chain" anchor="ADD SEND_EFFECT_CHAIN"> + <t>The front-end can add a send effect chain by sending the + following command:</t> + <t> + <list> + <t>ADD SEND_EFFECT_CHAIN <audio-device></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK<effect-chain>" - + <list> + <t>in case the send effect chain was + added successfully, where + <effect-chain> is the numerical ID + of the new send effect chain</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the send effect chain could not be added</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "ADD SEND_EFFECT_CHAIN 0"</t> + <t>S: "OK2"</t> + </list> + </t> + </section> + + <section title="Remove send effect chain" anchor="REMOVE SEND_EFFECT_CHAIN"> + <t>The front-end can remove a send effect chain by sending + the following command:</t> + <t> + <list> + <t>REMOVE SEND_EFFECT_CHAIN <audio-device> <effect-chain></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command and <effect-chain> by the numerical ID as + returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the send effect chain was + removed successfully</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the send effect chain could not be removed</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "REMOVE SEND_EFFECT_CHAIN 0 2"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Retrieving information about a send effect chain" anchor="GET SEND_EFFECT_CHAIN INFO"> + <t>The front-end can ask for informations of a send effect + chain by sending the following command:</t> + <t> + <list> + <t>GET SEND_EFFECT_CHAIN INFO <audio-device> <effect-chain></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command and <effect-chain> by the numerical ID as + returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>LinuxSampler will answer by sending a <CRLF> separated list. + Each answer line begins with the information + category name, followed by a colon and then a space + character <SP> and finally the info character + string to that information category. + At the moment the following categories are defined:</t> + <t> + <list> + <t>EFFECT_COUNT - + <list> + <t>amount of effects in this send + effect chain</t> + </list> + </t> + <t>EFFECT_SEQUENCE - + <list> + <t>comma separated list of the + numerical IDs of the effect + instances in this send effect chain, + in the order as they are procssed in + the effect chain</t> + </list> + </t> + </list> + </t> + </list> + </t> + <t>The mentioned fields above don't have to be in particular order.</t> + + <t>Example:</t> + <t> + <list> + <t>C: "GET SEND_EFFECT_CHAIN INFO 0 2"</t> + <t>S: "EFFECT_COUNT: 3"</t> + <t> "EFFECT_SEQUENCE: 31,4,7"</t> + <t> "."</t> + </list> + </t> + </section> + + <section title="Append effect instance to a send effect chain" anchor="APPEND SEND_EFFECT_CHAIN EFFECT"> + <t>The front-end can add an unused effect instance to the + end of a send effect chain by sending the following command:</t> + <t> + <list> + <t>APPEND SEND_EFFECT_CHAIN EFFECT <audio-device> <effect-chain> <effect-instance></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command and <effect-chain> by the numerical ID as + returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command and <effect-instance> as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command.</t> + <t>Only unused effect instances can be added to the effect + chain. Trying to add an effect instance which is already in + use somewhere in the audio signal path of the sampler will + result in an error.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the effect instance was + added successfully to the chain</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the effect instance could not be added</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "APPEND SEND_EFFECT_CHAIN EFFECT 0 2 38"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Insert effect instance to a send effect chain" anchor="INSERT SEND_EFFECT_CHAIN EFFECT"> + <t>The front-end can add an unused effect instance to a + certain position of a send effect chain by sending the + following command:</t> + <t> + <list> + <t>INSERT SEND_EFFECT_CHAIN EFFECT <audio-device> <effect-chain> <chain-pos> <effect-instance></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command, <effect-chain> by the numerical ID as + returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command, <effect-instance> as returned by the + <xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref> or + <xref target="LIST EFFECT_INSTANCES">"LIST EFFECT_INSTANCES"</xref> + command and <chain-pos> the exact position of the + effect chain where the supplied effect shall be inserted + to.</t> + <t>Only unused effect instances can be added to the effect + chain. Trying to add an effect instance which is already in + use somewhere in the audio signal path of the sampler will + result in an error.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the effect instance was + added successfully to the chain</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the effect instance could not be added</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "INSERT SEND_EFFECT_CHAIN EFFECT 0 2 4 38"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + <section title="Remove effect instance from send effect chain" anchor="REMOVE SEND_EFFECT_CHAIN EFFECT"> + <t>The front-end can remove an effect instance from a + certain position of a send effect chain by sending the + following command:</t> + <t> + <list> + <t>REMOVE SEND_EFFECT_CHAIN EFFECT <audio-device> <effect-chain> <chain-pos></t> + </list> + </t> + <t>Where <audio-device> should be replaced by the + numerical ID of the audio output device as given by the + <xref target="CREATE AUDIO_OUTPUT_DEVICE">"CREATE AUDIO_OUTPUT_DEVICE"</xref> + or <xref target="LIST AUDIO_OUTPUT_DEVICES">"LIST AUDIO_OUTPUT_DEVICES"</xref> + command, <effect-chain> by the numerical ID as + returned by the + <xref target="ADD SEND_EFFECT_CHAIN">"ADD SEND_EFFECT_CHAIN"</xref> + or + <xref target="LIST SEND_EFFECT_CHAINS">"LIST SEND_EFFECT_CHAINS"</xref> + command and <chain-pos> the exact position of the + effect instance to be removed from the effect chain.</t> + + <t>Possible Answers:</t> + <t> + <list> + <t>"OK" - + <list> + <t>in case the effect instance was + removed successfully</t> + </list> + </t> + <t>"ERR:<error-code>:<error-message>" - + <list> + <t>if the effect instance could not be removed</t> + </list> + </t> + </list> + </t> + + <t>Examples:</t> + <t> + <list> + <t>C: "REMOVE SEND_EFFECT_CHAIN EFFECT 0 2 4"</t> + <t>S: "OK"</t> + </list> + </t> + </section> + + </section> </section> <section title="Command Syntax" anchor="command_syntax"> @@ -6636,6 +7782,10 @@ </t> <t>/ SEND SP send_instruction </t> + <t>/ APPEND SP append_instruction + </t> + <t>/ INSERT SP insert_instruction + </t> <t>/ RESET </t> <t>/ QUIT @@ -6668,6 +7818,8 @@ </t> <t>/ MIDI_INSTRUMENT_MAP SP map_name </t> + <t>/ SEND_EFFECT_CHAIN SP device_index + </t> </list> </t> <t>subscribe_event = @@ -6724,6 +7876,14 @@ </t> <t>/ GLOBAL_INFO </t> + <t>/ EFFECT_INSTANCE_COUNT + </t> + <t>/ EFFECT_INSTANCE_INFO + </t> + <t>/ SEND_EFFECT_CHAIN_COUNT + </t> + <t>/ SEND_EFFECT_CHAIN_INFO + </t> </list> </t> <t>unsubscribe_event = @@ -6780,6 +7940,14 @@ </t> <t>/ GLOBAL_INFO </t> + <t>/ EFFECT_INSTANCE_COUNT + </t> + <t>/ EFFECT_INSTANCE_INFO + </t> + <t>/ SEND_EFFECT_CHAIN_COUNT + </t> + <t>/ SEND_EFFECT_CHAIN_INFO + </t> </list> </t> <t>map_instruction = @@ -6808,6 +7976,12 @@ </t> <t>/ MIDI_INSTRUMENT_MAP SP ALL </t> + <t>/ SEND_EFFECT_CHAIN SP device_index SP effect_chain + </t> + <t>/ SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP chain_pos + </t> + <t>/ FX_SEND SP EFFECT SP sampler_channel SP fx_send_id + </t> <t>/ DB_INSTRUMENT_DIRECTORY SP FORCE SP db_path </t> <t>/ DB_INSTRUMENT_DIRECTORY SP db_path @@ -6820,6 +7994,20 @@ <list> <t>AVAILABLE_ENGINES </t> + <t>/ AVAILABLE_EFFECTS + </t> + <t>/ EFFECT_INSTANCES + </t> + <t>/ EFFECT SP INFO SP effect_index + </t> + <t>/ EFFECT_INSTANCE SP INFO SP effect_instance + </t> + <t>/ EFFECT_INSTANCE_INPUT_CONTROL SP INFO SP effect_instance SP input_control + </t> + <t>/ SEND_EFFECT_CHAINS SP device_index + </t> + <t>/ SEND_EFFECT_CHAIN SP INFO SP device_index SP effect_chain + </t> <t>/ AVAILABLE_MIDI_INPUT_DRIVERS </t> <t>/ MIDI_INPUT_DRIVER SP INFO SP string @@ -6924,6 +8112,8 @@ </t> <t>/ MIDI_INPUT_PORT_PARAMETER SP number SP number SP string '=' param_val_list </t> + <t>/ EFFECT_INSTANCE_INPUT_CONTROL SP VALUE SP effect_instance SP input_control SP control_value + </t> <t>/ CHANNEL SP set_chan_instruction </t> <t>/ MIDI_INSTRUMENT_MAP SP NAME SP midi_map SP map_name @@ -6936,6 +8126,8 @@ </t> <t>/ FX_SEND SP LEVEL SP sampler_channel SP fx_send_id SP volume_value </t> + <t>/ FX_SEND SP EFFECT SP sampler_channel SP fx_send_id SP effect_chain SP chain_pos + </t> <t>/ DB_INSTRUMENT_DIRECTORY SP NAME SP db_path SP stringval_escaped </t> <t>/ DB_INSTRUMENT_DIRECTORY SP DESCRIPTION SP db_path SP stringval_escaped @@ -6970,6 +8162,10 @@ </t> <t>/ FX_SEND SP sampler_channel SP midi_ctrl SP fx_send_name </t> + <t>/ EFFECT_INSTANCE SP effect_index + </t> + <t>/ EFFECT_INSTANCE SP effect_system SP module SP effect_name + </t> </list> </t> <t>reset_instruction = @@ -7024,6 +8220,8 @@ </t> <t>/ FX_SEND SP sampler_channel SP fx_send_id </t> + <t>/ EFFECT_INSTANCE SP number + </t> </list> </t> <t>load_instruction = @@ -7034,6 +8232,18 @@ </t> </list> </t> +<t>append_instruction = + <list> + <t>SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP effect_instance + </t> + </list> +</t> +<t>insert_instruction = + <list> + <t>SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP chain_pos SP effect_instance + </t> + </list> +</t> <t>set_chan_instruction = <list> <t>AUDIO_OUTPUT_DEVICE SP sampler_channel SP device_index @@ -7112,6 +8322,12 @@ </t> <t>/ AVAILABLE_ENGINES </t> + <t>/ AVAILABLE_EFFECTS + </t> + <t>/ EFFECT_INSTANCES + </t> + <t>/ SEND_EFFECT_CHAINS SP number + </t> <t>/ AVAILABLE_MIDI_INPUT_DRIVERS </t> <t>/ AVAILABLE_AUDIO_OUTPUT_DRIVERS @@ -7166,6 +8382,12 @@ </t> </list> </t> +<t>effect_instance = + <list> + <t>number + </t> + </list> +</t> <t>device_index = <list> <t>number @@ -7236,6 +8458,12 @@ </t> </list> </t> +<t>control_value = + <list> + <t>real + </t> + </list> +</t> <t>sampler_channel = <list> <t>number @@ -7290,6 +8518,36 @@ </t> </list> </t> +<t>effect_name = + <list> + <t>stringval_escaped + </t> + </list> +</t> +<t>effect_index = + <list> + <t>number + </t> + </list> +</t> +<t>effect_chain = + <list> + <t>number + </t> + </list> +</t> +<t>chain_pos = + <list> + <t>number + </t> + </list> +</t> +<t>input_control = + <list> + <t>number + </t> + </list> +</t> <t>param_val_list = <list> <t>param_val @@ -7337,6 +8595,18 @@ </t> </list> </t> +<t>effect_system = + <list> + <t>string + </t> + </list> +</t> +<t>module = + <list> + <t>filename + </t> + </list> +</t> <!-- GRAMMAR_BNF_END - do NOT delete or modify this line !!! --> @@ -7404,6 +8674,9 @@ <t><xref target="GET FILE INSTRUMENTS">"GET FILE INSTRUMENTS"</xref></t> <t><xref target="LIST FILE INSTRUMENTS">"LIST FILE INSTRUMENTS"</xref></t> <t><xref target="GET FILE INSTRUMENT INFO">"GET FILE INSTRUMENT INFO"</xref></t> + <t><xref target="GET EFFECT INFO">"GET EFFECT INFO"</xref></t> + <t><xref target="GET EFFECT_INSTANCE INFO">"GET EFFECT_INSTANCE INFO"</xref></t> + <t><xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref></t> </list> Note that the forward slash character ('/') has a special meaning in filename / path based arguments: it acts as separator of the nodes in @@ -7448,6 +8721,9 @@ <t><xref target="SET DB_INSTRUMENT NAME">"SET DB_INSTRUMENT NAME"</xref></t> <t><xref target="SET DB_INSTRUMENT DESCRIPTION">"SET DB_INSTRUMENT DESCRIPTION"</xref></t> <t><xref target="FIND DB_INSTRUMENTS">"FIND DB_INSTRUMENTS"</xref></t> + <t><xref target="GET EFFECT INFO">"GET EFFECT INFO"</xref></t> + <t><xref target="GET EFFECT_INSTANCE INFO">"GET EFFECT_INSTANCE INFO"</xref></t> + <t><xref target="CREATE EFFECT_INSTANCE">"CREATE EFFECT_INSTANCE"</xref></t> </list> Please note that these lists are manually maintained. If you find a command that also supports escape sequences we forgot to @@ -8001,6 +9277,83 @@ message is sufficient here.</t> </section> + <section title="Number of effect instances changed" anchor="SUBSCRIBE EFFECT_INSTANCE_COUNT"> + <t>Client may want to be notified when the number of effect instances + is changed by issuing the following command:</t> + <t> + <list> + <t>SUBSCRIBE EFFECT_INSTANCE_COUNT</t> + </list> + </t> + <t>Server will start sending the following notification messages:</t> + <t> + <list> + <t>"EFFECT_INSTANCE_COUNT:<instances>"</t> + </list> + </t> + <t>where <instances> will be replaced by the new number + of effect instances.</t> + </section> + + <section title="Effect instance information changed" anchor="SUBSCRIBE EFFECT_INSTANCE_INFO"> + <t>Client may want to be notified when changes were made to effect instances + on the back-end by issuing the following command:</t> + <t> + <list> + <t>SUBSCRIBE EFFECT_INSTANCE_INFO</t> + </list> + </t> + <t>Server will start sending the following notification messages:</t> + <t> + <list> + <t>"EFFECT_INSTANCE_INFO:<instance-id>"</t> + </list> + </t> + <t>where <instance-id> will be replaced by the numerical ID + of the effect instance.</t> + </section> + + <section title="Number of send effect chains changed" anchor="SUBSCRIBE SEND_EFFECT_CHAIN_COUNT"> + <t>Client may want to be notified when the number of send effect chains + is changed by issuing the following command:</t> + <t> + <list> + <t>SUBSCRIBE SEND_EFFECT_CHAIN_COUNT</t> + </list> + </t> + <t>Server will start sending the following notification messages:</t> + <t> + <list> + <t>"NOTIFY:SEND_EFFECT_CHAIN_COUNT:<device-id> <chains>"</t> + </list> + </t> + <t>where <device-id> will be replaced by the numerical ID of the audio + output device, in which the number of send effect chains is changed and + <chains> will be replaced by the new number of send effect chains.</t> + </section> + + <section title="Send effect chain information changed" anchor="SUBSCRIBE SEND_EFFECT_CHAIN_INFO"> + <t>Client may want to be notified when changes were made to send effect chains + on the back-end by issuing the following command:</t> + <t> + <list> + <t>SUBSCRIBE SEND_EFFECT_CHAIN_INFO</t> + </list> + </t> + <t>Server will start sending the following notification messages:</t> + <t> + <list> + <t>"SEND_EFFECT_CHAIN_INFO:<device-id> <chain-id> <instances>" - + Notifies that the number of effect instances in a particular send effect chain + is changed, where <device-id> will be replaced by the numerical ID of the audio + output device the send effect chain belongs to, <chain-id> will be replaced + by the numerical ID of the send effect chain in which the number of effect instances + has changed and <instances> will be replaced by the new number + of effect instances in the specified send effect chain.</t> + </list> + </t> + </section> + <section title="Miscellaneous and debugging events" anchor="SUBSCRIBE MISCELLANEOUS"> <t>Client may want to be notified of miscellaneous and debugging events occurring at the server by issuing the following command:</t>
View file
linuxsampler-2342.tar.bz2/Makefile.cvs
Added
@@ -0,0 +1,26 @@ +default: all + +.PHONY: clean + +all: configure + +configure: configure.in m4/arts.m4 m4/nptl_bug.m4 m4/pthread.m4 + @aclocal -I m4 + @libtoolize --force --copy + @autoheader + @automake --add-missing --copy + @autoconf + @scripts/generate_parser.sh + ###################################################################### + # If you are compiling LinuxSampler from CVS, make sure to use the # + # latest version of libgig from CVS as well ! # + ###################################################################### + +clean: + @if -f Makefile ; then make distclean; fi || true + @rm -rvf *.cache *.log *.status *.m4 stamp-h* config.* + @rm -rvf `find . -name Makefile.in` + @rm -rvf missing install-sh mkinstalldirs depcomp ltmain.sh configure + @rm -rvf src/network/lscpparser.cpp src/network/lscpsymbols.h + @rm -rvf linuxsampler-*.tar.* + @rm -rvf Doxyfile
View file
linuxsampler-1.0.0.tar.bz2/benchmarks/Makefile -> linuxsampler-2342.tar.bz2/benchmarks/Makefile
Changed
@@ -22,8 +22,8 @@ .PHONY: all gigsynth.o Synthesizer.o RTMath.o -all: Synthesizer.o RTMath.o gigsynth.o - $(CPP) $(CFLAGS) -o gigsynth gigsynth.o Synthesizer.o RTMath.o +all: Synthesizer.o RTMath.o gigsynth.o Filter.o + $(CPP) $(CFLAGS) -o gigsynth gigsynth.o Synthesizer.o RTMath.o Filter.o clean: rm -f gigsynth $(OBJFILES) @@ -34,5 +34,8 @@ Synthesizer.o: $(CPP) $(INCLUDES) $(CFLAGS) -c ../src/engines/gig/Synthesizer.cpp +Filter.o: + $(CPP) $(INCLUDES) $(CFLAGS) -c ../src/engines/gig/Filter.cpp + RTMath.o: $(CPP) $(INCLUDES) $(CFLAGS) -c ../src/common/RTMath.cpp
View file
linuxsampler-1.0.0.tar.bz2/configure.in -> linuxsampler-2342.tar.bz2/configure.in
Changed
@@ -5,7 +5,7 @@ LINUXSAMPLER_RELEASE_MAJOR=1 LINUXSAMPLER_RELEASE_MINOR=0 -LINUXSAMPLER_RELEASE_BUILD=0 +LINUXSAMPLER_RELEASE_BUILD=0.svn18 #------------------------------------------------------------------------------------ # The following is the libtool / shared library version. This doesn't have to @@ -33,7 +33,7 @@ # the LSCP specification version this LinuSampler release complies with: LSCP_RELEASE_MAJOR=1 -LSCP_RELEASE_MINOR=4 +LSCP_RELEASE_MINOR=5 AC_DEFINE_UNQUOTED(LSCP_RELEASE_MAJOR, ${LSCP_RELEASE_MAJOR}, LSCP spec major version this release complies with.) AC_DEFINE_UNQUOTED(LSCP_RELEASE_MINOR, ${LSCP_RELEASE_MINOR}, LSCP spec minor version this release complies with.) @@ -78,6 +78,19 @@ fi AC_SUBST(CXX_CPU_SWITCH) +mac=no +linux=no +case "$host" in + *-*-darwin*) + mac=yes + ;; + *-*-linux*) + linux=yes + ;; +esac +AM_CONDITIONAL(LINUX, test "$linux" = yes) +AM_CONDITIONAL(MAC, test "$mac" = yes) + # check if we're on MS Windows AC_CHECK_HEADERS( mmsystem.h, @@ -528,6 +541,21 @@ AM_CONDITIONAL(HAVE_AU, test $config_have_au = "yes") AM_CONDITIONAL(HAVE_AUFLAGS, test "$AUFLAGS" != "") +if test $config_have_au = "yes" ; then + if test "x$DEVELOPER_EXTRAS_DIR" = "x" ; then + if test -d /Developer/Extras ; then + DEVELOPER_EXTRAS_DIR=/Developer/Extras + else + DEVELOPER_EXTRAS_DIR=/Developer/Examples + fi + fi + AC_SUBST(DEVELOPER_EXTRAS_DIR) +fi + +if test "x$MAC_PLUGIN_INSTALL_DIR" = "x" ; then + MAC_PLUGIN_INSTALL_DIR=/Library/Audio/Plug-Ins +fi +AC_SUBST(MAC_PLUGIN_INSTALL_DIR) # have we found at least one MIDI input and one audio output driver ? if test "$have_midi_input_driver" = "false"; then @@ -563,6 +591,53 @@ AC_SUBST(GIG_CFLAGS) AC_SUBST(GIG_LIBS) +# SF2 Engine (requires libgig) +AC_ARG_ENABLE(sf2-engine, + --disable-sf2-engine + Disable compilation of the SF2 engine. + You need to have libgig installed., + config_sf2_engine="$enableval", + config_sf2_engine="yes" +) +HAVE_SF2=0; +if test "$config_sf2_engine" = "yes"; then + HAVE_SF2=1 +else + echo "SF2 engine disabled by configure script parameter" +fi +AM_CONDITIONAL(HAVE_SF2, test $HAVE_SF2 = 1) +AC_DEFINE_UNQUOTED(HAVE_SF2,$HAVE_SF2,Define to 1 if you want SF2 engine and have libsf2 installed.) +config_have_sf2="no" +if test $HAVE_SF2 = "1"; then + config_have_sf2="yes" +fi + +# Check presence of libsndfile +libsndfile_version="1.0" +PKG_CHECK_MODULES(SNDFILE, sndfile >= $libsndfile_version, HAVE_SNDFILE=true, HAVE_SNDFILE=false) +if test "$HAVE_SNDFILE" = "false"; then + echo "Required libsndfile version not found!" + echo "You need to have libsndfile version ${libsndfile_version} installed!" + exit -1; +else + echo "yes, found libsndfile $libsndfile_version" +fi +AC_SUBST(SNDFILE_CFLAGS) +AC_SUBST(SNDFILE_LIBS) + +# Check for Vorbis support in libsndfile +linuxsampler_save_CFLAGS=$CFLAGS +CFLAGS="$SNDFILE_CFLAGS $CFLAGS" +AC_CHECK_DECLS(SF_FORMAT_VORBIS, , ,#include <sndfile.h>) + +# Check for loop functionality in libsndfile +AC_CHECK_MEMBERS(SF_INSTRUMENT.loops,, + AC_MSG_WARN(Your version of libsndfile does not support + reading of loop information. LinuxSampler will not be able to + extract loop information from sample files.), + #include <sndfile.h>) +CFLAGS=$linuxsampler_save_CFLAGS + # Instruments DB feature (requires SQLite 3.3) AC_ARG_ENABLE(instruments-db, --disable-instruments-db @@ -658,12 +733,14 @@ AC_DEFINE_UNQUOTED(CONFIG_RT_EXCEPTIONS, 1, Define to 1 to allow exceptions in the realtime context.) fi +config_pthread_testcancel="$mac" AC_ARG_ENABLE(pthread-testcancel, --enable-pthread-testcancel - Enable pthread_testcancel() calls and avoid asynchronous - cancel of pthreads (default=no)., + Enable pthread_testcancel() calls and avoid + asynchronous cancel of pthreads (default=yes + for Mac targets, no otherwise)., config_pthread_testcancel="$enableval", - config_pthread_testcancel="no" + ) if test "$config_pthread_testcancel" = "yes"; then AC_DEFINE_UNQUOTED(CONFIG_PTHREAD_TESTCANCEL, 1, Define to 1 to enable pthread_testcancel() calls.) @@ -1250,6 +1327,8 @@ src/network/Makefile \ src/engines/Makefile \ src/engines/gig/Makefile \ + src/engines/sf2/Makefile \ + src/engines/sfz/Makefile \ src/engines/common/Makefile \ src/effects/Makefile \ src/common/Makefile \ @@ -1340,6 +1419,12 @@ echo "# Audio Output Drivers:" echo "# ALSA: ${config_have_alsa}, JACK: ${config_have_jack}, ARTS: ${config_have_arts}, CoreAudio: ${config_have_coreaudio}, ASIO: ${config_have_asio}" echo "#-------------------------------------------------------------------" +echo "# Sampler Engines:" +echo "# GIG: yes, SF2: ${config_have_sf2}, SFZ: yes" +echo "#-------------------------------------------------------------------" +echo "# Effect plugin systems for internal effects:" +echo "# LADSPA: yes" +echo "#-------------------------------------------------------------------" echo "# Building sampler as plugin for following host standards:" echo "# DSSI: ${config_have_dssi}, LV2: ${config_have_lv2}, VST: ${config_have_vst}, AU: ${config_have_au}" echo "#-------------------------------------------------------------------#"
View file
linuxsampler-1.0.0.tar.bz2/linuxsampler.kdevelop -> linuxsampler-2342.tar.bz2/linuxsampler.kdevelop
Changed
@@ -16,12 +16,10 @@ <ignoreparts/> <secondaryLanguages/> <versioncontrol/> - <projectname>linuxsampler</projectname> - <defaultencoding/> </general> <kdevautoproject> <general> - <activetarget>src/linuxsampler</activetarget> + <activetarget>src/liblinuxsampler.la</activetarget> <useconfiguration>debug</useconfiguration> </general> <run> @@ -45,7 +43,7 @@ <cxxflags>-O2 -g0</cxxflags> </optimized> <debug> - <configargs>--enable-debug=full --enable-plugin-dir=/usr/lib/linuxsampler/plugins</configargs> + <configargs>--enable-debug=full</configargs> <builddir>debug</builddir> <ccompiler>kdevgccoptions</ccompiler> <cxxcompiler>kdevgppoptions</cxxcompiler> @@ -116,23 +114,6 @@ <codeCompletionDelay>250</codeCompletionDelay> <argumentsHintDelay>400</argumentsHintDelay> <headerCompletionDelay>250</headerCompletionDelay> - <showOnlyAccessibleItems>false</showOnlyAccessibleItems> - <completionBoxItemOrder>0</completionBoxItemOrder> - <howEvaluationContextMenu>true</howEvaluationContextMenu> - <showCommentWithArgumentHint>true</showCommentWithArgumentHint> - <statusBarTypeEvaluation>false</statusBarTypeEvaluation> - <namespaceAliases>std=_GLIBCXX_STD;__gnu_cxx=std</namespaceAliases> - <processPrimaryTypes>true</processPrimaryTypes> - <processFunctionArguments>false</processFunctionArguments> - <preProcessAllHeaders>false</preProcessAllHeaders> - <parseMissingHeaders>false</parseMissingHeaders> - <resolveIncludePaths>true</resolveIncludePaths> - <alwaysParseInBackground>true</alwaysParseInBackground> - <usePermanentCaching>true</usePermanentCaching> - <alwaysIncludeNamespaces>false</alwaysIncludeNamespaces> - <includePaths>.;</includePaths> - <parseMissingHeadersExperimental>false</parseMissingHeadersExperimental> - <resolveIncludePathsUsingMakeExperimental>false</resolveIncludePathsUsingMakeExperimental> </codecompletion> <creategettersetter> <prefixGet/> @@ -142,21 +123,6 @@ <inlineGet>true</inlineGet> <inlineSet>true</inlineSet> </creategettersetter> - <qt> - <used>false</used> - <version>3</version> - <includestyle>3</includestyle> - <root>/usr/share/qt3</root> - <designerintegration>EmbeddedKDevDesigner</designerintegration> - <qmake>/usr/bin/qmake-qt3</qmake> - <designer>/usr/bin/designer-qt3</designer> - <designerpluginpaths/> - </qt> - <splitheadersource> - <enabled>false</enabled> - <synchronize>true</synchronize> - <orientation>Vertical</orientation> - </splitheadersource> </kdevcppsupport> <kdevdoctreeview> <projectdoc> @@ -179,14 +145,13 @@ <general> <programargs/> <gdbpath/> - <dbgshell/> + <dbgshell>../libtool</dbgshell> <configGdbScript/> <runShellScript/> <runGdbScript/> <breakonloadinglibs>true</breakonloadinglibs> <separatetty>false</separatetty> <floatingtoolbar>false</floatingtoolbar> - <raiseGDBOnStart>false</raiseGDBOnStart> </general> <display> <staticmembers>false</staticmembers>
View file
linuxsampler-1.0.0.tar.bz2/man/linuxsampler.1.in -> linuxsampler-2342.tar.bz2/man/linuxsampler.1.in
Changed
@@ -1,4 +1,4 @@ -.TH "linuxsampler" "1" "15 Oct 2007" "linuxsampler @VERSION@" "User Manuals" +.TH "linuxsampler" "1" "04 Oct 2010" "linuxsampler @VERSION@" "User Manuals" .SH NAME linuxsampler \- modular, streaming capable sampler .SH SYNOPSIS @@ -16,6 +16,8 @@ .IP "--version" Print version information and exit. .IP "--profile" +This option is currently not supported anymore, since the respective +profiling code is currently broken. Original behavior: Output benchmark messages on the console. This reflects the current efficiency as abstract BogoVoice count which is something like a theoretical limit of the amount of voices which can be rendered in the given @@ -46,6 +48,13 @@ Overrides the location of the database file, which the sampler shall use for its instruments database system (default: @config_default_instruments_db_file@). +.SH ENVIRONMENT VARIABLES +.IP "LINUXSAMPLER_PLUGIN_DIR" +Allows to override the directory where LinuxSampler shall look for instrument +editor plugins. +.IP "LADSPA_PATH" +Allows to override the directory where LinuxSampler shall look for LADSPA +effect plugins. .SH "SEE ALSO" qsampler(1) .SH "BUGS"
View file
linuxsampler-1.0.0.tar.bz2/src/EventListeners.h -> linuxsampler-2342.tar.bz2/src/EventListeners.h
Changed
@@ -81,6 +81,15 @@ std::vector<L> vListenerList; }; +#define REGISTER_FIRE_EVENT_METHOD(method) virtual void method() \ + { for(int i = 0; i < GetListenerCount(); i++) GetListener(i)->method(); } + +#define REGISTER_FIRE_EVENT_METHOD_ARG1(method, T1) virtual void method(T1 _evt_arg1_) \ + { for(int i = 0; i < GetListenerCount(); i++) GetListener(i)->method(_evt_arg1_); } + +#define REGISTER_FIRE_EVENT_METHOD_ARG2(method, T1, T2) virtual void method(T1 _evt_arg1_, T2 _evt_arg2_) \ + { for(int i = 0; i < GetListenerCount(); i++) GetListener(i)->method(_evt_arg1_, _evt_arg2_); } + /** * This class is used as a listener, which is notified * when the number of sampler channels is changed.
View file
linuxsampler-1.0.0.tar.bz2/src/Makefile.am -> linuxsampler-2342.tar.bz2/src/Makefile.am
Changed
@@ -16,6 +16,12 @@ sqlite3_lib = endif +if HAVE_SF2 +sf2_engine_lib = $(top_builddir)/src/engines/sf2/liblinuxsamplersf2engine.la +else +sf2_engine_lib = +endif + AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) SUBDIRS = db network engines common testcases drivers plugins effects . hostplugins @@ -29,6 +35,8 @@ $(sqlite3_lib) \ $(top_builddir)/src/network/liblinuxsamplernetwork.la \ $(top_builddir)/src/engines/gig/liblinuxsamplergigengine.la \ + $(sf2_engine_lib) \ + $(top_builddir)/src/engines/sfz/liblinuxsamplersfzengine.la \ $(top_builddir)/src/engines/common/liblinuxsamplercommonengine.la \ $(top_builddir)/src/engines/liblinuxsamplerengines.la \ $(top_builddir)/src/drivers/liblinuxsamplerdrivers.la \
View file
linuxsampler-1.0.0.tar.bz2/src/Sampler.cpp -> linuxsampler-2342.tar.bz2/src/Sampler.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -88,6 +88,7 @@ // dereference midi input port. MidiInputPort* pMidiInputPort = __GetMidiInputDevicePort(GetMidiInputPort()); + midi_chan_t midiChannel = GetMidiInputChannel(); // disconnect old engine channel if (pEngineChannel) { Engine* engine = pEngineChannel->GetEngine(); @@ -107,7 +108,7 @@ pNewEngineChannel->Connect(pAudioOutputDevice); pAudioOutputDevice->Connect(pNewEngineChannel->GetEngine()); } - if (pMidiInputPort) pMidiInputPort->Connect(pNewEngineChannel, GetMidiInputChannel()); + if (pMidiInputPort) pMidiInputPort->Connect(pNewEngineChannel, midiChannel); pEngineChannel = pNewEngineChannel; // from now on get MIDI device and port from EngineChannel object
View file
linuxsampler-1.0.0.tar.bz2/src/common/ArrayList.h -> linuxsampler-2342.tar.bz2/src/common/ArrayList.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005, 2006 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -132,9 +132,39 @@ return pDataiPosition; } + /** + * Copy constructor. + */ + ArrayList(const ArrayList& list) { + copy(list); + } + + /** + * Assignment. + */ + ArrayList& operator=(const ArrayList& list) { + if (this != &list) { + clear(); + copy(list); + } + return *this; + } + private: T* pData; int iSize; + + void copy(const ArrayList& list) { + iSize = list.iSize; + if (list.pData) { + pData = new TiSize; + for (int i = 0 ; i < iSize ; i++) { + pDatai = list.pDatai; + } + } else { + pData = NULL; + } + } }; } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/common/Condition.cpp -> linuxsampler-2342.tar.bz2/src/common/Condition.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -268,12 +268,26 @@ #endif } +#ifndef WIN32 +namespace { + // If the thread is cancelled while waiting for the condition + // variable, the mutex will be locked. It needs to be unlocked so + // the Condition can be reused if the thread is restarted. + void condition_cleanup(void* c) { + static_cast<Condition*>(c)->Unlock(); + } +} +#endif + int Condition::WaitIf(bool bCondition, long TimeoutSeconds, long TimeoutNanoSeconds) { dmsg(7,("Condition::WaitIf: bCondition=%d TimeoutSeconds=%d TimeoutNanoSeconds=%d\n",bCondition, TimeoutSeconds, TimeoutNanoSeconds)); dmsg(7,("Condition::Waitif() -> LOCK()\n")); Lock(); dmsg(7,("Condition::Waitif() -> LOCK() passed\n")); int res = 0; + #ifndef WIN32 + pthread_cleanup_push(condition_cleanup, this); + #endif if (this->bCondition == bCondition) { if (bCondition) { // wait until condition turned 'false' #if defined(WIN32) @@ -328,6 +342,9 @@ #endif } } + #ifndef WIN32 + pthread_cleanup_pop(0); + #endif return res; } @@ -369,4 +386,13 @@ return bCondition; } +#ifdef WIN32 +void Condition::Reset() { + __win32_true_condition.waiters_count_ = 0; + __win32_true_condition.was_broadcast_ = 0; + __win32_false_condition.waiters_count_ = 0; + __win32_false_condition.was_broadcast_ = 0; +} +#endif + } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/common/Condition.h -> linuxsampler-2342.tar.bz2/src/common/Condition.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -117,6 +117,15 @@ */ bool GetUnsafe(); +#ifdef WIN32 + /** + * Resets the condition. This is only needed on Windows, after + * a thread waiting for a condition has been stopped with + * StopThread. + */ + void Reset(); +#endif + protected: #if defined(WIN32) friend class ConditionInternal;
View file
linuxsampler-2342.tar.bz2/src/common/DynamicLibraries.cpp
Added
@@ -0,0 +1,152 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#include "DynamicLibraries.h" +#include "global_private.h" +#if defined(WIN32) +# include <windows.h> +#else +# include <dlfcn.h> +# include <errno.h> +# include <dirent.h> +# include <sys/types.h> +# include <sys/stat.h> +# include <unistd.h> +#endif +#include <string.h> +#include <iostream> + +namespace LinuxSampler { + +/* + NOTE: it is expected by the sampler that a reference count is maintained for + DLLs, so DLLs can be opened n times, and a DLL shall only be freed from + memory after DynamicLibraryClose() was also called n times. Usually this + behavior is already implemented on Operating System level. If not, it has to + be implemented here for the respective OS ! +*/ + +int DynamicLibrariesSearch(String dir, String funct, DynamicLibrariesSearchCallbackFunction* pCallback, void* pCustom) throw (Exception) { + int iLibsLoadedCount = 0; + + #if defined(WIN32) + WIN32_FIND_DATA win32FindData; + const String dllpattern = dir + "\\*.dll"; + HANDLE hDir = FindFirstFile(dllpattern.c_str(), &win32FindData); + if (hDir == INVALID_HANDLE_VALUE) { + if (GetLastError() != ERROR_FILE_NOT_FOUND) { + throw Exception("library path '" + dir + "' doesn't exist"); + } else { + return 0; // no file found + } + } + + do { + // skip directory entries + if (win32FindData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) + continue; + // dir entry name as full qualified path + const String sPath = dir + "\\" + win32FindData.cFileName; + // load the DLL + HINSTANCE hinstLib; + void* pDLL = hinstLib = LoadLibrary(sPath.c_str()); + if (!pDLL) { + std::cerr << "Failed to load DLL: " << sPath << std::endl; + continue; + } + + void* pFunct = (void*)GetProcAddress(hinstLib, funct.c_str()); + if (pFunct == NULL) { + std::cerr << "ERROR: unable to find " << funct << "() in " << sPath + << std::endl << std::flush; + FreeLibrary(hinstLib); + continue; + } + + // call the the supplied callback function to report the found DLL + pCallback(sPath, pDLL, pFunct, pCustom); + + iLibsLoadedCount++; + + } while (FindNextFile(hDir, &win32FindData)); + + if (hDir != INVALID_HANDLE_VALUE) FindClose(hDir); + + #else // POSIX + + #if defined(__APPLE__) /* 20071224 Toshi Nagata */ + if (dir.find("~") == 0) + dir.replace(0, 1, getenv("HOME")); + #endif + DIR* hDir = opendir(dir.c_str()); + if (!hDir) { + throw Exception("library path '" + dir + "' doesn't exist"); + } + for (dirent* pEntry = readdir(hDir); pEntry; pEntry = readdir(hDir)) { + // dir entry name as full qualified path + const String sPath = dir + "/" + pEntry->d_name; + // skip entries that are not regular files + struct stat entry_stat; + if (lstat(sPath.c_str(), &entry_stat) != 0 || + (entry_stat.st_mode & S_IFMT) != S_IFREG) + continue; + // skip files that are not .so files + if (sPath.length() < 3 || + sPath.substr(sPath.length() - 3) != ".so" && + sPath.find(".so.") == String::npos) + continue; + // load the DLL + void* pDLL = dlopen(sPath.c_str(), RTLD_NOW); + if (!pDLL) { + std::cerr << "failed to load DLL: '" << sPath << "', cause: " + << dlerror() << std::endl; + continue; + } + // load the requested function + void* pFunct = dlsym(pDLL, funct.c_str()); + char* pcErr = dlerror(); + if (pcErr || !pFunct) { + std::cerr << "ERROR: unable to find " << funct << "() in '" << sPath + << "'" << std::endl << std::flush; + dlclose(pDLL); + continue; + } + + // call the the supplied callback function to report the found and + // successfully opened DLL + pCallback(sPath, pDLL, pFunct, pCustom); + + iLibsLoadedCount++; + } + closedir(hDir); + #endif + + return iLibsLoadedCount; +} + +void* DynamicLibraryOpen(String filename) { + #if defined(WIN32) + return LoadLibrary(filename.c_str()); + #else + return dlopen(filename.c_str(), RTLD_NOW); + #endif +} + +void* DynamicLibraryGetSymbol(void* hDLL, String symbol) { + #if defined(WIN32) + return (void*)GetProcAddress((HMODULE)hDLL, symbol.c_str()); + #else + return dlsym(hDLL, symbol.c_str()); + #endif +} + +void DynamicLibraryClose(void* hDLL) { + #if defined(WIN32) + FreeLibrary((HMODULE)hDLL); + #else + dlclose(hDLL); + #endif +} + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/common/DynamicLibraries.h
Added
@@ -0,0 +1,74 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#ifndef LS_DYNAMIC_LIBRARIES_H +#define LS_DYNAMIC_LIBRARIES_H + +#include "Exception.h" +#include <string> + +namespace LinuxSampler { + +/** + * Function signature for callback functions used with function + * DynamicLibrariesSearch() . + * + * @param filename - full qualified filename of DLL + * @param hDLL - handle of opened DLL + * @param pFunction - pointer to requested function of DLL + * @param pCustom - (optional) custom data + */ +typedef void DynamicLibrariesSearchCallbackFunction( + String filename, void* hDLL, void* pFunction, void* pCustom +); + +/** + * Search and load DLLs in the directory given by @a dir . For each DLL found, + * the library function supplied by @a funct is tried to be loaded and on + * success for each such DLL, the callback function @a pCallback is called. + * + * @e Note: This function leaves all DLLs open! You should close them once you + * don't need them anymore by calling DynamicLibraryClose() . + * + * @param dir - DLL directory + * @param funct - entry function to be loaded for each DLL + * @param pCallback - callback function which is called for each DLL found + * @param pCustom - (optional) arbitrary data passed to the callback function + * @throws Exception - if supplied directory cannot be opened + * @returns amount of DLLs loaded successfully + */ +int DynamicLibrariesSearch(String dir, String funct, DynamicLibrariesSearchCallbackFunction* pCallback, void* pCustom = NULL) throw (Exception); + +/** + * Load the DLL given by @a filename . A DLL can be opened multiple times. A + * reference count is used in this case. + * + * @param filename - DLL to be loaded + * @returns handle to opened DLL or NULL on error + */ +void* DynamicLibraryOpen(String filename); + +/** + * Retrieve symbol (e.g. function or data structure) with name @a symbol of + * DLL @a hDLL . + * + * @param hDLL - handle of DLL + * @param symbol - name of symbol to be accessed + * @returns pointer to requested symbol or NULL on error + */ +void* DynamicLibraryGetSymbol(void* hDLL, String symbol); + +/** + * Unload the DLL given by @a hDLL , previously opened by e.g. + * DynamicLibrariesSearch() or DynamicLibraryOpen() . If the DLL was opened + * multiple times, then just the reference count is decremented and finally when + * the reference count reached zero, the library is freed from memory. + * + * @param hDLL - handle of DLL to be closed + */ +void DynamicLibraryClose(void* hDLL); + +} // namespace LinuxSampler + +#endif // LS_DYNAMIC_LIBRARIES_H
View file
linuxsampler-1.0.0.tar.bz2/src/common/File.cpp -> linuxsampler-2342.tar.bz2/src/common/File.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 - 2009 Grigor Iliev, Benno Senoner * + * Copyright (C) 2008 - 2012 Grigor Iliev, Benno Senoner * * * * 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 * @@ -37,9 +37,11 @@ namespace LinuxSampler { #ifdef WIN32 - char File::DirSeparator = '\\'; + const char File::DirSeparator = '\\'; + const char File::PathSeparator = ';'; #else - char File::DirSeparator = '/'; + const char File::DirSeparator = '/'; + const char File::PathSeparator = ':'; #endif Mutex File::DirectoryWalkerMutex; std::vector<File::DirectoryWalker*> File::DirectoryWalkers;
View file
linuxsampler-1.0.0.tar.bz2/src/common/File.h -> linuxsampler-2342.tar.bz2/src/common/File.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 - 2009 Grigor Iliev, Benno Senoner * + * Copyright (C) 2008 - 2012 Grigor Iliev, Benno Senoner * * * * 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 * @@ -90,7 +90,8 @@ */ static void WalkDirectoryTree(std::string Dir, DirectoryWalker* pWalker); - static char DirSeparator; + static const char DirSeparator; + static const char PathSeparator; private: bool bExist;
View file
linuxsampler-2342.tar.bz2/src/common/IDGenerator.cpp
Added
@@ -0,0 +1,41 @@ +#include "IDGenerator.h" + +namespace LinuxSampler { + +IDGenerator::IDGenerator(bool simpleAlgorithm) { + previousId = -1; + simple = simpleAlgorithm; +} + +int IDGenerator::create() { + int newId = previousId + 1; + if (newId < 0 /*reached upper value range limit*/ || + ids.find(newId) != ids.end() /*already in use*/) + { + if (simple) return -1; // whole value range was used, and we dont know what we could pick next + + newId = -1; + for (int i = 0; i >= 0; i++) { + if (ids.find(i) == ids.end()) { + // we found an unused id ... + newId = i; + break; + } + } + if (newId < 0) { + // we didn't find a free ID, the whole value range is full! + return -1; + } + } + + if (!simple) ids.insert(newId); + previousId = newId; + return newId; +} + +void IDGenerator::destroy(int id) { + if (simple) return; // nothing to do + ids.erase(id); +} + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/common/IDGenerator.h
Added
@@ -0,0 +1,44 @@ +#ifndef LS_IDGENERATOR_H +#define LS_IDGENERATOR_H + +#include <set> + +namespace LinuxSampler { + +/** + * Generates unique numerical IDs starting from zero. + * + * @e Note: this class is not exported to the C++ API of the sampler! + */ +class IDGenerator { +public: + /** + * Constructor. + * + * @param simpleAlgorithm - if false, all created IDs which are still in + * use will be remembered, if true then IDs are + * simply generated by incrementing an int variable + * by 1 until the whole int value range was used + */ + IDGenerator(bool simpleAlgorithm = false); + + /** + * Returns new unique positive ID of at least zero, a negative number if + * no free ID could be generated. + */ + int create(); + + /** + * Free the given ID, for being re-used in future. + */ + void destroy(int id); + +private: + std::set<int> ids; + int previousId; + bool simple; +}; + +} // namespace LinuxSampler + +#endif // LS_IDGENERATOR_H
View file
linuxsampler-1.0.0.tar.bz2/src/common/Makefile.am -> linuxsampler-2342.tar.bz2/src/common/Makefile.am
Changed
@@ -19,6 +19,8 @@ global_private.cpp global_private.h \ atomic.h \ ArrayList.h \ + DynamicLibraries.cpp DynamicLibraries.h \ + IDGenerator.cpp IDGenerator.h \ Condition.cpp Condition.h \ ConditionServer.cpp ConditionServer.h \ Features.cpp Features.h \ @@ -32,7 +34,8 @@ Thread.cpp Thread.h \ WorkerThread.cpp WorkerThread.h \ Path.cpp Path.h \ - File.cpp File.h + File.cpp File.h \ + ladspa.h # create the plugins directory (i.e. /usr/lib/linuxsampler/plugins) install-exec-hook:
View file
linuxsampler-1.0.0.tar.bz2/src/common/Path.cpp -> linuxsampler-2342.tar.bz2/src/common/Path.cpp
Changed
@@ -261,7 +261,7 @@ } std::string Path::getBaseName(std::string path) { - Path p; + Path p; #if WIN32 p = fromWindows(path); #else @@ -278,4 +278,24 @@ return name.substr(0, lastdot); } +std::string Path::stripLastName() { + if (elements.size() > 0) elements.pop_back(); + #if WIN32 + return toWindows(); + #endif + + return toPosix(); +} + +std::string Path::stripLastName(std::string path) { + Path p; + #if WIN32 + p = fromWindows(path); + #else + p = fromPosix(path); + #endif + + return p.stripLastName(); +} + } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/common/Path.h -> linuxsampler-2342.tar.bz2/src/common/Path.h
Changed
@@ -126,6 +126,18 @@ static std::string getName(std::string path); /** + * Returns the path with the last name + * of the path's name sequence stripped off. + */ + std::string stripLastName(); + + /** + * Returns the path with the last name + * of the path's name sequence stripped off. + */ + static std::string stripLastName(std::string path); + + /** * Returns the last name in the path's name sequence * of this path with the file extension stripped off. */
View file
linuxsampler-1.0.0.tar.bz2/src/common/Pool.h -> linuxsampler-2342.tar.bz2/src/common/Pool.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -381,6 +381,19 @@ RTList(Pool<T>* pPool) : RTListBase<T>::RTListBase() { this->pPool = pPool; } + + /** + * Copy constructor + */ + RTList(RTList<T>& list) : RTListBase<T>::RTListBase() { + this->pPool = list.pPool; + Iterator it = list.first(); + Iterator end = list.end(); + for(; it != end; ++it) { + if (poolIsEmpty()) break; + *(allocAppend()) = *it; + } + } virtual ~RTList() { clear(); @@ -393,7 +406,7 @@ inline Iterator allocAppend() { if (pPool->poolIsEmpty()) return RTListBase<T>::begin(); Iterator element = pPool->alloc(); - append(element); + this->append(element); #if CONFIG_DEVMODE element.list = this; #endif // CONFIG_DEVMODE
View file
linuxsampler-1.0.0.tar.bz2/src/common/Thread.cpp -> linuxsampler-2342.tar.bz2/src/common/Thread.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2011 Christian Schoenebeck * * * * 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 * @@ -23,6 +23,10 @@ #include "Thread.h" +#if HAVE_CONFIG_H +# include <config.h> +#endif + // this is the minimum stack size a thread will be spawned with // if this value is too small, the OS will allocate memory on demand and // thus might lead to dropouts in realtime threads @@ -363,6 +367,12 @@ return 0; } +void Thread::TestCancel() { +#if CONFIG_PTHREAD_TESTCANCEL + pthread_testcancel(); +#endif +} + #if defined(WIN32) DWORD WINAPI __win32thread_launcher(LPVOID lpParameter) { Thread* t;
View file
linuxsampler-1.0.0.tar.bz2/src/common/Thread.h -> linuxsampler-2342.tar.bz2/src/common/Thread.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2011 Christian Schoenebeck * * * * 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 * @@ -57,11 +57,7 @@ virtual int SignalStartThread(); virtual int SignalStopThread(); - inline void TestCancel() { -#if CONFIG_PTHREAD_TESTCANCEL - pthread_testcancel(); -#endif - } + void TestCancel(); virtual bool IsRunning(); virtual int SetSchedulingPriority(); //FIXME: should be private
View file
linuxsampler-1.0.0.tar.bz2/src/common/atomic.h -> linuxsampler-2342.tar.bz2/src/common/atomic.h
Changed
@@ -17,7 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id: atomic.h,v 1.8 2009/03/29 18:43:39 schoenebeck Exp $ + $Id: atomic.h,v 1.8 2009-03-29 18:43:39 schoenebeck Exp $ */ /*
View file
linuxsampler-1.0.0.tar.bz2/src/common/global.h -> linuxsampler-2342.tar.bz2/src/common/global.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -41,7 +41,7 @@ // modern MinGW has usleep #if (__MINGW32_MAJOR_VERSION < 3 || \ (__MINGW32_MAJOR_VERSION == 3 && __MINGW32_MINOR_VERSION < 15)) && \ - !defined(__MINGW64) + !defined(__MINGW64) && !defined(__MINGW64_VERSION_MAJOR) #define usleep(a) Sleep(a/1000) #endif @@ -57,5 +57,10 @@ #include <sys/types.h> #endif +#ifdef __GNUC__ +#define DEPRECATED_API __attribute__ ((deprecated)) +#else +#define DEPRECATED_API +#endif #endif // __LS_GLOBAL_H__
View file
linuxsampler-1.0.0.tar.bz2/src/common/global_private.h -> linuxsampler-2342.tar.bz2/src/common/global_private.h
Changed
@@ -90,6 +90,13 @@ return i; } +inline float ToFloat(const std::string& s) throw(LinuxSampler::Exception) { + float i; + std::istringstream iss(s); + if(!(iss >> i)) throw LinuxSampler::Exception("Not a floating-point number"); + return i; +} + class Runnable { public: virtual ~Runnable() { }
View file
linuxsampler-2342.tar.bz2/src/common/ladspa.h
Added
@@ -0,0 +1,603 @@ +/* ladspa.h + + Linux Audio Developer's Simple Plugin API Version 1.1LGPL. + Copyright (C) 2000-2002 Richard W.E. Furse, Paul Barton-Davis, + Stefan Westerfeld. + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public License + as published by the Free Software Foundation; either version 2.1 of + the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 + USA. */ + +#ifndef LADSPA_INCLUDED +#define LADSPA_INCLUDED + +#define LADSPA_VERSION "1.1" +#define LADSPA_VERSION_MAJOR 1 +#define LADSPA_VERSION_MINOR 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/*****************************************************************************/ + +/* Overview: + + There is a large number of synthesis packages in use or development + on the Linux platform at this time. This API (`The Linux Audio + Developer's Simple Plugin API') attempts to give programmers the + ability to write simple `plugin' audio processors in C/C++ and link + them dynamically (`plug') into a range of these packages (`hosts'). + It should be possible for any host and any plugin to communicate + completely through this interface. + + This API is deliberately short and simple. To achieve compatibility + with a range of promising Linux sound synthesis packages it + attempts to find the `greatest common divisor' in their logical + behaviour. Having said this, certain limiting decisions are + implicit, notably the use of a fixed type (LADSPA_Data) for all + data transfer and absence of a parameterised `initialisation' + phase. See below for the LADSPA_Data typedef. + + Plugins are expected to distinguish between control and audio + data. Plugins have `ports' that are inputs or outputs for audio or + control data and each plugin is `run' for a `block' corresponding + to a short time interval measured in samples. Audio data is + communicated using arrays of LADSPA_Data, allowing a block of audio + to be processed by the plugin in a single pass. Control data is + communicated using single LADSPA_Data values. Control data has a + single value at the start of a call to the `run()' or `run_adding()' + function, and may be considered to remain this value for its + duration. The plugin may assume that all its input and output ports + have been connected to the relevant data location (see the + `connect_port()' function below) before it is asked to run. + + Plugins will reside in shared object files suitable for dynamic + linking by dlopen() and family. The file will provide a number of + `plugin types' that can be used to instantiate actual plugins + (sometimes known as `plugin instances') that can be connected + together to perform tasks. + + This API contains very limited error-handling. */ + +/*****************************************************************************/ + +/* Fundamental data type passed in and out of plugin. This data type + is used to communicate audio samples and control values. It is + assumed that the plugin will work sensibly given any numeric input + value although it may have a preferred range (see hints below). + + For audio it is generally assumed that 1.0f is the `0dB' reference + amplitude and is a `normal' signal level. */ + +typedef float LADSPA_Data; + +/*****************************************************************************/ + +/* Special Plugin Properties: + + Optional features of the plugin type are encapsulated in the + LADSPA_Properties type. This is assembled by ORing individual + properties together. */ + +typedef int LADSPA_Properties; + +/* Property LADSPA_PROPERTY_REALTIME indicates that the plugin has a + real-time dependency (e.g. listens to a MIDI device) and so its + output must not be cached or subject to significant latency. */ +#define LADSPA_PROPERTY_REALTIME 0x1 + +/* Property LADSPA_PROPERTY_INPLACE_BROKEN indicates that the plugin + may cease to work correctly if the host elects to use the same data + location for both input and output (see connect_port()). This + should be avoided as enabling this flag makes it impossible for + hosts to use the plugin to process audio `in-place.' */ +#define LADSPA_PROPERTY_INPLACE_BROKEN 0x2 + +/* Property LADSPA_PROPERTY_HARD_RT_CAPABLE indicates that the plugin + is capable of running not only in a conventional host but also in a + `hard real-time' environment. To qualify for this the plugin must + satisfy all of the following: + + (1) The plugin must not use malloc(), free() or other heap memory + management within its run() or run_adding() functions. All new + memory used in run() must be managed via the stack. These + restrictions only apply to the run() function. + + (2) The plugin will not attempt to make use of any library + functions with the exceptions of functions in the ANSI standard C + and C maths libraries, which the host is expected to provide. + + (3) The plugin will not access files, devices, pipes, sockets, IPC + or any other mechanism that might result in process or thread + blocking. + + (4) The plugin will take an amount of time to execute a run() or + run_adding() call approximately of form (A+B*SampleCount) where A + and B depend on the machine and host in use. This amount of time + may not depend on input signals or plugin state. The host is left + the responsibility to perform timings to estimate upper bounds for + A and B. */ +#define LADSPA_PROPERTY_HARD_RT_CAPABLE 0x4 + +#define LADSPA_IS_REALTIME(x) ((x) & LADSPA_PROPERTY_REALTIME) +#define LADSPA_IS_INPLACE_BROKEN(x) ((x) & LADSPA_PROPERTY_INPLACE_BROKEN) +#define LADSPA_IS_HARD_RT_CAPABLE(x) ((x) & LADSPA_PROPERTY_HARD_RT_CAPABLE) + +/*****************************************************************************/ + +/* Plugin Ports: + + Plugins have `ports' that are inputs or outputs for audio or + data. Ports can communicate arrays of LADSPA_Data (for audio + inputs/outputs) or single LADSPA_Data values (for control + input/outputs). This information is encapsulated in the + LADSPA_PortDescriptor type which is assembled by ORing individual + properties together. + + Note that a port must be an input or an output port but not both + and that a port must be a control or audio port but not both. */ + +typedef int LADSPA_PortDescriptor; + +/* Property LADSPA_PORT_INPUT indicates that the port is an input. */ +#define LADSPA_PORT_INPUT 0x1 + +/* Property LADSPA_PORT_OUTPUT indicates that the port is an output. */ +#define LADSPA_PORT_OUTPUT 0x2 + +/* Property LADSPA_PORT_CONTROL indicates that the port is a control + port. */ +#define LADSPA_PORT_CONTROL 0x4 + +/* Property LADSPA_PORT_AUDIO indicates that the port is a audio + port. */ +#define LADSPA_PORT_AUDIO 0x8 + +#define LADSPA_IS_PORT_INPUT(x) ((x) & LADSPA_PORT_INPUT) +#define LADSPA_IS_PORT_OUTPUT(x) ((x) & LADSPA_PORT_OUTPUT) +#define LADSPA_IS_PORT_CONTROL(x) ((x) & LADSPA_PORT_CONTROL) +#define LADSPA_IS_PORT_AUDIO(x) ((x) & LADSPA_PORT_AUDIO) + +/*****************************************************************************/ + +/* Plugin Port Range Hints: + + The host may wish to provide a representation of data entering or + leaving a plugin (e.g. to generate a GUI automatically). To make + this more meaningful, the plugin should provide `hints' to the host + describing the usual values taken by the data. + + Note that these are only hints. The host may ignore them and the + plugin must not assume that data supplied to it is meaningful. If + the plugin receives invalid input data it is expected to continue + to run without failure and, where possible, produce a sensible + output (e.g. a high-pass filter given a negative cutoff frequency + might switch to an all-pass mode). + + Hints are meaningful for all input and output ports but hints for + input control ports are expected to be particularly useful. + + More hint information is encapsulated in the + LADSPA_PortRangeHintDescriptor type which is assembled by ORing + individual hint types together. Hints may require further + LowerBound and UpperBound information. + + All the hint information for a particular port is aggregated in the + LADSPA_PortRangeHint structure. */ + +typedef int LADSPA_PortRangeHintDescriptor; + +/* Hint LADSPA_HINT_BOUNDED_BELOW indicates that the LowerBound field + of the LADSPA_PortRangeHint should be considered meaningful. The + value in this field should be considered the (inclusive) lower + bound of the valid range. If LADSPA_HINT_SAMPLE_RATE is also + specified then the value of LowerBound should be multiplied by the + sample rate. */ +#define LADSPA_HINT_BOUNDED_BELOW 0x1 + +/* Hint LADSPA_HINT_BOUNDED_ABOVE indicates that the UpperBound field + of the LADSPA_PortRangeHint should be considered meaningful. The + value in this field should be considered the (inclusive) upper + bound of the valid range. If LADSPA_HINT_SAMPLE_RATE is also + specified then the value of UpperBound should be multiplied by the + sample rate. */ +#define LADSPA_HINT_BOUNDED_ABOVE 0x2 + +/* Hint LADSPA_HINT_TOGGLED indicates that the data item should be + considered a Boolean toggle. Data less than or equal to zero should + be considered `off' or `false,' and data above zero should be + considered `on' or `true.' LADSPA_HINT_TOGGLED may not be used in + conjunction with any other hint except LADSPA_HINT_DEFAULT_0 or + LADSPA_HINT_DEFAULT_1. */ +#define LADSPA_HINT_TOGGLED 0x4 + +/* Hint LADSPA_HINT_SAMPLE_RATE indicates that any bounds specified + should be interpreted as multiples of the sample rate. For + instance, a frequency range from 0Hz to the Nyquist frequency (half + the sample rate) could be requested by this hint in conjunction + with LowerBound = 0 and UpperBound = 0.5. Hosts that support bounds + at all must support this hint to retain meaning. */ +#define LADSPA_HINT_SAMPLE_RATE 0x8 + +/* Hint LADSPA_HINT_LOGARITHMIC indicates that it is likely that the + user will find it more intuitive to view values using a logarithmic + scale. This is particularly useful for frequencies and gains. */ +#define LADSPA_HINT_LOGARITHMIC 0x10 + +/* Hint LADSPA_HINT_INTEGER indicates that a user interface would + probably wish to provide a stepped control taking only integer + values. Any bounds set should be slightly wider than the actual + integer range required to avoid floating point rounding errors. For + instance, the integer set {0,1,2,3} might be described as -0.1, + 3.1. */ +#define LADSPA_HINT_INTEGER 0x20 + +/* The various LADSPA_HINT_HAS_DEFAULT_* hints indicate a `normal' + value for the port that is sensible as a default. For instance, + this value is suitable for use as an initial value in a user + interface or as a value the host might assign to a control port + when the user has not provided one. Defaults are encoded using a + mask so only one default may be specified for a port. Some of the + hints make use of lower and upper bounds, in which case the + relevant bound or bounds must be available and + LADSPA_HINT_SAMPLE_RATE must be applied as usual. The resulting + default must be rounded if LADSPA_HINT_INTEGER is present. Default + values were introduced in LADSPA v1.1. */ +#define LADSPA_HINT_DEFAULT_MASK 0x3C0 + +/* This default values indicates that no default is provided. */ +#define LADSPA_HINT_DEFAULT_NONE 0x0 + +/* This default hint indicates that the suggested lower bound for the + port should be used. */ +#define LADSPA_HINT_DEFAULT_MINIMUM 0x40 + +/* This default hint indicates that a low value between the suggested + lower and upper bounds should be chosen. For ports with + LADSPA_HINT_LOGARITHMIC, this should be exp(log(lower) * 0.75 + + log(upper) * 0.25). Otherwise, this should be (lower * 0.75 + upper + * 0.25). */ +#define LADSPA_HINT_DEFAULT_LOW 0x80 + +/* This default hint indicates that a middle value between the + suggested lower and upper bounds should be chosen. For ports with + LADSPA_HINT_LOGARITHMIC, this should be exp(log(lower) * 0.5 + + log(upper) * 0.5). Otherwise, this should be (lower * 0.5 + upper * + 0.5). */ +#define LADSPA_HINT_DEFAULT_MIDDLE 0xC0 + +/* This default hint indicates that a high value between the suggested + lower and upper bounds should be chosen. For ports with + LADSPA_HINT_LOGARITHMIC, this should be exp(log(lower) * 0.25 + + log(upper) * 0.75). Otherwise, this should be (lower * 0.25 + upper + * 0.75). */ +#define LADSPA_HINT_DEFAULT_HIGH 0x100 + +/* This default hint indicates that the suggested upper bound for the + port should be used. */ +#define LADSPA_HINT_DEFAULT_MAXIMUM 0x140 + +/* This default hint indicates that the number 0 should be used. Note + that this default may be used in conjunction with + LADSPA_HINT_TOGGLED. */ +#define LADSPA_HINT_DEFAULT_0 0x200 + +/* This default hint indicates that the number 1 should be used. Note + that this default may be used in conjunction with + LADSPA_HINT_TOGGLED. */ +#define LADSPA_HINT_DEFAULT_1 0x240 + +/* This default hint indicates that the number 100 should be used. */ +#define LADSPA_HINT_DEFAULT_100 0x280 + +/* This default hint indicates that the Hz frequency of `concert A' + should be used. This will be 440 unless the host uses an unusual + tuning convention, in which case it may be within a few Hz. */ +#define LADSPA_HINT_DEFAULT_440 0x2C0 + +#define LADSPA_IS_HINT_BOUNDED_BELOW(x) ((x) & LADSPA_HINT_BOUNDED_BELOW) +#define LADSPA_IS_HINT_BOUNDED_ABOVE(x) ((x) & LADSPA_HINT_BOUNDED_ABOVE) +#define LADSPA_IS_HINT_TOGGLED(x) ((x) & LADSPA_HINT_TOGGLED) +#define LADSPA_IS_HINT_SAMPLE_RATE(x) ((x) & LADSPA_HINT_SAMPLE_RATE) +#define LADSPA_IS_HINT_LOGARITHMIC(x) ((x) & LADSPA_HINT_LOGARITHMIC) +#define LADSPA_IS_HINT_INTEGER(x) ((x) & LADSPA_HINT_INTEGER) + +#define LADSPA_IS_HINT_HAS_DEFAULT(x) ((x) & LADSPA_HINT_DEFAULT_MASK) +#define LADSPA_IS_HINT_DEFAULT_MINIMUM(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_MINIMUM) +#define LADSPA_IS_HINT_DEFAULT_LOW(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_LOW) +#define LADSPA_IS_HINT_DEFAULT_MIDDLE(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_MIDDLE) +#define LADSPA_IS_HINT_DEFAULT_HIGH(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_HIGH) +#define LADSPA_IS_HINT_DEFAULT_MAXIMUM(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_MAXIMUM) +#define LADSPA_IS_HINT_DEFAULT_0(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_0) +#define LADSPA_IS_HINT_DEFAULT_1(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_1) +#define LADSPA_IS_HINT_DEFAULT_100(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_100) +#define LADSPA_IS_HINT_DEFAULT_440(x) (((x) & LADSPA_HINT_DEFAULT_MASK) \ + == LADSPA_HINT_DEFAULT_440) + +typedef struct _LADSPA_PortRangeHint { + + /* Hints about the port. */ + LADSPA_PortRangeHintDescriptor HintDescriptor; + + /* Meaningful when hint LADSPA_HINT_BOUNDED_BELOW is active. When + LADSPA_HINT_SAMPLE_RATE is also active then this value should be + multiplied by the relevant sample rate. */ + LADSPA_Data LowerBound; + + /* Meaningful when hint LADSPA_HINT_BOUNDED_ABOVE is active. When + LADSPA_HINT_SAMPLE_RATE is also active then this value should be + multiplied by the relevant sample rate. */ + LADSPA_Data UpperBound; + +} LADSPA_PortRangeHint; + +/*****************************************************************************/ + +/* Plugin Handles: + + This plugin handle indicates a particular instance of the plugin + concerned. It is valid to compare this to NULL (0 for C++) but + otherwise the host should not attempt to interpret it. The plugin + may use it to reference internal instance data. */ + +typedef void * LADSPA_Handle; + +/*****************************************************************************/ + +/* Descriptor for a Type of Plugin: + + This structure is used to describe a plugin type. It provides a + number of functions to examine the type, instantiate it, link it to + buffers and workspaces and to run it. */ + +typedef struct _LADSPA_Descriptor { + + /* This numeric identifier indicates the plugin type + uniquely. Plugin programmers may reserve ranges of IDs from a + central body to avoid clashes. Hosts may assume that IDs are + below 0x1000000. */ + unsigned long UniqueID; + + /* This identifier can be used as a unique, case-sensitive + identifier for the plugin type within the plugin file. Plugin + types should be identified by file and label rather than by index + or plugin name, which may be changed in new plugin + versions. Labels must not contain white-space characters. */ + const char * Label; + + /* This indicates a number of properties of the plugin. */ + LADSPA_Properties Properties; + + /* This member points to the null-terminated name of the plugin + (e.g. "Sine Oscillator"). */ + const char * Name; + + /* This member points to the null-terminated string indicating the + maker of the plugin. This can be an empty string but not NULL. */ + const char * Maker; + + /* This member points to the null-terminated string indicating any + copyright applying to the plugin. If no Copyright applies the + string "None" should be used. */ + const char * Copyright; + + /* This indicates the number of ports (input AND output) present on + the plugin. */ + unsigned long PortCount; + + /* This member indicates an array of port descriptors. Valid indices + vary from 0 to PortCount-1. */ + const LADSPA_PortDescriptor * PortDescriptors; + + /* This member indicates an array of null-terminated strings + describing ports (e.g. "Frequency (Hz)"). Valid indices vary from + 0 to PortCount-1. */ + const char * const * PortNames; + + /* This member indicates an array of range hints for each port (see + above). Valid indices vary from 0 to PortCount-1. */ + const LADSPA_PortRangeHint * PortRangeHints; + + /* This may be used by the plugin developer to pass any custom + implementation data into an instantiate call. It must not be used + or interpreted by the host. It is expected that most plugin + writers will not use this facility as LADSPA_Handle should be + used to hold instance data. */ + void * ImplementationData; + + /* This member is a function pointer that instantiates a plugin. A + handle is returned indicating the new plugin instance. The + instantiation function accepts a sample rate as a parameter. The + plugin descriptor from which this instantiate function was found + must also be passed. This function must return NULL if + instantiation fails. + + Note that instance initialisation should generally occur in + activate() rather than here. */ + LADSPA_Handle (*instantiate)(const struct _LADSPA_Descriptor * Descriptor, + unsigned long SampleRate); + + /* This member is a function pointer that connects a port on an + instantiated plugin to a memory location at which a block of data + for the port will be read/written. The data location is expected + to be an array of LADSPA_Data for audio ports or a single + LADSPA_Data value for control ports. Memory issues will be + managed by the host. The plugin must read/write the data at these + locations every time run() or run_adding() is called and the data + present at the time of this connection call should not be + considered meaningful. + + connect_port() may be called more than once for a plugin instance + to allow the host to change the buffers that the plugin is + reading or writing. These calls may be made before or after + activate() or deactivate() calls. + + connect_port() must be called at least once for each port before + run() or run_adding() is called. When working with blocks of + LADSPA_Data the plugin should pay careful attention to the block + size passed to the run function as the block allocated may only + just be large enough to contain the block of samples. + + Plugin writers should be aware that the host may elect to use the + same buffer for more than one port and even use the same buffer + for both input and output (see LADSPA_PROPERTY_INPLACE_BROKEN). + However, overlapped buffers or use of a single buffer for both + audio and control data may result in unexpected behaviour. */ + void (*connect_port)(LADSPA_Handle Instance, + unsigned long Port, + LADSPA_Data * DataLocation); + + /* This member is a function pointer that initialises a plugin + instance and activates it for use. This is separated from + instantiate() to aid real-time support and so that hosts can + reinitialise a plugin instance by calling deactivate() and then + activate(). In this case the plugin instance must reset all state + information dependent on the history of the plugin instance + except for any data locations provided by connect_port() and any + gain set by set_run_adding_gain(). If there is nothing for + activate() to do then the plugin writer may provide a NULL rather + than an empty function. + + When present, hosts must call this function once before run() (or + run_adding()) is called for the first time. This call should be + made as close to the run() call as possible and indicates to + real-time plugins that they are now live. Plugins should not rely + on a prompt call to run() after activate(). activate() may not be + called again unless deactivate() is called first. Note that + connect_port() may be called before or after a call to + activate(). */ + void (*activate)(LADSPA_Handle Instance); + + /* This method is a function pointer that runs an instance of a + plugin for a block. Two parameters are required: the first is a + handle to the particular instance to be run and the second + indicates the block size (in samples) for which the plugin + instance may run. + + Note that if an activate() function exists then it must be called + before run() or run_adding(). If deactivate() is called for a + plugin instance then the plugin instance may not be reused until + activate() has been called again. + + If the plugin has the property LADSPA_PROPERTY_HARD_RT_CAPABLE + then there are various things that the plugin should not do + within the run() or run_adding() functions (see above). */ + void (*run)(LADSPA_Handle Instance, + unsigned long SampleCount); + + /* This method is a function pointer that runs an instance of a + plugin for a block. This has identical behaviour to run() except + in the way data is output from the plugin. When run() is used, + values are written directly to the memory areas associated with + the output ports. However when run_adding() is called, values + must be added to the values already present in the memory + areas. Furthermore, output values written must be scaled by the + current gain set by set_run_adding_gain() (see below) before + addition. + + run_adding() is optional. When it is not provided by a plugin, + this function pointer must be set to NULL. When it is provided, + the function set_run_adding_gain() must be provided also. */ + void (*run_adding)(LADSPA_Handle Instance, + unsigned long SampleCount); + + /* This method is a function pointer that sets the output gain for + use when run_adding() is called (see above). If this function is + never called the gain is assumed to default to 1. Gain + information should be retained when activate() or deactivate() + are called. + + This function should be provided by the plugin if and only if the + run_adding() function is provided. When it is absent this + function pointer must be set to NULL. */ + void (*set_run_adding_gain)(LADSPA_Handle Instance, + LADSPA_Data Gain); + + /* This is the counterpart to activate() (see above). If there is + nothing for deactivate() to do then the plugin writer may provide + a NULL rather than an empty function. + + Hosts must deactivate all activated units after they have been + run() (or run_adding()) for the last time. This call should be + made as close to the last run() call as possible and indicates to + real-time plugins that they are no longer live. Plugins should + not rely on prompt deactivation. Note that connect_port() may be + called before or after a call to deactivate(). + + Deactivation is not similar to pausing as the plugin instance + will be reinitialised when activate() is called to reuse it. */ + void (*deactivate)(LADSPA_Handle Instance); + + /* Once an instance of a plugin has been finished with it can be + deleted using the following function. The instance handle passed + ceases to be valid after this call. + + If activate() was called for a plugin instance then a + corresponding call to deactivate() must be made before cleanup() + is called. */ + void (*cleanup)(LADSPA_Handle Instance); + +} LADSPA_Descriptor; + +/**********************************************************************/ + +/* Accessing a Plugin: */ + +/* The exact mechanism by which plugins are loaded is host-dependent, + however all most hosts will need to know is the name of shared + object file containing the plugin types. To allow multiple hosts to + share plugin types, hosts may wish to check for environment + variable LADSPA_PATH. If present, this should contain a + colon-separated path indicating directories that should be searched + (in order) when loading plugin types. + + A plugin programmer must include a function called + "ladspa_descriptor" with the following function prototype within + the shared object file. This function will have C-style linkage (if + you are using C++ this is taken care of by the `extern "C"' clause + at the top of the file). + + A host will find the plugin shared object file by one means or + another, find the ladspa_descriptor() function, call it, and + proceed from there. + + Plugin types are accessed by index (not ID) using values from 0 + upwards. Out of range indexes must result in this function + returning NULL, so the plugin count can be determined by checking + for the least index that results in NULL being returned. */ + +const LADSPA_Descriptor * ladspa_descriptor(unsigned long Index); + +/* Datatype corresponding to the ladspa_descriptor() function. */ +typedef const LADSPA_Descriptor * +(*LADSPA_Descriptor_Function)(unsigned long Index); + +/**********************************************************************/ + +#ifdef __cplusplus +} +#endif + +#endif /* LADSPA_INCLUDED */ + +/* EOF */
View file
linuxsampler-1.0.0.tar.bz2/src/common/optional.h -> linuxsampler-2342.tar.bz2/src/common/optional.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005, 2006 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -28,6 +28,10 @@ namespace LinuxSampler { + /** + * Base class of template class optional, not meant to be instantiated + * directly. It just provides the optional<T>::nothing member. + */ class optional_base { public: class nothing_t { public: nothing_t() {} }; @@ -35,6 +39,15 @@ static const nothing_t nothing; }; + /** + * This class can be used for any variable that might not have a value + * set. E.g. as a return value type of a function, since in the case of + * return values of functions it's often difficult to return a pointer + * variable which might do the trick of an optional return value. It + * behaves pretty much like a pointer though. That is, it can be checked + * against NULL and the actual value can be dereferenced with the + * typical C pointer dereference operators. + */ template<class T> class optional : public optional_base { public: @@ -67,10 +80,9 @@ return data; } - optional& operator =(const optional& arg) throw (Exception) { - if (!arg.initialized) throw Exception("optional variable not initialized"); + optional& operator =(const optional& arg) { this->data = arg.data; - initialized = true; + initialized = arg.initialized; return *this; }
View file
linuxsampler-1.0.0.tar.bz2/src/common/stacktrace.c -> linuxsampler-2342.tar.bz2/src/common/stacktrace.c
Changed
@@ -1,6 +1,6 @@ /************************************************************************* * - * $Id: stacktrace.c,v 1.3 2007/06/11 13:42:21 schoenebeck Exp $ + * $Id: stacktrace.c,v 1.3 2007-06-11 13:42:21 schoenebeck Exp $ * * Copyright (c) 1998 by Bjorn Reese <breese@mail1.stofanet.dk> *
View file
linuxsampler-1.0.0.tar.bz2/src/common/stacktrace.h -> linuxsampler-2342.tar.bz2/src/common/stacktrace.h
Changed
@@ -1,6 +1,6 @@ /************************************************************************* * - * $Id: stacktrace.h,v 1.1 2004/10/08 20:30:25 schoenebeck Exp $ + * $Id: stacktrace.h,v 1.1 2004-10-08 20:30:25 schoenebeck Exp $ * * Copyright (c) 1998 by Bjorn Reese <breese@mail1.stofanet.dk> *
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/Plugin.cpp -> linuxsampler-2342.tar.bz2/src/drivers/Plugin.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 - 2009 Andreas Persson * + * Copyright (C) 2008 - 2011 Andreas Persson * * * * 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 * @@ -48,10 +48,15 @@ pSampler = new Sampler; + #if defined(__APPLE__) + // AU plugin sometimes hangs if bound to loopback + pLSCPServer = new LSCPServer(pSampler, htonl(INADDR_ANY), htons(LSCP_PORT)); + #else // using LOOPBACK instead of ANY to prevent windows firewall // warnings - pLSCPServer = new LSCPServer(pSampler, htonl(INADDR_LOOPBACK), - htons(LSCP_PORT)); + pLSCPServer = new LSCPServer(pSampler, htonl(INADDR_LOOPBACK), htons(LSCP_PORT)); + #endif + pLSCPServer->StartThread(); pLSCPServer->WaitUntilInitialized(); @@ -82,6 +87,7 @@ int EventThread::Main() { for (;;) { + TestCancel(); sleep(1); pSampler->fireStatistics(); } @@ -168,6 +174,20 @@ } /* + These methods can be overloaded by different plugin types to map + file names to/from file names to be used in the state text, making + it possible for state to be self-contained and/or movable. + */ + + String Plugin::PathToState(const String& string) { + return string; + } + + String Plugin::PathFromState(const String& string) { + return string; + } + + /* The sampler state is stored in a text base format, designed to be easy to parse with the istream >> operator. Values are separated by spaces or newlines. All string values that may @@ -213,7 +233,7 @@ int(iter->first.midi_bank_lsb)) << ' ' << int(iter->first.midi_prog) << ' ' << iter->second.EngineName << ' ' << - iter->second.InstrumentFile << '\n' << + PathToState(iter->second.InstrumentFile) << '\n' << MIDIMAPPING << ' ' << iter->second.InstrumentIndex << ' ' << iter->second.Volume << ' ' << @@ -235,7 +255,7 @@ String filename = engine_channel->InstrumentFileName(); s << channel->GetMidiInputChannel() << ' ' << engine_channel->Volume() << ' ' << - filename << '\n' << + PathToState(filename) << '\n' << engine_channel->InstrumentIndex() << ' ' << engine_channel->GetSolo() << ' ' << (engine_channel->GetMute() == 1) << ' ' << @@ -243,7 +263,8 @@ engine_channel->OutputChannel(1) << ' ' << (engine_channel->UsesNoMidiInstrumentMap() ? -2 : (engine_channel->UsesDefaultMidiInstrumentMap() ? -1 : - engine_channel->GetMidiInstrumentMap())) << '\n'; + engine_channel->GetMidiInstrumentMap())) << ' ' << + engine_channel->EngineName() << '\n'; for (int i = 0 ; i < engine_channel->GetFxSendCount() ; i++) { FxSend* fxsend = engine_channel->GetFxSend(i); @@ -297,19 +318,28 @@ bool mute; s >> index >> solo >> mute; + int left = -1; + int right; + int oldMapId; + String engineType = "gig"; + if (s.get() == ' ') { + s >> left >> right >> oldMapId; + if (s.get() == ' ') { + s >> engineType; + // skip rest of line + s.ignore(std::numeric_limits<int>::max(), '\n'); + } + } SamplerChannel* channel = global->pSampler->AddSamplerChannel(); - channel->SetEngineType("gig"); + channel->SetEngineType(engineType); channel->SetAudioOutputDevice(pAudioDevice); channel->SetMidiInputDevice(pMidiDevice); channel->SetMidiInputChannel(midi_chan_t(midiChannel)); engine_channel = channel->GetEngineChannel(); engine_channel->Volume(volume); - if (s.get() == ' ') { - int left; - int right; - int oldMapId; - s >> left >> right >> oldMapId; + + if (left != -1) { engine_channel->SetOutputChannel(0, left); engine_channel->SetOutputChannel(1, right); @@ -318,12 +348,10 @@ } else if (oldMapId >= 0) { engine_channel->SetMidiInstrumentMap(oldToNewIdoldMapId); } - // skip rest of line - s.ignore(std::numeric_limits<int>::max(), '\n'); } if (!filename.empty() && index != -1) { InstrumentManager::instrument_id_t id; - id.FileName = filename; + id.FileName = PathFromState(filename); id.Index = index; InstrumentManager::LoadInstrumentInBackground(id, engine_channel); } @@ -388,4 +416,12 @@ return true; } + + void Plugin::DestroyDevice(AudioOutputDevicePlugin* pDevice) { + AudioOutputDeviceFactory::DestroyPrivate(pDevice); + } + + void Plugin::DestroyDevice(MidiInputDevicePlugin* pDevice) { + MidiInputDeviceFactory::DestroyPrivate(pDevice); + } }
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/Plugin.h -> linuxsampler-2342.tar.bz2/src/drivers/Plugin.h
Changed
@@ -69,10 +69,15 @@ void PreInit(); void Init(int SampleRate, int FragmentSize, int Channels = -1); + virtual String PathToState(const String& string); + virtual String PathFromState(const String& string); + void InitState(); String GetState(); bool SetState(String State); void RemoveChannels(); + void DestroyDevice(AudioOutputDevicePlugin* pDevice); + void DestroyDevice(MidiInputDevicePlugin* pDevice); AudioOutputDevicePlugin* pAudioDevice; MidiInputDevicePlugin* pMidiDevice;
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/AudioOutputDevice.cpp -> linuxsampler-2342.tar.bz2/src/drivers/audio/AudioOutputDevice.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -24,6 +24,7 @@ #include "AudioOutputDeviceFactory.h" #include "AudioOutputDevice.h" #include "../../common/global_private.h" +#include "../../common/IDGenerator.h" namespace LinuxSampler { @@ -183,6 +184,7 @@ AudioOutputDevice::AudioOutputDevice(std::map<String,DeviceCreationParameter*> DriverParameters) : EnginesReader(Engines) { this->Parameters = DriverParameters; + EffectChainIDs = new IDGenerator(); } AudioOutputDevice::~AudioOutputDevice() { @@ -215,6 +217,8 @@ } vEffectChains.clear(); } + + delete EffectChainIDs; } void AudioOutputDevice::Connect(Engine* pEngine) { @@ -257,32 +261,61 @@ return Parameters; } - EffectChain* AudioOutputDevice::AddMasterEffectChain() { - EffectChain* pChain = new EffectChain(this); + EffectChain* AudioOutputDevice::AddSendEffectChain() { + EffectChain* pChain = new EffectChain(this, EffectChainIDs->create()); vEffectChains.push_back(pChain); return pChain; } - void AudioOutputDevice::RemoveMasterEffectChain(uint iChain) throw (Exception) { + void AudioOutputDevice::RemoveSendEffectChain(uint iChain) throw (Exception) { if (iChain >= vEffectChains.size()) throw Exception( - "Could not remove master effect chain " + ToString(iChain) + + "Could not remove send effect chain " + ToString(iChain) + ", index out of bounds" ); std::vector<EffectChain*>::iterator iter = vEffectChains.begin(); for (int i = 0; i < iChain; ++i) ++iter; + EffectChainIDs->destroy((*iter)->ID()); vEffectChains.erase(iter); } - EffectChain* AudioOutputDevice::MasterEffectChain(uint iChain) const { + EffectChain* AudioOutputDevice::SendEffectChain(uint iChain) const { if (iChain >= vEffectChains.size()) return NULL; return vEffectChainsiChain; } - uint AudioOutputDevice::MasterEffectChainCount() const { + EffectChain* AudioOutputDevice::SendEffectChainByID(uint iChainID) const { + for (int i = 0; i < SendEffectChainCount(); i++) { + if (SendEffectChain(i)->ID() == iChainID) return SendEffectChain(i); + } + + return NULL; + } + + uint AudioOutputDevice::SendEffectChainCount() const { return vEffectChains.size(); } + // TODO: to be removed + EffectChain* AudioOutputDevice::AddMasterEffectChain() { + return AddSendEffectChain(); + } + + // TODO: to be removed + void AudioOutputDevice::RemoveMasterEffectChain(uint iChain) throw (Exception) { + RemoveSendEffectChain(iChain); + } + + // TODO: to be removed + EffectChain* AudioOutputDevice::MasterEffectChain(uint iChain) const { + return SendEffectChain(iChain); + } + + // TODO: to be removed + uint AudioOutputDevice::MasterEffectChainCount() const { + return SendEffectChainCount(); + } + int AudioOutputDevice::RenderAudio(uint Samples) { if (Channels.empty()) return 0;
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/AudioOutputDevice.h -> linuxsampler-2342.tar.bz2/src/drivers/audio/AudioOutputDevice.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -43,6 +43,7 @@ // just symbol prototyping class Engine; class AudioOutputDeviceFactory; + class IDGenerator; /** Abstract base class for audio output drivers in LinuxSampler * @@ -244,29 +245,55 @@ std::map<String,DeviceCreationParameter*> DeviceParameters(); /** - * Add a chain of master effects to this AudioOutputDevice. + * Add a chain of send effects to this AudioOutputDevice. * You actually have to add effects to that chain afterwards. */ - EffectChain* AddMasterEffectChain(); + EffectChain* AddSendEffectChain(); /** - * Remove the master effect chain given by @a iChain . + * Remove the send effect chain given by @a iChain . * - * @throws Exception - if given master effect chain doesn't exist + * @throws Exception - if given send effect chain doesn't exist */ - void RemoveMasterEffectChain(uint iChain) throw (Exception); + void RemoveSendEffectChain(uint iChain) throw (Exception); /** - * Returns master effect chain given by @a iChain or @c NULL if + * Returns send effect chain given by @a iChain or @c NULL if * there's no such effect chain. */ - EffectChain* MasterEffectChain(uint iChain) const; + EffectChain* SendEffectChain(uint iChain) const; /** - * Returns amount of master effect chains this AudioOutputDevice + * Returns send effect chain with ID @a iChainID or @c NULL if + * there's no such effect chain. + */ + EffectChain* SendEffectChainByID(uint iChainID) const; + + /** + * Returns amount of send effect chains this AudioOutputDevice * currently provides. */ - uint MasterEffectChainCount() const; + uint SendEffectChainCount() const; + + /** + * @deprecated This method will be removed, use AddSendEffectChain() instead! + */ + EffectChain* AddMasterEffectChain() DEPRECATED_API; + + /** + * @deprecated This method will be removed, use RemoveSendEffectChain() instead! + */ + void RemoveMasterEffectChain(uint iChain) throw (Exception) DEPRECATED_API; + + /** + * @deprecated This method will be removed, use SendEffectChain() instead! + */ + EffectChain* MasterEffectChain(uint iChain) const DEPRECATED_API; + + /** + * @deprecated This method will be removed, use SendEffectChainCount() instead! + */ + uint MasterEffectChainCount() const DEPRECATED_API; protected: SynchronizedConfig<std::set<Engine*> > Engines; ///< All sampler engines that are connected to the audio output device. @@ -274,6 +301,7 @@ std::vector<AudioChannel*> Channels; ///< All audio channels of the audio output device. This is just a container; the descendant has to create channels by himself. std::map<String,DeviceCreationParameter*> Parameters; ///< All device parameters. std::vector<EffectChain*> vEffectChains; + IDGenerator* EffectChainIDs; AudioOutputDevice(std::map<String,DeviceCreationParameter*> DriverParameters);
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/AudioOutputDeviceCoreAudio.cpp -> linuxsampler-2342.tar.bz2/src/drivers/audio/AudioOutputDeviceCoreAudio.cpp
Changed
@@ -141,7 +141,7 @@ } } - AudioOutputDeviceCoreAudio::~AudioOutputDevice() { + AudioOutputDeviceCoreAudio::~AudioOutputDeviceCoreAudio() { atomic_set(&(aqPlayerState.mIsRunning), 0); destroyMutex.Lock(); AudioQueueDispose(aqPlayerState.mQueue, true);
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/AudioOutputDeviceFactory.cpp -> linuxsampler-2342.tar.bz2/src/drivers/audio/AudioOutputDeviceFactory.cpp
Changed
@@ -154,6 +154,7 @@ for (int i = 0; i >= 0; i++) { // seek for a free place starting from the beginning if (!mAudioOutputDevicesi) { iDeviceId = i; + mAudioOutputDevices.erase(i); break; } }
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/audio/iasiothiscallresolver.cpp -> linuxsampler-2342.tar.bz2/src/drivers/audio/iasiothiscallresolver.cpp
Changed
@@ -267,6 +267,7 @@ "call *"#funcOffset"(%%edx)\n\t" \ :"=a"(resultName) /* Output Operands */ \ :"c"(thisPtr) /* Input Operands */ \ + : "%edx" /* Clobbered Registers */ \ ); \ #define CALL_VOID_THISCALL_1( thisPtr, funcOffset, param1 ) \ @@ -276,6 +277,7 @@ : /* Output Operands */ \ :"r"(param1), /* Input Operands */ \ "c"(thisPtr) \ + : "%edx" /* Clobbered Registers */ \ ); \ #define CALL_THISCALL_1( resultName, thisPtr, funcOffset, param1 ) \ @@ -285,19 +287,25 @@ :"=a"(resultName) /* Output Operands */ \ :"r"(param1), /* Input Operands */ \ "c"(thisPtr) \ + : "%edx" /* Clobbered Registers */ \ ); \ #define CALL_THISCALL_1_DOUBLE( resultName, thisPtr, funcOffset, param1 ) \ - __asm__ __volatile__ ("pushl 4(%1)\n\t" \ - "pushl (%1)\n\t" \ - "movl (%2), %%edx\n\t" \ - "call *"#funcOffset"(%%edx);\n\t" \ - :"=a"(resultName) /* Output Operands */ \ - :"a"(¶m1), /* Input Operands */ \ - /* Note: Using "r" above instead of "a" fails */ \ - /* when using GCC 3.3.3, and maybe later versions*/\ - "c"(thisPtr) \ - ); \ + do { \ + double param1f64 = param1; /* Cast explicitly to double */ \ + double *param1f64Ptr = ¶m1f64; /* Make pointer to address */ \ + __asm__ __volatile__ ("pushl 4(%1)\n\t" \ + "pushl (%1)\n\t" \ + "movl (%2), %%edx\n\t" \ + "call *"#funcOffset"(%%edx);\n\t" \ + : "=a"(resultName) /* Output Operands */ \ + : "r"(param1f64Ptr), /* Input Operands */ \ + "c"(thisPtr), \ + "m"(*param1f64Ptr) /* Using address */ \ + : "%edx" /* Clobbered Registers */ \ + ); \ + } while (0); \ + #define CALL_THISCALL_2( resultName, thisPtr, funcOffset, param1, param2 ) \ __asm__ __volatile__ ("pushl %1\n\t" \ @@ -308,6 +316,7 @@ :"r"(param2), /* Input Operands */ \ "r"(param1), \ "c"(thisPtr) \ + : "%edx" /* Clobbered Registers */ \ ); \ #define CALL_THISCALL_4( resultName, thisPtr, funcOffset, param1, param2, param3, param4 )\ @@ -323,6 +332,7 @@ "r"(param2), \ "r"(param1), \ "c"(thisPtr) \ + : "%edx" /* Clobbered Registers */ \ ); \ #endif
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDevice.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDevice.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -104,7 +104,7 @@ } optional<int> MidiInputDevice::ParameterPorts::RangeMaxAsInt(std::map<String,String> Parameters) { - return 100; + return optional<int>::nothing; } std::vector<int> MidiInputDevice::ParameterPorts::PossibilitiesAsInt(std::map<String,String> Parameters) {
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceAlsa.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceAlsa.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * * * * 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 * @@ -28,6 +28,9 @@ namespace LinuxSampler { + /// number of currently existing ALSA midi input devices in LinuxSampler + static int existingAlsaDevices = 0; + // *************** ParameterName *************** // * @@ -119,6 +122,50 @@ +// *************** MidiInputDeviceAlsa::ParameterName *************** +// * + + MidiInputDeviceAlsa::ParameterName::ParameterName() : DeviceCreationParameterString() { + InitWithDefault(); // use default name + } + + MidiInputDeviceAlsa::ParameterName::ParameterName(String s) : DeviceCreationParameterString(s) { + } + + String MidiInputDeviceAlsa::ParameterName::Description() { + return "Arbitrary ALSA client name"; + } + + bool MidiInputDeviceAlsa::ParameterName::Fix() { + return true; + } + + bool MidiInputDeviceAlsa::ParameterName::Mandatory() { + return false; + } + + std::map<String,DeviceCreationParameter*> MidiInputDeviceAlsa::ParameterName::DependsAsParameters() { + return std::map<String,DeviceCreationParameter*>(); // no dependencies + } + + std::vector<String> MidiInputDeviceAlsa::ParameterName::PossibilitiesAsString(std::map<String,String> Parameters) { + return std::vector<String>(); + } + + optional<String> MidiInputDeviceAlsa::ParameterName::DefaultAsString(std::map<String,String> Parameters) { + return (existingAlsaDevices) ? "LinuxSampler" + ToString(existingAlsaDevices) : "LinuxSampler"; + } + + void MidiInputDeviceAlsa::ParameterName::OnSetValue(String s) throw (Exception) { + // not possible, as parameter is fix + } + + String MidiInputDeviceAlsa::ParameterName::Name() { + return "NAME"; + } + + + // *************** MidiInputPortAlsa *************** // * @@ -192,12 +239,13 @@ if (snd_seq_open(&hAlsaSeq, "default", SND_SEQ_OPEN_INPUT, 0) < 0) { throw MidiInputException("Error opening ALSA sequencer"); } + existingAlsaDevices++; this->hAlsaSeqClient = snd_seq_client_id(hAlsaSeq); - snd_seq_set_client_name(hAlsaSeq, "LinuxSampler"); - AcquirePorts(((DeviceCreationParameterInt*)Parameters"PORTS")->ValueAsInt()); - if (((DeviceCreationParameterBool*)Parameters"ACTIVE")->ValueAsBool()) { - Listen(); - } + snd_seq_set_client_name(hAlsaSeq, ((DeviceCreationParameterString*)Parameters"NAME")->ValueAsString().c_str()); + AcquirePorts(((DeviceCreationParameterInt*)Parameters"PORTS")->ValueAsInt()); + if (((DeviceCreationParameterBool*)Parameters"ACTIVE")->ValueAsBool()) { + Listen(); + } } MidiInputDeviceAlsa::~MidiInputDeviceAlsa() { @@ -210,6 +258,7 @@ Ports.clear(); snd_seq_close(hAlsaSeq); + existingAlsaDevices--; //FIXME: this is too simple, can lead to multiple clients with the same name } MidiInputDeviceAlsa::MidiInputPortAlsa* MidiInputDeviceAlsa::CreateMidiPort() { @@ -237,7 +286,7 @@ } String MidiInputDeviceAlsa::Version() { - String s = "$Revision: 1.23 $"; + String s = "$Revision: 1.24 $"; return s.substr(11, s.size() - 13); // cut dollar signs, spaces and CVS macro keyword }
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceAlsa.h -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceAlsa.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * * * * 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 * @@ -99,6 +99,25 @@ void UnsubscribeAll(); }; + /** MIDI Device Parameter 'NAME' + * + * Used to assign an arbitrary name to the ALSA client of this + * MIDI device. + */ + class ParameterName : public DeviceCreationParameterString { + public: + ParameterName(); + ParameterName(String s); + virtual String Description(); + virtual bool Fix(); + virtual bool Mandatory(); + virtual std::map<String,DeviceCreationParameter*> DependsAsParameters(); + virtual std::vector<String> PossibilitiesAsString(std::map<String,String> Parameters); + virtual optional<String> DefaultAsString(std::map<String,String> Parameters); + virtual void OnSetValue(String s) throw (Exception); + static String Name(); + }; + MidiInputDeviceAlsa(std::map<String,DeviceCreationParameter*> Parameters, void* pSampler); ~MidiInputDeviceAlsa();
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceFactory.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceFactory.cpp
Changed
@@ -55,6 +55,8 @@ /* Common parameters */ REGISTER_MIDI_INPUT_DRIVER_PARAMETER(MidiInputDeviceAlsa, ParameterActive); REGISTER_MIDI_INPUT_DRIVER_PARAMETER(MidiInputDeviceAlsa, ParameterPorts); + /* Driver specific parameters */ + REGISTER_MIDI_INPUT_DRIVER_PARAMETER(MidiInputDeviceAlsa, ParameterName); #endif // HAVE_ALSA #if HAVE_COREMIDI @@ -138,6 +140,7 @@ for (int i = 0; i >= 0; i++) { // seek for a free place starting from the beginning if (!mMidiInputDevicesi) { iDeviceId = i; + mMidiInputDevices.erase(i); break; } } @@ -147,7 +150,7 @@ // now create the device using those parameters MidiInputDevice* pDevice = InnerFactoriesDriverName->Create(thisDeviceParams, pSampler); pDevice->setDeviceId(iDeviceId); - // now attach all parameters to the newely created device. + // now attach all parameters to the newly created device. for (std::map<String,DeviceCreationParameter*>::iterator iter = thisDeviceParams.begin(); iter != thisDeviceParams.end(); iter++) { iter->second->Attach(pDevice); }
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceJack.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceJack.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Andreas Persson * + * Copyright (C) 2008 - 2010 Andreas Persson * * * * 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 * @@ -165,10 +165,10 @@ hJackClient = pJackClient->hJackClient; existingJackDevices++; - AcquirePorts(((DeviceCreationParameterInt*)Parameters"PORTS")->ValueAsInt()); - if (((DeviceCreationParameterBool*)Parameters"ACTIVE")->ValueAsBool()) { + AcquirePorts(((DeviceCreationParameterInt*)Parameters"PORTS")->ValueAsInt()); + if (((DeviceCreationParameterBool*)Parameters"ACTIVE")->ValueAsBool()) { Listen(); - } + } } MidiInputDeviceJack::~MidiInputDeviceJack() { @@ -182,7 +182,7 @@ Ports.clear(); JackClient::ReleaseMidi(((DeviceCreationParameterString*)Parameters"NAME")->ValueAsString()); - existingJackDevices--; + existingJackDevices--; //FIXME: this is too simple, can lead to multiple clients with the same name } MidiInputDeviceJack::MidiInputPortJack* MidiInputDeviceJack::CreateMidiPort() { @@ -210,7 +210,7 @@ } String MidiInputDeviceJack::Version() { - String s = "$Revision: 1.3 $"; + String s = "$Revision: 1.5 $"; return s.substr(11, s.size() - 13); // cut dollar signs, spaces and CVS macro keyword } @@ -225,15 +225,16 @@ #else int event_count = jack_midi_get_event_count(port_buffer); #endif - for (int i = 0 ; i < event_count ; i++) - { + for (int i = 0 ; i < event_count ; i++) { jack_midi_event_t ev; #if JACK_MIDI_FUNCS_NEED_NFRAMES jack_midi_event_get(&ev, port_buffer, i, nsamples); // old jack version #else jack_midi_event_get(&ev, port_buffer, i); #endif - port->DispatchRaw(ev.buffer, ev.time); + if (ev.buffer) { // jack2 1.9.5 has been seen sending NULL here + port->DispatchRaw(ev.buffer, ev.time); + } } } }
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceMme.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceMme.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -29,7 +29,7 @@ namespace LinuxSampler { -void CALLBACK MidiInputDeviceMme::MidiInputPortMme::win32_midiin_callback(HMIDIIN handle, UINT uMsg, DWORD dwInstance, DWORD dwParam1, DWORD dwParam2) { +void CALLBACK MidiInputDeviceMme::MidiInputPortMme::win32_midiin_callback(HMIDIIN handle, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2) { MidiInputDeviceMme::MidiInputPortMme* p = (MidiInputDeviceMme::MidiInputPortMme*)dwInstance; p->MmeCallbackDispatcher(handle, uMsg, dwParam1, dwParam2); } @@ -151,8 +151,8 @@ } MidiInputDeviceMme::MidiInputPortMme::~MidiInputPortMme() { - delete TmpSysExBuf; - delete SysExBuf; + delete TmpSysExBuf; + delete SysExBuf; } @@ -238,7 +238,7 @@ } -void MidiInputDeviceMme::MidiInputPortMme::MmeCallbackDispatcher(HMIDIIN handle, UINT uMsg, DWORD dwParam1, DWORD dwParam2) { +void MidiInputDeviceMme::MidiInputPortMme::MmeCallbackDispatcher(HMIDIIN handle, UINT uMsg, DWORD_PTR dwParam1, DWORD_PTR dwParam2) { unsigned char *DataPtr; // pointer to SysEx data unsigned char *data; // pointer to standard MIDI messages which are not sysex data(max 3 bytes long)
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputDeviceMme.h -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputDeviceMme.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -92,11 +92,11 @@ ~MidiInputPortMme(); void ConnectToMmeMidiSource(const char* MidiSource); void CloseMmeMidiPort(void); - void MmeCallbackDispatcher(HMIDIIN handle, UINT uMsg, DWORD dwParam1, DWORD dwParam2); + void MmeCallbackDispatcher(HMIDIIN handle, UINT uMsg, DWORD_PTR dwParam1, DWORD_PTR dwParam2); friend class MidiInputDeviceMme; private: MidiInputDeviceMme* pDevice; - static void CALLBACK win32_midiin_callback(HMIDIIN handle, UINT uMsg, DWORD dwInstance, DWORD dwParam1, DWORD dwParam2); + static void CALLBACK win32_midiin_callback(HMIDIIN handle, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2); HMIDIIN MidiInHandle; MIDIHDR midiHdr; bool MidiInOpened;
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/MidiInputPort.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/MidiInputPort.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -102,13 +102,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, MidiChannel); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, MidiChannel); } MidiChannelMapReader.Unlock(); @@ -127,13 +127,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, MidiChannel, FragmentPos); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOn(Key, Velocity, MidiChannel, FragmentPos); } MidiChannelMapReader.Unlock(); @@ -152,13 +152,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, MidiChannel); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, MidiChannel); } MidiChannelMapReader.Unlock(); @@ -177,13 +177,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, MidiChannel, FragmentPos); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendNoteOff(Key, Velocity, MidiChannel, FragmentPos); } MidiChannelMapReader.Unlock(); @@ -202,13 +202,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch); + for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, MidiChannel); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch); + for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, MidiChannel); } MidiChannelMapReader.Unlock(); } @@ -220,13 +220,13 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, MidiChannel, FragmentPos); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendPitchbend(Pitch, MidiChannel, FragmentPos); } MidiChannelMapReader.Unlock(); } @@ -238,15 +238,22 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value); + for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, MidiChannel); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value); + for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, MidiChannel); } MidiChannelMapReader.Unlock(); + + // dispatch event to all low priority MIDI listeners + const std::vector<VirtualMidiDevice*>& listeners = + virtualMidiDevicesReader.Lock(); + for (int i = 0; i < listeners.size(); ++i) + listenersi->SendCCToDevice(Controller, Value); + virtualMidiDevicesReader.Unlock(); } void MidiInputPort::DispatchControlChange(uint8_t Controller, uint8_t Value, uint MidiChannel, int32_t FragmentPos) { @@ -256,15 +263,22 @@ { std::set<EngineChannel*>::iterator engineiter = midiChannelMapMidiChannel.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapMidiChannel.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, MidiChannel, FragmentPos); } // dispatch event for engines listening to ALL MIDI channels { std::set<EngineChannel*>::iterator engineiter = midiChannelMapmidi_chan_all.begin(); std::set<EngineChannel*>::iterator end = midiChannelMapmidi_chan_all.end(); - for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, FragmentPos); + for (; engineiter != end; engineiter++) (*engineiter)->SendControlChange(Controller, Value, MidiChannel, FragmentPos); } MidiChannelMapReader.Unlock(); + + // dispatch event to all low priority MIDI listeners + const std::vector<VirtualMidiDevice*>& listeners = + virtualMidiDevicesReader.Lock(); + for (int i = 0; i < listeners.size(); ++i) + listenersi->SendCCToDevice(Controller, Value); + virtualMidiDevicesReader.Unlock(); } void MidiInputPort::DispatchSysex(void* pData, uint Size) {
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/VirtualMidiDevice.cpp -> linuxsampler-2342.tar.bz2/src/drivers/midi/VirtualMidiDevice.cpp
Changed
@@ -1,5 +1,5 @@ /* - Copyright (C) 2008 Christian Schoenebeck + Copyright (C) 2008 - 2009 Christian Schoenebeck */ #include "VirtualMidiDevice.h" @@ -8,7 +8,8 @@ #include "../../common/atomic.h" #include "../../common/RingBuffer.h" -#define MIDI_KEYS 128 +#define MIDI_KEYS 128 +#define MIDI_CONTROLLERS 128 // assuming VirtualMidiDevice implementation is only controlled // by mouse (and the user not being Billy the Kid) @@ -22,6 +23,9 @@ atomic_t pNoteIsActiveMIDI_KEYS; // status of each key (either active or inactive) atomic_t pNoteOnVelocityMIDI_KEYS; atomic_t pNoteOffVelocityMIDI_KEYS; + atomic_t ccsChanged; // whether some controller changed at all + atomic_t pCCChangedMIDI_CONTROLLERS; // which controller(s) changed + atomic_t pCCValueMIDI_CONTROLLERS; // current value of each controller RingBuffer<VirtualMidiDevice::event_t,false> events; private_data_t() : events(MAX_EVENTS, 0) {} @@ -30,12 +34,16 @@ VirtualMidiDevice::VirtualMidiDevice() : p(new private_data_t) { atomic_t zero = ATOMIC_INIT(0); atomic_t defaultVelocity = ATOMIC_INIT(127); + atomic_t defaultCCValue = ATOMIC_INIT(0); p->notesChanged = zero; + p->ccsChanged = zero; for (int i = 0; i < MIDI_KEYS; i++) { p->pNoteChangedi = zero; p->pNoteIsActivei = zero; p->pNoteOnVelocityi = defaultVelocity; p->pNoteOffVelocityi = defaultVelocity; + p->pCCChangedi = zero; + p->pCCValuei = defaultCCValue; } } @@ -58,6 +66,14 @@ p->events.push(&ev); return true; } + + bool VirtualMidiDevice::SendCCToSampler(uint8_t Controller, uint8_t Value) { + if (Controller >= MIDI_CONTROLLERS || Value > 127) return false; + event_t ev = { EVENT_TYPE_CC, Controller, Value }; + if (p->events.write_space() <= 0) return false; + p->events.push(&ev); + return true; + } bool VirtualMidiDevice::GetMidiEventFromDevice(event_t& Event) { return (p->events.pop(&Event) > 0); @@ -68,12 +84,24 @@ atomic_sub(c, &p->notesChanged ); return c; } + + bool VirtualMidiDevice::ControllersChanged() { + int c = atomic_read( &p->ccsChanged ); + atomic_sub(c, &p->ccsChanged ); + return c; + } bool VirtualMidiDevice::NoteChanged(uint8_t Key) { int c = atomic_read( &(p->pNoteChanged)Key ); atomic_sub(c, &(p->pNoteChanged)Key ); return c; } + + bool VirtualMidiDevice::ControllerChanged(uint8_t Controller) { + int c = atomic_read( &(p->pCCChanged)Controller ); + atomic_sub(c, &(p->pCCChanged)Controller ); + return c; + } bool VirtualMidiDevice::NoteIsActive(uint8_t Key) { return atomic_read( &(p->pNoteIsActive)Key ); @@ -86,6 +114,10 @@ uint8_t VirtualMidiDevice::NoteOffVelocity(uint8_t Key) { return atomic_read( &(p->pNoteOffVelocity)Key ); } + + uint8_t VirtualMidiDevice::ControllerValue(uint8_t Controller) { + return atomic_read( &(p->pCCValue)Controller ); + } void VirtualMidiDevice::SendNoteOnToDevice(uint8_t Key, uint8_t Velocity) { if (Key >= MIDI_KEYS) return; @@ -102,5 +134,12 @@ atomic_inc( &(p->pNoteChanged)Key ); atomic_inc( &p->notesChanged ); } + + void VirtualMidiDevice::SendCCToDevice(uint8_t Controller, uint8_t Value) { + if (Controller >= MIDI_CONTROLLERS) return; + atomic_set( &(p->pCCValue)Controller, Value ); + atomic_inc( &(p->pCCChanged)Controller ); + atomic_inc( &p->ccsChanged ); + } } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/drivers/midi/VirtualMidiDevice.h -> linuxsampler-2342.tar.bz2/src/drivers/midi/VirtualMidiDevice.h
Changed
@@ -1,5 +1,5 @@ /* - Copyright (C) 2008 Christian Schoenebeck + Copyright (C) 2008 - 2009 Christian Schoenebeck */ #ifndef LS_VIRTUALMIDIDEVICE_H @@ -21,13 +21,14 @@ public: enum event_type_t { EVENT_TYPE_NOTEON = 1, - EVENT_TYPE_NOTEOFF = 2 + EVENT_TYPE_NOTEOFF = 2, + EVENT_TYPE_CC = 3 }; struct event_t { event_type_t Type; - uint8_t Key; - uint8_t Velocity; + uint8_t Arg1; ///< Depends on @c Type (e.g. key number for note on/off events). + uint8_t Arg2; ///< Depends on @c Type (e.g. velocity for note on/off events). }; ///////////////////////////////////////////////////////////////// @@ -51,6 +52,14 @@ bool SendNoteOffToSampler(uint8_t Key, uint8_t Velocity); /** + * Sends a MIDI @e Control @e Change event to the sampler. + * + * @returns true on success, false if internal FIFO full + * (or provided values invalid) + */ + bool SendCCToSampler(uint8_t Controller, uint8_t Value); + + /** * Can be called by the virtual MIDI device to check whether a new note * on or note off MIDI event arrived to the sampler during the last * call to this method. So this is a asynchronously, "polling" based @@ -87,6 +96,29 @@ */ uint8_t NoteOffVelocity(uint8_t Key); + /** + * Can be called by the virtual MIDI device to check whether a Control + * Change MIDI event arrived to the sampler during the last + * call to this method. So this is a asynchronously, "polling" based + * communication mechanism, which works in conjunction with the + * ControllerValue() method call. + */ + bool ControllersChanged(); + + /** + * Can be called by the virtual MIDI device to check whether a Control + * Change MIDI event arrived to the sampler for @a Controller during + * the last call to this method. So this is a asynchronously, + * "polling" based communication mechanism, which works in + * conjunction with the ControllerValue() method call. + */ + bool ControllerChanged(uint8_t Controller); + + /** + * Returns the value of the @e last Control Change event. No FIFO is used! + */ + uint8_t ControllerValue(uint8_t Controller); + ///////////////////////////////////////////////////////////////// // Sampler methods // (usually only called by the Sampler) @@ -116,6 +148,18 @@ void SendNoteOffToDevice(uint8_t Key, uint8_t Velocity); /** + * Informs the virtual MIDI device that a @e Control @e Change event + * occured (e.g. caused by a MIDI keyboard connected to the sampler). + * Communication acts asynchronously, that is this method call doesn't + * lock in any way and returns immediately. It is thus realtime safe. + * + * @e Note: this method is usually only called by the sampler. + * + * @see ControllersChanged(), ControllerValue() + */ + void SendCCToDevice(uint8_t Controller, uint8_t Value); + + /** * Gets the next pending MIDI event from the virtual MIDI device by * using a lockfree FIFO. *
View file
linuxsampler-1.0.0.tar.bz2/src/effects/Effect.cpp -> linuxsampler-2342.tar.bz2/src/effects/Effect.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Christian Schoenebeck * + * Copyright (C) 2008, 2010 Christian Schoenebeck * * * * 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 * @@ -22,14 +22,23 @@ namespace LinuxSampler { +Effect::Effect() { + pParent = NULL; + iID = -1; +} + Effect::~Effect() { for (int i = 0; i < vInputChannels.size(); ++i) delete vInputChannelsi; for (int i = 0; i < vOutputChannels.size(); ++i) delete vOutputChannelsi; + for (int i = 0; i < vInputControls.size(); ++i) + delete vInputControlsi; + for (int i = 0; i < vOutputControls.size(); ++i) + delete vOutputControlsi; } -void Effect::InitEffect(AudioOutputDevice* pDevice) { +void Effect::InitEffect(AudioOutputDevice* pDevice) throw (Exception) { } AudioChannel* Effect::InputChannel(uint ChannelIndex) const { @@ -50,4 +59,29 @@ return vOutputChannels.size(); } +EffectControl* Effect::InputControl(uint ControlIndex) const { + if (ControlIndex >= vInputControls.size()) return NULL; + return vInputControlsControlIndex; +} + +uint Effect::InputControlCount() const { + return vInputControls.size(); +} + +void Effect::SetParent(void* pParent) { + this->pParent = pParent; +} + +void* Effect::Parent() const { + return pParent; +} + +void Effect::SetId(int id) { + iID = id; +} + +int Effect::ID() const { + return iID; +} + } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/effects/Effect.h -> linuxsampler-2342.tar.bz2/src/effects/Effect.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Christian Schoenebeck * + * Copyright (C) 2008, 2010 Christian Schoenebeck * * * * 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 * @@ -23,11 +23,14 @@ #include <vector> #include "../drivers/audio/AudioChannel.h" +#include "../common/Exception.h" +#include "EffectControl.h" namespace LinuxSampler { // just symbol prototyping class AudioOutputDevice; +class EffectInfo; /** * Abstract base class for sampler internal effects. @@ -39,10 +42,18 @@ // (these have to be implemented by the descendant) /** + * General information about this effect type, that is independent of this + * instance of this effect type. + * + * @returns general effect information + */ + virtual EffectInfo* GetEffectInfo() = 0; + + /** * Use the input audio signal given with @a ppInputChannels, render the * effect and mix the result into the effect's output channels. * - * @param Samples - amount of sample points to process + * @param Samples - amount of sample points to process */ virtual void RenderAudio(uint Samples) = 0; @@ -55,8 +66,14 @@ * output channels! ;-) * * @param pDevice - audio output device which is going to play the signal + * @throws Exception - if effect could not be initialized successfully + */ + virtual void InitEffect(AudioOutputDevice* pDevice) throw (Exception); + + /** + * Constructor, initializes variables. */ - virtual void InitEffect(AudioOutputDevice* pDevice); + Effect(); /** * Destructor, deletes all audio input and output channels. @@ -93,9 +110,47 @@ */ uint OutputChannelCount() const; + /** + * Returns effect parameter with index \a ControlIndex or NULL if index + * out of bounds. + */ + EffectControl* InputControl(uint ControlIndex) const; + + /** + * Returns the amount of effect parameters the effect provides. + */ + uint InputControlCount() const; + + /** + * Shall be called to set the object that uses this effect, e.g. to + * determine whether an effect is currently in use. + */ + void SetParent(void* pParent); + + /** + * Returns object which currently uses this effect. + */ + void* Parent() const; + + /** + * Sets the unique numerical ID of this effect within the sampler instance. + * This method is usually only called by the EffectFactory class. + */ + void SetId(int id); + + /** + * Returns unique numerical ID of this effect within the sampler instance, + * as previously set by SetId() . + */ + int ID() const; + protected: std::vector<AudioChannel*> vInputChannels; std::vector<AudioChannel*> vOutputChannels; + std::vector<EffectControl*> vInputControls; + std::vector<EffectControl*> vOutputControls; ///< yet unused + void* pParent; + int iID; }; } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/effects/EffectChain.cpp -> linuxsampler-2342.tar.bz2/src/effects/EffectChain.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Christian Schoenebeck * + * Copyright (C) 2008 - 2010 Christian Schoenebeck * * * * 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 * @@ -24,14 +24,16 @@ namespace LinuxSampler { -EffectChain::EffectChain(AudioOutputDevice* pDevice) { +EffectChain::EffectChain(AudioOutputDevice* pDevice, int iEffectChainId) { this->pDevice = pDevice; + iID = iEffectChainId; } void EffectChain::AppendEffect(Effect* pEffect) { pEffect->InitEffect(pDevice); _ChainEntry entry = { pEffect, true }; vEntries.push_back(entry); + pEffect->SetParent(this); } void EffectChain::InsertEffect(Effect* pEffect, int iChainPos) throw (Exception) { @@ -40,11 +42,12 @@ "Cannot insert effect at chain position " + ToString(iChainPos) + ", index out of bounds." ); - pEffect->InitEffect(pDevice); + pEffect->InitEffect(pDevice); // might throw Exception ! std::vector<_ChainEntry>::iterator iter = vEntries.begin(); for (int i = 0; i < iChainPos; ++i) ++iter; _ChainEntry entry = { pEffect, true }; vEntries.insert(iter, entry); + pEffect->SetParent(this); } void EffectChain::RemoveEffect(int iChainPos) throw (Exception) { @@ -55,7 +58,9 @@ ); std::vector<_ChainEntry>::iterator iter = vEntries.begin(); for (int i = 0; i < iChainPos; ++i) ++iter; + Effect* pEffect = (*iter).pEffect; vEntries.erase(iter); + pEffect->SetParent(NULL); // mark effect as not in use anymore } void EffectChain::RenderAudio(uint Samples) { @@ -115,4 +120,8 @@ } } +int EffectChain::ID() const { + return iID; +} + } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/effects/EffectChain.h -> linuxsampler-2342.tar.bz2/src/effects/EffectChain.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Christian Schoenebeck * + * Copyright (C) 2008 - 2010 Christian Schoenebeck * * * * 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 * @@ -40,8 +40,12 @@ * * @param pDevice - audio output context for the effects, providing * informations like samplerate + * @param iEffectChainId - (optional) numerical ID of the effect chain, + * intended for master effect chains, unique among + * all master effect chains which share the same + * audio output device */ - EffectChain(AudioOutputDevice* pDevice); + EffectChain(AudioOutputDevice* pDevice, int iEffectChainId = -1); /** * Add the given effect to the end of the effect chain. @@ -99,6 +103,19 @@ */ void ClearAllChannels(); + /** + * Returns numerical ID of this effect chain, intended for master effect + * chains. The ID is unique among all master effect chains which share the + * same audio output device. + * + * There is no ID for insert effect chains, since a sampler channel + * always provides exactly one insert effect chain. + * + * @returns id equal or larger than zero if master effect chain, negative + * number if this is an insert effect chain + */ + int ID() const; + private: struct _ChainEntry { Effect* pEffect; @@ -107,6 +124,7 @@ std::vector<_ChainEntry> vEntries; AudioOutputDevice* pDevice; + int iID; }; } // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/effects/EffectControl.cpp
Added
@@ -0,0 +1,90 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#include "EffectControl.h" + +namespace LinuxSampler { + +EffectControl::EffectControl() { + value = 0.0f; + type = EFFECT_TYPE_BOOL; +} + +EffectControl::~EffectControl() { +} + +void EffectControl::SetValue(float val) throw (Exception) { + if (minValue && val < *minValue) + throw Exception("Effect control value smaller than minimum allowed value"); + if (maxValue && val > *maxValue) + throw Exception("Effect control value greater than maximum allowed value"); + value = val; +} + +float& EffectControl::Value() { + return value; +} + +EffectControl::Type_t EffectControl::Type() const { + return type; +} + +String EffectControl::TypeAsString() const { + switch (type) { + case EFFECT_TYPE_FLOAT: + return "FLOAT"; + case EFFECT_TYPE_INT: + return "INT"; + case EFFECT_TYPE_BOOL: + return "BOOL"; + default: + return "INVALID"; + } +} + +String EffectControl::Description() const { + return description; +} + +optional<float> EffectControl::DefaultValue() const { + return defaultValue; +} + +optional<float> EffectControl::MinValue() const { + return minValue; +} + +optional<float> EffectControl::MaxValue() const { + return maxValue; +} + +std::vector<float> EffectControl::Possibilities() const { + return possibilities; +} + +void EffectControl::SetDefaultValue(float val) { + defaultValue = val; +} + +void EffectControl::SetMinValue(float val) { + minValue = val; +} + +void EffectControl::SetMaxValue(float val) { + maxValue = val; +} + +void EffectControl::SetPossibilities(const std::vector<float>& v) { + possibilities = v; +} + +void EffectControl::SetType(Type_t t) { + type = t; +} + +void EffectControl::SetDescription(String s) { + description = s; +} + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/effects/EffectControl.h
Added
@@ -0,0 +1,64 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#ifndef LS_EFFECTCONTROL_H +#define LS_EFFECTCONTROL_H + +#include "../common/Exception.h" +#include "../common/optional.h" +#include <vector> + +namespace LinuxSampler { + +// just symbol prototyping +class Effect; + +/** + * Represents an effect parameter. As the set of parameters an effect offers, + * varies quite a bit, this class provides necessary informations about the + * respective effect parameter. + */ +class EffectControl { +public: + enum Type_t { + EFFECT_TYPE_FLOAT, + EFFECT_TYPE_INT, + EFFECT_TYPE_BOOL + }; + + EffectControl(); + virtual ~EffectControl(); + virtual void SetValue(float val) throw (Exception); + virtual float& Value(); + Type_t Type() const; + String TypeAsString() const; + String Description() const; + optional<float> DefaultValue() const; + optional<float> MinValue() const; + optional<float> MaxValue() const; + std::vector<float> Possibilities() const; + +protected: + void SetDefaultValue(float val); + void SetMinValue(float val); + void SetMaxValue(float val); + void SetType(Type_t t); + void SetDescription(String s); + void SetPossibilities(const std::vector<float>& v); + + friend class Effect; + +private: + float value; + Type_t type; + String description; + optional<float> defaultValue; + optional<float> minValue; + optional<float> maxValue; + std::vector<float> possibilities; +}; + +} // namespace LinuxSampler + +#endif // LS_EFFECTCONTROL_H
View file
linuxsampler-2342.tar.bz2/src/effects/EffectFactory.cpp
Added
@@ -0,0 +1,213 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#include "EffectFactory.h" +#include "LadspaEffect.h" +#include "../common/Path.h" +#include "../common/IDGenerator.h" +#include <algorithm> + +namespace LinuxSampler { + +namespace { + +//////////////////////////////////////////////////////////////////////////// +// class 'EffectInfos' + +class EffectInfos { +public: + EffectInfos(); + ~EffectInfos(); + void Update(); + uint Count(); + EffectInfo* GetEffectInfo(uint index); +private: + std::vector<EffectInfo*> infos; + bool bInitialized; +}; + +EffectInfos::EffectInfos() : bInitialized(false) { +} + +EffectInfos::~EffectInfos() { + for (int i = 0; i < infos.size(); i++) delete infosi; +} + +void EffectInfos::Update() { + // clear out all old effect infos + for (int i = 0; i < infos.size(); i++) delete infosi; + + // scan for LADSPA effects + infos = LadspaEffect::AvailableEffects(); +} + +uint EffectInfos::Count() { + if (!bInitialized) { + Update(); + bInitialized = true; + } + return infos.size(); +} + +EffectInfo* EffectInfos::GetEffectInfo(uint index) { + if (index >= infos.size()) return NULL; + return infosindex; +} + + +//////////////////////////////////////////////////////////////////////////// +// private static variables + +EffectInfos effectInfos; + +std::vector<Effect*> vEffectInstances; + +IDGenerator idGenerator; + +} + + +//////////////////////////////////////////////////////////////////////////// +// class 'EffectFactory' + +String EffectFactory::AvailableEffectSystemsAsString() { + return "LADSPA"; +} + +uint EffectFactory::AvailableEffectsCount() { + return effectInfos.Count(); +} + +EffectInfo* EffectFactory::GetEffectInfo(uint index) { + return effectInfos.GetEffectInfo(index); +} + +static String _toLower(String s) { + std::transform(s.begin(), s.end(), s.begin(), ::tolower); + return s; +} + +static String _stripFileExtension(String sFileName) { +#if defined(WIN32) + Path p = Path::fromWindows(sFileName); + return p.stripLastName() + "\\" + p.getBaseName(); +#else + Path p = Path::fromPosix(sFileName); + return p.stripLastName() + "/" + p.getBaseName(); +#endif +} + +static String _stripFilePath(String sFileName) { +#if defined(WIN32) + Path p = Path::fromWindows(sFileName); +#else + Path p = Path::fromPosix(sFileName); +#endif + return p.getName(); +} + +static bool _moduleNameMatches(String name1, String name2, int iModuleMatchFlags) { + if (iModuleMatchFlags == EffectFactory::MODULE_IGNORE_ALL) return true; + if (iModuleMatchFlags == EffectFactory::MODULE_MATCH_EXACTLY) return name1 == name2; + if (iModuleMatchFlags & EffectFactory::MODULE_IGNORE_CASE) { + name1 = _toLower(name1); + name2 = _toLower(name2); + } + if (iModuleMatchFlags & EffectFactory::MODULE_IGNORE_EXTENSION) { + name1 = _stripFileExtension(name1); + name2 = _stripFileExtension(name2); + } + if (iModuleMatchFlags & EffectFactory::MODULE_IGNORE_PATH) { + name1 = _stripFilePath(name1); + name2 = _stripFilePath(name2); + } + return name1 == name2; +} + +EffectInfo* EffectFactory::GetEffectInfo(String effectSystem, String module, String effectName, int iModuleMatchFlags) { + for (int i = 0; i < effectInfos.Count(); i++) { + EffectInfo* pEffectInfo = effectInfos.GetEffectInfo(i); + if (pEffectInfo->EffectSystem() == effectSystem && + _moduleNameMatches(pEffectInfo->Module(), module, iModuleMatchFlags) && + pEffectInfo->Name() == effectName + ) { + return pEffectInfo; + } + } + return NULL; +} + +Effect* EffectFactory::Create(EffectInfo* pEffectInfo) throw (Exception) { + Effect* pEffect = NULL; + try { + if (pEffectInfo->EffectSystem() == "LADSPA") { + pEffect = new LadspaEffect(pEffectInfo); + } else { + throw Exception( + "Effect system '" + pEffectInfo->EffectSystem() + + "' not supported" + ); + } + } catch (Exception e) { + throw Exception("Could not create effect: " + e.Message()); + } catch (...) { + throw Exception("Could not create effect: unknown exception"); + } + if (!pEffect) { + // should never happen + throw Exception("Oops, EffectFactory bug: !pEffect"); + } + + // stick a new unique effect ID to the effect instance + const int id = idGenerator.create(); + if (id < 0) { + delete pEffect; + throw Exception("Could not generate a new effect ID, whole ID value range is occupied!"); + } + pEffect->SetId(id); + + vEffectInstances.push_back(pEffect); + return pEffect; +} + +void EffectFactory::Destroy(Effect* pEffect) throw (Exception) { + // check if effect is still in use + if (pEffect->Parent()) + throw Exception("effect still in use"); + + // now delete effect + for (int i = 0; i < vEffectInstances.size(); i++) { + if (vEffectInstancesi == pEffect) { + vEffectInstances.erase(vEffectInstances.begin() + i); + + // free the effect's ID + idGenerator.destroy(pEffect->ID()); + + delete pEffect; + } + } +} + +void EffectFactory::UpdateAvailableEffects() { + effectInfos.Update(); +} + +uint EffectFactory::EffectInstancesCount() { + return vEffectInstances.size(); +} + +Effect* EffectFactory::GetEffectInstance(uint index) { + if (index >= vEffectInstances.size()) return NULL; + return vEffectInstancesindex; +} + +Effect* EffectFactory::GetEffectInstanceByID(int id) { + for (int i = 0; i < vEffectInstances.size(); i++) { + if (vEffectInstancesi->ID() == id) + return vEffectInstancesi; + } + return NULL; +} + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/effects/EffectFactory.h
Added
@@ -0,0 +1,145 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#ifndef LS_EFFECT_FACTORY_H +#define LS_EFFECT_FACTORY_H + +#include "Effect.h" +#include "EffectInfo.h" +#include "../common/Exception.h" + +namespace LinuxSampler { + +/** + * Manages all sampler internal effects. It offers a list and detailed + * informations about all internal effects available for the sampler and allows + * to create and destroy instances of those effects. It provides a general + * interface for these functions, independent of the respective effect system's + * implementation details. + */ +class EffectFactory { +public: + /** + * Used as search criteria for plugin DLL filenames by GetEffectInfo() . + * These flags can be bitwise or-ed. + */ + enum ModuleMatchFlag_t { + MODULE_MATCH_EXACTLY = 0, ///< The plugin DLL filename has to match exactly. + MODULE_IGNORE_CASE = 1, ///< Ignore upper case / lower case differences in the module names. + MODULE_IGNORE_EXTENSION = 2, ///< Strip off the file extension (if any) before comparing the DLL filenames. + MODULE_IGNORE_PATH = 4, ///< Strip off the path of the plugin DLL filename before comparing. + MODULE_IGNORE_ALL = -1 ///< Will match all modules successfully, no matter what module name was provided. + }; + + /** + * Returns comma separated list of all effect systems currently available + * for this sampler. This list can vary on the exact configuration of the + * running machine and the options with which the sampler was compiled. + */ + static String AvailableEffectSystemsAsString(); + + /** + * Returns total amount of effects currently available for the sampler. This + * value can vary on the exact configuration of the running machine and + * especially on which effect plugins are currently installed on the machine. + * + * @e Note: When this method is called the 1st tim, it can take quite some + * time to return, since it will trigger a scan to retrieve all effects, + * currently available on the system. Those informations are then buffered + * in RAM and won't change on subsequent calls to AvailableEffectsCount() + * until an update of available effects is forced by calling + * UpdateAvailableEffects() . + * + * @see UpdateAvailableEffects() + */ + static uint AvailableEffectsCount(); + + /** + * Force to refresh the internal list of available effects and their + * detailed informations. This might be necessary e.g. when the user + * installed new effect plugins on his system and doesn't want to restart + * the whole sampler session just for being able to access the new effects. + */ + static void UpdateAvailableEffects(); + + /** + * Returns unique identifier and further detailed informations about the + * requested effect. + * + * @param index - index of the effect to retrieve informations about, must + * be between 0 and AvailableEffectsCount() + * @see UpdateAvailableEffects() + */ + static EffectInfo* GetEffectInfo(uint index); + + /** + * Returns unique identifier and further detailed informations about the + * the requested effect. Since the effect plugin's DLL filename (a.k.a. + * @a module) can vary for the very same effect on different systems, it + * is possible to use @a iModuleMatchFlags for defining in which way the + * provided DLL filename should be matched in this search or whether it + * should even be ignored completely. This allows to reload sampler sessions + * created on one system, successfully on another system, probably even + * having a completely different OS (e.g. Linux vs. Windows). + * + * @param effectSystem - e.g. 'LADSPA' + * @param module - usually the DLL filename of the effect plugin + * @param effectName - unique identifier of the effect within its plugin module + * @param iModuleMatchFlags - (optional) defines how strong the given + * @a module must match with the actual on the + * system available module name, the flags can + * be bitwise or-ed + * (default: the module name must match exactly) + * @returns effect info or NULL if there is no such effect + * @see ModuleMatchFlag_t + */ + static EffectInfo* GetEffectInfo(String effectSystem, String module, String effectName, int iModuleMatchFlags = MODULE_MATCH_EXACTLY); + + /** + * Create an instance of the requested effect. You should call Destroy() + * once the effect is not used anymore. + * + * @param pInfo - unique identifier of the effect to create + * @returns pointer to new effect instance, throws an Exception otherwise + * @throws Exception - if the requested effect could not be instantiated + * successfully + */ + static Effect* Create(EffectInfo* pInfo) throw (Exception); + + /** + * Destroy and free the given effect instance from memory, previously + * created with Create() . + * + * @param pEffect - effect instance to destroy + * @throws Exception - if effect is still in use + */ + static void Destroy(Effect* pEffect) throw (Exception); + + /** + * Returns total amount of effect instances created with Create() . + */ + static uint EffectInstancesCount(); + + /** + * Returns effect instance for the given index. + * + * @param index - index of the effect instance must be between 0 and + * EffectInstancesCount() + * @returns effect instance, or NULL if index out of bounds + */ + static Effect* GetEffectInstance(uint index); + + /** + * Returns effect instance with the given effect instance ID. + * + * @param id - effect instance ID of sought effect instance + * @returns effect instance or NULL if no effect instance with that ID + * could be found + */ + static Effect* GetEffectInstanceByID(int id); +}; + +} // namespace LinuxSampler + +#endif // LS_EFFECT_FACTORY_H
View file
linuxsampler-2342.tar.bz2/src/effects/EffectInfo.h
Added
@@ -0,0 +1,49 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#ifndef _EFFECT_INFO_H_ +#define _EFFECT_INFO_H_ + +namespace LinuxSampler { + +/** + * General informations about a specific effect. At the moment it is mainly + * used as unique identifier of a certain effect. In future it might also show + * further informations like amount of input / output channels, copyright + * informations etc. + * + * This abstract base class is implemented by the respective internal effect + * system. + * + * @see EffectFactory::GetEffectInfo() + */ +class EffectInfo { +public: + /** + * The underlying effect system the effect is based on, e.g. "LADSPA". + */ + virtual String EffectSystem() = 0; + + /** + * Unique name of the effect within its module (plugin DLL). + */ + virtual String Name() = 0; + + /** + * Name of the module (usually the DLL file name) that contains the effect. + */ + virtual String Module() = 0; + + /** + * Human readable name or description of the effect (not necessarily + * unique). + */ + virtual String Description() = 0; + + virtual ~EffectInfo() { } +}; + +} // namespace LinuxSampler + +#endif // _EFFECT_INFO_H_
View file
linuxsampler-2342.tar.bz2/src/effects/LadspaEffect.cpp
Added
@@ -0,0 +1,400 @@ +/* + Copyright (C) 2010 - 2012 Christian Schoenebeck +*/ + +#include "LadspaEffect.h" +#include "../common/DynamicLibraries.h" +#include "../common/global_private.h" +#include "../common/File.h" +#include "../drivers/audio/AudioOutputDevice.h" +#include <cmath> +#include <sstream> + +namespace LinuxSampler { + +//////////////////////////////////////////////////////////////////////////// +// private helper functions + +/// Returns total amount of ports for the given effect and port type. +static unsigned long _getPortCountByType(const LADSPA_Descriptor* psDescriptor, const LADSPA_PortDescriptor iType) { + unsigned long lCount = 0; + unsigned long lIndex; + for (lIndex = 0; lIndex < psDescriptor->PortCount; lIndex++) + if ((psDescriptor->PortDescriptorslIndex & iType) == iType) + lCount++; + + return lCount; +} + +//////////////////////////////////////////////////////////////////////////// +// class 'LadspaEffectInfo' + +/** + * Identifier of exactly one LADSPA effect, used as unique key, e.g. for the + * respective LADSPA effect to be loaded. + */ +class LadspaEffectInfo : public EffectInfo { +public: + String dll; + String label; + String name; + + String EffectSystem() { + return "LADSPA"; + } + + String Name() { + return label; + } + + String Module() { + return dll; + } + + String Description() { + return name; + } +}; + +//////////////////////////////////////////////////////////////////////////// +// class 'LadspaEffectControl' + +/** + * We just open access to protected members of EffectControl here. + */ +class LadspaEffectControl : public EffectControl { +public: + using EffectControl::SetDefaultValue; + using EffectControl::SetMinValue; + using EffectControl::SetMaxValue; + using EffectControl::SetType; + using EffectControl::SetDescription; + using EffectControl::SetPossibilities; +}; + +//////////////////////////////////////////////////////////////////////////// +// class 'LadspaEffect' + +LadspaEffect::LadspaEffect(EffectInfo* pInfo) throw (Exception) : Effect() { + this->pInfo = dynamic_cast<LadspaEffectInfo*>(pInfo); + if (!this->pInfo) + throw Exception("Effect key does not represent a LADSPA effect"); + + // DynamicLibraryOpen() and DynamicLibraryClose() maintain a reference + // count, so its OK to open and close the respective DLL for each effect, + // even though some effects might share the same DLL. + hDLL = DynamicLibraryOpen(this->pInfo->dll); + if (!hDLL) + throw Exception("Could not open DLL '" + this->pInfo->dll + "' for LADSPA effect"); + + LADSPA_Descriptor_Function pDescriptorFunction = (LADSPA_Descriptor_Function) + DynamicLibraryGetSymbol(hDLL, "ladspa_descriptor"); + + if (!pDescriptorFunction) + throw Exception("'" + this->pInfo->dll + "' is not a LADSPA plugin library"); + + // search for requested effect in that LADSPA DLL + for (long lPluginIndex = 0; true; lPluginIndex++) { + pDescriptor = pDescriptorFunction(lPluginIndex); + if (!pDescriptor) + throw Exception( + "Effect '" + this->pInfo->label + + "' could not be found in LADSPA DLL '" + this->pInfo->dll + "'" + ); + + if (pDescriptor->Label == this->pInfo->label) + break; // found + } + + // those will be set later in InitEffect() + hEffect = NULL; + pDevice = NULL; + + // create control input and control output variables (effect parameters) + // (they are going to be assigned to the actual LADSPA effect instance + // later in InitEffect() ) + const int iInControls = _getPortCountByType( + pDescriptor, + LADSPA_PORT_CONTROL | LADSPA_PORT_INPUT + ); + const int iOutControls = _getPortCountByType( + pDescriptor, + LADSPA_PORT_CONTROL | LADSPA_PORT_OUTPUT + ); + vInputControls.resize(iInControls); + vOutputControls.resize(iOutControls); + // create LadspaEffectControl instances and determine its informations + // (value range, description, default value) + int iInControl = 0; + int iOutControl = 0; + for (int iPort = 0; iPort < pDescriptor->PortCount; iPort++) { + LADSPA_PortDescriptor pPortDescriptor = pDescriptor->PortDescriptorsiPort; + if (LADSPA_IS_PORT_CONTROL(pPortDescriptor)) { + if (LADSPA_IS_PORT_INPUT(pPortDescriptor)) { + LadspaEffectControl* pEffectControl = new LadspaEffectControl(); + vInputControlsiInControl++ = pEffectControl; + + const float lower = getLowerB(iPort); + const float upper = getUpperB(iPort); + + // determine default value + float fDefault = 0.5f * lower + 0.5f * upper; // middle value by default + if (LADSPA_IS_HINT_HAS_DEFAULT(pPortDescriptor)) { + if (LADSPA_IS_HINT_DEFAULT_MINIMUM(pPortDescriptor)) { + fDefault = lower; + } else if (LADSPA_IS_HINT_DEFAULT_LOW(pPortDescriptor)) { + if (LADSPA_IS_HINT_LOGARITHMIC(pPortDescriptor)) { + fDefault = exp(log(lower) * 0.75 + log(upper) * 0.25); + } else { + fDefault = lower * 0.75 + upper * 0.25; + } + } else if (LADSPA_IS_HINT_DEFAULT_MIDDLE(pPortDescriptor)) { + if (LADSPA_IS_HINT_LOGARITHMIC(pPortDescriptor)) { + fDefault = exp(log(lower) * 0.5 + log(upper) * 0.5); + } else { + fDefault = 0.5f * lower + 0.5f * upper; + } + } else if (LADSPA_IS_HINT_DEFAULT_HIGH(pPortDescriptor)) { + if (LADSPA_IS_HINT_LOGARITHMIC(pPortDescriptor)) { + fDefault = exp(log(lower) * 0.25 + log(upper) * 0.75); + } else { + fDefault = lower * 0.25 + upper * 0.75; + } + } else if (LADSPA_IS_HINT_DEFAULT_MAXIMUM(pPortDescriptor)) { + fDefault = upper; + } else if (LADSPA_IS_HINT_DEFAULT_0(pPortDescriptor)) { + fDefault = 0.0f; + } else if (LADSPA_IS_HINT_DEFAULT_1(pPortDescriptor)) { + fDefault = 1.0f; + } else if (LADSPA_IS_HINT_DEFAULT_100(pPortDescriptor)) { + fDefault = 100.0f; + } else if (LADSPA_IS_HINT_DEFAULT_440(pPortDescriptor)) { + fDefault = 440.0f; + } + + pEffectControl->SetDefaultValue(fDefault); + } + pEffectControl->SetValue(fDefault); + + // determine value range type + EffectControl::Type_t type; + if (LADSPA_IS_HINT_INTEGER(pPortDescriptor)) { + type = EffectControl::EFFECT_TYPE_INT; + } else if (LADSPA_IS_HINT_TOGGLED(pPortDescriptor)) { + type = EffectControl::EFFECT_TYPE_BOOL; + } else { + type = EffectControl::EFFECT_TYPE_FLOAT; + } + pEffectControl->SetType(type); + + // is there a minimum value? + if (LADSPA_IS_HINT_BOUNDED_BELOW(pPortDescriptor)) { + pEffectControl->SetMinValue(lower); + } + + // is there a maximum value? + if (LADSPA_IS_HINT_BOUNDED_ABOVE(pPortDescriptor)) { + pEffectControl->SetMaxValue(upper); + } + + // boolean type? + if (LADSPA_IS_HINT_TOGGLED(pPortDescriptor)) { + std::vector<float> vPossibilities; + vPossibilities.push_back(0.0f); + vPossibilities.push_back(1.0f); + pEffectControl->SetPossibilities(vPossibilities); + } + + // retrieve human readable description about port + pEffectControl->SetDescription(pDescriptor->PortNamesiPort); + + } else if (LADSPA_IS_PORT_OUTPUT(pPortDescriptor)) { + LadspaEffectControl* pEffectControl = new LadspaEffectControl(); + vOutputControlsiOutControl++ = pEffectControl; + + //TODO: init output controls like input controls above + } + } + } +} + +LadspaEffect::~LadspaEffect() { + if (!hEffect) return; + if (pDescriptor->deactivate) + pDescriptor->deactivate(hEffect); + pDescriptor->cleanup(hEffect); + DynamicLibraryClose(hDLL); +} + +EffectInfo* LadspaEffect::GetEffectInfo() { + return pInfo; +} + +void LadspaEffect::RenderAudio(uint Samples) { + // (re)assign audio input and audio output buffers + int iInputPort = 0; + int iOutputPort = 0; + for (int iPort = 0; iPort < pDescriptor->PortCount; iPort++) { + LADSPA_PortDescriptor pPortDescriptor = pDescriptor->PortDescriptorsiPort; + if (LADSPA_IS_PORT_AUDIO(pPortDescriptor)) { + if (LADSPA_IS_PORT_INPUT(pPortDescriptor)) { + pDescriptor->connect_port(hEffect, iPort, vInputChannelsiInputPort++->Buffer()); + } else if (LADSPA_IS_PORT_OUTPUT(pPortDescriptor)) { + pDescriptor->connect_port(hEffect, iPort, vOutputChannelsiOutputPort++->Buffer()); + } + } + } + + // let the effect do its job + pDescriptor->run(hEffect, Samples); +} + +void LadspaEffect::InitEffect(AudioOutputDevice* pDevice) throw (Exception) { + this->pDevice = pDevice; + + const int iInChannels = _getPortCountByType( + pDescriptor, + LADSPA_PORT_AUDIO | LADSPA_PORT_INPUT + ); + const int iOutChannels = _getPortCountByType( + pDescriptor, + LADSPA_PORT_AUDIO | LADSPA_PORT_OUTPUT + ); + const int iInControls = vInputControls.size(); + const int iOutControls = vOutputControls.size(); + + // now create the actual LADSPA effect instance ... + dmsg(1, ("Instantiating LADSPA effect '%s'.\n", pInfo->label.c_str())); + hEffect = pDescriptor->instantiate(pDescriptor, pDevice->SampleRate()); + if (!hEffect) + throw Exception("Could not instantiate LADSPA effect '" + pInfo->label + "'"); + + // create audio input channels + vInputChannels.resize(iInChannels); + for (int i = 0; i < iInChannels; i++) { + vInputChannelsi = new AudioChannel(i, pDevice->MaxSamplesPerCycle()); + } + + // create audio output channels + vOutputChannels.resize(iOutChannels); + for (int i = 0; i < iOutChannels; i++) { + vOutputChannelsi = new AudioChannel(i, pDevice->MaxSamplesPerCycle()); + } + + // TODO: recalculate the min and max values that depends on sample rate + + // assign (already created and initialized) control input and control + // output variables (effect parameters) + int iInControl = 0; + int iOutControl = 0; + for (int iPort = 0; iPort < pDescriptor->PortCount; iPort++) { + LADSPA_PortDescriptor pPortDescriptor = pDescriptor->PortDescriptorsiPort; + if (LADSPA_IS_PORT_CONTROL(pPortDescriptor)) { + if (LADSPA_IS_PORT_INPUT(pPortDescriptor)) { + LadspaEffectControl* pEffectControl = + (LadspaEffectControl*) vInputControlsiInControl++; + pDescriptor->connect_port(hEffect, iPort, &pEffectControl->Value()); + } else if (LADSPA_IS_PORT_OUTPUT(pPortDescriptor)) { + LadspaEffectControl* pEffectControl = + (LadspaEffectControl*) vOutputControlsiOutControl++; + pDescriptor->connect_port(hEffect, iPort, &pEffectControl->Value()); + } + } + } + + // call LADSPA effect's activate function (if there is one) + if (pDescriptor->activate != NULL) + pDescriptor->activate(hEffect); + + dmsg(1, ("LADSPA effect '%s' activated.\n", pInfo->label.c_str())); +} + +/// Returns lowest allowed value for this LADSPA control port. +float LadspaEffect::getLowerB(int iPort) const { + float low = + (pDescriptor->PortRangeHintsiPort.HintDescriptor & LADSPA_HINT_BOUNDED_BELOW) + ? pDescriptor->PortRangeHintsiPort.LowerBound : 0.0f; + + if (pDescriptor->PortRangeHintsiPort.HintDescriptor & LADSPA_HINT_SAMPLE_RATE) + low *= float(pDevice == NULL ? 44100 : pDevice->SampleRate()); + + return low; +} + +/// Returns biggest allowed value for this LADSPA control port. +float LadspaEffect::getUpperB(int iPort) const { + float up = + (pDescriptor->PortRangeHintsiPort.HintDescriptor & LADSPA_HINT_BOUNDED_ABOVE) + ? pDescriptor->PortRangeHintsiPort.UpperBound : 1.0f; + + if (pDescriptor->PortRangeHintsiPort.HintDescriptor & LADSPA_HINT_SAMPLE_RATE) + up *= float(pDevice == NULL ? 44100 : pDevice->SampleRate()); + + return up; +} + +static void _foundLadspaDll(String filename, void* hDLL, void* pFunction, void* pCustom) { + LADSPA_Descriptor_Function fDescriptorFunction = (LADSPA_Descriptor_Function) pFunction; + std::vector<EffectInfo*>* pV = (std::vector<EffectInfo*>*) pCustom; + const LADSPA_Descriptor* psDescriptor; + for (long lIndex = 0; (psDescriptor = fDescriptorFunction(lIndex)) != NULL; lIndex++) { + //printf("\t%s (%lu/%s)\n", psDescriptor->Name, psDescriptor->UniqueID, psDescriptor->Label); + LadspaEffectInfo* pInfo = new LadspaEffectInfo; + pInfo->name = psDescriptor->Name; + pInfo->label = psDescriptor->Label; + pInfo->dll = filename; + pV->push_back(pInfo); + } + DynamicLibraryClose(hDLL); +} + +static String defaultLadspaDir() { + #if defined(WIN32) + const String sysDir = + getenv("PROGRAMFILES") ? getenv("PROGRAMFILES") : "C:\\Program Files"; + const String searchDirs = { + sysDir + "\\ladspa", //FIXME: hmm... who knows what the common default LADSPA path on Windows is? + sysDir + "\\Audacity\\Plug-Ins" + }; + #else + const String searchDirs = { + "/usr/lib/ladspa", + "/usr/local/lib/ladspa" + }; + #endif + // check if one of the suggested directories exists + for (int i = 0; i < sizeof(searchDirs) / sizeof(String); i++) { + File f(searchDirsi); + if (f.Exist() && f.IsDirectory()) + return searchDirsi; + } + // No directory of the list exists? Whatever, return the 1st one of the list. + return searchDirs0; +} + +std::vector<EffectInfo*> LadspaEffect::AvailableEffects() { + std::vector<EffectInfo*> v; // will be filled in callback function _foundLadspaDll() + + char* pcLadspaPath = getenv("LADSPA_PATH"); + String ladspaDir = pcLadspaPath ? pcLadspaPath : defaultLadspaDir(); + + try { + std::istringstream ss(ladspaDir); + std::string path; + while (std::getline(ss, path, File::PathSeparator)) { + if (!path.empty()) { + DynamicLibrariesSearch(path.c_str(), "ladspa_descriptor", _foundLadspaDll, &v); + } + } + } catch (Exception e) { + std::cerr << "Could not scan LADSPA effects: " << e.Message() + << std::endl << std::flush; + } catch (...) { + std::cerr << "Could not scan LADSPA effects: unknown exception\n" + << std::flush; + } + + return v; +} + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/effects/LadspaEffect.h
Added
@@ -0,0 +1,48 @@ +/* + Copyright (C) 2010 Christian Schoenebeck +*/ + +#ifndef LS_LADSPAEFFECT_H +#define LS_LADSPAEFFECT_H + +#include "Effect.h" +#include "EffectInfo.h" +#include "../common/ladspa.h" +#include "../common/Exception.h" +#include <vector> + +namespace LinuxSampler { + +class LadspaEffectInfo; +class AudioOutputDevice; + +/** + * Implementation of internal effects using the LADSPA effect system. + * + * @e Note: this class is only sampler internal and won't be exported to the + * external C++ API of the sampler. Use the static class EffectFactory instead + * for managing LADSPA effects by external applications. + */ +class LadspaEffect : public Effect { +public: + LadspaEffect(EffectInfo* pInfo) throw (Exception); + ~LadspaEffect(); + EffectInfo* GetEffectInfo(); + void RenderAudio(uint Samples); + void InitEffect(AudioOutputDevice* pDevice) throw (Exception); + static std::vector<EffectInfo*> AvailableEffects(); + +private: + LadspaEffectInfo* pInfo; + void* hDLL; + const LADSPA_Descriptor* pDescriptor; + LADSPA_Handle hEffect; + AudioOutputDevice* pDevice; + + float getLowerB(int iPort) const; + float getUpperB(int iPort) const; +}; + +} // namespace LinuxSampler + +#endif // LS_LADSPAEFFECT_H
View file
linuxsampler-1.0.0.tar.bz2/src/effects/Makefile.am -> linuxsampler-2342.tar.bz2/src/effects/Makefile.am
Changed
@@ -4,9 +4,16 @@ liblinuxsamplereffectsincludedir = $(includedir)/linuxsampler/effects liblinuxsamplereffectsinclude_HEADERS = \ Effect.h \ - EffectChain.h + EffectInfo.h \ + EffectFactory.h \ + EffectChain.h \ + EffectControl.h noinst_LTLIBRARIES = liblinuxsamplereffects.la liblinuxsamplereffects_la_SOURCES = \ Effect.cpp Effect.h \ - EffectChain.cpp EffectChain.h + EffectInfo.h \ + EffectFactory.cpp EffectFactory.h \ + EffectChain.cpp EffectChain.h \ + EffectControl.cpp EffectControl.h \ + LadspaEffect.cpp LadspaEffect.h
View file
linuxsampler-2342.tar.bz2/src/engines/AbstractEngine.cpp
Added
@@ -0,0 +1,633 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "AbstractEngine.h" +#include "AbstractEngineChannel.h" +#include "EngineFactory.h" +#include "../common/global_private.h" +#include "../effects/EffectFactory.h" + +namespace LinuxSampler { + + //InstrumentResourceManager Engine::instruments; + + std::map<AbstractEngine::Format, std::map<AudioOutputDevice*,AbstractEngine*> > AbstractEngine::engines; + + /** + * Get an AbstractEngine object for the given AbstractEngineChannel and the + * given AudioOutputDevice. All engine channels which are connected to + * the same audio output device will use the same engine instance. This + * method will be called by an EngineChannel whenever it's + * connecting to an audio output device. + * + * @param pChannel - engine channel which acquires an engine object + * @param pDevice - the audio output device \a pChannel is connected to + */ + AbstractEngine* AbstractEngine::AcquireEngine(AbstractEngineChannel* pChannel, AudioOutputDevice* pDevice) { + AbstractEngine* pEngine = NULL; + // check if there's already an engine for the given audio output device + std::map<AbstractEngine::Format, std::map<AudioOutputDevice*,AbstractEngine*> >::iterator it; + it = engines.find(pChannel->GetEngineFormat()); + if (it != engines.end() && (*it).second.count(pDevice)) { + dmsg(4,("Using existing Engine.\n")); + pEngine = (*it).secondpDevice; + + // Disable the engine while the new engine channel is + // added and initialized. The engine will be enabled again + // in EngineChannel::Connect. + pEngine->DisableAndLock(); + } else { // create a new engine (and disk thread) instance for the given audio output device + dmsg(4,("Creating new Engine.\n")); + pEngine = (AbstractEngine*) EngineFactory::Create(pChannel->EngineName()); + pEngine->Connect(pDevice); + enginespChannel->GetEngineFormat()pDevice = pEngine; + } + // register engine channel to the engine instance + pEngine->engineChannels.add(pChannel); + // remember index in the ArrayList + pChannel->iEngineIndexSelf = pEngine->engineChannels.size() - 1; + dmsg(4,("This Engine has now %d EngineChannels.\n",pEngine->engineChannels.size())); + return pEngine; + } + + AbstractEngine::AbstractEngine() { + pAudioOutputDevice = NULL; + pEventGenerator = NULL; + pSysexBuffer = new RingBuffer<uint8_t,false>(CONFIG_SYSEX_BUFFER_SIZE, 0); + pEventQueue = new RingBuffer<Event,false>(CONFIG_MAX_EVENTS_PER_FRAGMENT, 0); + pEventPool = new Pool<Event>(CONFIG_MAX_EVENTS_PER_FRAGMENT); + pGlobalEvents = new RTList<Event>(pEventPool); + FrameTime = 0; + RandomSeed = 0; + pDedicatedVoiceChannelLeft = pDedicatedVoiceChannelRight = NULL; + } + + AbstractEngine::~AbstractEngine() { + if (pEventQueue) delete pEventQueue; + if (pEventPool) delete pEventPool; + if (pEventGenerator) delete pEventGenerator; + if (pGlobalEvents) delete pGlobalEvents; + if (pSysexBuffer) delete pSysexBuffer; + if (pDedicatedVoiceChannelLeft) delete pDedicatedVoiceChannelLeft; + if (pDedicatedVoiceChannelRight) delete pDedicatedVoiceChannelRight; + Unregister(); + } + + /** + * Once an engine channel is disconnected from an audio output device, + * it will immediately call this method to unregister itself from the + * engine instance and if that engine instance is not used by any other + * engine channel anymore, then that engine instance will be destroyed. + * + * @param pChannel - engine channel which wants to disconnect from it's + * engine instance + * @param pDevice - audio output device \a pChannel was connected to + */ + void AbstractEngine::FreeEngine(AbstractEngineChannel* pChannel, AudioOutputDevice* pDevice) { + dmsg(4,("Disconnecting EngineChannel from Engine.\n")); + AbstractEngine* pEngine = enginespChannel->GetEngineFormat()pDevice; + // unregister EngineChannel from the Engine instance + pEngine->engineChannels.remove(pChannel); + // if the used Engine instance is not used anymore, then destroy it + if (pEngine->engineChannels.empty()) { + pDevice->Disconnect(pEngine); + enginespChannel->GetEngineFormat().erase(pDevice); + delete pEngine; + dmsg(4,("Destroying Engine.\n")); + } + else dmsg(4,("This Engine has now %d EngineChannels.\n",pEngine->engineChannels.size())); + } + + void AbstractEngine::Enable() { + dmsg(3,("AbstractEngine: enabling\n")); + EngineDisabled.PushAndUnlock(false, 2, 0, true); // set condition object 'EngineDisabled' to false (wait max. 2s) + dmsg(3,("AbstractEngine: enabled (val=%d)\n", EngineDisabled.GetUnsafe())); + } + + /** + * Temporarily stop the engine to not do anything. The engine will just be + * frozen during that time, that means after enabling it again it will + * continue where it was, with all its voices and playback state it had at + * the point of disabling. Notice that the engine's (audio) thread will + * continue to run, it just remains in an inactive loop during that time. + * + * If you need to be sure that all voices and disk streams are killed as + * well, use @c SuspendAll() instead. + * + * @see Enable(), SuspendAll() + */ + void AbstractEngine::Disable() { + dmsg(3,("AbstractEngine: disabling\n")); + bool* pWasDisabled = EngineDisabled.PushAndUnlock(true, 2); // wait max. 2s + if (!pWasDisabled) dmsg(3,("AbstractEngine warning: Timeout waiting to disable engine.\n")); + } + + void AbstractEngine::DisableAndLock() { + dmsg(3,("AbstractEngine: disabling\n")); + bool* pWasDisabled = EngineDisabled.Push(true, 2); // wait max. 2s + if (!pWasDisabled) dmsg(3,("AbstractEngine warning: Timeout waiting to disable engine.\n")); + } + + /** + * Reset all voices and disk thread and clear input event queue and all + * control and status variables. + */ + void AbstractEngine::Reset() { + DisableAndLock(); + ResetInternal(); + ResetScaleTuning(); + Enable(); + } + + /** + * Reset to normal, chromatic scale (means equal tempered). + */ + void AbstractEngine::ResetScaleTuning() { + memset(&ScaleTuning0, 0x00, 12); + } + + /** + * Copy all events from the engine's global input queue buffer to the + * engine's internal event list. This will be done at the beginning of + * each audio cycle (that is each RenderAudio() call) to distinguish + * all global events which have to be processed in the current audio + * cycle. These events are usually just SysEx messages. Every + * EngineChannel has it's own input event queue buffer and event list + * to handle common events like NoteOn, NoteOff and ControlChange + * events. + * + * @param Samples - number of sample points to be processed in the + * current audio cycle + */ + void AbstractEngine::ImportEvents(uint Samples) { + RingBuffer<Event,false>::NonVolatileReader eventQueueReader = pEventQueue->get_non_volatile_reader(); + Event* pEvent; + while (true) { + // get next event from input event queue + if (!(pEvent = eventQueueReader.pop())) break; + // if younger event reached, ignore that and all subsequent ones for now + if (pEvent->FragmentPos() >= Samples) { + eventQueueReader--; + dmsg(2,("Younger Event, pos=%d ,Samples=%d!\n",pEvent->FragmentPos(),Samples)); + pEvent->ResetFragmentPos(); + break; + } + // copy event to internal event list + if (pGlobalEvents->poolIsEmpty()) { + dmsg(1,("Event pool emtpy!\n")); + break; + } + *pGlobalEvents->allocAppend() = *pEvent; + } + eventQueueReader.free(); // free all copied events from input queue + } + + /** + * Clear all engine global event lists. + */ + void AbstractEngine::ClearEventLists() { + pGlobalEvents->clear(); + } + + /** + * Will be called in case the respective engine channel sports FX send + * channels. In this particular case, engine channel local buffers are + * used to render and mix all voices to. This method is responsible for + * copying the audio data from those local buffers to the master audio + * output channels as well as to the FX send audio output channels with + * their respective FX send levels. + * + * @param pEngineChannel - engine channel from which audio should be + * routed + * @param Samples - amount of sample points to be routed in + * this audio fragment cycle + */ + void AbstractEngine::RouteAudio(EngineChannel* pEngineChannel, uint Samples) { + AbstractEngineChannel* pChannel = static_cast<AbstractEngineChannel*>(pEngineChannel); + AudioChannel* ppSource2 = { + pChannel->pChannelLeft, + pChannel->pChannelRight + }; + // route dry signal + { + AudioChannel* pDstL = pAudioOutputDevice->Channel(pChannel->AudioDeviceChannelLeft); + AudioChannel* pDstR = pAudioOutputDevice->Channel(pChannel->AudioDeviceChannelRight); + ppSource0->MixTo(pDstL, Samples); + ppSource1->MixTo(pDstR, Samples); + } + // route FX send signal (wet) + { + for (int iFxSend = 0; iFxSend < pChannel->GetFxSendCount(); iFxSend++) { + FxSend* pFxSend = pChannel->GetFxSend(iFxSend); + const bool success = RouteFxSend(pFxSend, ppSource, pFxSend->Level(), Samples); + if (!success) goto channel_cleanup; + } + } + channel_cleanup: + // reset buffers with silence (zero out) for the next audio cycle + ppSource0->Clear(); + ppSource1->Clear(); + } + + /** + * Similar to RouteAudio(), but this method is even more special. It is + * only called by voices which have dedicated effect send(s) level(s). So + * such voices have to be routed separately apart from the other voices + * which can just be mixed together and routed afterwards in one turn. + */ + void AbstractEngine::RouteDedicatedVoiceChannels(EngineChannel* pEngineChannel, optional<float> FxSendLevels2, uint Samples) { + AbstractEngineChannel* pChannel = static_cast<AbstractEngineChannel*>(pEngineChannel); + AudioChannel* ppSource2 = { + pDedicatedVoiceChannelLeft, + pDedicatedVoiceChannelRight + }; + // route dry signal + { + AudioChannel* pDstL = pAudioOutputDevice->Channel(pChannel->AudioDeviceChannelLeft); + AudioChannel* pDstR = pAudioOutputDevice->Channel(pChannel->AudioDeviceChannelRight); + ppSource0->MixTo(pDstL, Samples); + ppSource1->MixTo(pDstR, Samples); + } + // route FX send signals (wet) + // (we simply hard code the voices 'reverb send' to the 1st effect + // send bus, and the voioces 'chorus send' to the 2nd effect send bus) + { + for (int iFxSend = 0; iFxSend < 2 && iFxSend < pChannel->GetFxSendCount(); iFxSend++) { + // no voice specific FX send level defined for this effect? + if (!FxSendLevelsiFxSend) continue; // ignore this effect then + + FxSend* pFxSend = pChannel->GetFxSend(iFxSend); + const bool success = RouteFxSend(pFxSend, ppSource, *FxSendLevelsiFxSend, Samples); + if (!success) goto channel_cleanup; + } + } + channel_cleanup: + // reset buffers with silence (zero out) for the next dedicated voice rendering/routing process + ppSource0->Clear(); + ppSource1->Clear(); + } + + /** + * Route the audio signal given by @a ppSource to the effect send bus + * defined by @a pFxSend (wet signal only). + * + * @param pFxSend - definition of effect send bus + * @param ppSource - the 2 channels of the audio signal to be routed + * @param FxSendLevel - the effect send level to by applied + * @param Samples - amount of sample points to be processed + * @returns true if signal was routed successfully, false on error + */ + bool AbstractEngine::RouteFxSend(FxSend* pFxSend, AudioChannel* ppSource2, float FxSendLevel, uint Samples) { + for (int iChan = 0; iChan < 2; ++iChan) { + const int iDstChan = pFxSend->DestinationChannel(iChan); + if (iDstChan < 0) { + dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination channel (%d->%d)", ((iChan) ? "R" : "L"), iChan, iDstChan)); + return false; // error + } + AudioChannel* pDstChan = NULL; + if (pFxSend->DestinationEffectChain() >= 0) { // fx send routed to an internal send effect + EffectChain* pEffectChain = + pAudioOutputDevice->SendEffectChainByID( + pFxSend->DestinationEffectChain() + ); + if (!pEffectChain) { + dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination effect chain %d", ((iChan) ? "R" : "L"), pFxSend->DestinationEffectChain())); + return false; // error + } + Effect* pEffect = + pEffectChain->GetEffect( + pFxSend->DestinationEffectChainPosition() + ); + if (!pEffect) { + dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination effect %d of effect chain %d", ((iChan) ? "R" : "L"), pFxSend->DestinationEffectChainPosition(), pFxSend->DestinationEffectChain())); + return false; // error + } + pDstChan = pEffect->InputChannel(iDstChan); + } else { // FX send routed directly to an audio output channel + pDstChan = pAudioOutputDevice->Channel(iDstChan); + } + if (!pDstChan) { + dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination channel (%d->%d)", ((iChan) ? "R" : "L"), iChan, iDstChan)); + return false; // error + } + ppSourceiChan->MixTo(pDstChan, Samples, FxSendLevel); + } + return true; // success + } + + /** + * Calculates the Roland GS sysex check sum. + * + * @param AddrReader - reader which currently points to the first GS + * command address byte of the GS sysex message in + * question + * @param DataSize - size of the GS message data (in bytes) + */ + uint8_t AbstractEngine::GSCheckSum(const RingBuffer<uint8_t,false>::NonVolatileReader AddrReader, uint DataSize) { + RingBuffer<uint8_t,false>::NonVolatileReader reader = AddrReader; + uint bytes = 3 /*addr*/ + DataSize; + uint8_t addr_and_databytes; + reader.read(&addr_and_data0, bytes); + uint8_t sum = 0; + for (uint i = 0; i < bytes; i++) sum += addr_and_datai; + return 128 - sum % 128; + } + + /** + * Allows to tune each of the twelve semitones of an octave. + * + * @param ScaleTunes - detuning of all twelve semitones (in cents) + */ + void AbstractEngine::AdjustScale(int8_t ScaleTunes12) { + memcpy(&this->ScaleTuning0, &ScaleTunes0, 12); //TODO: currently not sample accurate + } + + uint AbstractEngine::VoiceCount() { + return atomic_read(&ActiveVoiceCount); + } + + void AbstractEngine::SetVoiceCount(uint Count) { + atomic_set(&ActiveVoiceCount, Count); + } + + uint AbstractEngine::VoiceCountMax() { + return ActiveVoiceCountMax; + } + + /** + * Moves pitchbend event from the general (input) event list to the engine + * channel's event list. It will actually processed later by the + * respective voice. + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itPitchbendEvent - absolute pitch value and time stamp of the event + */ + void AbstractEngine::ProcessPitchbend(AbstractEngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent) { + pEngineChannel->Pitch = itPitchbendEvent->Param.Pitch.Pitch; // store current pitch value + } + + void AbstractEngine::ProcessFxSendControllers ( + AbstractEngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ) { + if (!pEngineChannel->fxSends.empty()) { + for (int iFxSend = 0; iFxSend < pEngineChannel->GetFxSendCount(); iFxSend++) { + FxSend* pFxSend = pEngineChannel->GetFxSend(iFxSend); + if (pFxSend->MidiController() == itControlChangeEvent->Param.CC.Controller) { + pFxSend->SetLevel(itControlChangeEvent->Param.CC.Value); + pFxSend->SetInfoChanged(true); + } + } + } + } + + /** + * Will be called by the MIDI input device whenever a MIDI system + * exclusive message has arrived. + * + * @param pData - pointer to sysex data + * @param Size - lenght of sysex data (in bytes) + * @param pSender - the MIDI input port on which the SysEx message was + * received + */ + void AbstractEngine::SendSysex(void* pData, uint Size, MidiInputPort* pSender) { + Event event = pEventGenerator->CreateEvent(); + event.Type = Event::type_sysex; + event.Param.Sysex.Size = Size; + event.pEngineChannel = NULL; // as Engine global event + event.pMidiInputPort = pSender; + if (pEventQueue->write_space() > 0) { + if (pSysexBuffer->write_space() >= Size) { + // copy sysex data to input buffer + uint toWrite = Size; + uint8_t* pPos = (uint8_t*) pData; + while (toWrite) { + const uint writeNow = RTMath::Min(toWrite, pSysexBuffer->write_space_to_end()); + pSysexBuffer->write(pPos, writeNow); + toWrite -= writeNow; + pPos += writeNow; + + } + // finally place sysex event into input event queue + pEventQueue->push(&event); + } + else dmsg(1,("Engine: Sysex message too large (%d byte) for input buffer (%d byte)!",Size,CONFIG_SYSEX_BUFFER_SIZE)); + } + else dmsg(1,("Engine: Input event queue full!")); + } + + /** + * Reacts on MIDI system exclusive messages. + * + * @param itSysexEvent - sysex data size and time stamp of the sysex event + */ + void AbstractEngine::ProcessSysex(Pool<Event>::Iterator& itSysexEvent) { + RingBuffer<uint8_t,false>::NonVolatileReader reader = pSysexBuffer->get_non_volatile_reader(); + + uint8_t exclusive_status, id; + if (!reader.pop(&exclusive_status)) goto free_sysex_data; + if (!reader.pop(&id)) goto free_sysex_data; + if (exclusive_status != 0xF0) goto free_sysex_data; + + switch (id) { + case 0x7f: { // (Realtime) Universal Sysex (GM Standard) + uint8_t sysex_channel, sub_id1, sub_id2, val_msb, val_lsb;; + if (!reader.pop(&sysex_channel)) goto free_sysex_data; + if (!reader.pop(&sub_id1)) goto free_sysex_data; + if (!reader.pop(&sub_id2)) goto free_sysex_data; + if (!reader.pop(&val_lsb)) goto free_sysex_data; + if (!reader.pop(&val_msb)) goto free_sysex_data; + //TODO: for now we simply ignore the sysex channel, seldom used anyway + switch (sub_id1) { + case 0x04: // Device Control + switch (sub_id2) { + case 0x01: { // Master Volume + const double volume = + double((uint(val_msb)<<7) | uint(val_lsb)) / 16383.0; + #if CONFIG_MASTER_VOLUME_SYSEX_BY_PORT + // apply volume to all sampler channels that + // are connected to the same MIDI input port + // this sysex message arrived on + for (int i = 0; i < engineChannels.size(); ++i) { + EngineChannel* pEngineChannel = engineChannelsi; + if (pEngineChannel->GetMidiInputPort() == + itSysexEvent->pMidiInputPort) + { + pEngineChannel->Volume(volume); + } + } + #else + // apply volume globally to the whole sampler + GLOBAL_VOLUME = volume; + #endif // CONFIG_MASTER_VOLUME_SYSEX_BY_PORT + break; + } + } + break; + } + break; + } + case 0x41: { // Roland + dmsg(3,("Roland Sysex\n")); + uint8_t device_id, model_id, cmd_id; + if (!reader.pop(&device_id)) goto free_sysex_data; + if (!reader.pop(&model_id)) goto free_sysex_data; + if (!reader.pop(&cmd_id)) goto free_sysex_data; + if (model_id != 0x42 /*GS*/) goto free_sysex_data; + if (cmd_id != 0x12 /*DT1*/) goto free_sysex_data; + + // command address + uint8_t addr3; // 2 byte addr MSB, followed by 1 byte addr LSB) + const RingBuffer<uint8_t,false>::NonVolatileReader checksum_reader = reader; // so we can calculate the check sum later + if (reader.read(&addr0, 3) != 3) goto free_sysex_data; + if (addr0 == 0x40 && addr1 == 0x00) { // System Parameters + dmsg(3,("\tSystem Parameter\n")); + if (addr2 == 0x7f) { // GS reset + for (int i = 0; i < engineChannels.size(); ++i) { + AbstractEngineChannel* pEngineChannel + = static_cast<AbstractEngineChannel*>(engineChannelsi); + if (pEngineChannel->GetMidiInputPort() == itSysexEvent->pMidiInputPort) { + KillAllVoices(pEngineChannel, itSysexEvent); + pEngineChannel->ResetControllers(); + } + } + } + } + else if (addr0 == 0x40 && addr1 == 0x01) { // Common Parameters + dmsg(3,("\tCommon Parameter\n")); + } + else if (addr0 == 0x40 && (addr1 & 0xf0) == 0x10) { // Part Parameters (1) + dmsg(3,("\tPart Parameter\n")); + switch (addr2) { + case 0x40: { // scale tuning + dmsg(3,("\t\tScale Tuning\n")); + uint8_t scale_tunes12; // detuning of all 12 semitones of an octave + if (reader.read(&scale_tunes0, 12) != 12) goto free_sysex_data; + uint8_t checksum; + if (!reader.pop(&checksum)) goto free_sysex_data; + #if CONFIG_ASSERT_GS_SYSEX_CHECKSUM + if (GSCheckSum(checksum_reader, 12)) goto free_sysex_data; + #endif // CONFIG_ASSERT_GS_SYSEX_CHECKSUM + for (int i = 0; i < 12; i++) scale_tunesi -= 64; + AdjustScale((int8_t*) scale_tunes); + dmsg(3,("\t\t\tNew scale applied.\n")); + break; + } + case 0x15: { // chromatic / drumkit mode + dmsg(3,("\t\tMIDI Instrument Map Switch\n")); + uint8_t part = addr1 & 0x0f; + uint8_t map; + if (!reader.pop(&map)) goto free_sysex_data; + for (int i = 0; i < engineChannels.size(); ++i) { + AbstractEngineChannel* pEngineChannel + = static_cast<AbstractEngineChannel*>(engineChannelsi); + if ( + (pEngineChannel->midiChannel == part || + pEngineChannel->midiChannel == midi_chan_all) && + pEngineChannel->GetMidiInputPort() == itSysexEvent->pMidiInputPort + ) { + try { + pEngineChannel->SetMidiInstrumentMap(map); + } catch (Exception e) { + dmsg(2,("\t\t\tCould not apply MIDI instrument map %d to part %d: %s\n", map, part, e.Message().c_str())); + goto free_sysex_data; + } catch (...) { + dmsg(2,("\t\t\tCould not apply MIDI instrument map %d to part %d (unknown exception)\n", map, part)); + goto free_sysex_data; + } + } + } + dmsg(3,("\t\t\tApplied MIDI instrument map %d to part %d.\n", map, part)); + break; + } + } + } + else if (addr0 == 0x40 && (addr1 & 0xf0) == 0x20) { // Part Parameters (2) + } + else if (addr0 == 0x41) { // Drum Setup Parameters + } + break; + } + } + + free_sysex_data: // finally free sysex data + pSysexBuffer->increment_read_ptr(itSysexEvent->Param.Sysex.Size); + } + + String AbstractEngine::GetFormatString(Format f) { + switch(f) { + case GIG: return "GIG"; + case SF2: return "SF2"; + case SFZ: return "SFZ"; + default: return "UNKNOWN"; + } + } + + String AbstractEngine::EngineName() { + return GetFormatString(GetEngineFormat()); + } + + // static constant initializers + const AbstractEngine::FloatTable AbstractEngine::VolumeCurve(InitVolumeCurve()); + const AbstractEngine::FloatTable AbstractEngine::PanCurve(InitPanCurve()); + const AbstractEngine::FloatTable AbstractEngine::CrossfadeCurve(InitCrossfadeCurve()); + + float* AbstractEngine::InitVolumeCurve() { + // line-segment approximation + const float segments = { + 0, 0, 2, 0.0046, 16, 0.016, 31, 0.051, 45, 0.115, 54.5, 0.2, + 64.5, 0.39, 74, 0.74, 92, 1.03, 114, 1.94, 119.2, 2.2, 127, 2.2 + }; + return InitCurve(segments); + } + + float* AbstractEngine::InitPanCurve() { + // line-segment approximation + const float segments = { + 0, 0, 1, 0, + 2, 0.05, 31.5, 0.7, 51, 0.851, 74.5, 1.12, + 127, 1.41, 128, 1.41 + }; + return InitCurve(segments, 129); + } + + float* AbstractEngine::InitCrossfadeCurve() { + // line-segment approximation + const float segments = { + 0, 0, 1, 0.03, 10, 0.1, 51, 0.58, 127, 1 + }; + return InitCurve(segments); + } + + float* AbstractEngine::InitCurve(const float* segments, int size) { + float* y = new floatsize; + for (int x = 0 ; x < size ; x++) { + if (x > segments2) segments += 2; + yx = segments1 + (x - segments0) * + (segments3 - segments1) / (segments2 - segments0); + } + return y; + } + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/AbstractEngine.h
Added
@@ -0,0 +1,152 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_ABSTRACTENGINE_H__ +#define __LS_ABSTRACTENGINE_H__ + +#include "Engine.h" +#include "../common/ArrayList.h" +#include "../common/atomic.h" +#include "../common/ConditionServer.h" +#include "../common/Pool.h" +#include "../common/RingBuffer.h" +#include "../drivers/audio/AudioOutputDevice.h" +#include "common/Event.h" +#include "common/SignalUnitRack.h" + +namespace LinuxSampler { + + class AbstractEngineChannel; + + class AbstractEngine: public Engine { + + public: + enum Format { GIG = 1, SF2, SFZ }; + static String GetFormatString(Format f); + static AbstractEngine* AcquireEngine(AbstractEngineChannel* pChannel, AudioOutputDevice* pDevice); + static void FreeEngine(AbstractEngineChannel* pChannel, AudioOutputDevice* pDevice); + + AbstractEngine(); + virtual ~AbstractEngine(); + + // implementation of abstract methods derived from class 'LinuxSampler::Engine' + virtual void SendSysex(void* pData, uint Size, MidiInputPort* pSender); + virtual void Reset(); + virtual void Enable(); + virtual void Disable(); + virtual uint VoiceCount(); + virtual uint VoiceCountMax(); + virtual String EngineName(); + + virtual Format GetEngineFormat() = 0; + virtual void Connect(AudioOutputDevice* pAudioOut) = 0; + virtual void DisableAndLock(); + + void SetVoiceCount(uint Count);// Simple array wrapper just to make sure memory is freed + // when liblinuxsampler is unloaded + + float Random() { + RandomSeed = RandomSeed * 1103515245 + 12345; // classic pseudo random number generator + return RandomSeed / 4294967296.0f; + } + + class FloatTable { + private: + const float* array; + public: + FloatTable(const float* array) : array(array) { } + ~FloatTable() { delete array; } + const float& operator(int i) const { return arrayi; } + }; + + static const FloatTable VolumeCurve; ///< Table that maps volume control change values 0..127 to amplitude. Unity gain is at 90. + static const FloatTable PanCurve; ///< Table that maps pan control change values 0..128 to right channel amplitude. Unity gain is at 64 (center). + static const FloatTable CrossfadeCurve; ///< Table that maps crossfade control change values 0..127 to amplitude. Unity gain is at 127. + + AudioOutputDevice* pAudioOutputDevice; + + //TODO: should be protected + AudioChannel* pDedicatedVoiceChannelLeft; ///< encapsulates a special audio rendering buffer (left) for rendering and routing audio on a per voice basis (this is a very special case and only used for voices which lie on a note which was set with individual, dedicated FX send level) + AudioChannel* pDedicatedVoiceChannelRight; ///< encapsulates a special audio rendering buffer (right) for rendering and routing audio on a per voice basis (this is a very special case and only used for voices which lie on a note which was set with individual, dedicated FX send level) + + friend class AbstractVoice; + friend class AbstractEngineChannel; + template<class V, class R, class I> friend class EngineChannelBase; + template<class EC, class R, class S, class D> friend class VoiceBase; + + protected: + ArrayList<EngineChannel*> engineChannels; ///< All engine channels of a Engine instance. + ConditionServer EngineDisabled; + int8_t ScaleTuning12; ///< contains optional detune factors (-64..+63 cents) for all 12 semitones of an octave + RingBuffer<Event,false>* pEventQueue; ///< Input event queue for engine global events (e.g. SysEx messages). + EventGenerator* pEventGenerator; + RTList<Event>* pGlobalEvents; ///< All engine global events for the current audio fragment (usually only SysEx messages). + Pool<Event>* pEventPool; ///< Contains all Event objects that can be used. + RingBuffer<uint8_t,false>* pSysexBuffer; ///< Input buffer for MIDI system exclusive messages. + uint SampleRate; ///< Sample rate of the engines output audio signal (in Hz) + uint MaxSamplesPerCycle; ///< Size of each audio output buffer + unsigned long FrameTime; ///< Time in frames of the start of the current audio fragment + int ActiveVoiceCountMax; ///< the maximum voice usage since application start + atomic_t ActiveVoiceCount; ///< number of currently active voices + int VoiceSpawnsLeft; ///< We only allow CONFIG_MAX_VOICES voices to be spawned per audio fragment, we use this variable to ensure this limit. + + void RouteAudio(EngineChannel* pEngineChannel, uint Samples); + void RouteDedicatedVoiceChannels(EngineChannel* pEngineChannel, optional<float> FxSendLevels2, uint Samples); + void ClearEventLists(); + void ImportEvents(uint Samples); + void ProcessSysex(Pool<Event>::Iterator& itSysexEvent); + void ResetScaleTuning(); + void ProcessPitchbend(AbstractEngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent); + + void ProcessFxSendControllers ( + AbstractEngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ); + + uint8_t GSCheckSum(const RingBuffer<uint8_t,false>::NonVolatileReader AddrReader, uint DataSize); + + virtual void ResetInternal() = 0; + virtual void KillAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itKillEvent) = 0; + virtual void ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent) = 0; + virtual void ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent) = 0; + virtual void ProcessControlChange(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itControlChangeEvent) = 0; + virtual int GetMinFadeOutSamples() = 0; + + private: + static std::map<Format, std::map<AudioOutputDevice*,AbstractEngine*> > engines; + uint32_t RandomSeed; ///< State of the random number generator used by the random dimension. + + static float* InitVolumeCurve(); + static float* InitPanCurve(); + static float* InitCrossfadeCurve(); + static float* InitCurve(const float* segments, int size = 128); + + void AdjustScale(int8_t ScaleTunes12); + bool RouteFxSend(FxSend* pFxSend, AudioChannel* ppSource2, float FxSendLevel, uint Samples); + }; + +} // namespace LinuxSampler + +#endif /* __LS_ABSTRACTENGINE_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/AbstractEngineChannel.cpp
Added
@@ -0,0 +1,745 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "AbstractEngineChannel.h" +#include "../common/global_private.h" +#include "../Sampler.h" + +namespace LinuxSampler { + + AbstractEngineChannel::AbstractEngineChannel() : + virtualMidiDevicesReader_AudioThread(virtualMidiDevices), + virtualMidiDevicesReader_MidiThread(virtualMidiDevices) + { + pEngine = NULL; + pEvents = NULL; // we allocate when we retrieve the right Engine object + pEventQueue = new RingBuffer<Event,false>(CONFIG_MAX_EVENTS_PER_FRAGMENT, 0); + InstrumentIdx = -1; + InstrumentStat = -1; + pChannelLeft = NULL; + pChannelRight = NULL; + AudioDeviceChannelLeft = -1; + AudioDeviceChannelRight = -1; + pMidiInputPort = NULL; + midiChannel = midi_chan_all; + ResetControllers(); + PortamentoMode = false; + PortamentoTime = CONFIG_PORTAMENTO_TIME_DEFAULT; + } + + AbstractEngineChannel::~AbstractEngineChannel() { + delete pEventQueue; + DeleteGroupEventLists(); + RemoveAllFxSends(); + } + + Engine* AbstractEngineChannel::GetEngine() { + return pEngine; + } + + uint AbstractEngineChannel::Channels() { + return 2; + } + + /** + * More or less a workaround to set the instrument name, index and load + * status variable to zero percent immediately, that is without blocking + * the calling thread. It might be used in future for other preparations + * as well though. + * + * @param FileName - file name of the instrument file + * @param Instrument - index of the instrument in the file + * @see LoadInstrument() + */ + void AbstractEngineChannel::PrepareLoadInstrument(const char* FileName, uint Instrument) { + InstrumentFile = FileName; + InstrumentIdx = Instrument; + InstrumentStat = 0; + } + + String AbstractEngineChannel::InstrumentFileName() { + return InstrumentFile; + } + + String AbstractEngineChannel::InstrumentName() { + return InstrumentIdxName; + } + + int AbstractEngineChannel::InstrumentIndex() { + return InstrumentIdx; + } + + int AbstractEngineChannel::InstrumentStatus() { + return InstrumentStat; + } + + String AbstractEngineChannel::EngineName() { + return AbstractEngine::GetFormatString(GetEngineFormat()); + } + + void AbstractEngineChannel::Reset() { + if (pEngine) pEngine->DisableAndLock(); + ResetInternal(); + ResetControllers(); + if (pEngine) { + pEngine->Enable(); + pEngine->Reset(); + } + } + + void AbstractEngineChannel::ResetControllers() { + Pitch = 0; + GlobalVolume = 1.0f; + MidiVolume = 1.0; + GlobalPanLeft = 1.0f; + GlobalPanRight = 1.0f; + iLastPanRequest = 64; + GlobalTranspose = 0; + // set all MIDI controller values to zero + memset(ControllerTable, 0x00, 129); + // reset all FX Send levels + for ( + std::vector<FxSend*>::iterator iter = fxSends.begin(); + iter != fxSends.end(); iter++ + ) { + (*iter)->Reset(); + } + } + + /** + * This method is not thread safe! + */ + void AbstractEngineChannel::ResetInternal() { + CurrentKeyDimension = 0; + PortamentoPos = -1.0f; // no portamento active yet + + // delete all input events + pEventQueue->init(); + + if (pEngine) pEngine->ResetInternal(); + + // status of engine channel has changed, so set notify flag + bStatusChanged = true; + } + + /** + * Implementation of virtual method from abstract EngineChannel interface. + * This method will periodically be polled (e.g. by the LSCP server) to + * check if some engine channel parameter has changed since the last + * StatusChanged() call. + * + * This method can also be used to mark the engine channel as changed + * from outside, e.g. by a MIDI input device. The optional argument + * \a nNewStatus can be used for this. + * + * TODO: This "poll method" is just a lazy solution and might be + * replaced in future. + * @param bNewStatus - (optional, default: false) sets the new status flag + * @returns true if engine channel status has changed since last + * StatusChanged() call + */ + bool AbstractEngineChannel::StatusChanged(bool bNewStatus) { + bool b = bStatusChanged; + bStatusChanged = bNewStatus; + return b; + } + + float AbstractEngineChannel::Volume() { + return GlobalVolume; + } + + void AbstractEngineChannel::Volume(float f) { + GlobalVolume = f; + bStatusChanged = true; // status of engine channel has changed, so set notify flag + } + + float AbstractEngineChannel::Pan() { + return float(iLastPanRequest - 64) / 64.0f; + } + + void AbstractEngineChannel::Pan(float f) { + int iMidiPan = int(f * 64.0f) + 64; + if (iMidiPan > 127) iMidiPan = 127; + else if (iMidiPan < 0) iMidiPan = 0; + GlobalPanLeft = AbstractEngine::PanCurve128 - iMidiPan; + GlobalPanRight = AbstractEngine::PanCurveiMidiPan; + iLastPanRequest = iMidiPan; + } + + AudioOutputDevice* AbstractEngineChannel::GetAudioOutputDevice() { + return (pEngine) ? pEngine->pAudioOutputDevice : NULL; + } + + /** + * Gets thread safe access to the currently connected audio output + * device from other threads than the lscp thread. + */ + AudioOutputDevice* AbstractEngineChannel::GetAudioOutputDeviceSafe() { + EngineMutex.Lock(); + AudioOutputDevice* res = GetAudioOutputDevice(); + EngineMutex.Unlock(); + return res; + } + + void AbstractEngineChannel::SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel) { + if (!pEngine || !pEngine->pAudioOutputDevice) throw AudioOutputException("No audio output device connected yet."); + + AudioChannel* pChannel = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannel); + if (!pChannel) throw AudioOutputException("Invalid audio output device channel " + ToString(AudioDeviceChannel)); + switch (EngineAudioChannel) { + case 0: // left output channel + if (fxSends.empty()) pChannelLeft = pChannel; + AudioDeviceChannelLeft = AudioDeviceChannel; + break; + case 1: // right output channel + if (fxSends.empty()) pChannelRight = pChannel; + AudioDeviceChannelRight = AudioDeviceChannel; + break; + default: + throw AudioOutputException("Invalid engine audio channel " + ToString(EngineAudioChannel)); + } + + bStatusChanged = true; + } + + int AbstractEngineChannel::OutputChannel(uint EngineAudioChannel) { + switch (EngineAudioChannel) { + case 0: // left channel + return AudioDeviceChannelLeft; + case 1: // right channel + return AudioDeviceChannelRight; + default: + throw AudioOutputException("Invalid engine audio channel " + ToString(EngineAudioChannel)); + } + } + + void AbstractEngineChannel::Connect(MidiInputPort* pMidiPort, midi_chan_t MidiChannel) { + if (!pMidiPort || pMidiPort == this->pMidiInputPort) return; + DisconnectMidiInputPort(); + this->pMidiInputPort = pMidiPort; + this->midiChannel = MidiChannel; + pMidiPort->Connect(this, MidiChannel); + } + + void AbstractEngineChannel::DisconnectMidiInputPort() { + MidiInputPort* pOldPort = this->pMidiInputPort; + this->pMidiInputPort = NULL; + if (pOldPort) pOldPort->Disconnect(this); + } + + MidiInputPort* AbstractEngineChannel::GetMidiInputPort() { + return pMidiInputPort; + } + + midi_chan_t AbstractEngineChannel::MidiChannel() { + return midiChannel; + } + + void AbstractEngineChannel::Connect(VirtualMidiDevice* pDevice) { + // double buffer ... double work ... + { + ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.GetConfigForUpdate(); + devices.add(pDevice); + } + { + ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.SwitchConfig(); + devices.add(pDevice); + } + } + + void AbstractEngineChannel::Disconnect(VirtualMidiDevice* pDevice) { + // double buffer ... double work ... + { + ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.GetConfigForUpdate(); + devices.remove(pDevice); + } + { + ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.SwitchConfig(); + devices.remove(pDevice); + } + } + + /** + * Will be called by the MIDIIn Thread to let the audio thread trigger a new + * voice for the given key. This method is meant for real time rendering, + * that is an event will immediately be created with the current system + * time as time stamp. + * + * @param Key - MIDI key number of the triggered key + * @param Velocity - MIDI velocity value of the triggered key + */ + void AbstractEngineChannel::SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel) { + if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(); + event.Type = Event::type_note_on; + event.Param.Note.Key = Key; + event.Param.Note.Velocity = Velocity; + event.Param.Note.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("EngineChannel: Input event queue full!")); + // inform connected virtual MIDI devices if any ... + // (e.g. virtual MIDI keyboard in instrument editor(s)) + ArrayList<VirtualMidiDevice*>& devices = + const_cast<ArrayList<VirtualMidiDevice*>&>( + virtualMidiDevicesReader_MidiThread.Lock() + ); + for (int i = 0; i < devices.size(); i++) { + devicesi->SendNoteOnToDevice(Key, Velocity); + } + virtualMidiDevicesReader_MidiThread.Unlock(); + } + } + + /** + * Will be called by the MIDIIn Thread to let the audio thread trigger a new + * voice for the given key. This method is meant for offline rendering + * and / or for cases where the exact position of the event in the current + * audio fragment is already known. + * + * @param Key - MIDI key number of the triggered key + * @param Velocity - MIDI velocity value of the triggered key + * @param FragmentPos - sample point position in the current audio + * fragment to which this event belongs to + */ + void AbstractEngineChannel::SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos) { + if (FragmentPos < 0) { + dmsg(1,("EngineChannel::SendNoteOn(): negative FragmentPos! Seems MIDI driver is buggy!")); + } + else if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); + event.Type = Event::type_note_on; + event.Param.Note.Key = Key; + event.Param.Note.Velocity = Velocity; + event.Param.Note.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("EngineChannel: Input event queue full!")); + // inform connected virtual MIDI devices if any ... + // (e.g. virtual MIDI keyboard in instrument editor(s)) + ArrayList<VirtualMidiDevice*>& devices = + const_cast<ArrayList<VirtualMidiDevice*>&>( + virtualMidiDevicesReader_MidiThread.Lock() + ); + for (int i = 0; i < devices.size(); i++) { + devicesi->SendNoteOnToDevice(Key, Velocity); + } + virtualMidiDevicesReader_MidiThread.Unlock(); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread to release + * voice(s) on the given key. This method is meant for real time rendering, + * that is an event will immediately be created with the current system + * time as time stamp. + * + * @param Key - MIDI key number of the released key + * @param Velocity - MIDI release velocity value of the released key + */ + void AbstractEngineChannel::SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel) { + if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(); + event.Type = Event::type_note_off; + event.Param.Note.Key = Key; + event.Param.Note.Velocity = Velocity; + event.Param.Note.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("EngineChannel: Input event queue full!")); + // inform connected virtual MIDI devices if any ... + // (e.g. virtual MIDI keyboard in instrument editor(s)) + ArrayList<VirtualMidiDevice*>& devices = + const_cast<ArrayList<VirtualMidiDevice*>&>( + virtualMidiDevicesReader_MidiThread.Lock() + ); + for (int i = 0; i < devices.size(); i++) { + devicesi->SendNoteOffToDevice(Key, Velocity); + } + virtualMidiDevicesReader_MidiThread.Unlock(); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread to release + * voice(s) on the given key. This method is meant for offline rendering + * and / or for cases where the exact position of the event in the current + * audio fragment is already known. + * + * @param Key - MIDI key number of the released key + * @param Velocity - MIDI release velocity value of the released key + * @param FragmentPos - sample point position in the current audio + * fragment to which this event belongs to + */ + void AbstractEngineChannel::SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos) { + if (FragmentPos < 0) { + dmsg(1,("EngineChannel::SendNoteOff(): negative FragmentPos! Seems MIDI driver is buggy!")); + } + else if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); + event.Type = Event::type_note_off; + event.Param.Note.Key = Key; + event.Param.Note.Velocity = Velocity; + event.Param.Note.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("EngineChannel: Input event queue full!")); + // inform connected virtual MIDI devices if any ... + // (e.g. virtual MIDI keyboard in instrument editor(s)) + ArrayList<VirtualMidiDevice*>& devices = + const_cast<ArrayList<VirtualMidiDevice*>&>( + virtualMidiDevicesReader_MidiThread.Lock() + ); + for (int i = 0; i < devices.size(); i++) { + devicesi->SendNoteOffToDevice(Key, Velocity); + } + virtualMidiDevicesReader_MidiThread.Unlock(); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread to change + * the pitch value for all voices. This method is meant for real time + * rendering, that is an event will immediately be created with the + * current system time as time stamp. + * + * @param Pitch - MIDI pitch value (-8192 ... +8191) + */ + void AbstractEngineChannel::SendPitchbend(int Pitch, uint8_t MidiChannel) { + if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(); + event.Type = Event::type_pitchbend; + event.Param.Pitch.Pitch = Pitch; + event.Param.Pitch.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("EngineChannel: Input event queue full!")); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread to change + * the pitch value for all voices. This method is meant for offline + * rendering and / or for cases where the exact position of the event in + * the current audio fragment is already known. + * + * @param Pitch - MIDI pitch value (-8192 ... +8191) + * @param FragmentPos - sample point position in the current audio + * fragment to which this event belongs to + */ + void AbstractEngineChannel::SendPitchbend(int Pitch, uint8_t MidiChannel, int32_t FragmentPos) { + if (FragmentPos < 0) { + dmsg(1,("AbstractEngineChannel::SendPitchBend(): negative FragmentPos! Seems MIDI driver is buggy!")); + } + else if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); + event.Type = Event::type_pitchbend; + event.Param.Pitch.Pitch = Pitch; + event.Param.Pitch.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("AbstractEngineChannel: Input event queue full!")); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread that a + * continuous controller value has changed. This method is meant for real + * time rendering, that is an event will immediately be created with the + * current system time as time stamp. + * + * @param Controller - MIDI controller number of the occured control change + * @param Value - value of the control change + */ + void AbstractEngineChannel::SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel) { + if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(); + event.Type = Event::type_control_change; + event.Param.CC.Controller = Controller; + event.Param.CC.Value = Value; + event.Param.CC.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("AbstractEngineChannel: Input event queue full!")); + } + } + + /** + * Will be called by the MIDIIn Thread to signal the audio thread that a + * continuous controller value has changed. This method is meant for + * offline rendering and / or for cases where the exact position of the + * event in the current audio fragment is already known. + * + * @param Controller - MIDI controller number of the occured control change + * @param Value - value of the control change + * @param FragmentPos - sample point position in the current audio + * fragment to which this event belongs to + */ + void AbstractEngineChannel::SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel, int32_t FragmentPos) { + if (FragmentPos < 0) { + dmsg(1,("AbstractEngineChannel::SendControlChange(): negative FragmentPos! Seems MIDI driver is buggy!")); + } + else if (pEngine) { + Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); + event.Type = Event::type_control_change; + event.Param.CC.Controller = Controller; + event.Param.CC.Value = Value; + event.Param.CC.Channel = MidiChannel; + event.pEngineChannel = this; + if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); + else dmsg(1,("AbstractEngineChannel: Input event queue full!")); + } + } + + /** + * Copy all events from the engine channel's input event queue buffer to + * the internal event list. This will be done at the beginning of each + * audio cycle (that is each RenderAudio() call) to distinguish all + * events which have to be processed in the current audio cycle. Each + * EngineChannel has it's own input event queue for the common channel + * specific events (like NoteOn, NoteOff and ControlChange events). + * Beside that, the engine also has a input event queue for global + * events (usually SysEx messages). + * + * @param Samples - number of sample points to be processed in the + * current audio cycle + */ + void AbstractEngineChannel::ImportEvents(uint Samples) { + // import events from pure software MIDI "devices" + // (e.g. virtual keyboard in instrument editor) + { + const uint8_t channel = MidiChannel() == midi_chan_all ? 0 : MidiChannel(); + const int FragmentPos = 0; // randomly chosen, we don't care about jitter for virtual MIDI devices + Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); + VirtualMidiDevice::event_t devEvent; // the event format we get from the virtual MIDI device + // as we're going to (carefully) write some status to the + // synchronized struct, we cast away the const + ArrayList<VirtualMidiDevice*>& devices = + const_cast<ArrayList<VirtualMidiDevice*>&>(virtualMidiDevicesReader_AudioThread.Lock()); + // iterate through all virtual MIDI devices + for (int i = 0; i < devices.size(); i++) { + VirtualMidiDevice* pDev = devicesi; + // I think we can simply flush the whole FIFO(s), the user shouldn't be so fast ;-) + while (pDev->GetMidiEventFromDevice(devEvent)) { + switch (devEvent.Type) { + case VirtualMidiDevice::EVENT_TYPE_NOTEON: + event.Type = Event::type_note_on; + event.Param.Note.Key = devEvent.Arg1; + event.Param.Note.Velocity = devEvent.Arg2; + event.Param.Note.Channel = channel; + break; + case VirtualMidiDevice::EVENT_TYPE_NOTEOFF: + event.Type = Event::type_note_off; + event.Param.Note.Key = devEvent.Arg1; + event.Param.Note.Velocity = devEvent.Arg2; + event.Param.Note.Channel = channel; + break; + case VirtualMidiDevice::EVENT_TYPE_CC: + event.Type = Event::type_control_change; + event.Param.CC.Controller = devEvent.Arg1; + event.Param.CC.Value = devEvent.Arg2; + event.Param.CC.Channel = channel; + break; + default: + std::cerr << "AbstractEngineChannel::ImportEvents() ERROR: unknown event type (" + << devEvent.Type << "). This is a bug!"; + continue; + } + event.pEngineChannel = this; + // copy event to internal event list + if (pEvents->poolIsEmpty()) { + dmsg(1,("Event pool emtpy!\n")); + goto exitVirtualDevicesLoop; + } + *pEvents->allocAppend() = event; + } + } + } + exitVirtualDevicesLoop: + virtualMidiDevicesReader_AudioThread.Unlock(); + + // import events from the regular MIDI devices + RingBuffer<Event,false>::NonVolatileReader eventQueueReader = pEventQueue->get_non_volatile_reader(); + Event* pEvent; + while (true) { + // get next event from input event queue + if (!(pEvent = eventQueueReader.pop())) break; + // if younger event reached, ignore that and all subsequent ones for now + if (pEvent->FragmentPos() >= Samples) { + eventQueueReader--; + dmsg(2,("Younger Event, pos=%d ,Samples=%d!\n",pEvent->FragmentPos(),Samples)); + pEvent->ResetFragmentPos(); + break; + } + // copy event to internal event list + if (pEvents->poolIsEmpty()) { + dmsg(1,("Event pool emtpy!\n")); + break; + } + *pEvents->allocAppend() = *pEvent; + } + eventQueueReader.free(); // free all copied events from input queue + } + + FxSend* AbstractEngineChannel::AddFxSend(uint8_t MidiCtrl, String Name) throw (Exception) { + if (pEngine) pEngine->DisableAndLock(); + FxSend* pFxSend = new FxSend(this, MidiCtrl, Name); + if (fxSends.empty()) { + if (pEngine && pEngine->pAudioOutputDevice) { + AudioOutputDevice* pDevice = pEngine->pAudioOutputDevice; + // create local render buffers + pChannelLeft = new AudioChannel(0, pDevice->MaxSamplesPerCycle()); + pChannelRight = new AudioChannel(1, pDevice->MaxSamplesPerCycle()); + } else { + // postpone local render buffer creation until audio device is assigned + pChannelLeft = NULL; + pChannelRight = NULL; + } + } + fxSends.push_back(pFxSend); + if (pEngine) pEngine->Enable(); + fireFxSendCountChanged(GetSamplerChannel()->Index(), GetFxSendCount()); + + return pFxSend; + } + + FxSend* AbstractEngineChannel::GetFxSend(uint FxSendIndex) { + return (FxSendIndex < fxSends.size()) ? fxSendsFxSendIndex : NULL; + } + + uint AbstractEngineChannel::GetFxSendCount() { + return fxSends.size(); + } + + void AbstractEngineChannel::RemoveFxSend(FxSend* pFxSend) { + if (pEngine) pEngine->DisableAndLock(); + for ( + std::vector<FxSend*>::iterator iter = fxSends.begin(); + iter != fxSends.end(); iter++ + ) { + if (*iter == pFxSend) { + delete pFxSend; + fxSends.erase(iter); + if (fxSends.empty()) { + // destroy local render buffers + if (pChannelLeft) delete pChannelLeft; + if (pChannelRight) delete pChannelRight; + // fallback to render directly into AudioOutputDevice's buffers + if (pEngine && pEngine->pAudioOutputDevice) { + pChannelLeft = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelLeft); + pChannelRight = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelRight); + } else { // we update the pointers later + pChannelLeft = NULL; + pChannelRight = NULL; + } + } + break; + } + } + if (pEngine) pEngine->Enable(); + fireFxSendCountChanged(GetSamplerChannel()->Index(), GetFxSendCount()); + } + + void AbstractEngineChannel::RemoveAllFxSends() { + if (pEngine) pEngine->DisableAndLock(); + if (!fxSends.empty()) { // free local render buffers + if (pChannelLeft) { + delete pChannelLeft; + if (pEngine && pEngine->pAudioOutputDevice) { + // fallback to render directly to the AudioOutputDevice's buffer + pChannelLeft = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelLeft); + } else pChannelLeft = NULL; + } + if (pChannelRight) { + delete pChannelRight; + if (pEngine && pEngine->pAudioOutputDevice) { + // fallback to render directly to the AudioOutputDevice's buffer + pChannelRight = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelRight); + } else pChannelRight = NULL; + } + } + for (int i = 0; i < fxSends.size(); i++) delete fxSendsi; + fxSends.clear(); + if (pEngine) pEngine->Enable(); + } + + /** + * Add a group number to the set of key groups. Should be called + * when an instrument is loaded to make sure there are event lists + * for all key groups. + */ + void AbstractEngineChannel::AddGroup(uint group) { + if (group) { + std::pair<ActiveKeyGroupMap::iterator, bool> p = + ActiveKeyGroups.insert(ActiveKeyGroupMap::value_type(group, 0)); + if (p.second) { + // If the engine channel is pending deletion (see bug + // #113), pEngine will be null, so we can't use + // pEngine->pEventPool here. Instead we're using a + // specialized RTList that allows specifying the pool + // later. + (*p.first).second = new LazyList<Event>; + } + } + } + + /** + * Handle key group (a.k.a. exclusive group) conflicts. + */ + void AbstractEngineChannel::HandleKeyGroupConflicts(uint KeyGroup, Pool<Event>::Iterator& itNoteOnEvent) { + dmsg(4,("HandelKeyGroupConflicts KeyGroup=%d\n", KeyGroup)); + if (KeyGroup) { + // send a release event to all active voices in the group + RTList<Event>::Iterator itEvent = ActiveKeyGroupsKeyGroup->allocAppend(pEngine->pEventPool); + *itEvent = *itNoteOnEvent; + } + } + + /** + * Empty the lists of group events. Should be called from the + * audio thread, after all voices have been rendered. + */ + void AbstractEngineChannel::ClearGroupEventLists() { + for (ActiveKeyGroupMap::iterator iter = ActiveKeyGroups.begin(); + iter != ActiveKeyGroups.end(); iter++) { + if (iter->second) { + iter->second->clear(); + } else { + dmsg(1,("EngineChannel: group event list was NULL")); + } + } + } + + /** + * Remove all lists with group events. + */ + void AbstractEngineChannel::DeleteGroupEventLists() { + for (ActiveKeyGroupMap::iterator iter = ActiveKeyGroups.begin(); + iter != ActiveKeyGroups.end(); iter++) { + delete iter->second; + } + ActiveKeyGroups.clear(); + } + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/AbstractEngineChannel.h
Added
@@ -0,0 +1,160 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_ABSTRACTENGINECHANNEL_H__ +#define __LS_ABSTRACTENGINECHANNEL_H__ + +#include "EngineChannel.h" +#include "AbstractEngine.h" + +#include "../common/Pool.h" +#include "../common/RingBuffer.h" + +namespace LinuxSampler { + + class AbstractEngineChannel: public EngineChannel { + public: + // implementation of abstract methods derived from interface class 'LinuxSampler::EngineChannel' + virtual void PrepareLoadInstrument(const char* FileName, uint Instrument); + virtual void Reset(); + virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel); + virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos); + virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel); + virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos); + virtual void SendPitchbend(int Pitch, uint8_t MidiChannel); + virtual void SendPitchbend(int Pitch, uint8_t MidiChannel, int32_t FragmentPos); + virtual void SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel); + virtual void SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel, int32_t FragmentPos); + virtual bool StatusChanged(bool bNewStatus = false); + virtual float Volume(); + virtual void Volume(float f); + virtual float Pan(); + virtual void Pan(float f); + virtual uint Channels(); + virtual AudioOutputDevice* GetAudioOutputDevice(); + virtual void SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel); + virtual int OutputChannel(uint EngineAudioChannel); + virtual void Connect(MidiInputPort* pMidiPort, midi_chan_t MidiChannel); + virtual void DisconnectMidiInputPort(); + virtual MidiInputPort* GetMidiInputPort(); + virtual midi_chan_t MidiChannel(); + virtual String InstrumentFileName(); + virtual String InstrumentName(); + virtual int InstrumentIndex(); + virtual int InstrumentStatus(); + virtual Engine* GetEngine(); + virtual String EngineName(); + virtual FxSend* AddFxSend(uint8_t MidiCtrl, String Name = "") throw (Exception); + virtual FxSend* GetFxSend(uint FxSendIndex); + virtual uint GetFxSendCount(); + virtual void RemoveFxSend(FxSend* pFxSend); + virtual void Connect(VirtualMidiDevice* pDevice); + virtual void Disconnect(VirtualMidiDevice* pDevice); + + + virtual AbstractEngine::Format GetEngineFormat() = 0; + + AudioOutputDevice* GetAudioOutputDeviceSafe(); + + friend class AbstractVoice; + friend class AbstractEngine; + template<class TV, class TRR, class TR, class TD, class TIM, class TI> friend class EngineBase; + template<class EC, class R, class S, class D> friend class VoiceBase; + + protected: + AbstractEngineChannel(); + virtual ~AbstractEngineChannel(); + + AbstractEngine* pEngine; + Mutex EngineMutex; ///< protects the Engine from access by the instrument loader thread when lscp is disconnecting + + public: // TODO: should be protected + AudioChannel* pChannelLeft; ///< encapsulates the audio rendering buffer (left) + AudioChannel* pChannelRight; ///< encapsulates the audio rendering buffer (right) + protected: + int AudioDeviceChannelLeft; ///< audio device channel number to which the left channel is connected to + int AudioDeviceChannelRight; ///< audio device channel number to which the right channel is connected to + MidiInputPort* pMidiInputPort; ///< Points to the connected MIDI input port or NULL if none assigned. + midi_chan_t midiChannel; ///< MIDI channel(s) on which this engine channel listens to. + RingBuffer<Event,false>* pEventQueue; ///< Input event queue. + RTList<Event>* pEvents; ///< All engine channel specific events for the current audio fragment. + uint8_t ControllerTable129; ///< Reflects the current values (0-127) of all MIDI controllers for this engine / sampler channel. Number 128 is for channel pressure (mono aftertouch). + String InstrumentFile; + int InstrumentIdx; + String InstrumentIdxName; + int InstrumentStat; + double GlobalVolume; ///< Master volume factor set through the C++ API / LSCP (a value < 1.0 means attenuation, a value > 1.0 means amplification) + double MidiVolume; ///< Volume factor altered by MIDI CC#7 (a value < 1.0 means attenuation, a value > 1.0 means amplification) + float GlobalPanLeft; + float GlobalPanRight; + int Pitch; ///< Current (absolute) MIDI pitch value. + float CurrentKeyDimension; ///< Current value (0-1.0) for the keyboard dimension, altered by pressing a keyswitching key. + bool PortamentoMode; ///< in Portamento Mode we slide the pitch from the last note to the current note. + float PortamentoTime; ///< How long it will take to glide from the previous note to the current (in seconds) + float PortamentoPos; ///< Current position on the keyboard, that is integer and fractional part (only used if PortamentoMode is on) + std::vector<FxSend*> fxSends; + int GlobalTranspose; ///< amount of semi tones all notes should be transposed + int iLastPanRequest; ///< just for the return value of Pan(), so we don't have to make an injective function + int iEngineIndexSelf; ///< Reflects the index of this EngineChannel in the Engine's ArrayList. + bool bStatusChanged; ///< true in case an engine parameter has changed (e.g. new instrument, another volumet) + uint32_t RoundRobinIndex; ///< counter for round robin sample selection, incremented for each note on + + SynchronizedConfig< ArrayList<VirtualMidiDevice*> > virtualMidiDevices; + SynchronizedConfig< ArrayList<VirtualMidiDevice*> >::Reader virtualMidiDevicesReader_AudioThread; + SynchronizedConfig< ArrayList<VirtualMidiDevice*> >::Reader virtualMidiDevicesReader_MidiThread; + + // specialization of RTList that doesn't require the pool + // to be provided at construction time + template<typename T> + class LazyList : public RTList<T> { + public: + using RTList<T>::allocAppend; + using RTList<T>::pPool; + + LazyList() : RTList<T>(0) { } + typename RTList<T>::Iterator allocAppend(Pool<T>* pool) { + pPool = pool; + return allocAppend(); + } + }; + + typedef std::map<uint, LazyList<Event>*> ActiveKeyGroupMap; + ActiveKeyGroupMap ActiveKeyGroups; ///< Contains event queues for key groups, ordered by key group ID. + + virtual void ResetControllers(); + virtual void ResetInternal(); + virtual void RemoveAllFxSends(); + + void ImportEvents(uint Samples); + + void AddGroup(uint group); + void HandleKeyGroupConflicts(uint KeyGroup, Pool<Event>::Iterator& itNoteOnEvent); + void ClearGroupEventLists(); + void DeleteGroupEventLists(); + }; + +} // namespace LinuxSampler + +#endif /* __LS_ABSTRACTENGINECHANNEL_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/EngineBase.h
Added
@@ -0,0 +1,1465 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_ENGINEBASE_H__ +#define __LS_ENGINEBASE_H__ + +#include "AbstractEngine.h" +#include "EngineChannelBase.h" +#include "common/DiskThreadBase.h" +#include "common/MidiKeyboardManager.h" +#include "InstrumentManager.h" +#include "../common/global_private.h" + + +namespace LinuxSampler { + + class AbstractEngineChannel; + + template < + class V /* Voice */, + class RR /* Root Region */, + class R /* Region */, + class D /* Disk Thread */, + class IM /* Instrument Manager */, + class I /* Instrument */ + > + class EngineBase: public AbstractEngine, public RegionPools<R>, public VoicePool<V> { + + public: + typedef typename RTList<V>::Iterator VoiceIterator; + typedef typename Pool<V>::Iterator PoolVoiceIterator; + typedef typename RTList<RR*>::Iterator RootRegionIterator; + typedef typename MidiKeyboardManager<V>::MidiKey MidiKey; + + EngineBase() : SuspendedRegions(128) { + pDiskThread = NULL; + pVoicePool = new Pool<V>(GLOBAL_MAX_VOICES); + pRegionPool0 = new Pool<R*>(GLOBAL_MAX_VOICES); + pRegionPool1 = new Pool<R*>(GLOBAL_MAX_VOICES); + pVoiceStealingQueue = new RTList<Event>(pEventPool); + iMaxDiskStreams = GLOBAL_MAX_STREAMS; + + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + iterVoice->SetEngine(this); + } + pVoicePool->clear(); + + ResetInternal(); + ResetScaleTuning(); + ResetSuspendedRegions(); + } + + virtual ~EngineBase() { + if (pDiskThread) { + dmsg(1,("Stopping disk thread...")); + pDiskThread->StopThread(); + delete pDiskThread; + dmsg(1,("OK\n")); + } + + if (pVoicePool) { + pVoicePool->clear(); + delete pVoicePool; + } + + if (pVoiceStealingQueue) delete pVoiceStealingQueue; + + if (pRegionPool0) delete pRegionPool0; + if (pRegionPool1) delete pRegionPool1; + ResetSuspendedRegions(); + } + + // implementation of abstract methods derived from class 'LinuxSampler::Engine' + + /** + * Let this engine proceed to render the given amount of sample points. + * The engine will iterate through all engine channels and render audio + * for each engine channel independently. The calculated audio data of + * all voices of each engine channel will be placed into the audio sum + * buffers of the respective audio output device, connected to the + * respective engine channel. + * + * @param Samples - number of sample points to be rendered + * @returns 0 on success + */ + virtual int RenderAudio(uint Samples) { + dmsg(8,("RenderAudio(Samples=%d)\n", Samples)); + + // return if engine disabled + if (EngineDisabled.Pop()) { + dmsg(5,("EngineBase: engine disabled (val=%d)\n",EngineDisabled.GetUnsafe())); + EngineDisabled.RttDone(); + return 0; + } + + // process requests for suspending / resuming regions (i.e. to avoid + // crashes while these regions are modified by an instrument editor) + ProcessSuspensionsChanges(); + + // update time of start and end of this audio fragment (as events' time stamps relate to this) + pEventGenerator->UpdateFragmentTime(Samples); + + // We only allow the given maximum number of voices to be spawned + // in each audio fragment. All subsequent request for spawning new + // voices in the same audio fragment will be ignored. + VoiceSpawnsLeft = MaxVoices(); + + // get all events from the engine's global input event queue which belong to the current fragment + // (these are usually just SysEx messages) + ImportEvents(Samples); + + // process engine global events (these are currently only MIDI System Exclusive messages) + { + RTList<Event>::Iterator itEvent = pGlobalEvents->first(); + RTList<Event>::Iterator end = pGlobalEvents->end(); + for (; itEvent != end; ++itEvent) { + switch (itEvent->Type) { + case Event::type_sysex: + dmsg(5,("Engine: Sysex received\n")); + ProcessSysex(itEvent); + break; + } + } + } + + // reset internal voice counter (just for statistic of active voices) + ActiveVoiceCountTemp = 0; + + HandleInstrumentChanges(); + + // handle events on all engine channels + for (int i = 0; i < engineChannels.size(); i++) { + ProcessEvents(engineChannelsi, Samples); + } + + // render all 'normal', active voices on all engine channels + for (int i = 0; i < engineChannels.size(); i++) { + RenderActiveVoices(engineChannelsi, Samples); + } + + // now that all ordinary voices on ALL engine channels are rendered, render new stolen voices + RenderStolenVoices(Samples); + + // handle audio routing for engine channels with FX sends + for (int i = 0; i < engineChannels.size(); i++) { + AbstractEngineChannel* pChannel = static_cast<AbstractEngineChannel*>(engineChannelsi); + if (pChannel->fxSends.empty()) continue; // ignore if no FX sends + RouteAudio(engineChannelsi, Samples); + } + + // handle cleanup on all engine channels for the next audio fragment + for (int i = 0; i < engineChannels.size(); i++) { + PostProcess(engineChannelsi); + } + + + // empty the engine's event list for the next audio fragment + ClearEventLists(); + + // reset voice stealing for the next audio fragment + pVoiceStealingQueue->clear(); + + // just some statistics about this engine instance + SetVoiceCount(ActiveVoiceCountTemp); + if (VoiceCount() > ActiveVoiceCountMax) ActiveVoiceCountMax = VoiceCount(); + + // in case regions were previously suspended and we killed voices + // with disk streams due to that, check if those streams have finally + // been deleted by the disk thread + if (iPendingStreamDeletions) ProcessPendingStreamDeletions(); + + // Release the instrument change command. (This has to + // be done after all voices have been rendered and not + // in HandleInstrumentChanges, as the RegionsInUse + // list has been built up by the voice renderers.) + for (int i = 0; i < engineChannels.size(); i++) { + EngineChannelBase<V, R, I>* channel = + static_cast<EngineChannelBase<V, R, I>*>(engineChannelsi); + channel->InstrumentChangeCommandReader.Unlock(); + } + FrameTime += Samples; + + EngineDisabled.RttDone(); + return 0; + } + + virtual int MaxVoices() { return pVoicePool->poolSize(); } + + virtual void SetMaxVoices(int iVoices) throw (Exception) { + if (iVoices < 1) + throw Exception("Maximum voices for an engine cannot be set lower than 1"); + + SuspendAll(); + + // NOTE: we need to clear pRegionsInUse before deleting pDimRegionPool, + // otherwise memory corruption will occur if there are active voices (see bug #118) + for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { + EngineChannelBase<V, R, I>* pChannel = static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannel); + pChannel->ClearRegionsInUse(); + } + + if (pRegionPool0) delete pRegionPool0; + if (pRegionPool1) delete pRegionPool1; + + pRegionPool0 = new Pool<R*>(iVoices); + pRegionPool1 = new Pool<R*>(iVoices); + + for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { + EngineChannelBase<V, R, I>* pChannel = static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannel); + pChannel->ResetRegionsInUse(pRegionPool); + } + + try { + pVoicePool->resizePool(iVoices); + } catch (...) { + throw Exception("FATAL: Could not resize voice pool!"); + } + + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + iterVoice->SetEngine(this); + iterVoice->pDiskThread = this->pDiskThread; + } + pVoicePool->clear(); + + PostSetMaxVoices(iVoices); + ResumeAll(); + } + + /** Called after the new max number of voices is set and before resuming the engine. */ + virtual void PostSetMaxVoices(int iVoices) { } + + virtual uint DiskStreamCount() { return (pDiskThread) ? pDiskThread->GetActiveStreamCount() : 0; } + virtual uint DiskStreamCountMax() { return (pDiskThread) ? pDiskThread->ActiveStreamCountMax : 0; } + virtual int MaxDiskStreams() { return iMaxDiskStreams; } + + virtual void SetMaxDiskStreams(int iStreams) throw (Exception) { + if (iStreams < 0) + throw Exception("Maximum disk streams for an engine cannot be set lower than 0"); + + SuspendAll(); + + iMaxDiskStreams = iStreams; + + // reconnect to audio output device, because that will automatically + // recreate the disk thread with the required amount of streams + if (pAudioOutputDevice) Connect(pAudioOutputDevice); + + ResumeAll(); + } + + virtual String DiskStreamBufferFillBytes() { return (pDiskThread) ? pDiskThread->GetBufferFillBytes() : ""; } + virtual String DiskStreamBufferFillPercentage() { return (pDiskThread) ? pDiskThread->GetBufferFillPercentage() : ""; } + virtual InstrumentManager* GetInstrumentManager() { return &instruments; } + + /** + * Connect this engine instance with the given audio output device. + * This method will be called when an Engine instance is created. + * All of the engine's data structures which are dependant to the used + * audio output device / driver will be (re)allocated and / or + * adjusted appropriately. + * + * @param pAudioOut - audio output device to connect to + */ + virtual void Connect(AudioOutputDevice* pAudioOut) { + // caution: don't ignore if connecting to the same device here, + // because otherwise SetMaxDiskStreams() implementation won't work anymore! + + pAudioOutputDevice = pAudioOut; + + ResetInternal(); + + // inform audio driver for the need of two channels + try { + pAudioOutputDevice->AcquireChannels(2); // default stereo + } + catch (AudioOutputException e) { + String msg = "Audio output device unable to provide 2 audio channels, cause: " + e.Message(); + throw Exception(msg); + } + + this->MaxSamplesPerCycle = pAudioOutputDevice->MaxSamplesPerCycle(); + this->SampleRate = pAudioOutputDevice->SampleRate(); + + MinFadeOutSamples = int(double(SampleRate) * CONFIG_EG_MIN_RELEASE_TIME) - 1; + if (MaxSamplesPerCycle < MinFadeOutSamples) { + std::cerr << "EngineBase: WARNING, CONFIG_EG_MIN_RELEASE_TIME " + << "too big for current audio fragment size & sampling rate! " + << "May lead to click sounds if voice stealing chimes in!\n" << std::flush; + // force volume ramp downs at the beginning of each fragment + MinFadeOutSamples = MaxSamplesPerCycle; + // lower minimum release time + const float minReleaseTime = (float) MaxSamplesPerCycle / (float) SampleRate; + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + iterVoice->CalculateFadeOutCoeff(minReleaseTime, SampleRate); + } + pVoicePool->clear(); + } + + // (re)create disk thread + if (this->pDiskThread) { + dmsg(1,("Stopping disk thread...")); + this->pDiskThread->StopThread(); + delete this->pDiskThread; + dmsg(1,("OK\n")); + } + this->pDiskThread = CreateDiskThread(); + + if (!pDiskThread) { + dmsg(0,("EngineBase new diskthread = NULL\n")); + exit(EXIT_FAILURE); + } + + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + iterVoice->pDiskThread = this->pDiskThread; + dmsg(3,("d")); + } + pVoicePool->clear(); + + // (re)create event generator + if (pEventGenerator) delete pEventGenerator; + pEventGenerator = new EventGenerator(pAudioOut->SampleRate()); + + dmsg(1,("Starting disk thread...")); + pDiskThread->StartThread(); + dmsg(1,("OK\n")); + + bool printEqInfo = true; + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + if (!iterVoice->pDiskThread) { + dmsg(0,("Engine -> voice::trigger: !pDiskThread\n")); + exit(EXIT_FAILURE); + } + + iterVoice->CreateEq(); + + if(printEqInfo) { + iterVoice->PrintEqInfo(); + printEqInfo = false; + } + } + pVoicePool->clear(); + + // (re)create dedicated voice audio buffers + //TODO: we could optimize resource usage a bit by just allocating these dedicated voice buffers when there is at least one engine channel with FX sends, because only in this case those special buffers are used actually, but since it would usually only save couple bytes in total, its probably not worth it + if (pDedicatedVoiceChannelLeft) delete pDedicatedVoiceChannelLeft; + if (pDedicatedVoiceChannelRight) delete pDedicatedVoiceChannelRight; + pDedicatedVoiceChannelLeft = new AudioChannel(0, MaxSamplesPerCycle); + pDedicatedVoiceChannelRight = new AudioChannel(1, MaxSamplesPerCycle); + } + + /** + * Similar to @c Disable() but this method additionally kills all voices + * and disk streams and blocks until all voices and disk streams are actually + * killed / deleted. + * + * @e Note: only the original calling thread is able to re-enable the + * engine afterwards by calling @c ResumeAll() later on! + */ + virtual void SuspendAll() { + dmsg(2,("Engine: Suspending all ...\n")); + // stop the engine, so we can safely modify the engine's + // data structures from this foreign thread + DisableAndLock(); + // we could also use the respective class member variable here, + // but this is probably safer and cleaner + int iPendingStreamDeletions = 0; + // kill all voices on all engine channels the *die hard* way + for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { + EngineChannelBase<V, R, I>* pEngineChannel = + static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannel); + + iPendingStreamDeletions += pEngineChannel->KillAllVoicesImmediately(); + } + // wait until all streams were actually deleted by the disk thread + while (iPendingStreamDeletions) { + while ( + iPendingStreamDeletions && + pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE + ) iPendingStreamDeletions--; + if (!iPendingStreamDeletions) break; + usleep(10000); // sleep for 10ms + } + dmsg(2,("EngineBase: Everything suspended.\n")); + } + + /** + * At the moment same as calling @c Enable() directly, but this might + * change in future, so better call this method as counterpart to + * @c SuspendAll() instead of @c Enable() ! + */ + virtual void ResumeAll() { Enable(); } + + /** + * Order the engine to stop rendering audio for the given region. + * Additionally this method will block until all voices and their disk + * streams associated with that region are actually killed / deleted, so + * one can i.e. safely modify the region with an instrument editor after + * returning from this method. + * + * @param pRegion - region the engine shall stop using + */ + virtual void Suspend(RR* pRegion) { + dmsg(2,("EngineBase: Suspending Region %x ...\n",pRegion)); + SuspendedRegionsMutex.Lock(); + SuspensionChangeOngoing.Set(true); + pPendingRegionSuspension = pRegion; + SuspensionChangeOngoing.WaitAndUnlockIf(true); + SuspendedRegionsMutex.Unlock(); + dmsg(2,("EngineBase: Region %x suspended.",pRegion)); + } + + /** + * Orders the engine to resume playing back the given region, previously + * suspended with @c Suspend() . + * + * @param pRegion - region the engine shall be allowed to use again + */ + virtual void Resume(RR* pRegion) { + dmsg(2,("EngineBase: Resuming Region %x ...\n",pRegion)); + SuspendedRegionsMutex.Lock(); + SuspensionChangeOngoing.Set(true); + pPendingRegionResumption = pRegion; + SuspensionChangeOngoing.WaitAndUnlockIf(true); + SuspendedRegionsMutex.Unlock(); + dmsg(2,("EngineBase: Region %x resumed.\n",pRegion)); + } + + virtual void ResetSuspendedRegions() { + SuspendedRegions.clear(); + iPendingStreamDeletions = 0; + pPendingRegionSuspension = pPendingRegionResumption = NULL; + SuspensionChangeOngoing.Set(false); + } + + /** + * Called by the engine's (audio) thread once per cycle to process requests + * from the outer world to suspend or resume a given @c gig::Region . + */ + virtual void ProcessSuspensionsChanges() { + // process request for suspending one region + if (pPendingRegionSuspension) { + // kill all voices on all engine channels that use this region + for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { + EngineChannelBase<V, R, I>* pEngineChannel = + static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannel); + SuspensionVoiceHandler handler(pPendingRegionSuspension); + pEngineChannel->ProcessActiveVoices(&handler); + iPendingStreamDeletions += handler.PendingStreamDeletions; + } + // make sure the region is not yet on the list + bool bAlreadySuspended = false; + RootRegionIterator iter = SuspendedRegions.first(); + RootRegionIterator end = SuspendedRegions.end(); + for (; iter != end; ++iter) { // iterate through all suspended regions + if (*iter == pPendingRegionSuspension) { // found + bAlreadySuspended = true; + dmsg(1,("EngineBase: attempt to suspend an already suspended region !!!\n")); + break; + } + } + if (!bAlreadySuspended) { + // put the region on the list of suspended regions + RootRegionIterator iter = SuspendedRegions.allocAppend(); + if (iter) { + *iter = pPendingRegionSuspension; + } else std::cerr << "EngineBase: Could not suspend Region, list is full. This is a bug!!!\n" << std::flush; + } + // free request slot for next caller (and to make sure that + // we're not going to process the same request in the next cycle) + pPendingRegionSuspension = NULL; + // if no disk stream deletions are pending, awaken other side, as + // we're done in this case + if (!iPendingStreamDeletions) SuspensionChangeOngoing.Set(false); + } + + // process request for resuming one region + if (pPendingRegionResumption) { + // remove region from the list of suspended regions + RootRegionIterator iter = SuspendedRegions.first(); + RootRegionIterator end = SuspendedRegions.end(); + for (; iter != end; ++iter) { // iterate through all suspended regions + if (*iter == pPendingRegionResumption) { // found + SuspendedRegions.free(iter); + break; // done + } + } + // free request slot for next caller + pPendingRegionResumption = NULL; + // awake other side as we're done + SuspensionChangeOngoing.Set(false); + } + } + + /** + * Called by the engine's (audio) thread once per cycle to check if + * streams of voices that were killed due to suspension request have + * finally really been deleted by the disk thread. + */ + virtual void ProcessPendingStreamDeletions() { + if (!iPendingStreamDeletions) return; + //TODO: or shall we better store a list with stream handles instead of a scalar amount of streams to be deleted? might be safer + while ( + iPendingStreamDeletions && + pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE + ) iPendingStreamDeletions--; + // just for safety ... + while (pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE); + // now that all disk streams are deleted, awake other side as + // we're finally done with suspending the requested region + if (!iPendingStreamDeletions) SuspensionChangeOngoing.Set(false); + } + + /** + * Returns @c true if the given region is currently set to be suspended + * from being used, @c false otherwise. + */ + virtual bool RegionSuspended(RR* pRegion) { + if (SuspendedRegions.isEmpty()) return false; + //TODO: or shall we use a sorted container instead of the RTList? might be faster ... or trivial ;-) + RootRegionIterator iter = SuspendedRegions.first(); + RootRegionIterator end = SuspendedRegions.end(); + for (; iter != end; ++iter) // iterate through all suspended regions + if (*iter == pRegion) return true; + return false; + } + + // implementation of abstract method derived from class 'LinuxSampler::RegionPools' + virtual Pool<R*>* GetRegionPool(int index) { + if (index < 0 || index > 1) throw Exception("Index out of bounds"); + return pRegionPoolindex; + } + + // implementation of abstract method derived from class 'LinuxSampler::VoicePool' + virtual Pool<V>* GetVoicePool() { return pVoicePool; } + + D* GetDiskThread() { return pDiskThread; } + + //friend class EngineChannelBase<V, R, I>; + + static IM instruments; + + protected: + class SuspensionVoiceHandler : public MidiKeyboardManager<V>::VoiceHandler { + public: + int PendingStreamDeletions; + RR* pPendingRegionSuspension; + SuspensionVoiceHandler(RR* pPendingRegionSuspension) { + PendingStreamDeletions = 0; + this->pPendingRegionSuspension = pPendingRegionSuspension; + } + + virtual bool Process(MidiKey* pMidiKey) { + VoiceIterator itVoice = pMidiKey->pActiveVoices->first(); + // if current key is not associated with this region, skip this key + if (itVoice->GetRegion()->GetParent() != pPendingRegionSuspension) return false; + + return true; + } + + virtual void Process(VoiceIterator& itVoice) { + // request a notification from disk thread side for stream deletion + const Stream::Handle hStream = itVoice->KillImmediately(true); + if (hStream != Stream::INVALID_HANDLE) { // voice actually used a stream + PendingStreamDeletions++; + } + //NOTE: maybe we should call FreeVoice() here, shouldn't cause a harm though I think, since the voices should be freed by RenderActiveVoices() in the render loop, they are probably just freed a bit later than they could/should be + } + }; + + Pool<R*>* pRegionPool2; ///< Double buffered pool, used by the engine channels to keep track of regions in use. + int MinFadeOutSamples; ///< The number of samples needed to make an instant fade out (e.g. for voice stealing) without leading to clicks. + D* pDiskThread; + + int ActiveVoiceCountTemp; ///< number of currently active voices (for internal usage, will be used for incrementation) + VoiceIterator itLastStolenVoice; ///< Only for voice stealing: points to the last voice which was theft in current audio fragment, NULL otherwise. + RTList<uint>::Iterator iuiLastStolenKey; ///< Only for voice stealing: key number of last key on which the last voice was theft in current audio fragment, NULL otherwise. + EngineChannelBase<V, R, I>* pLastStolenChannel; ///< Only for voice stealing: points to the engine channel on which the previous voice was stolen in this audio fragment. + VoiceIterator itLastStolenVoiceGlobally; ///< Same as itLastStolenVoice, but engine globally + RTList<uint>::Iterator iuiLastStolenKeyGlobally; ///< Same as iuiLastStolenKey, but engine globally + RTList<Event>* pVoiceStealingQueue; ///< All voice-launching events which had to be postponed due to free voice shortage. + Mutex ResetInternalMutex; ///< Mutex to protect the ResetInternal function for concurrent usage (e.g. by the lscp and instrument loader threads). + int iMaxDiskStreams; + + /** + * Dispatch and handle all events in this audio fragment for the given + * engine channel. + * + * @param pEngineChannel - engine channel on which events should be + * processed + * @param Samples - amount of sample points to be processed in + * this audio fragment cycle + */ + void ProcessEvents(EngineChannel* pEngineChannel, uint Samples) { + // get all events from the engine channels's input event queue which belong to the current fragment + // (these are the common events like NoteOn, NoteOff, ControlChange, etc.) + AbstractEngineChannel* pChannel = static_cast<AbstractEngineChannel*>(pEngineChannel); + pChannel->ImportEvents(Samples); + + // process events + { + RTList<Event>::Iterator itEvent = pChannel->pEvents->first(); + RTList<Event>::Iterator end = pChannel->pEvents->end(); + for (; itEvent != end; ++itEvent) { + switch (itEvent->Type) { + case Event::type_note_on: + dmsg(5,("Engine: Note on received\n")); + ProcessNoteOn((EngineChannel*)itEvent->pEngineChannel, itEvent); + break; + case Event::type_note_off: + dmsg(5,("Engine: Note off received\n")); + ProcessNoteOff((EngineChannel*)itEvent->pEngineChannel, itEvent); + break; + case Event::type_control_change: + dmsg(5,("Engine: MIDI CC received\n")); + ProcessControlChange((EngineChannel*)itEvent->pEngineChannel, itEvent); + break; + case Event::type_pitchbend: + dmsg(5,("Engine: Pitchbend received\n")); + ProcessPitchbend(static_cast<AbstractEngineChannel*>(itEvent->pEngineChannel), itEvent); + break; + } + } + } + + // reset voice stealing for the next engine channel (or next audio fragment) + itLastStolenVoice = VoiceIterator(); + itLastStolenVoiceGlobally = VoiceIterator(); + iuiLastStolenKey = RTList<uint>::Iterator(); + iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); + pLastStolenChannel = NULL; + } + + /** + * Will be called by LaunchVoice() method in case there are no free + * voices left. This method will select and kill one old voice for + * voice stealing and postpone the note-on event until the selected + * voice actually died. + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itNoteOnEvent - key, velocity and time stamp of the event + * @returns 0 on success, a value < 0 if no active voice could be picked for voice stealing + */ + int StealVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent) { + if (VoiceSpawnsLeft <= 0) { + dmsg(1,("Max. voice thefts per audio fragment reached (you may raise CONFIG_MAX_VOICES).\n")); + return -1; + } + + EngineChannelBase<V, R, I>* pEngineChn = static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + + if (!pEventPool->poolIsEmpty()) { + + if(!pEngineChn->StealVoice(itNoteOnEvent, &itLastStolenVoice, &iuiLastStolenKey)) { + --VoiceSpawnsLeft; + return 0; + } + + // if we couldn't steal a voice from the same engine channel then + // steal oldest voice on the oldest key from any other engine channel + // (the smaller engine channel number, the higher priority) + EngineChannelBase<V, R, I>* pSelectedChannel; + int iChannelIndex; + VoiceIterator itSelectedVoice; + + // select engine channel + if (pLastStolenChannel) { + pSelectedChannel = pLastStolenChannel; + iChannelIndex = pSelectedChannel->iEngineIndexSelf; + } else { // pick the engine channel followed by this engine channel + iChannelIndex = (pEngineChn->iEngineIndexSelf + 1) % engineChannels.size(); + pSelectedChannel = static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannelIndex); + } + + // if we already stole in this fragment, try to proceed on same key + if (this->itLastStolenVoiceGlobally) { + itSelectedVoice = this->itLastStolenVoiceGlobally; + do { + ++itSelectedVoice; + } while (itSelectedVoice && !itSelectedVoice->IsStealable()); // proceed iterating if voice was created in this fragment cycle + } + + #if CONFIG_DEVMODE + EngineChannel* pBegin = pSelectedChannel; // to detect endless loop + #endif // CONFIG_DEVMODE + + // did we find a 'stealable' voice? + if (itSelectedVoice && itSelectedVoice->IsStealable()) { + // remember which voice we stole, so we can simply proceed on next voice stealing + this->itLastStolenVoiceGlobally = itSelectedVoice; + } else while (true) { // iterate through engine channels + // get (next) oldest key + RTList<uint>::Iterator iuiSelectedKey = (this->iuiLastStolenKeyGlobally) ? ++this->iuiLastStolenKeyGlobally : pSelectedChannel->pActiveKeys->first(); + this->iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); // to prevent endless loop (see line above) + while (iuiSelectedKey) { + MidiKey* pSelectedKey = &pSelectedChannel->pMIDIKeyInfo*iuiSelectedKey; + itSelectedVoice = pSelectedKey->pActiveVoices->first(); + // proceed iterating if voice was created in this fragment cycle + while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; + // found a "stealable" voice ? + if (itSelectedVoice && itSelectedVoice->IsStealable()) { + // remember which voice on which key on which engine channel we stole, so we can simply proceed on next voice stealing + this->iuiLastStolenKeyGlobally = iuiSelectedKey; + this->itLastStolenVoiceGlobally = itSelectedVoice; + this->pLastStolenChannel = pSelectedChannel; + goto stealable_voice_found; // selection succeeded + } + ++iuiSelectedKey; // get next key on current engine channel + } + // get next engine channel + iChannelIndex = (iChannelIndex + 1) % engineChannels.size(); + pSelectedChannel = static_cast<EngineChannelBase<V, R, I>*>(engineChannelsiChannelIndex); + + #if CONFIG_DEVMODE + if (pSelectedChannel == pBegin) { + dmsg(1,("FATAL ERROR: voice stealing endless loop!\n")); + dmsg(1,("VoiceSpawnsLeft=%d.\n", VoiceSpawnsLeft)); + dmsg(1,("Exiting.\n")); + exit(-1); + } + #endif // CONFIG_DEVMODE + } + + // jump point if a 'stealable' voice was found + stealable_voice_found: + + #if CONFIG_DEVMODE + if (!itSelectedVoice->IsActive()) { + dmsg(1,("EngineBase: ERROR, tried to steal a voice which was not active !!!\n")); + return -1; + } + #endif // CONFIG_DEVMODE + + // now kill the selected voice + itSelectedVoice->Kill(itNoteOnEvent); + + --VoiceSpawnsLeft; + + return 0; // success + } + else { + dmsg(1,("Event pool emtpy!\n")); + return -1; + } + } + + void HandleInstrumentChanges() { + bool instrumentChanged = false; + for (int i = 0; i < engineChannels.size(); i++) { + EngineChannelBase<V, R, I>* pEngineChannel = + static_cast<EngineChannelBase<V, R, I>*>(engineChannelsi); + + // as we're going to (carefully) write some status to the + // synchronized struct, we cast away the const + InstrumentChangeCmd<R, I>& cmd = + const_cast<InstrumentChangeCmd<R, I>&>(pEngineChannel->InstrumentChangeCommandReader.Lock()); + + pEngineChannel->pRegionsInUse = cmd.pRegionsInUse; + pEngineChannel->pRegionsInUse->clear(); + + if (cmd.bChangeInstrument) { + // change instrument + dmsg(5,("Engine: instrument change command received\n")); + cmd.bChangeInstrument = false; + pEngineChannel->pInstrument = cmd.pInstrument; + instrumentChanged = true; + + pEngineChannel->MarkAllActiveVoicesAsOrphans(); + } + } + + if (instrumentChanged) { + //TODO: this is a lazy solution ATM and not safe in case somebody is currently editing the instrument we're currently switching to (we should store all suspended regions on instrument manager side and when switching to another instrument copy that list to the engine's local list of suspensions + ResetSuspendedRegions(); + } + } + + /** + * Render all 'normal' voices (that is voices which were not stolen in + * this fragment) on the given engine channel. + * + * @param pEngineChannel - engine channel on which audio should be + * rendered + * @param Samples - amount of sample points to be rendered in + * this audio fragment cycle + */ + void RenderActiveVoices(EngineChannel* pEngineChannel, uint Samples) { + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted + #endif + + EngineChannelBase<V, R, I>* pChannel = + static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + pChannel->RenderActiveVoices(Samples); + + ActiveVoiceCountTemp += pEngineChannel->GetVoiceCount(); + } + + /** + * Render all stolen voices (only voices which were stolen in this + * fragment) on the given engine channel. Stolen voices are rendered + * after all normal voices have been rendered; this is needed to render + * audio of those voices which were selected for voice stealing until + * the point were the stealing (that is the take over of the voice) + * actually happened. + * + * @param pEngineChannel - engine channel on which audio should be + * rendered + * @param Samples - amount of sample points to be rendered in + * this audio fragment cycle + */ + void RenderStolenVoices(uint Samples) { + RTList<Event>::Iterator itVoiceStealEvent = pVoiceStealingQueue->first(); + RTList<Event>::Iterator end = pVoiceStealingQueue->end(); + for (; itVoiceStealEvent != end; ++itVoiceStealEvent) { + EngineChannelBase<V, R, I>* pEngineChannel = + static_cast<EngineChannelBase<V, R, I>*>(itVoiceStealEvent->pEngineChannel);; + if (!pEngineChannel->pInstrument) continue; // ignore if no instrument loaded + PoolVoiceIterator itNewVoice = + LaunchVoice(pEngineChannel, itVoiceStealEvent, itVoiceStealEvent->Param.Note.Layer, itVoiceStealEvent->Param.Note.ReleaseTrigger, false, false); + if (itNewVoice) { + itNewVoice->Render(Samples); + if (itNewVoice->IsActive()) { // still active + *(pEngineChannel->pRegionsInUse->allocAppend()) = itNewVoice->GetRegion(); + ActiveVoiceCountTemp++; + pEngineChannel->SetVoiceCount(pEngineChannel->GetVoiceCount() + 1); + + if (itNewVoice->PlaybackState == Voice::playback_state_disk) { + if (itNewVoice->DiskStreamRef.State != Stream::state_unused) { + pEngineChannel->SetDiskStreamCount(pEngineChannel->GetDiskStreamCount() + 1); + } + } + } else { // voice reached end, is now inactive + pEngineChannel->FreeVoice(itNewVoice); // remove voice from the list of active voices + } + } + else dmsg(1,("EngineBase: ERROR, voice stealing didn't work out!\n")); + + // we need to clear the key's event list explicitly here in case key was never active + MidiKey* pKey = &pEngineChannel->pMIDIKeyInfoitVoiceStealEvent->Param.Note.Key; + pKey->VoiceTheftsQueued--; + if (!pKey->Active && !pKey->VoiceTheftsQueued) pKey->pEvents->clear(); + } + } + + /** + * Free all keys which have turned inactive in this audio fragment, from + * the list of active keys and clear all event lists on that engine + * channel. + * + * @param pEngineChannel - engine channel to cleanup + */ + void PostProcess(EngineChannel* pEngineChannel) { + EngineChannelBase<V, R, I>* pChannel = + static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + pChannel->FreeAllInactiveKyes(); + + // empty the engine channel's own event lists + pChannel->ClearEventLists(); + } + + /** + * Process MIDI control change events with hard coded behavior, + * that is controllers whose behavior is defined independently + * of the actual sampler engine type and instrument. + * + * @param pEngineChannel - engine channel on which the MIDI CC event was received + * @param itControlChangeEvent - the actual MIDI CC event + */ + void ProcessHardcodedControllers ( + EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ) { + EngineChannelBase<V, R, I>* pChannel = + static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + + switch (itControlChangeEvent->Param.CC.Controller) { + case 5: { // portamento time + pChannel->PortamentoTime = (float) itControlChangeEvent->Param.CC.Value / 127.0f * (float) CONFIG_PORTAMENTO_TIME_MAX + (float) CONFIG_PORTAMENTO_TIME_MIN; + break; + } + case 6: { // data entry (currently only used for RPN and NRPN controllers) + //dmsg(1,("DATA ENTRY %d\n", itControlChangeEvent->Param.CC.Value)); + if (pChannel->GetMidiRpnController() >= 0) { // RPN controller number was sent previously ... + dmsg(4,("Guess it's an RPN ...\n")); + if (pChannel->GetMidiRpnController() == 2) { // coarse tuning in half tones + int transpose = (int) itControlChangeEvent->Param.CC.Value - 64; + // limit to +- two octaves for now + transpose = RTMath::Min(transpose, 24); + transpose = RTMath::Max(transpose, -24); + pChannel->GlobalTranspose = transpose; + // workaround, so we won't have hanging notes + pChannel->ReleaseAllVoices(itControlChangeEvent); + } + // to prevent other MIDI CC #6 messages to be misenterpreted as RPN controller data + pChannel->ResetMidiRpnController(); + } else if (pChannel->GetMidiNrpnController() >= 0) { // NRPN controller number was sent previously ... + dmsg(4,("Guess it's an NRPN ...\n")); + const int NrpnCtrlMSB = pChannel->GetMidiNrpnController() >> 8; + const int NrpnCtrlLSB = pChannel->GetMidiNrpnController() & 0xff; + dmsg(4,("NRPN MSB=%d LSB=%d Data=%d\n", NrpnCtrlMSB, NrpnCtrlLSB, itControlChangeEvent->Param.CC.Value)); + switch (NrpnCtrlMSB) { + case 0x1a: { // volume level of note (Roland GS NRPN) + const uint note = NrpnCtrlLSB; + const uint vol = itControlChangeEvent->Param.CC.Value; + dmsg(4,("Note Volume NRPN received (note=%d,vol=%d).\n", note, vol)); + if (note < 128 && vol < 128) + pChannel->pMIDIKeyInfonote.Volume = VolumeCurvevol; + break; + } + case 0x1c: { // panpot of note (Roland GS NRPN) + const uint note = NrpnCtrlLSB; + const uint pan = itControlChangeEvent->Param.CC.Value; + dmsg(4,("Note Pan NRPN received (note=%d,pan=%d).\n", note, pan)); + if (note < 128 && pan < 128) { + pChannel->pMIDIKeyInfonote.PanLeft = PanCurve128 - pan; + pChannel->pMIDIKeyInfonote.PanRight = PanCurvepan; + } + break; + } + case 0x1d: { // reverb send of note (Roland GS NRPN) + const uint note = NrpnCtrlLSB; + const float reverb = float(itControlChangeEvent->Param.CC.Value) / 127.0f; + dmsg(4,("Note Reverb Send NRPN received (note=%d,send=%d).\n", note, reverb)); + if (note < 128) + pChannel->pMIDIKeyInfonote.ReverbSend = reverb; + break; + } + case 0x1e: { // chorus send of note (Roland GS NRPN) + const uint note = NrpnCtrlLSB; + const float chorus = float(itControlChangeEvent->Param.CC.Value) / 127.0f; + dmsg(4,("Note Chorus Send NRPN received (note=%d,send=%d).\n", note, chorus)); + if (note < 128) + pChannel->pMIDIKeyInfonote.ChorusSend = chorus; + break; + } + } + // to prevent other MIDI CC #6 messages to be misenterpreted as NRPN controller data + pChannel->ResetMidiNrpnController(); + } + break; + } + case 7: { // volume + //TODO: not sample accurate yet + pChannel->MidiVolume = VolumeCurveitControlChangeEvent->Param.CC.Value; + pChannel->bStatusChanged = true; // engine channel status has changed, so set notify flag + break; + } + case 10: { // panpot + //TODO: not sample accurate yet + pChannel->GlobalPanLeft = PanCurve128 - itControlChangeEvent->Param.CC.Value; + pChannel->GlobalPanRight = PanCurveitControlChangeEvent->Param.CC.Value; + pChannel->iLastPanRequest = itControlChangeEvent->Param.CC.Value; + break; + } + case 64: { // sustain + if (itControlChangeEvent->Param.CC.Value >= 64 && !pChannel->SustainPedal) { + dmsg(4,("DAMPER (RIGHT) PEDAL DOWN\n")); + pChannel->SustainPedal = true; + pChannel->listeners.PreProcessSustainPedalDown(); + + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessSustainPedalDown(); + return; + } + #endif + + pChannel->ProcessSustainPedalDown(itControlChangeEvent); + pChannel->listeners.PostProcessSustainPedalDown(); + } + if (itControlChangeEvent->Param.CC.Value < 64 && pChannel->SustainPedal) { + dmsg(4,("DAMPER (RIGHT) PEDAL UP\n")); + pChannel->SustainPedal = false; + pChannel->listeners.PreProcessSustainPedalUp(); + + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessSustainPedalUp(); + return; + } + #endif + + pChannel->ProcessSustainPedalUp(itControlChangeEvent); + pChannel->listeners.PostProcessSustainPedalUp(); + } + break; + } + case 65: { // portamento on / off + const bool bPortamento = itControlChangeEvent->Param.CC.Value >= 64; + if (bPortamento != pChannel->PortamentoMode) + KillAllVoices(pChannel, itControlChangeEvent); + pChannel->PortamentoMode = bPortamento; + break; + } + case 66: { // sostenuto + if (itControlChangeEvent->Param.CC.Value >= 64 && !pChannel->SostenutoPedal) { + dmsg(4,("SOSTENUTO (CENTER) PEDAL DOWN\n")); + pChannel->SostenutoPedal = true; + pChannel->listeners.PreProcessSostenutoPedalDown(); + + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessSostenutoPedalDown(); + return; + } + #endif + + pChannel->ProcessSostenutoPedalDown(); + pChannel->listeners.PostProcessSostenutoPedalDown(); + } + if (itControlChangeEvent->Param.CC.Value < 64 && pChannel->SostenutoPedal) { + dmsg(4,("SOSTENUTO (CENTER) PEDAL UP\n")); + pChannel->SostenutoPedal = false; + pChannel->listeners.PreProcessSostenutoPedalUp(); + + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessSostenutoPedalUp(); + return; + } + #endif + + pChannel->ProcessSostenutoPedalUp(itControlChangeEvent); + pChannel->listeners.PostProcessSostenutoPedalUp(); + } + break; + } + case 98: { // NRPN controller LSB + dmsg(4,("NRPN LSB %d\n", itControlChangeEvent->Param.CC.Value)); + pEngineChannel->SetMidiNrpnControllerLsb(itControlChangeEvent->Param.CC.Value); + break; + } + case 99: { // NRPN controller MSB + dmsg(4,("NRPN MSB %d\n", itControlChangeEvent->Param.CC.Value)); + pEngineChannel->SetMidiNrpnControllerMsb(itControlChangeEvent->Param.CC.Value); + break; + } + case 100: { // RPN controller LSB + dmsg(4,("RPN LSB %d\n", itControlChangeEvent->Param.CC.Value)); + pEngineChannel->SetMidiRpnControllerLsb(itControlChangeEvent->Param.CC.Value); + break; + } + case 101: { // RPN controller MSB + dmsg(4,("RPN MSB %d\n", itControlChangeEvent->Param.CC.Value)); + pEngineChannel->SetMidiRpnControllerMsb(itControlChangeEvent->Param.CC.Value); + break; + } + + + // Channel Mode Messages + + case 120: { // all sound off + KillAllVoices(pEngineChannel, itControlChangeEvent); + break; + } + case 121: { // reset all controllers + pChannel->ResetControllers(); + break; + } + case 123: { // all notes off + #if CONFIG_PROCESS_ALL_NOTES_OFF + pChannel->ReleaseAllVoices(itControlChangeEvent); + #endif // CONFIG_PROCESS_ALL_NOTES_OFF + break; + } + case 126: { // mono mode on + if (!pChannel->SoloMode) + KillAllVoices(pEngineChannel, itControlChangeEvent); + pChannel->SoloMode = true; + break; + } + case 127: { // poly mode on + if (pChannel->SoloMode) + KillAllVoices(pEngineChannel, itControlChangeEvent); + pChannel->SoloMode = false; + break; + } + } + } + + virtual D* CreateDiskThread() = 0; + + /** + * Assigns and triggers a new voice for the respective MIDI key. + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itNoteOnEvent - key, velocity and time stamp of the event + */ + virtual void ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent) { + EngineChannelBase<V, R, I>* pChannel = + static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + + //HACK: we should better add the transpose value only to the most mandatory places (like for retrieving the region and calculating the tuning), because otherwise voices will unintendedly survive when changing transpose while playing + int k = itNoteOnEvent->Param.Note.Key + pChannel->GlobalTranspose; + if (k < 0 || k > 127) return; //ignore keys outside the key range + + itNoteOnEvent->Param.Note.Key += pChannel->GlobalTranspose; + int vel = itNoteOnEvent->Param.Note.Velocity; + + const int key = itNoteOnEvent->Param.Note.Key; + MidiKey* pKey = &pChannel->pMIDIKeyInfokey; + + pChannel->listeners.PreProcessNoteOn(key, vel); + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessNoteOn(key, vel); + return; + } + #endif + + if (!pChannel->pInstrument) { + pChannel->listeners.PostProcessNoteOn(key, vel); + return; // ignore if no instrument loaded + } + + // move note on event to the key's own event list + RTList<Event>::Iterator itNoteOnEventOnKeyList = itNoteOnEvent.moveToEndOf(pKey->pEvents); + + // if Solo Mode then kill all already active voices + if (pChannel->SoloMode) { + Pool<uint>::Iterator itYoungestKey = pChannel->pActiveKeys->last(); + if (itYoungestKey) { + const int iYoungestKey = *itYoungestKey; + const MidiKey* pOtherKey = &pChannel->pMIDIKeyInfoiYoungestKey; + if (pOtherKey->Active) { + // get final portamento position of currently active voice + if (pChannel->PortamentoMode) { + VoiceIterator itVoice = pOtherKey->pActiveVoices->last(); + if (itVoice) itVoice->UpdatePortamentoPos(itNoteOnEventOnKeyList); + } + // kill all voices on the (other) key + VoiceIterator itVoiceToBeKilled = pOtherKey->pActiveVoices->first(); + VoiceIterator end = pOtherKey->pActiveVoices->end(); + for (; itVoiceToBeKilled != end; ++itVoiceToBeKilled) { + if (!(itVoiceToBeKilled->Type & Voice::type_release_trigger)) + itVoiceToBeKilled->Kill(itNoteOnEventOnKeyList); + } + } + } + // set this key as 'currently active solo key' + pChannel->SoloKey = key; + } + + pChannel->ProcessKeySwitchChange(key); + + pKey->KeyPressed = true; // the MIDI key was now pressed down + pKey->Velocity = itNoteOnEventOnKeyList->Param.Note.Velocity; + pKey->NoteOnTime = FrameTime + itNoteOnEventOnKeyList->FragmentPos(); // will be used to calculate note length + + // cancel release process of voices on this key if needed + if (pKey->Active && !pChannel->SustainPedal) { + RTList<Event>::Iterator itCancelReleaseEvent = pKey->pEvents->allocAppend(); + if (itCancelReleaseEvent) { + *itCancelReleaseEvent = *itNoteOnEventOnKeyList; // copy event + itCancelReleaseEvent->Type = Event::type_cancel_release; // transform event type + } + else dmsg(1,("Event pool emtpy!\n")); + } + + TriggerNewVoices(pEngineChannel, itNoteOnEventOnKeyList); + + // if neither a voice was spawned or postponed then remove note on event from key again + if (!pKey->Active && !pKey->VoiceTheftsQueued) + pKey->pEvents->free(itNoteOnEventOnKeyList); + + if (!pChannel->SoloMode || pChannel->PortamentoPos < 0.0f) pChannel->PortamentoPos = (float) key; + if (pKey->pRoundRobinIndex) { + (*pKey->pRoundRobinIndex)++; // counter specific for the key or region + pChannel->RoundRobinIndex++; // common counter for the channel + } + pChannel->listeners.PostProcessNoteOn(key, vel); + } + + /** + * Allocate and trigger new voice(s) for the key. + */ + virtual void TriggerNewVoices ( + EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts = true + ) = 0; + + /** + * Allocate and trigger release voice(s) for the key. + */ + virtual void TriggerReleaseVoices ( + EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ) = 0; + + /** + * Releases the voices on the given key if sustain pedal is not pressed. + * If sustain is pressed, the release of the note will be postponed until + * sustain pedal will be released or voice turned inactive by itself (e.g. + * due to completion of sample playback). + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itNoteOffEvent - key, velocity and time stamp of the event + */ + virtual void ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent) { + EngineChannelBase<V, R, I>* pChannel = static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + + int k = itNoteOffEvent->Param.Note.Key + pChannel->GlobalTranspose; + if (k < 0 || k > 127) return; //ignore keys outside the key range + + //HACK: we should better add the transpose value only to the most mandatory places (like for retrieving the region and calculating the tuning), because otherwise voices will unintendedly survive when changing transpose while playing + itNoteOffEvent->Param.Note.Key += pChannel->GlobalTranspose; + int vel = itNoteOffEvent->Param.Note.Velocity; + + const int iKey = itNoteOffEvent->Param.Note.Key; + MidiKey* pKey = &pChannel->pMIDIKeyInfoiKey; + + pChannel->listeners.PreProcessNoteOff(iKey, vel); + + #if !CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { // skip if sampler channel is muted + pChannel->listeners.PostProcessNoteOff(iKey, vel); + return; + } + #endif + + pKey->KeyPressed = false; // the MIDI key was now released + + // move event to the key's own event list + RTList<Event>::Iterator itNoteOffEventOnKeyList = itNoteOffEvent.moveToEndOf(pKey->pEvents); + + bool bShouldRelease = pKey->Active && pChannel->ShouldReleaseVoice(itNoteOffEventOnKeyList->Param.Note.Key); + + // in case Solo Mode is enabled, kill all voices on this key and respawn a voice on the highest pressed key (if any) + if (pChannel->SoloMode && pChannel->pInstrument) { //TODO: this feels like too much code just for handling solo mode :P + bool bOtherKeysPressed = false; + if (iKey == pChannel->SoloKey) { + pChannel->SoloKey = -1; + // if there's still a key pressed down, respawn a voice (group) on the highest key + for (int i = 127; i > 0; i--) { + MidiKey* pOtherKey = &pChannel->pMIDIKeyInfoi; + if (pOtherKey->KeyPressed) { + bOtherKeysPressed = true; + // make the other key the new 'currently active solo key' + pChannel->SoloKey = i; + // get final portamento position of currently active voice + if (pChannel->PortamentoMode) { + VoiceIterator itVoice = pKey->pActiveVoices->first(); + if (itVoice) itVoice->UpdatePortamentoPos(itNoteOffEventOnKeyList); + } + // create a pseudo note on event + RTList<Event>::Iterator itPseudoNoteOnEvent = pOtherKey->pEvents->allocAppend(); + if (itPseudoNoteOnEvent) { + // copy event + *itPseudoNoteOnEvent = *itNoteOffEventOnKeyList; + // transform event to a note on event + itPseudoNoteOnEvent->Type = Event::type_note_on; + itPseudoNoteOnEvent->Param.Note.Key = i; + itPseudoNoteOnEvent->Param.Note.Velocity = pOtherKey->Velocity; + // allocate and trigger new voice(s) for the other key + TriggerNewVoices(pChannel, itPseudoNoteOnEvent, false); + // if neither a voice was spawned or postponed then remove note on event from key again + if (!pOtherKey->Active && !pOtherKey->VoiceTheftsQueued) + pOtherKey->pEvents->free(itPseudoNoteOnEvent); + + } else dmsg(1,("Could not respawn voice, no free event left\n")); + break; // done + } + } + } + if (bOtherKeysPressed) { + if (pKey->Active) { // kill all voices on this key + bShouldRelease = false; // no need to release, as we kill it here + VoiceIterator itVoiceToBeKilled = pKey->pActiveVoices->first(); + VoiceIterator end = pKey->pActiveVoices->end(); + for (; itVoiceToBeKilled != end; ++itVoiceToBeKilled) { + if (!(itVoiceToBeKilled->Type & Voice::type_release_trigger)) + itVoiceToBeKilled->Kill(itNoteOffEventOnKeyList); + } + } + } else pChannel->PortamentoPos = -1.0f; + } + + // if no solo mode (the usual case) or if solo mode and no other key pressed, then release voices on this key if needed + if (bShouldRelease) { + itNoteOffEventOnKeyList->Type = Event::type_release; // transform event type + + // spawn release triggered voice(s) if needed + if (pKey->ReleaseTrigger && pChannel->pInstrument) { + TriggerReleaseVoices(pChannel, itNoteOffEventOnKeyList); + pKey->ReleaseTrigger = false; + } + } + + // if neither a voice was spawned or postponed on this key then remove note off event from key again + if (!pKey->Active && !pKey->VoiceTheftsQueued) + pKey->pEvents->free(itNoteOffEventOnKeyList); + + pChannel->listeners.PostProcessNoteOff(iKey, vel); + } + + /** + * Reset all voices and disk thread and clear input event queue and all + * control and status variables. This method is protected by a mutex. + */ + virtual void ResetInternal() { + ResetInternalMutex.Lock(); + + // make sure that the engine does not get any sysex messages + // while it's reseting + bool sysexDisabled = MidiInputPort::RemoveSysexListener(this); + SetVoiceCount(0); + ActiveVoiceCountMax = 0; + + // reset voice stealing parameters + pVoiceStealingQueue->clear(); + itLastStolenVoice = VoiceIterator(); + itLastStolenVoiceGlobally = VoiceIterator(); + iuiLastStolenKey = RTList<uint>::Iterator(); + iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); + pLastStolenChannel = NULL; + + // reset all voices + for (VoiceIterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { + iterVoice->Reset(); + } + pVoicePool->clear(); + + // reset disk thread + if (pDiskThread) pDiskThread->Reset(); + + // delete all input events + pEventQueue->init(); + pSysexBuffer->init(); + if (sysexDisabled) MidiInputPort::AddSysexListener(this); + ResetInternalMutex.Unlock(); + } + + /** + * Kills all voices on an engine channel as soon as possible. Voices + * won't get into release state, their volume level will be ramped down + * as fast as possible. + * + * @param pEngineChannel - engine channel on which all voices should be killed + * @param itKillEvent - event which caused this killing of all voices + */ + virtual void KillAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itKillEvent) { + EngineChannelBase<V, R, I>* pChannel = static_cast<EngineChannelBase<V, R, I>*>(pEngineChannel); + int count = pChannel->KillAllVoices(itKillEvent); + VoiceSpawnsLeft -= count; //FIXME: just a temporary workaround, we should check the cause in StealVoice() instead + } + + /** + * Allocates and triggers a new voice. This method will usually be + * called by the ProcessNoteOn() method and by the voices itself + * (e.g. to spawn further voices on the same key for layered sounds). + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itNoteOnEvent - key, velocity and time stamp of the event + * @param iLayer - layer index for the new voice (optional - only + * in case of layered sounds of course) + * @param ReleaseTriggerVoice - if new voice is a release triggered voice + * (optional, default = false) + * @param VoiceStealing - if voice stealing should be performed + * when there is no free voice + * (optional, default = true) + * @param HandleKeyGroupConflicts - if voices should be killed due to a + * key group conflict + * @returns pointer to new voice or NULL if there was no free voice or + * if the voice wasn't triggered (for example when no region is + * defined for the given key). + */ + virtual PoolVoiceIterator LaunchVoice ( + EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ) = 0; + + virtual int GetMinFadeOutSamples() { return MinFadeOutSamples; } + + int InitNewVoice ( + EngineChannelBase<V, R, I>* pChannel, + R* pRegion, + Pool<Event>::Iterator& itNoteOnEvent, + Voice::type_t VoiceType, + int iLayer, + int iKeyGroup, + bool ReleaseTriggerVoice, + bool VoiceStealing, + typename Pool<V>::Iterator& itNewVoice + ) { + int key = itNoteOnEvent->Param.Note.Key; + typename MidiKeyboardManager<V>::MidiKey* pKey = &pChannel->pMIDIKeyInfokey; + if (itNewVoice) { + // launch the new voice + if (itNewVoice->Trigger(pChannel, itNoteOnEvent, pChannel->Pitch, pRegion, VoiceType, iKeyGroup) < 0) { + dmsg(4,("Voice not triggered\n")); + pKey->pActiveVoices->free(itNewVoice); + } + else { // on success + --VoiceSpawnsLeft; + if (!pKey->Active) { // mark as active key + pKey->Active = true; + pKey->itSelf = pChannel->pActiveKeys->allocAppend(); + *pKey->itSelf = itNoteOnEvent->Param.Note.Key; + } + if (itNewVoice->Type & Voice::type_release_trigger_required) pKey->ReleaseTrigger = true; // mark key for the need of release triggered voice(s) + return 0; // success + } + } + else if (VoiceStealing) { + // try to steal one voice + int result = StealVoice(pChannel, itNoteOnEvent); + if (!result) { // voice stolen successfully + // put note-on event into voice-stealing queue, so it will be reprocessed after killed voice died + RTList<Event>::Iterator itStealEvent = pVoiceStealingQueue->allocAppend(); + if (itStealEvent) { + *itStealEvent = *itNoteOnEvent; // copy event + itStealEvent->Param.Note.Layer = iLayer; + itStealEvent->Param.Note.ReleaseTrigger = ReleaseTriggerVoice; + pKey->VoiceTheftsQueued++; + } + else dmsg(1,("Voice stealing queue full!\n")); + } + } + + return -1; + } + + private: + Pool<V>* pVoicePool; ///< Contains all voices that can be activated. + Pool<RR*> SuspendedRegions; + Mutex SuspendedRegionsMutex; + Condition SuspensionChangeOngoing; + RR* pPendingRegionSuspension; + RR* pPendingRegionResumption; + int iPendingStreamDeletions; + }; + + template <class V, class RR, class R, class D, class IM, class I> + IM EngineBase<V, RR, R, D, IM, I>::instruments; + +} // namespace LinuxSampler + +#endif /* __LS_ENGINEBASE_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/EngineChannel.cpp -> linuxsampler-2342.tar.bz2/src/engines/EngineChannel.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -43,10 +43,13 @@ uint8_t uiMidiBankLsb; uint8_t uiMidiRpnMsb; ///< MIDI Registered Parameter Number (upper 8 bits / coarse) uint8_t uiMidiRpnLsb; ///< MIDI Registered Parameter Number (lower 8 bits / fine) + uint8_t uiMidiNrpnMsb; ///< MIDI Non-Registered Parameter Number (upper 8 bits / coarse) + uint8_t uiMidiNrpnLsb; ///< MIDI Non-Registered Parameter Number (lower 8 bits / fine) bool bMidiBankMsbReceived; bool bMidiBankLsbReceived; bool bProgramChangeReceived; bool bMidiRpnReceived; + bool bMidiNrpnReceived; int iMidiInstrumentMap; atomic_t voiceCount; atomic_t diskStreamCount; @@ -68,11 +71,28 @@ SetDiskStreamCount(0); p->pSamplerChannel = NULL; ResetMidiRpnController(); + ResetMidiNrpnController(); } EngineChannel::~EngineChannel() { delete p; } + + /** + * Sometimes an instrument is splitted over several files. For example + * the GigaStudio format may split an instrument over a certain amount + * of files like: "Foo.gig", "Foo.gx01", "Foo.gx02", ... + * This method allows to retrieve the whole list of files that is used + * for the currently loaded instrument on this engine channel. + * Calling this method with index 0 is equivalent as calling the equal + * named method without any argument. + * + * @param index - index of sought file name (0, 1, 2, ...) + * @returns file name or empty string if index out of bounds + */ + String EngineChannel::InstrumentFileName(int index) { + return (index == 0) ? InstrumentFileName() : ""; + } void EngineChannel::SetMute(int state) throw (Exception) { if (p->iMute == state) return; @@ -202,6 +222,8 @@ StatusChanged(true); } + // RPNs ... + void EngineChannel::SetMidiRpnControllerMsb(uint8_t CtrlMSB) { p->uiMidiRpnMsb = CtrlMSB; p->bMidiRpnReceived = true; @@ -222,6 +244,28 @@ (p->uiMidiRpnMsb << 8) | p->uiMidiRpnLsb : -1; } + // NRPNs ... + + void EngineChannel::SetMidiNrpnControllerMsb(uint8_t CtrlMSB) { + p->uiMidiNrpnMsb = CtrlMSB; + p->bMidiNrpnReceived = true; + } + + void EngineChannel::SetMidiNrpnControllerLsb(uint8_t CtrlLSB) { + p->uiMidiNrpnLsb = CtrlLSB; + p->bMidiNrpnReceived = true; + } + + void EngineChannel::ResetMidiNrpnController() { + p->uiMidiNrpnMsb = p->uiMidiNrpnLsb = 0; + p->bMidiNrpnReceived = false; + } + + int EngineChannel::GetMidiNrpnController() { + return (p->bMidiNrpnReceived) ? + (p->uiMidiNrpnMsb << 8) | p->uiMidiNrpnLsb : -1; + } + uint EngineChannel::GetVoiceCount() { return atomic_read(&p->voiceCount); } @@ -272,12 +316,15 @@ } } - void EngineChannel::ExecuteProgramChange(uint8_t Program) { - dmsg(1,("Received MIDI program change (prog=%d)\n",Program)); + void EngineChannel::ExecuteProgramChange(uint32_t Program) { + uint8_t hb = (Program >> 16) & 0xff; + uint8_t lb = (Program >> 8) & 0xff; + uint8_t pc = Program & 0x7f; + + dmsg(1,("Received MIDI program change (msb=%d) (lsb=%d) (prog=%d)\n", hb ,lb, pc)); std::vector<int> maps = MidiInstrumentMapper::Maps(); if (maps.empty()) return; - SetMidiProgram(Program); if (UsesNoMidiInstrumentMap()) return; if (MidiInstrumentMapper::GetMapCount() == 0) return; // retrieve the MIDI instrument map this engine channel is assigned to @@ -285,9 +332,9 @@ ? MidiInstrumentMapper::GetDefaultMap() /*default*/ : GetMidiInstrumentMap(); // is there an entry for this MIDI bank&prog pair in that map? midi_prog_index_t midiIndex; - midiIndex.midi_bank_msb = GetMidiBankMsb(); - midiIndex.midi_bank_lsb = GetMidiBankLsb(); - midiIndex.midi_prog = GetMidiProgram(); + midiIndex.midi_bank_msb = hb; + midiIndex.midi_bank_lsb = lb; + midiIndex.midi_prog = pc; optional<MidiInstrumentMapper::entry_t> mapping = MidiInstrumentMapper::GetEntry(iMapID, midiIndex); if (mapping) { // if mapping exists ...
View file
linuxsampler-1.0.0.tar.bz2/src/engines/EngineChannel.h -> linuxsampler-2342.tar.bz2/src/engines/EngineChannel.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -61,14 +61,14 @@ virtual void PrepareLoadInstrument(const char* FileName, uint Instrument) = 0; virtual void LoadInstrument() = 0; virtual void Reset() = 0; - virtual void SendNoteOn(uint8_t Key, uint8_t Velocity) = 0; - virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, int32_t FragmentPos) = 0; - virtual void SendNoteOff(uint8_t Key, uint8_t Velocity) = 0; - virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, int32_t FragmentPos) = 0; - virtual void SendPitchbend(int Pitch) = 0; - virtual void SendPitchbend(int Pitch, int32_t FragmentPos) = 0; - virtual void SendControlChange(uint8_t Controller, uint8_t Value) = 0; - virtual void SendControlChange(uint8_t Controller, uint8_t Value, int32_t FragmentPos) = 0; + virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel) = 0; + virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos) = 0; + virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel) = 0; + virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, uint8_t MidiChannel, int32_t FragmentPos) = 0; + virtual void SendPitchbend(int Pitch, uint8_t MidiChannel) = 0; + virtual void SendPitchbend(int Pitch, uint8_t MidiChannel, int32_t FragmentPos) = 0; + virtual void SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel) = 0; + virtual void SendControlChange(uint8_t Controller, uint8_t Value, uint8_t MidiChannel, int32_t FragmentPos) = 0; virtual void SendProgramChange(uint8_t Program) = 0; virtual bool StatusChanged(bool bNewStatus = false) = 0; virtual float Volume() = 0; @@ -85,7 +85,8 @@ virtual void DisconnectMidiInputPort() = 0; virtual MidiInputPort* GetMidiInputPort() = 0; virtual midi_chan_t MidiChannel() = 0; - virtual String InstrumentFileName() = 0; + virtual String InstrumentFileName() = 0; ///< Returns the file name of the currently loaded instrument. Equivalent as calling InstrumentFileName(0). + virtual String InstrumentFileName(int index); virtual String InstrumentName() = 0; virtual int InstrumentIndex() = 0; virtual int InstrumentStatus() = 0; @@ -251,6 +252,23 @@ */ void ResetMidiRpnController(); + /** + * Set MIDI Non-Registered Parameter Number (NRPN) Controller + * (upper 8 bits / coarse). + */ + void SetMidiNrpnControllerMsb(uint8_t CtrlMSB); + + /** + * Set MIDI Non-Registered Parameter Number (NRPN) Controller + * (lower 8 bits / fine). + */ + void SetMidiNrpnControllerLsb(uint8_t CtrlLSB); + + /** + * Reset to no NRPN controller currently selected. + */ + void ResetMidiNrpnController(); + /** * Registers the specified listener to be notified when the number * of effect sends on this channel is changed. @@ -283,6 +301,21 @@ int GetMidiRpnController(); /** + * Get currently selected MIDI Non-Registered Parameter Number + * (NRPN) Controller, this method will return the already merged + * value (MSB and LSB value). + * + * @e WARNING: you have to call @c ResetMidiNrpnController() + * after using this value, otherwise all subsequent MIDI CC #6 + * (Data) messages are interpreted as NRPN controller value + * messages. + * + * @returns currently selected NRPN controller number, a negative + * value if no NRPN controller currently selected + */ + int GetMidiNrpnController(); + + /** * Gets the current number of active voices. */ uint GetVoiceCount(); @@ -314,7 +347,7 @@ * * This method is not real-time safe. */ - void ExecuteProgramChange(uint8_t Program); + void ExecuteProgramChange(uint32_t Program); protected: EngineChannel();
View file
linuxsampler-2342.tar.bz2/src/engines/EngineChannelBase.h
Added
@@ -0,0 +1,370 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_ENGINECHANNELBASE_H__ +#define __LS_ENGINECHANNELBASE_H__ + +#include "AbstractEngineChannel.h" +#include "common/MidiKeyboardManager.h" +#include "common/Voice.h" +#include "../common/ResourceManager.h" + +namespace LinuxSampler { + /// Command used by the instrument loader thread to + /// request an instrument change on a channel. + template <class R /* Region */, class I /* Instrument */> + class InstrumentChangeCmd { + public: + bool bChangeInstrument; ///< Set to true by the loader when the channel should change instrument. + I* pInstrument; ///< The new instrument. Also used by the loader to read the previously loaded instrument. + RTList<R*>* pRegionsInUse; ///< List of dimension regions in use by the currently loaded instrument. Continuously updated by the audio thread. + }; + + template<class R> + class RegionPools { + public: + virtual Pool<R*>* GetRegionPool(int index) = 0; + }; + + template<class V> + class VoicePool { + public: + virtual Pool<V>* GetVoicePool() = 0; + }; + + template <class V /* Voice */, class R /* Region */, class I /* Instrument */> + class EngineChannelBase: public AbstractEngineChannel, public MidiKeyboardManager<V>, public ResourceConsumer<I> { + public: + typedef typename RTList<R*>::Iterator RTListRegionIterator; + typedef typename MidiKeyboardManager<V>::MidiKey MidiKey; + + virtual void HandBack(I* Instrument) { + ResourceManager<InstrumentManager::instrument_id_t, I>* mgr = + dynamic_cast<ResourceManager<InstrumentManager::instrument_id_t, I>*>(pEngine->GetInstrumentManager()); + mgr->HandBack(Instrument, this); + } + + virtual void ClearRegionsInUse() { + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + if (cmd.pRegionsInUse) cmd.pRegionsInUse->clear(); + cmd.bChangeInstrument = false; + } + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.SwitchConfig(); + if (cmd.pRegionsInUse) cmd.pRegionsInUse->clear(); + cmd.bChangeInstrument = false; + } + } + + virtual void ResetRegionsInUse(Pool<R*>* pRegionPool) { + DeleteRegionsInUse(); + AllocateRegionsInUse(pRegionPool); + } + + virtual void DeleteRegionsInUse() { + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + if (cmd.pRegionsInUse) { + delete cmd.pRegionsInUse; + cmd.pRegionsInUse = NULL; + } + cmd.bChangeInstrument = false; + } + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.SwitchConfig(); + if (cmd.pRegionsInUse) { + delete cmd.pRegionsInUse; + cmd.pRegionsInUse = NULL; + } + cmd.bChangeInstrument = false; + } + } + + virtual void AllocateRegionsInUse(Pool<R*>* pRegionPool) { + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + cmd.pRegionsInUse = new RTList<R*>(pRegionPool0); + cmd.bChangeInstrument = false; + } + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.SwitchConfig(); + cmd.pRegionsInUse = new RTList<R*>(pRegionPool1); + cmd.bChangeInstrument = false; + } + } + + virtual void Connect(AudioOutputDevice* pAudioOut) { + if (pEngine) { + if (pEngine->pAudioOutputDevice == pAudioOut) return; + DisconnectAudioOutputDevice(); + } + AbstractEngine* newEngine = AbstractEngine::AcquireEngine(this, pAudioOut); + EngineMutex.Lock(); + pEngine = newEngine; + EngineMutex.Unlock(); + ResetInternal(); + pEvents = new RTList<Event>(pEngine->pEventPool); + + RegionPools<R>* pRegionPool = dynamic_cast<RegionPools<R>*>(pEngine); + // reset the instrument change command struct (need to be done + // twice, as it is double buffered) + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + cmd.pRegionsInUse = new RTList<R*>(pRegionPool->GetRegionPool(0)); + cmd.pInstrument = 0; + cmd.bChangeInstrument = false; + } + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.SwitchConfig(); + cmd.pRegionsInUse = new RTList<R*>(pRegionPool->GetRegionPool(1)); + cmd.pInstrument = 0; + cmd.bChangeInstrument = false; + } + + if (pInstrument != NULL) { + pInstrument = NULL; + InstrumentStat = -1; + InstrumentIdx = -1; + InstrumentIdxName = ""; + InstrumentFile = ""; + bStatusChanged = true; + } + + VoicePool<V>* pVoicePool = dynamic_cast<VoicePool<V>*>(pEngine); + MidiKeyboardManager<V>::AllocateActiveVoices(pVoicePool->GetVoicePool()); + MidiKeyboardManager<V>::AllocateEvents(pEngine->pEventPool); + + AudioDeviceChannelLeft = 0; + AudioDeviceChannelRight = 1; + if (fxSends.empty()) { // render directly into the AudioDevice's output buffers + pChannelLeft = pAudioOut->Channel(AudioDeviceChannelLeft); + pChannelRight = pAudioOut->Channel(AudioDeviceChannelRight); + } else { // use local buffers for rendering and copy later + // ensure the local buffers have the correct size + if (pChannelLeft) delete pChannelLeft; + if (pChannelRight) delete pChannelRight; + pChannelLeft = new AudioChannel(0, pAudioOut->MaxSamplesPerCycle()); + pChannelRight = new AudioChannel(1, pAudioOut->MaxSamplesPerCycle()); + } + if (pEngine->EngineDisabled.GetUnsafe()) pEngine->Enable(); + MidiInputPort::AddSysexListener(pEngine); + } + + virtual void DisconnectAudioOutputDevice() { + if (pEngine) { // if clause to prevent disconnect loops + + ResetInternal(); + + DeleteRegionsInUse(); + + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + if (cmd.pInstrument) { + // release the currently loaded instrument + HandBack(cmd.pInstrument); + } + + if (pEvents) { + delete pEvents; + pEvents = NULL; + } + + MidiKeyboardManager<V>::DeleteActiveVoices(); + MidiKeyboardManager<V>::DeleteEvents(); + DeleteGroupEventLists(); + + AudioOutputDevice* oldAudioDevice = pEngine->pAudioOutputDevice; + EngineMutex.Lock(); + pEngine = NULL; + EngineMutex.Unlock(); + AbstractEngine::FreeEngine(this, oldAudioDevice); + AudioDeviceChannelLeft = -1; + AudioDeviceChannelRight = -1; + if (!fxSends.empty()) { // free the local rendering buffers + if (pChannelLeft) delete pChannelLeft; + if (pChannelRight) delete pChannelRight; + } + pChannelLeft = NULL; + pChannelRight = NULL; + } + } + + class ClearEventListsHandler : public MidiKeyboardManager<V>::VoiceHandlerBase { + public: + virtual bool Process(MidiKey* pMidiKey) { pMidiKey->pEvents->clear(); return false; } + }; + + void ClearEventLists() { + pEvents->clear(); + // empty MIDI key specific event lists + ClearEventListsHandler handler; + this->ProcessActiveVoices(&handler); + + // empty exclusive group specific event lists + ClearGroupEventLists(); + } + + // implementation of abstract methods derived from interface class 'InstrumentConsumer' + + /** + * Will be called by the InstrumentResourceManager when the instrument + * we are currently using on this EngineChannel is going to be updated, + * so we can stop playback before that happens. + */ + virtual void ResourceToBeUpdated(I* pResource, void*& pUpdateArg) { + dmsg(3,("EngineChannelBase: Received instrument update message.\n")); + if (pEngine) pEngine->DisableAndLock(); + ResetInternal(); + this->pInstrument = NULL; + } + + /** + * Will be called by the InstrumentResourceManager when the instrument + * update process was completed, so we can continue with playback. + */ + virtual void ResourceUpdated(I* pOldResource, I* pNewResource, void* pUpdateArg) { + this->pInstrument = pNewResource; //TODO: there are couple of engine parameters we should update here as well if the instrument was updated (see LoadInstrument()) + if (pEngine) pEngine->Enable(); + bStatusChanged = true; // status of engine has changed, so set notify flag + } + + /** + * Will be called by the InstrumentResourceManager on progress changes + * while loading or realoading an instrument for this EngineChannel. + * + * @param fProgress - current progress as value between 0.0 and 1.0 + */ + virtual void OnResourceProgress(float fProgress) { + this->InstrumentStat = int(fProgress * 100.0f); + dmsg(7,("EngineChannelBase: progress %d%", InstrumentStat)); + bStatusChanged = true; // status of engine has changed, so set notify flag + } + + void RenderActiveVoices(uint Samples) { + RenderVoicesHandler handler(this, Samples); + this->ProcessActiveVoices(&handler); + + SetVoiceCount(handler.VoiceCount); + SetDiskStreamCount(handler.StreamCount); + } + + RTList<R*>* pRegionsInUse; ///< temporary pointer into the instrument change command, used by the audio thread + I* pInstrument; + + template<class TV, class TRR, class TR, class TD, class TIM, class TI> friend class EngineBase; + + protected: + EngineChannelBase() : InstrumentChangeCommandReader(InstrumentChangeCommand) { + pInstrument = NULL; + + // reset the instrument change command struct (need to be done + // twice, as it is double buffered) + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + cmd.pRegionsInUse = NULL; + cmd.pInstrument = NULL; + cmd.bChangeInstrument = false; + } + { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.SwitchConfig(); + cmd.pRegionsInUse = NULL; + cmd.pInstrument = NULL; + cmd.bChangeInstrument = false; + } + } + + virtual ~EngineChannelBase() { } + + typedef typename RTList<V>::Iterator RTListVoiceIterator; + + class RenderVoicesHandler : public MidiKeyboardManager<V>::VoiceHandlerBase { + public: + uint Samples; + uint VoiceCount; + uint StreamCount; + EngineChannelBase<V, R, I>* pChannel; + + RenderVoicesHandler(EngineChannelBase<V, R, I>* channel, uint samples) : + pChannel(channel), Samples(samples), VoiceCount(0), StreamCount(0) { } + + virtual void Process(RTListVoiceIterator& itVoice) { + // now render current voice + itVoice->Render(Samples); + if (itVoice->IsActive()) { // still active + if (!itVoice->Orphan) { + *(pChannel->pRegionsInUse->allocAppend()) = itVoice->GetRegion(); + } + VoiceCount++; + + if (itVoice->PlaybackState == Voice::playback_state_disk) { + if ((itVoice->DiskStreamRef).State != Stream::state_unused) StreamCount++; + } + } else { // voice reached end, is now inactive + itVoice->VoiceFreed(); + pChannel->FreeVoice(itVoice); // remove voice from the list of active voices + } + } + }; + + typedef typename SynchronizedConfig<InstrumentChangeCmd<R, I> >::Reader SyncConfInstrChangeCmdReader; + + SynchronizedConfig<InstrumentChangeCmd<R, I> > InstrumentChangeCommand; + SyncConfInstrChangeCmdReader InstrumentChangeCommandReader; + + /** This method is not thread safe! */ + virtual void ResetInternal() { + AbstractEngineChannel::ResetInternal(); + + MidiKeyboardManager<V>::Reset(); + } + + virtual void ResetControllers() { + AbstractEngineChannel::ResetControllers(); + + MidiKeyboardManager<V>::SustainPedal = false; + MidiKeyboardManager<V>::SostenutoPedal = false; + } + + /** + * Changes the instrument for an engine channel. + * + * @param pInstrument - new instrument + * @returns the resulting instrument change command after the + * command switch, containing the old instrument and + * the dimregions it is using + */ + InstrumentChangeCmd<R, I>& ChangeInstrument(I* pInstrument) { + InstrumentChangeCmd<R, I>& cmd = InstrumentChangeCommand.GetConfigForUpdate(); + cmd.pInstrument = pInstrument; + cmd.bChangeInstrument = true; + + return InstrumentChangeCommand.SwitchConfig(); + } + + virtual void ProcessKeySwitchChange(int key) = 0; + }; + +} // namespace LinuxSampler + +#endif /* __LS_ENGINECHANNELBASE_H__ */
View file
linuxsampler-1.0.0.tar.bz2/src/engines/EngineChannelFactory.cpp -> linuxsampler-2342.tar.bz2/src/engines/EngineChannelFactory.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005, 2006 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -24,6 +24,12 @@ #include "gig/EngineChannel.h" +#if HAVE_SF2 +#include "sf2/EngineChannel.h" +#endif + +#include "sfz/EngineChannel.h" + namespace LinuxSampler { class LockedChannel { public: @@ -83,6 +89,7 @@ } lockedChannels; Mutex EngineChannelFactory::LockedChannelsMutex; + Mutex EngineChannelFactory::EngineChannelsMutex; void EngineChannelFactory::SetDeleteEnabled(const EngineChannel* pEngineChannel, bool enable) { LockedChannelsMutex.Lock(); @@ -102,17 +109,31 @@ static std::set<LinuxSampler::EngineChannel*> engineChannels; LinuxSampler::EngineChannel* EngineChannelFactory::Create(String EngineType) throw (Exception) { + LinuxSampler::EngineChannel* pEngineChannel; if (!strcasecmp(EngineType.c_str(),"GigEngine") || !strcasecmp(EngineType.c_str(),"gig")) { - LinuxSampler::EngineChannel* pEngineChannel = new gig::EngineChannel; - engineChannels.insert(pEngineChannel); - return pEngineChannel; + pEngineChannel = new gig::EngineChannel; + } else if (!strcasecmp(EngineType.c_str(),"sf2")) { + #if HAVE_SF2 + pEngineChannel = new sf2::EngineChannel; + #else + throw Exception("LinuxSampler is not compiled with SF2 support"); + #endif + } else if (!strcasecmp(EngineType.c_str(),"sfz")) { + pEngineChannel = new sfz::EngineChannel; + } else { + throw Exception("Unknown engine type"); } - throw Exception("Unknown engine type"); + EngineChannelsMutex.Lock(); + engineChannels.insert(pEngineChannel); + EngineChannelsMutex.Unlock(); + return pEngineChannel; } void EngineChannelFactory::Destroy(LinuxSampler::EngineChannel* pEngineChannel) { pEngineChannel->RemoveAllFxSendCountListeners(); + EngineChannelsMutex.Lock(); engineChannels.erase(pEngineChannel); + EngineChannelsMutex.Unlock(); // Postpone the deletion of the specified EngineChannel if needed (bug #113) LockedChannelsMutex.Lock();
View file
linuxsampler-1.0.0.tar.bz2/src/engines/EngineChannelFactory.h -> linuxsampler-2342.tar.bz2/src/engines/EngineChannelFactory.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005, 2006 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -61,6 +61,8 @@ */ static void SetDeleteEnabled(const EngineChannel* pEngineChannel, bool enable); + static Mutex EngineChannelsMutex; + private: static Mutex LockedChannelsMutex; };
View file
linuxsampler-1.0.0.tar.bz2/src/engines/EngineFactory.cpp -> linuxsampler-2342.tar.bz2/src/engines/EngineFactory.cpp
Changed
@@ -24,6 +24,12 @@ #include "gig/Engine.h" +#if HAVE_SF2 +#include "sf2/Engine.h" +#endif + +#include "sfz/Engine.h" + #include "../common/global.h" namespace LinuxSampler { @@ -33,7 +39,11 @@ std::vector<String> EngineFactory::AvailableEngineTypes() { std::vector<String> result; - result.push_back("GIG"); // we only have one sampler engine implementation ATM + result.push_back("GIG"); + #if HAVE_SF2 + result.push_back("SF2"); + #endif + result.push_back("SFZ"); return result; } @@ -53,7 +63,20 @@ Engine* pEngine = new gig::Engine; engines.insert(pEngine); return pEngine; + } else if (!strcasecmp(EngineType.c_str(),"sf2")) { + #if HAVE_SF2 + Engine* pEngine = new sf2::Engine; + engines.insert(pEngine); + return pEngine; + #else + throw Exception("LinuxSampler is not compiled with SF2 support"); + #endif + } else if (!strcasecmp(EngineType.c_str(),"sfz")) { + Engine* pEngine = new sfz::Engine; + engines.insert(pEngine); + return pEngine; } + throw Exception("Unknown engine type"); }
View file
linuxsampler-1.0.0.tar.bz2/src/engines/FxSend.cpp -> linuxsampler-2342.tar.bz2/src/engines/FxSend.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -34,7 +34,7 @@ namespace LinuxSampler { FxSend::FxSend(EngineChannel* pEngineChannel, uint8_t MidiCtrl, String Name) throw (Exception) - : iMasterEffectChain(-1), iMasterEffect(-1) + : iDestinationEffectChain(-1), iDestinationEffectChainPos(-1), bInfoChanged(false) { this->pEngineChannel = pEngineChannel; AudioOutputDevice* pDevice = pEngineChannel->GetAudioOutputDevice(); @@ -78,29 +78,47 @@ fLevel = DEFAULT_FX_SEND_LEVEL; } - int FxSend::DestinationMasterEffectChain() const { - return iMasterEffectChain; + int FxSend::DestinationEffectChain() const { + return iDestinationEffectChain; } - int FxSend::DestinationMasterEffect() const { - return iMasterEffect; + int FxSend::DestinationEffectChainPosition() const { + return iDestinationEffectChainPos; } - void FxSend::SetDestinationMasterEffect(int iChain, int iEffect) throw (Exception) { + void FxSend::SetDestinationEffect(int iChain, int iChainPos) throw (Exception) { AudioOutputDevice* pDevice = pEngineChannel->GetAudioOutputDevice(); - if (iChain < 0 || iChain >= pDevice->MasterEffectChainCount()) - throw Exception( - "Could not assign FX Send to master effect chain " + + bool chainFound = false; + if (iChain != -1) { + if (pDevice->SendEffectChainByID(iChain) != NULL) chainFound = true; + if (!chainFound) throw Exception( + "Could not assign FX Send to send effect chain " + ToString(iChain) + ": effect chain doesn't exist." ); - if (iEffect < 0 || iEffect >= pDevice->MasterEffectChain(iChain)->EffectCount()) + } + if (chainFound && (iChainPos < 0 || iChainPos >= pDevice->SendEffectChainByID(iChain)->EffectCount())) throw Exception( - "Could not assign FX Send to master effect " + - ToString(iEffect) + " of effect chain " + ToString(iChain) + - ": effect doesn't exist." + "Could not assign FX Send to send effect chain position " + + ToString(iChainPos) + " of send effect chain " + ToString(iChain) + + ": effect chain position out of bounds." ); - iMasterEffectChain = iChain; - iMasterEffect = iEffect; + iDestinationEffectChain = iChain; + iDestinationEffectChainPos = (iChain == -1 ? -1 : iChainPos); + } + + // TODO: to be removed + int FxSend::DestinationMasterEffectChain() const { + return DestinationEffectChain(); + } + + // TODO: to be removed + int FxSend::DestinationMasterEffect() const { + return DestinationEffectChainPosition(); + } + + // TODO: to be removed + void FxSend::SetDestinationMasterEffect(int iChain, int iChainPos) throw (Exception) { + SetDestinationEffect(iChain, iChainPos); } int FxSend::DestinationChannel(int SrcChan) {
View file
linuxsampler-1.0.0.tar.bz2/src/engines/FxSend.h -> linuxsampler-2342.tar.bz2/src/engines/FxSend.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -39,14 +39,15 @@ * * This class is used to manage effect sends on Engine Channels. An effect * send is used to route sampler channel's audio signals to either sampler - * external effect processors or to sampler internal effect processors. - * Each effect send entity can define an arbitrary MIDI controller number - * which can alter the effect send's send level. + * external effect processors (by routing the effect send to dedicated + * audio output channels of the sampler channel's audio output device) or + * to sampler internal effect processors (send effects). Each effect send + * entity can define an arbitrary MIDI controller number which can alter + * the effect send's send level. * - * Regarding sampler internal effects: only master effects are supported - * ATM, no insert effects yet. See AudioOutputDevice regarding management - * of master effects, since master effects only live in the context of - * exactly @e ONE AudioOutputDevice. + * Regarding sampler internal effects: See AudioOutputDevice regarding + * management of send effects, since send effects only live in the context + * of exactly @e ONE AudioOutputDevice. * * Note: effect sends cannot be routed to a different AudioOutputDevice * than assigned to the FxSend's EngineChannel. Also note that an effect @@ -72,31 +73,49 @@ FxSend(EngineChannel* pEngineChannel, uint8_t MidiCtrl, String Name = "") throw (Exception); /** - * Index of the master effect chain this FX send is routed to or - * -1 if FX send is not routed to a master effect. + * Index of the send effect chain this FX send is routed to or + * -1 if FX send is not routed to a send effect. */ - int DestinationMasterEffectChain() const; + int DestinationEffectChain() const; /** - * Index of the master effect of the master effect chain given by - * DestinationMasterEffectChain(), in case FX send is routed to - * a master effect or -1 otherwise. + * Index of the send effect of the send effect chain given by + * DestinationEffectChain(), in case FX send is routed to + * a send effect or -1 otherwise. This is the effect chain + * position, not the effect ID! */ - int DestinationMasterEffect() const; + int DestinationEffectChainPosition() const; /** - * Route this FX send to the given master effect given by index - * @a iEffect of the master effect chain given by @a iChain . + * Route this FX send to the given send effect given by index + * @a iChainPos of the send effect chain given by @a iChain . * * If you want to remove the routing of an FX send, currently - * directed to a master effect processor, and want to route it + * directed to a send effect processor, and want to route it * directly to an audio output device channel instead, then set * both arguments to @c -1 . * - * @throw Exception - if given effect / effect chain doesn't exist - * @see AudioOutputDevice::MasterEffectChain() + * @throw Exception - if given effect chain or effect chain position + * doesn't exist + * + * @see AudioOutputDevice::SendEffectChain() + */ + void SetDestinationEffect(int iChain, int iChainPos) throw (Exception); + + /** + * @deprecated This method will be removed, use DestinationEffectChain() instead! + */ + int DestinationMasterEffectChain() const DEPRECATED_API; + + /** + * @deprecated This method will be removed, use DestinationEffectChainPosition() instead! + */ + int DestinationMasterEffect() const DEPRECATED_API; + + /** + * @deprecated This method will be removed, use SetDestinationEffect() instead! */ - void SetDestinationMasterEffect(int iChain, int iEffect) throw (Exception); + void SetDestinationMasterEffect(int iChain, int iChainPos) throw (Exception) DEPRECATED_API; /** * Returns the audio output device's audio channel to which effect @@ -105,10 +124,18 @@ int DestinationChannel(int SrcChan); /** - * Alters the routing of an audio channel. + * Alters the routing of an audio channel. By default all audio + * channels of an effect send are routed in consecutive same order + * to its destination. You can use this method to change this + * default routing. If this effect send is routed to an internel + * effect, then @a DstChan is the input channel of that destination + * effect. Otherwise, if this effect send is not routed to an + * internal effect, then @a DstChan is the output channel of the + * sampler channel's audio output device. * * @param SrcChan - the effect send's source channel * @param DstChan - the audio output device's destination channel + * or send effect's input channel * @throws Exception - in case arguments out of range */ void SetDestinationChannel(int SrcChan, int DstChan) throw (Exception); @@ -192,8 +219,8 @@ protected: EngineChannel* pEngineChannel; - int iMasterEffectChain; - int iMasterEffect; + int iDestinationEffectChain; + int iDestinationEffectChainPos; std::vector<int> Routing; uint8_t MidiFxSendController; String sName;
View file
linuxsampler-2342.tar.bz2/src/engines/InstrumentManagerBase.h
Added
@@ -0,0 +1,251 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This library 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 library is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this library; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_INSTRUMENTMANAGERBASE_H__ +#define __LS_INSTRUMENTMANAGERBASE_H__ + +#include "InstrumentManager.h" +#include "AbstractEngine.h" +#include "AbstractEngineChannel.h" +#include "../common/ResourceManager.h" +#include "../common/global_private.h" +#include "../drivers/audio/AudioOutputDeviceFactory.h" + +// We need to know the maximum number of sample points which are going to +// be processed for each render cycle of the audio output driver, to know +// how much initial sample points we need to cache into RAM. If the given +// sampler channel does not have an audio output device assigned yet +// though, we simply use this default value. +#define RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE 128 + +namespace LinuxSampler { + + template <class F /* Instrument File */, class I /* Instrument */, class R /* Regions */, class S /*Sample */> + class InstrumentManagerBase : public InstrumentManager, public ResourceManager<InstrumentManager::instrument_id_t, I> { + public: + struct region_info_t { + int refCount; + F* file; + void* pArg; + + region_info_t() { + refCount = 0; file = NULL; pArg = NULL; + } + }; + + typedef ResourceConsumer<I> InstrumentConsumer; + + InstrumentManagerBase() { } + virtual ~InstrumentManagerBase() { } + + virtual InstrumentEditor* LaunchInstrumentEditor(instrument_id_t ID, void* pUserData = NULL) throw (InstrumentManagerException) { + throw InstrumentManagerException( + "Instrument editing is not supported for this instrument format" + ); + } + + virtual String GetInstrumentDataStructureName(instrument_id_t ID) { + throw InstrumentManagerException("Not implemented"); + } + + virtual String GetInstrumentDataStructureVersion(instrument_id_t ID) { + throw InstrumentManagerException("Not implemented"); + } + + /** + * Give back an instrument. This should be used instead of + * HandBack if there are some regions that are still in + * use. (When an instrument is changed, the voices currently + * playing are allowed to keep playing with the old instrument + * until note off arrives. New notes will use the new instrument.) + */ + void HandBackInstrument ( + I* pResource, + InstrumentConsumer* pConsumer, + RTList<R*>* pRegionsInUse + ) { + RegionInfoMutex.Lock(); + for (typename RTList<R*>::Iterator i = pRegionsInUse->first() ; i != pRegionsInUse->end() ; i++) { + RegionInfo*i.refCount++; + SampleRefCount(*i)->pSample++; + } + this->HandBack(pResource, pConsumer, true); + RegionInfoMutex.Unlock(); + } + + /** + * Give back a region that belongs to an instrument that + * was previously handed back. + */ + virtual void HandBackRegion(R* pRegion) { + RegionInfoMutex.Lock(); + if (RegionInfo.find(pRegion) == RegionInfo.end()) { + std::cerr << "Handing back unknown region. This is a BUG!!!" << std::endl; + } + region_info_t& regInfo = RegionInfopRegion; + int regionRefCount = --regInfo.refCount; + int sampleRefCount = --SampleRefCountpRegion->pSample; + if (regionRefCount == 0) { + S* pSample = pRegion->pSample; + + DeleteRegionIfNotUsed(pRegion, ®Info); + + if (sampleRefCount == 0) { + SampleRefCount.erase(pSample); + DeleteSampleIfNotUsed(pSample, ®Info); + } + RegionInfo.erase(pRegion); + } + RegionInfoMutex.Unlock(); + } + + virtual InstrumentManager::mode_t GetMode(const InstrumentManager::instrument_id_t& ID) { + return static_cast<InstrumentManager::mode_t>(ResourceManager<instrument_id_t, I>::AvailabilityMode(ID)); + } + + virtual void SetMode(const InstrumentManager::instrument_id_t& ID, InstrumentManager::mode_t Mode) { + dmsg(2,("InstrumentManagerBase: setting mode for %s (Index=%d) to %d\n",ID.FileName.c_str(),ID.Index,Mode)); + this->SetAvailabilityMode(ID, static_cast<typename ResourceManager<instrument_id_t, I>::mode_t>(Mode)); + } + + protected: + // data stored as long as an instrument resource exists + struct instr_entry_t { + InstrumentManager::instrument_id_t ID; + F* pFile; + uint MaxSamplesPerCycle; ///< if some engine requests an already allocated instrument with a higher value, we have to reallocate the instrument + }; + + + /** + * Used by the implementing instrument manager descendents in case + * they don't have a reference to a sampler channel, which in turn + * provides a reference to an audio device which would actually + * define the maximum amount of sample points per audio render + * cycle. So in those missing cases (e.g. when MIDI instrument maps + * are created), this method will iterate through all already + * existing audio devices and return the biggest max. samples per + * cycle value of those audio devices. + * + * In case no audio device is currently created, this method will + * return a hard coded constant default value. + * + * Background: We need to know the maximum number of sample points + * which are going to be processed for each render cycle of the + * audio output driver, to know how many initial sample points we + * need to cache into RAM by the implementing instrument manager. + */ + virtual uint DefaultMaxSamplesPerCycle() { + uint samples = 0; + std::map<uint, AudioOutputDevice*> devices = AudioOutputDeviceFactory::Devices(); + for (std::map<uint, AudioOutputDevice*>::iterator iter = devices.begin(); iter != devices.end(); ++iter) { + AudioOutputDevice* pDevice = iter->second; + if (pDevice->MaxSamplesPerCycle() > samples) + samples = pDevice->MaxSamplesPerCycle(); + } + return (samples != 0) ? samples : RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE; + } + + uint GetMaxSamplesPerCycle(InstrumentConsumer* pConsumer) { + // try to resolve the audio device context + AbstractEngineChannel* pEngineChannel = dynamic_cast<AbstractEngineChannel*>(pConsumer); + AudioOutputDevice* pDevice = pEngineChannel ? pEngineChannel->GetAudioOutputDeviceSafe() : 0; + return pDevice ? pDevice->MaxSamplesPerCycle() : DefaultMaxSamplesPerCycle(); + } + + Mutex RegionInfoMutex; ///< protects the RegionInfo and SampleRefCount maps from concurrent access by the instrument loader and disk threads + std::map< R*, region_info_t> RegionInfo; ///< contains dimension regions that are still in use but belong to released instrument + std::map< S*, int> SampleRefCount; ///< contains samples that are still in use but belong to a released instrument + + virtual void DeleteRegionIfNotUsed(R* pRegion, region_info_t* pRegInfo) = 0; + virtual void DeleteSampleIfNotUsed(S* pSample, region_info_t* pRegInfo) = 0; + + void SetKeyBindings(uint8_t* bindingsArray, int low, int high, int undefined = -1) { + if (low == undefined || high == undefined) return; + if (low < 0 || low > 127 || high < 0 || high > 127 || low > high) { + std::cerr << "Invalid key range: " << low << " - " << high << std::endl; + return; + } + + for (int i = low; i <= high; i++) bindingsArrayi = 1; + } + + /** + * Caches a certain size at the beginning of the given sample in RAM. If the + * sample is very short, the whole sample will be loaded into RAM and thus + * no disk streaming is needed for this sample. Caching an initial part of + * samples is needed to compensate disk reading latency. + * + * @param pSample - points to the sample to be cached + * @param maxSamplesPerCycle - max samples per cycle + */ + void CacheInitialSamples(S* pSample, uint maxSamplesPerCycle) { + if (!pSample) { + dmsg(4,("InstrumentManagerBase: Skipping sample (pSample == NULL)\n")); + return; + } + if (!pSample->GetTotalFrameCount()) return; // skip zero size samples + + if (pSample->GetTotalFrameCount() <= CONFIG_PRELOAD_SAMPLES) { + // Sample is too short for disk streaming, so we load the whole + // sample into RAM and place 'pAudioIO->FragmentSize << CONFIG_MAX_PITCH' + // number of '0' samples (silence samples) behind the official buffer + // border, to allow the interpolator do it's work even at the end of + // the sample. + const uint neededSilenceSamples = (maxSamplesPerCycle << CONFIG_MAX_PITCH) + 3; + const uint currentlyCachedSilenceSamples = pSample->GetCache().NullExtensionSize / pSample->GetFrameSize(); + if (currentlyCachedSilenceSamples < neededSilenceSamples) { + dmsg(3,("Caching whole sample (sample name: \"%s\", sample size: %d)\n", pSample->GetName().c_str(), pSample->GetTotalFrameCount())); + typename S::buffer_t buf = pSample->LoadSampleDataWithNullSamplesExtension(neededSilenceSamples); + dmsg(4,("Cached %d Bytes, %d silence bytes.\n", buf.Size, buf.NullExtensionSize)); + } + } + else { // we only cache CONFIG_PRELOAD_SAMPLES and stream the other sample points from disk + if (!pSample->GetCache().Size) pSample->LoadSampleData(CONFIG_PRELOAD_SAMPLES); + } + + if (!pSample->GetCache().Size) std::cerr << "Unable to cache sample - maybe memory full!" << std::endl << std::flush; + } + + // implementation of derived abstract methods from 'InstrumentManager' + std::vector<instrument_id_t> Instruments() { + return ResourceManager<InstrumentManager::instrument_id_t, I>::Entries(); + } + + // implementation of derived abstract methods from 'ResourceManager' + void OnBorrow(I* pResource, InstrumentConsumer* pConsumer, void*& pArg) { + instr_entry_t* pEntry = static_cast<instr_entry_t*>(pArg); + + uint maxSamplesPerCycle = GetMaxSamplesPerCycle(pConsumer); + + if (pEntry->MaxSamplesPerCycle < maxSamplesPerCycle) { + dmsg(1,("Completely reloading instrument due to insufficient precached samples ...\n")); + this->Update(pResource, pConsumer); + } + } + }; + +} // namespace LinuxSampler + +#endif // __LS_INSTRUMENTMANAGERBASE_H__
View file
linuxsampler-1.0.0.tar.bz2/src/engines/InstrumentManagerThread.cpp -> linuxsampler-2342.tar.bz2/src/engines/InstrumentManagerThread.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -46,19 +46,17 @@ void InstrumentManagerThread::StartNewLoad(String Filename, uint uiInstrumentIndex, EngineChannel* pEngineChannel) { dmsg(1,("Scheduling '%s' (Index=%d) to be loaded in background (if not loaded yet).\n",Filename.c_str(),uiInstrumentIndex)); - static bool listenerRegistered = false; - if (!listenerRegistered) { - pEngineChannel->GetSampler()->AddChannelCountListener(&eventHandler); - listenerRegistered = true; - } - + // the listener only needs to be registered once in the + // Sampler, but as we don't know if Sampler has been + // recreated, we simply remove and add every time + pEngineChannel->GetSampler()->RemoveChannelCountListener(&eventHandler); + pEngineChannel->GetSampler()->AddChannelCountListener(&eventHandler); - // already tell the engine which instrument to load - pEngineChannel->PrepareLoadInstrument(Filename.c_str(), uiInstrumentIndex); - command_t cmd; cmd.type = command_t::DIRECT_LOAD; cmd.pEngineChannel = pEngineChannel; + cmd.instrumentId.Index = uiInstrumentIndex; + cmd.instrumentId.FileName = Filename; mutex.Lock(); queue.push_back(cmd); @@ -99,23 +97,31 @@ int InstrumentManagerThread::Main() { while (true) { - #if CONFIG_PTHREAD_TESTCANCEL - TestCancel(); - #endif + #if CONFIG_PTHREAD_TESTCANCEL + TestCancel(); + #endif - while (!queue.empty()) { + while (true) { command_t cmd; // grab a new command from the queue mutex.Lock(); - cmd = queue.front(); - queue.pop_front(); + bool empty = queue.empty(); + if (!empty) { + cmd = queue.front(); + queue.pop_front(); + + if (cmd.type == command_t::DIRECT_LOAD) { + EngineChannelFactory::SetDeleteEnabled(cmd.pEngineChannel, false); + } + } mutex.Unlock(); + if (empty) break; try { switch (cmd.type) { case command_t::DIRECT_LOAD: - EngineChannelFactory::SetDeleteEnabled(cmd.pEngineChannel, false); + cmd.pEngineChannel->PrepareLoadInstrument(cmd.instrumentId.FileName.c_str(), cmd.instrumentId.Index); cmd.pEngineChannel->LoadInstrument(); EngineChannelFactory::SetDeleteEnabled(cmd.pEngineChannel, true); break; @@ -167,4 +173,23 @@ } pThread->mutex.Unlock(); } + +#ifdef __APPLE__ + int InstrumentManagerThread::StopThread() { + // This is a fix for Mac OS X, where SignalStopThread doesn't + // wake up a thread waiting for a condition variable. + SignalStopThread(); // send stop signal, but don't wait + conditionJobsLeft.Set(true); // wake thread + return Thread::StopThread(); // then wait for it to cancel + } +#endif + +#ifdef WIN32 + int InstrumentManagerThread::StopThread() { + int res = Thread::StopThread(); + conditionJobsLeft.Reset(); + return res; + } +#endif + } // namespace LinuxSampler
View file
linuxsampler-1.0.0.tar.bz2/src/engines/InstrumentManagerThread.h -> linuxsampler-2342.tar.bz2/src/engines/InstrumentManagerThread.h
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2005, 2006 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -48,6 +48,9 @@ void StartNewLoad(String Filename, uint uiInstrumentIndex, EngineChannel* pEngineChannel); void StartSettingMode(InstrumentManager* pManager, const InstrumentManager::instrument_id_t& ID, InstrumentManager::mode_t Mode); virtual ~InstrumentManagerThread(); +#if defined(__APPLE__) || defined(WIN32) + int StopThread(); +#endif protected: struct command_t { enum cmd_type_t { @@ -56,7 +59,7 @@ } type; EngineChannel* pEngineChannel; ///< only for DIRECT_LOAD commands InstrumentManager* pManager; ///< only for INSTR_MODE commands - InstrumentManager::instrument_id_t instrumentId; ///< only for INSTR_MODE commands + InstrumentManager::instrument_id_t instrumentId; ///< for both DIRECT_LOAD and INSTR_MODE InstrumentManager::mode_t mode; ///< only for INSTR_MODE commands };
View file
linuxsampler-1.0.0.tar.bz2/src/engines/Makefile.am -> linuxsampler-2342.tar.bz2/src/engines/Makefile.am
Changed
@@ -1,7 +1,7 @@ -INCLUDES = $(all_includes) $(GIG_CFLAGS) +INCLUDES = $(all_includes) $(GIG_CFLAGS) $(LIB_SF2) AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) -DCONFIG_PLUGIN_DIR=\"$(config_plugin_dir)\" METASOURCES = AUTO -SUBDIRS = gig common +SUBDIRS = gig sf2 sfz common liblinuxsamplerengineincludedir = $(includedir)/linuxsampler/engines liblinuxsamplerengineinclude_HEADERS = \ @@ -13,9 +13,14 @@ noinst_LTLIBRARIES = liblinuxsamplerengines.la liblinuxsamplerengines_la_SOURCES = \ Engine.cpp Engine.h \ + AbstractEngine.cpp AbstractEngine.h \ + EngineBase.h \ EngineChannel.cpp EngineChannel.h \ + AbstractEngineChannel.cpp AbstractEngineChannel.h \ + EngineChannelBase.h \ EngineFactory.cpp EngineFactory.h \ EngineChannelFactory.cpp EngineChannelFactory.h \ FxSend.cpp FxSend.h \ InstrumentManager.cpp InstrumentManager.h \ + InstrumentManagerBase.h \ InstrumentManagerThread.cpp InstrumentManagerThread.h
View file
linuxsampler-2342.tar.bz2/src/engines/common/AbstractVoice.cpp
Added
@@ -0,0 +1,796 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "AbstractVoice.h" + +namespace LinuxSampler { + + AbstractVoice::AbstractVoice(SignalUnitRack* pRack): pSignalUnitRack(pRack) { + pEngineChannel = NULL; + pLFO1 = new LFOUnsigned(1.0f); // amplitude LFO (0..1 range) + pLFO2 = new LFOUnsigned(1.0f); // filter LFO (0..1 range) + pLFO3 = new LFOSigned(1200.0f); // pitch LFO (-1200..+1200 range) + PlaybackState = playback_state_end; + SynthesisMode = 0; // set all mode bits to 0 first + // select synthesis implementation (asm core is not supported ATM) + #if 0 // CONFIG_ASM && ARCH_X86 + SYNTHESIS_MODE_SET_IMPLEMENTATION(SynthesisMode, Features::supportsMMX() && Features::supportsSSE()); + #else + SYNTHESIS_MODE_SET_IMPLEMENTATION(SynthesisMode, false); + #endif + SYNTHESIS_MODE_SET_PROFILING(SynthesisMode, gig::Profiler::isEnabled()); + + finalSynthesisParameters.filterLeft.Reset(); + finalSynthesisParameters.filterRight.Reset(); + + pEq = NULL; + bEqSupport = false; + } + + AbstractVoice::~AbstractVoice() { + if (pLFO1) delete pLFO1; + if (pLFO2) delete pLFO2; + if (pLFO3) delete pLFO3; + + if(pEq != NULL) delete pEq; + } + + void AbstractVoice::CreateEq() { + if(!bEqSupport) return; + if(pEq != NULL) delete pEq; + pEq = new EqSupport; + pEq->InitEffect(GetEngine()->pAudioOutputDevice); + } + + /** + * Resets voice variables. Should only be called if rendering process is + * suspended / not running. + */ + void AbstractVoice::Reset() { + finalSynthesisParameters.filterLeft.Reset(); + finalSynthesisParameters.filterRight.Reset(); + DiskStreamRef.pStream = NULL; + DiskStreamRef.hStream = 0; + DiskStreamRef.State = Stream::state_unused; + DiskStreamRef.OrderID = 0; + PlaybackState = playback_state_end; + itTriggerEvent = Pool<Event>::Iterator(); + itKillEvent = Pool<Event>::Iterator(); + } + + /** + * Initializes and triggers the voice, a disk stream will be launched if + * needed. + * + * @param pEngineChannel - engine channel on which this voice was ordered + * @param itNoteOnEvent - event that caused triggering of this voice + * @param PitchBend - MIDI detune factor (-8192 ... +8191) + * @param pRegion- points to the region which provides sample wave(s) and articulation data + * @param VoiceType - type of this voice + * @param iKeyGroup - a value > 0 defines a key group in which this voice is member of + * @returns 0 on success, a value < 0 if the voice wasn't triggered + * (either due to an error or e.g. because no region is + * defined for the given key) + */ + int AbstractVoice::Trigger ( + AbstractEngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int PitchBend, + type_t VoiceType, + int iKeyGroup + ) { + this->pEngineChannel = pEngineChannel; + Orphan = false; + + #if CONFIG_DEVMODE + if (itNoteOnEvent->FragmentPos() > GetEngine()->MaxSamplesPerCycle) { // just a sanity check for debugging + dmsg(1,("Voice::Trigger(): ERROR, TriggerDelay > Totalsamples\n")); + } + #endif // CONFIG_DEVMODE + + Type = VoiceType; + MIDIKey = itNoteOnEvent->Param.Note.Key; + MIDIVelocity = itNoteOnEvent->Param.Note.Velocity; + MIDIPan = pEngineChannel->ControllerTable10; + if (MIDIPan == 0 && pEngineChannel->GlobalPanRight == 1) MIDIPan = 64; // workaround used to determine whether the MIDI pan has not been set + PlaybackState = playback_state_init; // mark voice as triggered, but no audio rendered yet + Delay = itNoteOnEvent->FragmentPos(); + itTriggerEvent = itNoteOnEvent; + itKillEvent = Pool<Event>::Iterator(); + MidiKeyBase* pKeyInfo = GetMidiKeyInfo(MIDIKey); + + pGroupEvents = iKeyGroup ? pEngineChannel->ActiveKeyGroupsiKeyGroup : 0; + + SmplInfo = GetSampleInfo(); + RgnInfo = GetRegionInfo(); + InstrInfo = GetInstrumentInfo(); + + AboutToTrigger(); + + // calculate volume + const double velocityAttenuation = GetVelocityAttenuation(itNoteOnEvent->Param.Note.Velocity); + float volume = CalculateVolume(velocityAttenuation) * pKeyInfo->Volume; + if (volume <= 0) return -1; + + // select channel mode (mono or stereo) + SYNTHESIS_MODE_SET_CHANNELS(SynthesisMode, SmplInfo.ChannelCount == 2); + // select bit depth (16 or 24) + SYNTHESIS_MODE_SET_BITDEPTH24(SynthesisMode, SmplInfo.BitDepth == 24); + + // get starting crossfade volume level + float crossfadeVolume = CalculateCrossfadeVolume(itNoteOnEvent->Param.Note.Velocity); + + VolumeLeft = volume * pKeyInfo->PanLeft * AbstractEngine::PanCurve64 - RgnInfo.Pan; + VolumeRight = volume * pKeyInfo->PanRight * AbstractEngine::PanCurve64 + RgnInfo.Pan; + + float subfragmentRate = GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + CrossfadeSmoother.trigger(crossfadeVolume, subfragmentRate); + VolumeSmoother.trigger(pEngineChannel->MidiVolume, subfragmentRate); + PanLeftSmoother.trigger(pEngineChannel->GlobalPanLeft, subfragmentRate); + PanRightSmoother.trigger(pEngineChannel->GlobalPanRight, subfragmentRate); + + // Check if the sample needs disk streaming or is too short for that + long cachedsamples = GetSampleCacheSize() / SmplInfo.FrameSize; + DiskVoice = cachedsamples < SmplInfo.TotalFrameCount; + + SetSampleStartOffset(); + + if (DiskVoice) { // voice to be streamed from disk + if (cachedsamples > (GetEngine()->MaxSamplesPerCycle << CONFIG_MAX_PITCH)) { + MaxRAMPos = cachedsamples - (GetEngine()->MaxSamplesPerCycle << CONFIG_MAX_PITCH) / SmplInfo.ChannelCount; //TODO: this calculation is too pessimistic and may better be moved to Render() method, so it calculates MaxRAMPos dependent to the current demand of sample points to be rendered (e.g. in case of JACK) + } else { + // The cache is too small to fit a max sample buffer. + // Setting MaxRAMPos to 0 will probably cause a click + // in the audio, but it's better than not handling + // this case at all, which would have caused the + // unsigned MaxRAMPos to be set to a negative number. + MaxRAMPos = 0; + } + + // check if there's a loop defined which completely fits into the cached (RAM) part of the sample + RAMLoop = (SmplInfo.HasLoops && (SmplInfo.LoopStart + SmplInfo.LoopLength) <= MaxRAMPos); + + if (OrderNewStream()) return -1; + dmsg(4,("Disk voice launched (cached samples: %d, total Samples: %d, MaxRAMPos: %d, RAMLooping: %s)\n", cachedsamples, SmplInfo.TotalFrameCount, MaxRAMPos, (RAMLoop) ? "yes" : "no")); + } + else { // RAM only voice + MaxRAMPos = cachedsamples; + RAMLoop = (SmplInfo.HasLoops); + dmsg(4,("RAM only voice launched (Looping: %s)\n", (RAMLoop) ? "yes" : "no")); + } + if (RAMLoop) { + loop.uiTotalCycles = SmplInfo.LoopPlayCount; + loop.uiCyclesLeft = SmplInfo.LoopPlayCount; + loop.uiStart = SmplInfo.LoopStart; + loop.uiEnd = SmplInfo.LoopStart + SmplInfo.LoopLength; + loop.uiSize = SmplInfo.LoopLength; + } + + Pitch = CalculatePitchInfo(PitchBend); + + // the length of the decay and release curves are dependent on the velocity + const double velrelease = 1 / GetVelocityRelease(itNoteOnEvent->Param.Note.Velocity); + + if (pSignalUnitRack == NULL) { // setup EG 1 (VCA EG) + // get current value of EG1 controller + double eg1controllervalue = GetEG1ControllerValue(itNoteOnEvent->Param.Note.Velocity); + + // calculate influence of EG1 controller on EG1's parameters + EGInfo egInfo = CalculateEG1ControllerInfluence(eg1controllervalue); + + TriggerEG1(egInfo, velrelease, velocityAttenuation, GetEngine()->SampleRate, itNoteOnEvent->Param.Note.Velocity); + } else { + pSignalUnitRack->Trigger(); + } + +#ifdef CONFIG_INTERPOLATE_VOLUME + // setup initial volume in synthesis parameters + #ifdef CONFIG_PROCESS_MUTED_CHANNELS + if (pEngineChannel->GetMute()) { + finalSynthesisParameters.fFinalVolumeLeft = 0; + finalSynthesisParameters.fFinalVolumeRight = 0; + } + else + #else + { + float finalVolume; + if (pSignalUnitRack == NULL) { + finalVolume = pEngineChannel->MidiVolume * crossfadeVolume * pEG1->getLevel(); + } else { + finalVolume = pEngineChannel->MidiVolume * crossfadeVolume * pSignalUnitRack->GetEndpointUnit()->GetVolume(); + } + + finalSynthesisParameters.fFinalVolumeLeft = finalVolume * VolumeLeft * pEngineChannel->GlobalPanLeft; + finalSynthesisParameters.fFinalVolumeRight = finalVolume * VolumeRight * pEngineChannel->GlobalPanRight; + } + #endif +#endif + + if (pSignalUnitRack == NULL) { + // setup EG 2 (VCF Cutoff EG) + { + // get current value of EG2 controller + double eg2controllervalue = GetEG2ControllerValue(itNoteOnEvent->Param.Note.Velocity); + + // calculate influence of EG2 controller on EG2's parameters + EGInfo egInfo = CalculateEG2ControllerInfluence(eg2controllervalue); + + TriggerEG2(egInfo, velrelease, velocityAttenuation, GetEngine()->SampleRate, itNoteOnEvent->Param.Note.Velocity); + } + + + // setup EG 3 (VCO EG) + { + // if portamento mode is on, we dedicate EG3 purely for portamento, otherwise if portamento is off we do as told by the patch + bool bPortamento = pEngineChannel->PortamentoMode && pEngineChannel->PortamentoPos >= 0.0f; + float eg3depth = (bPortamento) + ? RTMath::CentsToFreqRatio((pEngineChannel->PortamentoPos - (float) MIDIKey) * 100) + : RTMath::CentsToFreqRatio(RgnInfo.EG3Depth); + float eg3time = (bPortamento) + ? pEngineChannel->PortamentoTime + : RgnInfo.EG3Attack; + EG3.trigger(eg3depth, eg3time, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + dmsg(5,("PortamentoPos=%f, depth=%f, time=%f\n", pEngineChannel->PortamentoPos, eg3depth, eg3time)); + } + + + // setup LFO 1 (VCA LFO) + InitLFO1(); + // setup LFO 2 (VCF Cutoff LFO) + InitLFO2(); + // setup LFO 3 (VCO LFO) + InitLFO3(); + } + + + #if CONFIG_FORCE_FILTER + const bool bUseFilter = true; + #else // use filter only if instrument file told so + const bool bUseFilter = RgnInfo.VCFEnabled; + #endif // CONFIG_FORCE_FILTER + SYNTHESIS_MODE_SET_FILTER(SynthesisMode, bUseFilter); + if (bUseFilter) { + #ifdef CONFIG_OVERRIDE_CUTOFF_CTRL + VCFCutoffCtrl.controller = CONFIG_OVERRIDE_CUTOFF_CTRL; + #else // use the one defined in the instrument file + VCFCutoffCtrl.controller = GetVCFCutoffCtrl(); + #endif // CONFIG_OVERRIDE_CUTOFF_CTRL + + #ifdef CONFIG_OVERRIDE_RESONANCE_CTRL + VCFResonanceCtrl.controller = CONFIG_OVERRIDE_RESONANCE_CTRL; + #else // use the one defined in the instrument file + VCFResonanceCtrl.controller = GetVCFResonanceCtrl(); + #endif // CONFIG_OVERRIDE_RESONANCE_CTRL + + #ifndef CONFIG_OVERRIDE_FILTER_TYPE + finalSynthesisParameters.filterLeft.SetType(RgnInfo.VCFType); + finalSynthesisParameters.filterRight.SetType(RgnInfo.VCFType); + #else // override filter type + finalSynthesisParameters.filterLeft.SetType(CONFIG_OVERRIDE_FILTER_TYPE); + finalSynthesisParameters.filterRight.SetType(CONFIG_OVERRIDE_FILTER_TYPE); + #endif // CONFIG_OVERRIDE_FILTER_TYPE + + VCFCutoffCtrl.value = pEngineChannel->ControllerTableVCFCutoffCtrl.controller; + VCFResonanceCtrl.value = pEngineChannel->ControllerTableVCFResonanceCtrl.controller; + + // calculate cutoff frequency + CutoffBase = CalculateCutoffBase(itNoteOnEvent->Param.Note.Velocity); + + VCFCutoffCtrl.fvalue = CalculateFinalCutoff(CutoffBase); + + // calculate resonance + float resonance = (float) (VCFResonanceCtrl.controller ? VCFResonanceCtrl.value : RgnInfo.VCFResonance); + VCFResonanceCtrl.fvalue = resonance; + } else { + VCFCutoffCtrl.controller = 0; + VCFResonanceCtrl.controller = 0; + } + + const bool bEq = + pSignalUnitRack != NULL && pSignalUnitRack->HasEq() && pEq->HasSupport(); + + if (bEq) { + pEq->GetInChannelLeft()->Clear(); + pEq->GetInChannelRight()->Clear(); + pEq->RenderAudio(GetEngine()->pAudioOutputDevice->MaxSamplesPerCycle()); + } + + return 0; // success + } + + void AbstractVoice::SetSampleStartOffset() { + finalSynthesisParameters.dPos = RgnInfo.SampleStartOffset; // offset where we should start playback of sample (0 - 2000 sample points) + Pos = RgnInfo.SampleStartOffset; + } + + /** + * Synthesizes the current audio fragment for this voice. + * + * @param Samples - number of sample points to be rendered in this audio + * fragment cycle + * @param pSrc - pointer to input sample data + * @param Skip - number of sample points to skip in output buffer + */ + void AbstractVoice::Synthesize(uint Samples, sample_t* pSrc, uint Skip) { + bool delay = false; // Whether the voice playback should be delayed for this call + + if (pSignalUnitRack != NULL) { + uint delaySteps = pSignalUnitRack->GetEndpointUnit()->DelayTrigger(); + if (delaySteps > 0) { // delay on the endpoint unit means delay of the voice playback + if (delaySteps >= Samples) { + pSignalUnitRack->GetEndpointUnit()->DecreaseDelay(Samples); + delay = true; + } else { + pSignalUnitRack->GetEndpointUnit()->DecreaseDelay(delaySteps); + Samples -= delaySteps; + Skip += delaySteps; + } + } + } + + AbstractEngineChannel* pChannel = pEngineChannel; + MidiKeyBase* pMidiKeyInfo = GetMidiKeyInfo(MIDIKey); + + const bool bVoiceRequiresDedicatedRouting = + pEngineChannel->GetFxSendCount() > 0 && + (pMidiKeyInfo->ReverbSend || pMidiKeyInfo->ChorusSend); + + const bool bEq = + pSignalUnitRack != NULL && pSignalUnitRack->HasEq() && pEq->HasSupport(); + + if (bEq) { + pEq->GetInChannelLeft()->Clear(); + pEq->GetInChannelRight()->Clear(); + finalSynthesisParameters.pOutLeft = &pEq->GetInChannelLeft()->Buffer()Skip; + finalSynthesisParameters.pOutRight = &pEq->GetInChannelRight()->Buffer()Skip; + pSignalUnitRack->UpdateEqSettings(pEq); + } else if (bVoiceRequiresDedicatedRouting) { + finalSynthesisParameters.pOutLeft = &GetEngine()->pDedicatedVoiceChannelLeft->Buffer()Skip; + finalSynthesisParameters.pOutRight = &GetEngine()->pDedicatedVoiceChannelRight->Buffer()Skip; + } else { + finalSynthesisParameters.pOutLeft = &pChannel->pChannelLeft->Buffer()Skip; + finalSynthesisParameters.pOutRight = &pChannel->pChannelRight->Buffer()Skip; + } + finalSynthesisParameters.pSrc = pSrc; + + RTList<Event>::Iterator itCCEvent = pChannel->pEvents->first(); + RTList<Event>::Iterator itNoteEvent; + GetFirstEventOnKey(MIDIKey, itNoteEvent); + + RTList<Event>::Iterator itGroupEvent; + if (pGroupEvents) itGroupEvent = pGroupEvents->first(); + + if (itTriggerEvent) { // skip events that happened before this voice was triggered + while (itCCEvent && itCCEvent->FragmentPos() <= Skip) ++itCCEvent; + while (itGroupEvent && itGroupEvent->FragmentPos() <= Skip) ++itGroupEvent; + + // we can't simply compare the timestamp here, because note events + // might happen on the same time stamp, so we have to deal on the + // actual sequence the note events arrived instead (see bug #112) + for (; itNoteEvent; ++itNoteEvent) { + if (itTriggerEvent == itNoteEvent) { + ++itNoteEvent; + break; + } + } + } + + uint killPos; + if (itKillEvent) { + int maxFadeOutPos = Samples - GetEngine()->GetMinFadeOutSamples(); + if (maxFadeOutPos < 0) { + // There's not enough space in buffer to do a fade out + // from max volume (this can only happen for audio + // drivers that use Samples < MaxSamplesPerCycle). + // End the EG1 here, at pos 0, with a shorter max fade + // out time. + if (pSignalUnitRack == NULL) { + pEG1->enterFadeOutStage(Samples / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } else { + pSignalUnitRack->EnterFadeOutStage(Samples / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + itKillEvent = Pool<Event>::Iterator(); + } else { + killPos = RTMath::Min(itKillEvent->FragmentPos(), maxFadeOutPos); + } + } + + uint i = Skip; + while (i < Samples) { + int iSubFragmentEnd = RTMath::Min(i + CONFIG_DEFAULT_SUBFRAGMENT_SIZE, Samples); + + // initialize all final synthesis parameters + fFinalCutoff = VCFCutoffCtrl.fvalue; + fFinalResonance = VCFResonanceCtrl.fvalue; + + // process MIDI control change and pitchbend events for this subfragment + processCCEvents(itCCEvent, iSubFragmentEnd); + uint8_t pan = MIDIPan; + if (pSignalUnitRack != NULL) pan = pSignalUnitRack->GetEndpointUnit()->CaluclatePan(pan); + + PanLeftSmoother.update(AbstractEngine::PanCurve128 - pan); + PanRightSmoother.update(AbstractEngine::PanCurvepan); + + finalSynthesisParameters.fFinalPitch = Pitch.PitchBase * Pitch.PitchBend; + float fFinalVolume = VolumeSmoother.render() * CrossfadeSmoother.render(); +#ifdef CONFIG_PROCESS_MUTED_CHANNELS + if (pChannel->GetMute()) fFinalVolume = 0; +#endif + + // process transition events (note on, note off & sustain pedal) + processTransitionEvents(itNoteEvent, iSubFragmentEnd); + processGroupEvents(itGroupEvent, iSubFragmentEnd); + + if (pSignalUnitRack == NULL) { + // if the voice was killed in this subfragment, or if the + // filter EG is finished, switch EG1 to fade out stage + if ((itKillEvent && killPos <= iSubFragmentEnd) || + (SYNTHESIS_MODE_GET_FILTER(SynthesisMode) && + pEG2->getSegmentType() == EG::segment_end)) { + pEG1->enterFadeOutStage(); + itKillEvent = Pool<Event>::Iterator(); + } + + // process envelope generators + switch (pEG1->getSegmentType()) { + case EG::segment_lin: + fFinalVolume *= pEG1->processLin(); + break; + case EG::segment_exp: + fFinalVolume *= pEG1->processExp(); + break; + case EG::segment_end: + fFinalVolume *= pEG1->getLevel(); + break; // noop + case EG::segment_pow: + fFinalVolume *= pEG1->processPow(); + break; + } + switch (pEG2->getSegmentType()) { + case EG::segment_lin: + fFinalCutoff *= pEG2->processLin(); + break; + case EG::segment_exp: + fFinalCutoff *= pEG2->processExp(); + break; + case EG::segment_end: + fFinalCutoff *= pEG2->getLevel(); + break; // noop + case EG::segment_pow: + fFinalCutoff *= pEG2->processPow(); + break; + } + if (EG3.active()) finalSynthesisParameters.fFinalPitch *= EG3.render(); + + // process low frequency oscillators + if (bLFO1Enabled) fFinalVolume *= (1.0f - pLFO1->render()); + if (bLFO2Enabled) fFinalCutoff *= pLFO2->render(); + if (bLFO3Enabled) finalSynthesisParameters.fFinalPitch *= RTMath::CentsToFreqRatio(pLFO3->render()); + } else { + // if the voice was killed in this subfragment, enter fade out stage + if (itKillEvent && killPos <= iSubFragmentEnd) { + pSignalUnitRack->EnterFadeOutStage(); + itKillEvent = Pool<Event>::Iterator(); + } + + // if the filter EG is finished, switch EG1 to fade out stage + /*if (SYNTHESIS_MODE_GET_FILTER(SynthesisMode) && + pEG2->getSegmentType() == EG::segment_end) { + pEG1->enterFadeOutStage(); + itKillEvent = Pool<Event>::Iterator(); + }*/ + // TODO: ^^^ + + fFinalVolume *= pSignalUnitRack->GetEndpointUnit()->GetVolume(); + fFinalCutoff = pSignalUnitRack->GetEndpointUnit()->CalculateFilterCutoff(fFinalCutoff); + fFinalResonance = pSignalUnitRack->GetEndpointUnit()->CalculateResonance(fFinalResonance); + + finalSynthesisParameters.fFinalPitch = + pSignalUnitRack->GetEndpointUnit()->CalculatePitch(finalSynthesisParameters.fFinalPitch); + + } + + // limit the pitch so we don't read outside the buffer + finalSynthesisParameters.fFinalPitch = RTMath::Min(finalSynthesisParameters.fFinalPitch, float(1 << CONFIG_MAX_PITCH)); + + // if filter enabled then update filter coefficients + if (SYNTHESIS_MODE_GET_FILTER(SynthesisMode)) { + finalSynthesisParameters.filterLeft.SetParameters(fFinalCutoff, fFinalResonance, GetEngine()->SampleRate); + finalSynthesisParameters.filterRight.SetParameters(fFinalCutoff, fFinalResonance, GetEngine()->SampleRate); + } + + // do we need resampling? + const float __PLUS_ONE_CENT = 1.000577789506554859250142541782224725466f; + const float __MINUS_ONE_CENT = 0.9994225441413807496009516495583113737666f; + const bool bResamplingRequired = !(finalSynthesisParameters.fFinalPitch <= __PLUS_ONE_CENT && + finalSynthesisParameters.fFinalPitch >= __MINUS_ONE_CENT); + SYNTHESIS_MODE_SET_INTERPOLATE(SynthesisMode, bResamplingRequired); + + // prepare final synthesis parameters structure + finalSynthesisParameters.uiToGo = iSubFragmentEnd - i; +#ifdef CONFIG_INTERPOLATE_VOLUME + finalSynthesisParameters.fFinalVolumeDeltaLeft = + (fFinalVolume * VolumeLeft * PanLeftSmoother.render() - + finalSynthesisParameters.fFinalVolumeLeft) / finalSynthesisParameters.uiToGo; + finalSynthesisParameters.fFinalVolumeDeltaRight = + (fFinalVolume * VolumeRight * PanRightSmoother.render() - + finalSynthesisParameters.fFinalVolumeRight) / finalSynthesisParameters.uiToGo; +#else + finalSynthesisParameters.fFinalVolumeLeft = + fFinalVolume * VolumeLeft * PanLeftSmoother.render(); + finalSynthesisParameters.fFinalVolumeRight = + fFinalVolume * VolumeRight * PanRightSmoother.render(); +#endif + // render audio for one subfragment + if (!delay) RunSynthesisFunction(SynthesisMode, &finalSynthesisParameters, &loop); + + if (pSignalUnitRack == NULL) { + // stop the rendering if volume EG is finished + if (pEG1->getSegmentType() == EG::segment_end) break; + } else { + // stop the rendering if the endpoint unit is not active + if (!pSignalUnitRack->GetEndpointUnit()->Active()) break; + } + + const double newPos = Pos + (iSubFragmentEnd - i) * finalSynthesisParameters.fFinalPitch; + + if (pSignalUnitRack == NULL) { + // increment envelopes' positions + if (pEG1->active()) { + + // if sample has a loop and loop start has been reached in this subfragment, send a special event to EG1 to let it finish the attack hold stage + if (SmplInfo.HasLoops && Pos <= SmplInfo.LoopStart && SmplInfo.LoopStart < newPos) { + pEG1->update(EG::event_hold_end, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + + pEG1->increment(1); + if (!pEG1->toStageEndLeft()) pEG1->update(EG::event_stage_end, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + if (pEG2->active()) { + pEG2->increment(1); + if (!pEG2->toStageEndLeft()) pEG2->update(EG::event_stage_end, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + EG3.increment(1); + if (!EG3.toEndLeft()) EG3.update(); // neutralize envelope coefficient if end reached + } else { + // if sample has a loop and loop start has been reached in this subfragment, send a special event to EG1 to let it finish the attack hold stage + /*if (SmplInfo.HasLoops && Pos <= SmplInfo.LoopStart && SmplInfo.LoopStart < newPos) { + pEG1->update(EG::event_hold_end, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + }*/ + // TODO: ^^^ + + if (!delay) pSignalUnitRack->Increment(); + } + + Pos = newPos; + i = iSubFragmentEnd; + } + + if (delay) return; + + if (bVoiceRequiresDedicatedRouting) { + if (bEq) { + pEq->RenderAudio(Samples); + pEq->GetOutChannelLeft()->CopyTo(GetEngine()->pDedicatedVoiceChannelLeft, Samples); + pEq->GetOutChannelRight()->CopyTo(GetEngine()->pDedicatedVoiceChannelRight, Samples); + } + optional<float> effectSendLevels2 = { + pMidiKeyInfo->ReverbSend, + pMidiKeyInfo->ChorusSend + }; + GetEngine()->RouteDedicatedVoiceChannels(pEngineChannel, effectSendLevels, Samples); + } else if (bEq) { + pEq->RenderAudio(Samples); + pEq->GetOutChannelLeft()->MixTo(pChannel->pChannelLeft, Samples); + pEq->GetOutChannelRight()->MixTo(pChannel->pChannelRight, Samples); + } + } + + /** + * Process given list of MIDI control change and pitch bend events for + * the given time. + * + * @param itEvent - iterator pointing to the next event to be processed + * @param End - youngest time stamp where processing should be stopped + */ + void AbstractVoice::processCCEvents(RTList<Event>::Iterator& itEvent, uint End) { + for (; itEvent && itEvent->FragmentPos() <= End; ++itEvent) { + if (itEvent->Type == Event::type_control_change && itEvent->Param.CC.Controller) { // if (valid) MIDI control change event + if (itEvent->Param.CC.Controller == VCFCutoffCtrl.controller) { + ProcessCutoffEvent(itEvent); + } + if (itEvent->Param.CC.Controller == VCFResonanceCtrl.controller) { + processResonanceEvent(itEvent); + } + if (pSignalUnitRack == NULL) { + if (itEvent->Param.CC.Controller == pLFO1->ExtController) { + pLFO1->update(itEvent->Param.CC.Value); + } + if (itEvent->Param.CC.Controller == pLFO2->ExtController) { + pLFO2->update(itEvent->Param.CC.Value); + } + if (itEvent->Param.CC.Controller == pLFO3->ExtController) { + pLFO3->update(itEvent->Param.CC.Value); + } + } + if (itEvent->Param.CC.Controller == 7) { // volume + VolumeSmoother.update(AbstractEngine::VolumeCurveitEvent->Param.CC.Value); + } else if (itEvent->Param.CC.Controller == 10) { // panpot + MIDIPan = itEvent->Param.CC.Value; + } + } else if (itEvent->Type == Event::type_pitchbend) { // if pitch bend event + processPitchEvent(itEvent); + } + + ProcessCCEvent(itEvent); + if (pSignalUnitRack != NULL) { + pSignalUnitRack->ProcessCCEvent(itEvent); + } + } + } + + void AbstractVoice::processPitchEvent(RTList<Event>::Iterator& itEvent) { + Pitch.PitchBend = RTMath::CentsToFreqRatio(itEvent->Param.Pitch.Pitch * Pitch.PitchBendRange); + } + + void AbstractVoice::processResonanceEvent(RTList<Event>::Iterator& itEvent) { + // convert absolute controller value to differential + const int ctrldelta = itEvent->Param.CC.Value - VCFResonanceCtrl.value; + VCFResonanceCtrl.value = itEvent->Param.CC.Value; + const float resonancedelta = (float) ctrldelta; + fFinalResonance += resonancedelta; + // needed for initialization of parameter + VCFResonanceCtrl.fvalue = itEvent->Param.CC.Value; + } + + /** + * Process given list of MIDI note on, note off and sustain pedal events + * for the given time. + * + * @param itEvent - iterator pointing to the next event to be processed + * @param End - youngest time stamp where processing should be stopped + */ + void AbstractVoice::processTransitionEvents(RTList<Event>::Iterator& itEvent, uint End) { + for (; itEvent && itEvent->FragmentPos() <= End; ++itEvent) { + // some voice types ignore note off + if (!(Type & (Voice::type_one_shot | Voice::type_release_trigger | Voice::type_controller_triggered))) { + if (itEvent->Type == Event::type_release) { + EnterReleaseStage(); + } else if (itEvent->Type == Event::type_cancel_release) { + if (pSignalUnitRack == NULL) { + pEG1->update(EG::event_cancel_release, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + pEG2->update(EG::event_cancel_release, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } else { + pSignalUnitRack->CancelRelease(); + } + } + } + } + } + + /** + * Process given list of events aimed at all voices in a key group. + * + * @param itEvent - iterator pointing to the next event to be processed + * @param End - youngest time stamp where processing should be stopped + */ + void AbstractVoice::processGroupEvents(RTList<Event>::Iterator& itEvent, uint End) { + for (; itEvent && itEvent->FragmentPos() <= End; ++itEvent) { + ProcessGroupEvent(itEvent); + } + } + + /** @brief Update current portamento position. + * + * Will be called when portamento mode is enabled to get the final + * portamento position of this active voice from where the next voice(s) + * might continue to slide on. + * + * @param itNoteOffEvent - event which causes this voice to die soon + */ + void AbstractVoice::UpdatePortamentoPos(Pool<Event>::Iterator& itNoteOffEvent) { + if (pSignalUnitRack == NULL) { + const float fFinalEG3Level = EG3.level(itNoteOffEvent->FragmentPos()); + pEngineChannel->PortamentoPos = (float) MIDIKey + RTMath::FreqRatioToCents(fFinalEG3Level) * 0.01f; + } else { + // TODO: + } + } + + /** + * Kill the voice in regular sense. Let the voice render audio until + * the kill event actually occured and then fade down the volume level + * very quickly and let the voice die finally. Unlike a normal release + * of a voice, a kill process cannot be cancalled and is therefore + * usually used for voice stealing and key group conflicts. + * + * @param itKillEvent - event which caused the voice to be killed + */ + void AbstractVoice::Kill(Pool<Event>::Iterator& itKillEvent) { + #if CONFIG_DEVMODE + if (!itKillEvent) dmsg(1,("AbstractVoice::Kill(): ERROR, !itKillEvent !!!\n")); + if (itKillEvent && !itKillEvent.isValid()) dmsg(1,("AbstractVoice::Kill(): ERROR, itKillEvent invalid !!!\n")); + #endif // CONFIG_DEVMODE + + if (itTriggerEvent && itKillEvent->FragmentPos() <= itTriggerEvent->FragmentPos()) return; + this->itKillEvent = itKillEvent; + } + + Voice::PitchInfo AbstractVoice::CalculatePitchInfo(int PitchBend) { + PitchInfo pitch; + double pitchbasecents = InstrInfo.FineTune + RgnInfo.FineTune + GetEngine()->ScaleTuningMIDIKey % 12; + + // GSt behaviour: maximum transpose up is 40 semitones. If + // MIDI key is more than 40 semitones above unity note, + // the transpose is not done. + if (!SmplInfo.Unpitched && (MIDIKey - (int) RgnInfo.UnityNote) < 40) pitchbasecents += (MIDIKey - (int) RgnInfo.UnityNote) * 100; + + pitch.PitchBase = RTMath::CentsToFreqRatioUnlimited(pitchbasecents) * (double(SmplInfo.SampleRate) / double(GetEngine()->SampleRate)); + pitch.PitchBendRange = 1.0 / 8192.0 * 100.0 * InstrInfo.PitchbendRange; + pitch.PitchBend = RTMath::CentsToFreqRatio(PitchBend * pitch.PitchBendRange); + + return pitch; + } + + double AbstractVoice::CalculateVolume(double velocityAttenuation) { + // For 16 bit samples, we downscale by 32768 to convert from + // int16 value range to DSP value range (which is + // -1.0..1.0). For 24 bit, we downscale from int32. + float volume = velocityAttenuation / (SmplInfo.BitDepth == 16 ? 32768.0f : 32768.0f * 65536.0f); + + volume *= GetSampleAttenuation() * pEngineChannel->GlobalVolume * GLOBAL_VOLUME; + + // the volume of release triggered samples depends on note length + if (Type & Voice::type_release_trigger) { + float noteLength = float(GetEngine()->FrameTime + Delay - + GetNoteOnTime(MIDIKey) ) / GetEngine()->SampleRate; + + volume *= GetReleaseTriggerAttenuation(noteLength); + } + + return volume; + } + + float AbstractVoice::GetReleaseTriggerAttenuation(float noteLength) { + return 1 - RgnInfo.ReleaseTriggerDecay * noteLength; + } + + void AbstractVoice::EnterReleaseStage() { + if (pSignalUnitRack == NULL) { + pEG1->update(EG::event_release, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + pEG2->update(EG::event_release, GetEngine()->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } else { + pSignalUnitRack->EnterReleaseStage(); + } + } + + bool AbstractVoice::EG1Finished() { + if (pSignalUnitRack == NULL) { + return pEG1->getSegmentType() == EG::segment_end; + } else { + return !pSignalUnitRack->GetEndpointUnit()->Active(); + } + } + +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/common/AbstractVoice.h
Added
@@ -0,0 +1,306 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2011 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_ABSTRACTVOICE_H__ +#define __LS_ABSTRACTVOICE_H__ + +#include "Voice.h" + +#include "../../common/global_private.h" +#include "../AbstractEngineChannel.h" +#include "../common/LFOBase.h" +#include "../EngineBase.h" +#include "EG.h" +#include "../gig/EGADSR.h" +#include "../gig/EGDecay.h" +#include "../gig/SmoothVolume.h" +#include "../gig/Synthesizer.h" +#include "../gig/Profiler.h" +#include "SignalUnitRack.h" + +// include the appropriate (unsigned) triangle LFO implementation +#if CONFIG_UNSIGNED_TRIANG_ALGO == INT_MATH_SOLUTION +# include "../common/LFOTriangleIntMath.h" +#elif CONFIG_UNSIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION +# include "../common/LFOTriangleIntAbsMath.h" +#elif CONFIG_UNSIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION +# include "../common/LFOTriangleDiHarmonic.h" +#else +# error "Unknown or no (unsigned) triangle LFO implementation selected!" +#endif + +// include the appropriate (signed) triangle LFO implementation +#if CONFIG_SIGNED_TRIANG_ALGO == INT_MATH_SOLUTION +# include "../common/LFOTriangleIntMath.h" +#elif CONFIG_SIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION +# include "../common/LFOTriangleIntAbsMath.h" +#elif CONFIG_SIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION +# include "../common/LFOTriangleDiHarmonic.h" +#else +# error "Unknown or no (signed) triangle LFO implementation selected!" +#endif + +namespace LinuxSampler { + + #if CONFIG_UNSIGNED_TRIANG_ALGO == INT_MATH_SOLUTION + typedef LFOTriangleIntMath<range_unsigned> LFOUnsigned; + #elif CONFIG_UNSIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION + typedef LFOTriangleIntAbsMath<range_unsigned> LFOUnsigned; + #elif CONFIG_UNSIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION + typedef LFOTriangleDiHarmonic<range_unsigned> LFOUnsigned; + #endif + + #if CONFIG_SIGNED_TRIANG_ALGO == INT_MATH_SOLUTION + typedef LFOTriangleIntMath<range_signed> LFOSigned; + #elif CONFIG_SIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION + typedef LFOTriangleIntAbsMath<range_signed> LFOSigned; + #elif CONFIG_SIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION + typedef LFOTriangleDiHarmonic<range_signed> LFOSigned; + #endif + + class AbstractVoice : public Voice { + public: + type_t Type; ///< Voice Type (bit field, a voice may have several types) + int MIDIKey; ///< MIDI key number of the key that triggered the voice + uint8_t MIDIVelocity; ///< MIDI velocity of the key that triggered the voice + uint8_t MIDIPan; ///< the current MIDI pan value + + SignalUnitRack* const pSignalUnitRack; + + AbstractVoice(SignalUnitRack* pRack); + virtual ~AbstractVoice(); + + inline bool IsActive() { return PlaybackState; } + inline bool IsStealable() { return !itKillEvent && PlaybackState >= playback_state_ram; } + + virtual void Reset(); + + virtual int Trigger ( + AbstractEngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int PitchBend, + type_t VoiceType, + int iKeyGroup + ); + + /** Invoked when the voice is freed - gone from active to inactive. */ + virtual void VoiceFreed() { } + + virtual void Synthesize(uint Samples, sample_t* pSrc, uint Skip); + + uint GetSampleRate() { return GetEngine()->SampleRate; } + + uint8_t GetControllerValue(uint8_t Controller) { + return (Controller > 128) ? 0 : pEngineChannel->ControllerTableController; + } + + void processCCEvents(RTList<Event>::Iterator& itEvent, uint End); + void processPitchEvent(RTList<Event>::Iterator& itEvent); + void processResonanceEvent(RTList<Event>::Iterator& itEvent); + void processTransitionEvents(RTList<Event>::Iterator& itEvent, uint End); + void processGroupEvents(RTList<Event>::Iterator& itEvent, uint End); + void UpdatePortamentoPos(Pool<Event>::Iterator& itNoteOffEvent); + void Kill(Pool<Event>::Iterator& itKillEvent); + void CreateEq(); + + bool Orphan; ///< true if this voice is playing a sample from an instrument that is unloaded. When the voice dies, the sample (and dimension region) will be handed back to the instrument resource manager. + playback_state_t PlaybackState; ///< When a sample will be triggered, it will be first played from RAM cache and after a couple of sample points it will switch to disk streaming and at the end of a disk stream we have to add null samples, so the interpolator can do it's work correctly + Stream::reference_t DiskStreamRef; ///< Reference / link to the disk stream + + template<class TV, class TRR, class TR, class TD, class TIM, class TI> friend class EngineBase; + + protected: + SampleInfo SmplInfo; + RegionInfo RgnInfo; + InstrumentInfo InstrInfo; + AbstractEngineChannel* pEngineChannel; + + double Pos; ///< Current playback position in sample + PitchInfo Pitch; + float CutoffBase; ///< Cutoff frequency before control change, EG and LFO are applied + float VolumeLeft; ///< Left channel volume. This factor is calculated when the voice is triggered and doesn't change after that. + float VolumeRight; ///< Right channel volume. This factor is calculated when the voice is triggered and doesn't change after that. + gig::SmoothVolume CrossfadeSmoother; ///< Crossfade volume, updated by crossfade CC events + gig::SmoothVolume VolumeSmoother; ///< Volume, updated by CC 7 (volume) events + gig::SmoothVolume PanLeftSmoother; ///< Left channel volume, updated by CC 10 (pan) events + gig::SmoothVolume PanRightSmoother; ///< Right channel volume, updated by CC 10 (pan) events + bool DiskVoice; ///< If the sample is very short it completely fits into the RAM cache and doesn't need to be streamed from disk, in that case this flag is set to false + bool RAMLoop; ///< If this voice has a loop defined which completely fits into the cached RAM part of the sample, in this case we handle the looping within the voice class, else if the loop is located in the disk stream part, we let the disk stream handle the looping + unsigned long MaxRAMPos; ///< The upper allowed limit (not actually the end) in the RAM sample cache, after that point it's not safe to chase the interpolator another time over over the current cache position, instead we switch to disk then. + uint Delay; ///< Number of sample points the rendering process of this voice should be delayed (jitter correction), will be set to 0 after the first audio fragment cycle + EG* pEG1; ///< Envelope Generator 1 (Amplification) + EG* pEG2; ///< Envelope Generator 2 (Filter cutoff frequency) + gig::EGDecay EG3; ///< Envelope Generator 3 (Pitch) TODO: use common EG instead? + midi_ctrl VCFCutoffCtrl; + midi_ctrl VCFResonanceCtrl; + LFOUnsigned* pLFO1; ///< Low Frequency Oscillator 1 (Amplification) + LFOUnsigned* pLFO2; ///< Low Frequency Oscillator 2 (Filter cutoff frequency) + LFOSigned* pLFO3; ///< Low Frequency Oscillator 3 (Pitch) + bool bLFO1Enabled; ///< Should we use the Amplitude LFO for this voice? + bool bLFO2Enabled; ///< Should we use the Filter Cutoff LFO for this voice? + bool bLFO3Enabled; ///< Should we use the Pitch LFO for this voice? + Pool<Event>::Iterator itTriggerEvent; ///< First event on the key's list the voice should process (only needed for the first audio fragment in which voice was triggered, after that it will be set to NULL). + Pool<Event>::Iterator itKillEvent; ///< Event which caused this voice to be killed + int SynthesisMode; + float fFinalCutoff; + float fFinalResonance; + gig::SynthesisParam finalSynthesisParameters; + gig::Loop loop; + RTList<Event>* pGroupEvents; ///< Events directed to an exclusive group + + EqSupport* pEq; ///< Used for per voice equalization + bool bEqSupport; + + void PrintEqInfo() { + if (!bEqSupport || pEq == NULL) { + dmsg(1,("EQ support: no\n")); + } else { + pEq->PrintInfo(); + } + } + + virtual AbstractEngine* GetEngine() = 0; + virtual SampleInfo GetSampleInfo() = 0; + virtual RegionInfo GetRegionInfo() = 0; + virtual InstrumentInfo GetInstrumentInfo() = 0; + + /** + * Most of the important members of the voice are set when the voice + * is triggered (like pEngineChannel, pRegion, pSample, etc). + * This method is called after these members are set and before + * the voice is actually triggered. + * Override this method if you need to do some additional + * initialization which depends on these members before the voice + * is triggered. + */ + virtual void AboutToTrigger() { } + + virtual bool EG1Finished(); + + /** + * Gets the sample cache size in bytes. + */ + virtual unsigned long GetSampleCacheSize() = 0; + + /** + * Because in most cases we cache part of the sample in RAM, if the + * offset is too big (will extend beyond the RAM cache if the cache contains + * the beginning of the sample) we should cache in the RAM buffer not the + * beginning of the sample but a part that starts from the sample offset point. + * In that case the current sample position should start from zero (Pos). + * When the offset fits into RAM buffer or the whole sample is cached + * in RAM, Pos should contain the actual offset. + * We don't trim the sample because it might have a defined + * loop start point before the start point of the playback. + */ + virtual void SetSampleStartOffset(); + + /** + * Returns the correct amplitude factor for the given \a MIDIKeyVelocity. + * All involved parameters (VelocityResponseCurve, VelocityResponseDepth + * and VelocityResponseCurveScaling) involved are taken into account to + * calculate the amplitude factor. Use this method when a key was + * triggered to get the volume with which the sample should be played + * back. + * + * @param MIDIKeyVelocity MIDI velocity value of the triggered key (between 0 and 127) + * @returns amplitude factor (between 0.0 and 1.0) + */ + virtual double GetVelocityAttenuation(uint8_t MIDIKeyVelocity) = 0; + + virtual double GetSampleAttenuation() = 0; + + virtual double CalculateVolume(double velocityAttenuation); + + virtual float GetReleaseTriggerAttenuation(float noteLength); + + /** + * Get starting crossfade volume level + */ + virtual double CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity) = 0; + + virtual MidiKeyBase* GetMidiKeyInfo(int MIDIKey) = 0; + + virtual int OrderNewStream() = 0; + + virtual PitchInfo CalculatePitchInfo(int PitchBend); + + // TODO: cleanup the interface. The following two methods + // are maybe not neccessary after the TriggerEG1 method + // was added. + + /** + * Get current value of EG1 controller. + */ + virtual double GetEG1ControllerValue(uint8_t MIDIKeyVelocity) = 0; + + /** + * Calculate influence of EG1 controller on EG1's parameters. + */ + virtual EGInfo CalculateEG1ControllerInfluence(double eg1ControllerValue) = 0; + + // TODO: cleanup the interface. The velrelase and + // velocityAttenuation parameters are perhaps too gig + // specific. + /** + * Trigger the amplitude envelope generator. + */ + virtual void TriggerEG1(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) = 0; + + /** + * Get current value of EG2 controller. + */ + virtual double GetEG2ControllerValue(uint8_t MIDIKeyVelocity) = 0; + + /** + * Calculate influence of EG2 controller on EG2's parameters. + */ + virtual EGInfo CalculateEG2ControllerInfluence(double eg2ControllerValue) = 0; + + virtual void TriggerEG2(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) = 0; + + virtual float CalculateCutoffBase(uint8_t MIDIKeyVelocity) = 0; + virtual float CalculateFinalCutoff(float cutoffBase) = 0; + + virtual void InitLFO1() = 0; + virtual void InitLFO2() = 0; + virtual void InitLFO3() = 0; + + virtual uint8_t GetVCFCutoffCtrl() = 0; + virtual uint8_t GetVCFResonanceCtrl() = 0; + virtual uint8_t CrossfadeAttenuation(uint8_t& CrossfadeControllerValue) = 0; + + virtual void GetFirstEventOnKey(uint8_t MIDIKey, RTList<Event>::Iterator& itEvent) = 0; + virtual void ProcessCCEvent(RTList<Event>::Iterator& itEvent) = 0; + virtual void ProcessCutoffEvent(RTList<Event>::Iterator& itEvent) = 0; + virtual double GetVelocityRelease(uint8_t MIDIKeyVelocity) = 0; + + virtual unsigned long GetNoteOnTime(int MIDIKey) = 0; + + virtual void ProcessGroupEvent(RTList<Event>::Iterator& itEvent) = 0; + void EnterReleaseStage(); + }; +} // namespace LinuxSampler + +#endif /* __LS_ABSTRACTVOICE_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/common/DiskThreadBase.cpp
Added
@@ -0,0 +1,44 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <sstream> + +#include "DiskThreadBase.h" + +namespace LinuxSampler { + // *********** C functions ************** + // * + + /** + * This is the comparison function the qsort algo uses to determine if a value is + * bigger than another one or special in our case; if the writespace of a stream + * is bigger than another one. + */ + int CompareStreamWriteSpace(const void* A, const void* B) { + Stream* a = *(Stream**) A; + Stream* b = *(Stream**) B; + return b->GetWriteSpace() - a->GetWriteSpace(); + } +} // namespace LinuxSampler +
View file
linuxsampler-2342.tar.bz2/src/engines/common/DiskThreadBase.h
Added
@@ -0,0 +1,549 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2011 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_DISKTHREADBASE_H__ +#define __LS_DISKTHREADBASE_H__ + +#include "StreamBase.h" +#include "../EngineChannel.h" +#include "../InstrumentManagerBase.h" + +#include "../../common/global_private.h" + +#include "../../common/Thread.h" +#include "../../common/RingBuffer.h" +#include "../../common/atomic.h" + +namespace LinuxSampler { + + int CompareStreamWriteSpace(const void* A, const void* B); + + /** @brief Disk Reader Thread + * + * The disk reader thread is responsible for periodically refilling + * disk streams in parallel to the audio thread's rendering process. + * + * There is also a function for releasing parts of instruments not + * in use anymore (as this is not real time safe, the audio thread + * cannot do it directly). + */ + template <class R /* Resource */, class IM /* Instrument Manager */> + class DiskThreadBase : public Thread { + private: + // Private Types + struct create_command_t { + Stream::OrderID_t OrderID; + Stream::Handle hStream; + Stream::reference_t* pStreamRef; + R* pRegion; + unsigned long SampleOffset; + bool DoLoop; + }; + struct delete_command_t { + Stream* pStream; + Stream::Handle hStream; + Stream::OrderID_t OrderID; + bool bNotify; + }; + struct program_change_command_t { + uint32_t Program; + EngineChannel* pEngineChannel; + }; + // Attributes + bool IsIdle; + uint Streams; + RingBuffer<create_command_t,false>* CreationQueue; ///< Contains commands to create streams + RingBuffer<delete_command_t,false>* DeletionQueue; ///< Contains commands to delete streams + RingBuffer<delete_command_t,false>* GhostQueue; ///< Contains handles to streams that are not used anymore and weren't deletable immediately + RingBuffer<Stream::Handle,false> DeletionNotificationQueue; ///< In case the original sender requested a notification for its stream deletion order, this queue will receive the handle of the respective stream once actually be deleted by the disk thread. + RingBuffer<R*,false>* DeleteRegionQueue; ///< Contains dimension regions that are not used anymore and should be handed back to the instrument resource manager + RingBuffer<program_change_command_t,false> ProgramChangeQueue; ///< Contains requests for MIDI program change + unsigned int RefillStreamsPerRun; ///< How many streams should be refilled in each loop run + Stream** pStreams; ///< Contains all disk streams (whether used or unused) + Stream** pCreatedStreams; ///< This is where the voice (audio thread) picks up it's meanwhile hopefully created disk stream. + static Stream* SLOT_RESERVED; ///< This value is used to mark an entry in pCreatedStreams as reserved. + + // Methods + + void CreateStream(create_command_t& Command) { + // search for unused stream + Stream* newstream = NULL; + for (int i = Streams - 1; i >= 0; i--) { + if (pStreamsi->GetState() == Stream::state_unused) { + newstream = pStreamsi; + break; + } + } + if (!newstream) { + std::cerr << "No unused stream found (OrderID:" << Command.OrderID; + std::cerr << ") - report if this happens, this is a bug!\n" << std::flush; + return; + } + LaunchStream(newstream, Command.hStream, Command.pStreamRef, Command.pRegion, Command.SampleOffset, Command.DoLoop); + dmsg(4,("new Stream launched by disk thread (OrderID:%d,StreamHandle:%d)\n", Command.OrderID, Command.hStream)); + if (pCreatedStreamsCommand.OrderID != SLOT_RESERVED) { + std::cerr << "DiskThread: Slot " << Command.OrderID << " already occupied! Please report this!\n" << std::flush; + newstream->Kill(); + return; + } + pCreatedStreamsCommand.OrderID = newstream; + } + + void DeleteStream(delete_command_t& Command) { + if (Command.pStream) { + Command.pStream->Kill(); + if (Command.bNotify) DeletionNotificationQueue.push(&Command.hStream); + } + else { // the stream wasn't created by disk thread or picked up by audio thread yet + + // if stream was created but not picked up yet + Stream* pStream = pCreatedStreamsCommand.OrderID; + if (pStream && pStream != SLOT_RESERVED) { + pStream->Kill(); + pCreatedStreamsCommand.OrderID = NULL; // free slot for new order + // if original sender requested a notification, let him know now + if (Command.bNotify) + DeletionNotificationQueue.push(&Command.hStream); + return; + } + + // the stream was not created yet + if (GhostQueue->write_space() > 0) { + GhostQueue->push(&Command); + } else { // error, queue full + if (Command.bNotify) { + dmsg(1,("DiskThread: GhostQueue full! (might lead to dead lock with instrument editor!)\n")); + } else { + dmsg(1,("DiskThread: GhostQueue full!\n")); + } + } + } + } + + void RefillStreams() { + // sort the streams by most empty stream + qsort(pStreams, Streams, sizeof(Stream*), CompareStreamWriteSpace); + + // refill the most empty streams + for (uint i = 0; i < RefillStreamsPerRun; i++) { + if (pStreamsi->GetState() == Stream::state_active) { + + //float filledpercentage = (float) pStreamsi->GetReadSpace() / 131072.0 * 100.0; + //dmsg(("\nbuffer fill: %.1f%\n", filledpercentage)); + + int writespace = pStreamsi->GetWriteSpaceToEnd(); + if (writespace == 0) break; + + int capped_writespace = writespace; + // if there is too much buffer space available then cut the read/write + // size to CONFIG_STREAM_MAX_REFILL_SIZE which is by default 65536 samples = 256KBytes + if (writespace > CONFIG_STREAM_MAX_REFILL_SIZE) capped_writespace = CONFIG_STREAM_MAX_REFILL_SIZE; + + // adjust the amount to read in order to ensure that the buffer wraps correctly + int read_amount = pStreamsi->AdjustWriteSpaceToAvoidBoundary(writespace, capped_writespace); + // if we wasn't able to refill one of the stream buffers by more than + // CONFIG_STREAM_MIN_REFILL_SIZE we'll send the disk thread to sleep later + if (pStreamsi->ReadAhead(read_amount) > CONFIG_STREAM_MIN_REFILL_SIZE) this->IsIdle = false; + } + } + } + + Stream::Handle CreateHandle() { + static uint32_t counter = 0; + if (counter == 0xffffffff) counter = 1; // we use '0' as 'invalid handle' only, so we skip 0 + else counter++; + return counter; + } + + Stream::OrderID_t CreateOrderID() { + static Stream::OrderID_t counter(0); + for (int i = 0; i < Streams; i++) { + if (counter == Streams) counter = 1; // we use '0' as 'invalid order' only, so we skip 0 + else counter++; + if (!pCreatedStreamscounter) { + pCreatedStreamscounter = SLOT_RESERVED; // mark this slot as reserved + return counter; // found empty slot + } + } + return 0; // no free slot + } + + atomic_t ActiveStreamCount; + public: + // Methods + DiskThreadBase(int MaxStreams, uint BufferWrapElements, IM* pInstruments) : + Thread(true, false, 1, -2), + pInstruments(pInstruments), + DeletionNotificationQueue(4*MaxStreams), + ProgramChangeQueue(512) + { + CreationQueue = new RingBuffer<create_command_t,false>(4*MaxStreams); + DeletionQueue = new RingBuffer<delete_command_t,false>(4*MaxStreams); + GhostQueue = new RingBuffer<delete_command_t,false>(MaxStreams); + DeleteRegionQueue = new RingBuffer<R*,false>(4*MaxStreams); + pStreams = new Stream*MaxStreams; + pCreatedStreams = new Stream*MaxStreams + 1; + Streams = MaxStreams; + RefillStreamsPerRun = CONFIG_REFILL_STREAMS_PER_RUN; + + for (int i = 1; i <= MaxStreams; i++) { + pCreatedStreamsi = NULL; + } + ActiveStreamCountMax = 0; + } + + virtual ~DiskThreadBase() { + for (int i = 0; i < Streams; i++) { + if (pStreamsi) delete pStreamsi; + } + if (CreationQueue) delete CreationQueue; + if (DeletionQueue) delete DeletionQueue; + if (GhostQueue) delete GhostQueue; + if (DeleteRegionQueue) delete DeleteRegionQueue; + if (pStreams) delete pStreams; + if (pCreatedStreams) delete pCreatedStreams; + } + + + // ######################################################################### + // # Foreign Thread Section + // # (following code intended to be interface for audio thread) + + /** + * Suspend disk thread, kill all active streams, clear all queues and the + * pickup array and reset all streams. Call this method to bring everything + * in the disk thread to day one. If the disk thread was running, it will be + * respawned right after everything was reset. + */ + void Reset() { + bool running = this->IsRunning(); + if (running) this->StopThread(); + for (int i = 0; i < Streams; i++) { + pStreamsi->Kill(); + } + for (int i = 1; i <= Streams; i++) { + pCreatedStreamsi = NULL; + } + GhostQueue->init(); + CreationQueue->init(); + DeletionQueue->init(); + DeletionNotificationQueue.init(); + + // make sure that all DimensionRegions are released + while (DeleteRegionQueue->read_space() > 0) { + R* pRgn; + DeleteRegionQueue->pop(&pRgn); + pInstruments->HandBackRegion(pRgn); + } + DeleteRegionQueue->init(); + SetActiveStreamCount(0); + ActiveStreamCountMax = 0; + if (running) this->StartThread(); // start thread only if it was running before + } + + String GetBufferFillBytes() { + bool activestreams = false; + std::stringstream ss; + for (uint i = 0; i < this->Streams; i++) { + if (pStreamsi->GetState() == Stream::state_unused) continue; + uint bufferfill = pStreamsi->GetReadSpace() * sizeof(sample_t); + uint streamid = (uint) pStreamsi->GetHandle(); + if (!streamid) continue; + + if (activestreams) ss << "," << streamid << '' << bufferfill; + else { + ss << '' << streamid << '' << bufferfill; + activestreams = true; + } + } + return ss.str(); + } + + String GetBufferFillPercentage() { + bool activestreams = false; + std::stringstream ss; + for (uint i = 0; i < this->Streams; i++) { + if (pStreamsi->GetState() == Stream::state_unused) continue; + uint bufferfill = (uint) ((float) pStreamsi->GetReadSpace() / (float) CONFIG_STREAM_BUFFER_SIZE * 100); + uint streamid = (uint) pStreamsi->GetHandle(); + if (!streamid) continue; + + if (activestreams) ss << "," << streamid << '' << bufferfill << '%'; + else { + ss << '' << streamid << '' << bufferfill; + activestreams = true; + } + } + return ss.str(); + } + + /** + * Returns -1 if command queue or pickup pool is full, 0 on success (will be + * called by audio thread within the voice class). + */ + int OrderNewStream(Stream::reference_t* pStreamRef, R* pRegion, unsigned long SampleOffset, bool DoLoop) { + dmsg(4,("Disk Thread: new stream ordered\n")); + if (CreationQueue->write_space() < 1) { + dmsg(1,("DiskThread: Order queue full!\n")); + return -1; + } + + const Stream::OrderID_t newOrder = CreateOrderID(); + if (!newOrder) { + dmsg(1,("DiskThread: there was no free slot\n")); + return -1; // there was no free slot + } + + pStreamRef->State = Stream::state_active; + pStreamRef->OrderID = newOrder; + pStreamRef->hStream = CreateHandle(); + pStreamRef->pStream = NULL; // a stream has to be activated by the disk thread first + + create_command_t cmd; + cmd.OrderID = pStreamRef->OrderID; + cmd.hStream = pStreamRef->hStream; + cmd.pStreamRef = pStreamRef; + cmd.pRegion = pRegion; + cmd.SampleOffset = SampleOffset; + cmd.DoLoop = DoLoop; + + CreationQueue->push(&cmd); + return 0; + } + + /** + * Request the disk thread to delete the given disk stream. This method + * will return immediately, thus it won't block until the respective voice + * was actually deleted. (Called by audio thread within the Voice class). + * + * @param pStreamRef - stream that shall be deleted + * @param bRequestNotification - set to true in case you want to receive a + * notification once the stream has actually + * been deleted + * @returns 0 on success, -1 if command queue is full + * @see AskForDeletedStream() + */ + int OrderDeletionOfStream(Stream::reference_t* pStreamRef, bool bRequestNotification = false) { + dmsg(4,("Disk Thread: stream deletion ordered\n")); + if (DeletionQueue->write_space() < 1) { + dmsg(1,("DiskThread: Deletion queue full!\n")); + return -1; + } + + delete_command_t cmd; + cmd.pStream = pStreamRef->pStream; + cmd.hStream = pStreamRef->hStream; + cmd.OrderID = pStreamRef->OrderID; + cmd.bNotify = bRequestNotification; + + DeletionQueue->push(&cmd); + return 0; + } + + /** + * Tell the disk thread to release a dimension region that belongs + * to an instrument which isn't loaded anymore. The disk thread + * will hand back the dimension region to the instrument resource + * manager. (OrderDeletionOfDimreg is called from the audio thread + * when a voice dies.) + */ + int OrderDeletionOfRegion(R* pReg) { + dmsg(4,("Disk Thread: dimreg deletion ordered\n")); + if (DeleteRegionQueue->write_space() < 1) { + dmsg(1,("DiskThread: DeleteRegion queue full!\n")); + return -1; + } + DeleteRegionQueue->push(&pReg); + return 0; + } + + /** + * Tell the disk thread to do a program change on the specified + * EngineChannel. + */ + int OrderProgramChange(uint32_t Program, EngineChannel* pEngineChannel) { + program_change_command_t cmd; + cmd.Program = Program; + cmd.pEngineChannel = pEngineChannel; + + dmsg(4,("Disk Thread: program change ordered\n")); + if (ProgramChangeQueue.write_space() < 1) { + dmsg(1,("DiskThread: ProgramChange queue full!\n")); + return -1; + } + ProgramChangeQueue.push(&cmd); + return 0; + } + + /** + * Returns the pointer to a disk stream if the ordered disk stream + * represented by the \a StreamOrderID was already activated by the disk + * thread, returns NULL otherwise. If the call was successful, thus if it + * returned a valid stream pointer, the caller has to the store that pointer + * by himself, because it's not possible to call this method again with the + * same used order ID; this method is just intended for picking up an ordered + * disk stream. This method will usually be called by the voice class (within + * the audio thread). + * + * @param StreamOrderID - ID previously returned by OrderNewStream() + * @returns pointer to created stream object, NULL otherwise + */ + Stream* AskForCreatedStream(Stream::OrderID_t StreamOrderID) { + dmsg(4,("Disk Thread: been asked if stream already created, OrderID=%x ", StreamOrderID)); + Stream* pStream = pCreatedStreamsStreamOrderID; + if (pStream && pStream != SLOT_RESERVED) { + dmsg(4,("(yes created)\n")); + pCreatedStreamsStreamOrderID = NULL; // free the slot for a new order + return pStream; + } + dmsg(4,("(no not yet created)\n")); + return NULL; + } + + /** + * In case the original sender requested a notification with his stream + * deletion order, he can use this method to poll if the respective stream + * has actually been deleted. + * + * @returns handle / identifier of the deleted stream, or + * Stream::INVALID_HANDLE if no notification present + */ + Stream::Handle AskForDeletedStream() { + if (DeletionNotificationQueue.read_space()) { + Stream::Handle hStream; + DeletionNotificationQueue.pop(&hStream); + return hStream; + } else return Stream::INVALID_HANDLE; // no notification received yet + } + + // the number of streams currently in usage + // printed on the console the main thread (along with the active voice count) + uint GetActiveStreamCount() { return atomic_read(&ActiveStreamCount); } + void SetActiveStreamCount(uint Streams) { atomic_set(&ActiveStreamCount, Streams); } + int ActiveStreamCountMax; + + protected: + IM* pInstruments; ///< The instrument resource manager of the engine that is using this disk thread. Used by the dimension region deletion feature. + + // ######################################################################### + // # Disk Thread Only Section + // # (following code should only be executed by the disk thread) + + // Implementation of virtual method from class Thread + int Main() { + dmsg(3,("Disk thread running\n")); + while (true) { + #if !defined(WIN32) + pthread_testcancel(); // mandatory for OSX + #endif + #if CONFIG_PTHREAD_TESTCANCEL + TestCancel(); + #endif + IsIdle = true; // will be set to false if a stream got filled + + // if there are ghost streams, delete them + for (int i = 0; i < GhostQueue->read_space(); i++) { //FIXME: unefficient + delete_command_t ghostStream; + GhostQueue->pop(&ghostStream); + bool found = false; + for (int i = 0; i < this->Streams; i++) { + if (pStreamsi->GetHandle() == ghostStream.hStream) { + pStreamsi->Kill(); + found = true; + // if original sender requested a notification, let him know now + if (ghostStream.bNotify) + DeletionNotificationQueue.push(&ghostStream.hStream); + break; + } + } + if (!found) GhostQueue->push(&ghostStream); // put ghost stream handle back to the queue + } + + // if there are creation commands, create new streams + while (Stream::UnusedStreams > 0 && CreationQueue->read_space() > 0) { + create_command_t command; + CreationQueue->pop(&command); + CreateStream(command); + } + + // if there are deletion commands, delete those streams + while (Stream::UnusedStreams < Stream::TotalStreams && DeletionQueue->read_space() > 0) { + delete_command_t command; + DeletionQueue->pop(&command); + DeleteStream(command); + } + + // release DimensionRegions that belong to instruments + // that are no longer loaded + while (DeleteRegionQueue->read_space() > 0) { + R* pRgn; + DeleteRegionQueue->pop(&pRgn); + pInstruments->HandBackRegion(pRgn); + } + + // perform MIDI program change commands + while (ProgramChangeQueue.read_space() > 0) { + program_change_command_t cmd; + ProgramChangeQueue.pop(&cmd); + cmd.pEngineChannel->ExecuteProgramChange(cmd.Program); + } + RefillStreams(); // refill the most empty streams + + // if nothing was done during this iteration (eg no streambuffer + // filled with data) then sleep for 30ms + if (IsIdle) usleep(30000); + + int streamsInUsage = 0; + for (int i = Streams - 1; i >= 0; i--) { + if (pStreamsi->GetState() != Stream::state_unused) streamsInUsage++; + } + SetActiveStreamCount(streamsInUsage); + if (streamsInUsage > ActiveStreamCountMax) ActiveStreamCountMax = streamsInUsage; + } + + return EXIT_FAILURE; + } + + virtual Stream* CreateStream(long BufferSize, uint BufferWrapElements) = 0; + + void CreateAllStreams(int MaxStreams, uint BufferWrapElements) { + for (int i = 0; i < MaxStreams; i++) { + pStreamsi = CreateStream(CONFIG_STREAM_BUFFER_SIZE, BufferWrapElements); + } + } + + virtual void LaunchStream ( + Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + R* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) = 0; + + friend class Stream; + }; +} // namespace LinuxSampler + +#endif // __LS_DISKTHREADBASE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/EG.cpp
Added
@@ -0,0 +1,74 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#include "EG.h" + +namespace LinuxSampler { + + EG::EG() { + enterEndStage(); + Level = 0.0; + CalculateFadeOutCoeff(CONFIG_EG_MIN_RELEASE_TIME, 44100.0); // even if the sample rate will be 192kHz it won't hurt at all + } + + void EG::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + const float killSteps = FadeOutTime * SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + FadeOutCoeff = -1.0f / killSteps; + } + + void EG::enterFadeOutStage() { + Stage = stage_fadeout; + Segment = segment_lin; + StepsLeft = int(Level / (-FadeOutCoeff)); + Coeff = FadeOutCoeff; + if (StepsLeft <= 0) enterEndStage(); + } + + void EG::enterFadeOutStage(int maxFadeOutSteps) { + Stage = stage_fadeout; + Segment = segment_lin; + StepsLeft = int(Level / (-FadeOutCoeff)); + if (StepsLeft > maxFadeOutSteps) { + StepsLeft = maxFadeOutSteps; + Coeff = -Level / maxFadeOutSteps; + } else { + Coeff = FadeOutCoeff; + } + if (StepsLeft <= 0) enterEndStage(); + } + + bool EG::atEnd(event_t Event) { + if (Stage == stage_end) return true; + if (Stage == stage_fadeout) { + if (Event == event_stage_end) enterEndStage(); + return true; + } + return false; + } + + void EG::enterEndStage() { + Stage = stage_end; + Segment = segment_end; + Level = 0; + } +}
View file
linuxsampler-2342.tar.bz2/src/engines/common/EG.h
Added
@@ -0,0 +1,174 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#ifndef LS_EG_H +#define LS_EG_H + +#include <cmath> +#include "../../common/RTMath.h" + +namespace LinuxSampler { + class EG { + public: + + /** + * Used to define what kind of segment the envelope currently is at. + */ + enum segment_t { + segment_end = 0, ///< final end state of envelope reached + segment_lin = 1, ///< envelope is currently at a linear segment + segment_exp = 2, ///< envelope is currently at a exponential segment + segment_pow = 3 ///< envelope is currently at a power segment + }; + + /** + * Used to inform the EG about an event. + */ + enum event_t { + event_stage_end, + event_release, + event_cancel_release, + event_hold_end + }; + + /** + * Change fade out time. + */ + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + /** + * Returns true in case envelope hasn't reached its final end state yet. + */ + bool active() { + return Segment; + } + + /** + * Returns what kind of segment the envelope currently is at. + */ + segment_t getSegmentType() { + return Segment; + } + + /** + * Advance envelope by \a SamplePoints steps. + */ + void increment(int SamplePoints) { + StepsLeft = RTMath::Max(0, StepsLeft - SamplePoints); + } + + /** + * Returns amount of steps until the end of current envelope stage. + */ + int toStageEndLeft() { + return StepsLeft; + } + + /** + * Should be called to inform the EG about an external event and + * also whenever an envelope stage is completed. This will handle + * the envelope's transition to the respective next stage. + * + * @param Event - what happened + */ + virtual void update(event_t Event, uint SampleRate) = 0; + + /** + * Calculates exactly one, the next sample point of EG + * (linear segment). Call this if envelope is currently in a linear + * segment. + * + * @returns next envelope level + */ + float processLin() { + return (Level += Coeff); + } + + /** + * Calculates exactly one, the next sample point of EG + * (exponential segment). Call this if envelope is currently in an + * exponential segment. + * + * @returns next envelope level + */ + float processExp() { + return (Level = Level * Coeff + Offset); + } + + /** + * Calculates exactly one, the next sample point of EG (power + * segment). Call this if envelope is currently in an power + * segment. + * + * @returns next envelope level + */ + float processPow() { + // TODO: this could be optimised by a pow approximation + Level = Offset + Coeff * powf(X, Exp); + X += XDelta; + return Level; + } + + /** + * Returns current envelope level without modifying anything. This + * might be needed once the envelope reached its final end state, + * because calling processLin() or processExp() at this point will + * result in undesired behavior. + */ + float getLevel() { + return Level; + } + + void enterFadeOutStage(); + void enterFadeOutStage(int maxFadeOutSteps); + + protected: + float Level; + float Coeff; + float Offset; + float Exp; + float X; + float XDelta; + int StepsLeft; + segment_t Segment; + + EG(); + void enterFirstStage() { // must be called in trigger + Stage = stage_main; + } + bool atEnd(event_t Event); // must be called first in update + void enterEndStage(); + + private: + enum stage_t { + stage_main, + stage_fadeout, + stage_end + }; + + stage_t Stage; + float FadeOutCoeff; ///< very fast ramp down for e.g. voice stealing +}; +} + +#endif
View file
linuxsampler-1.0.0.tar.bz2/src/engines/common/Event.h -> linuxsampler-2342.tar.bz2/src/engines/common/Event.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -83,17 +83,21 @@ struct _Note { uint8_t Key; ///< MIDI key number of note-on / note-off event. uint8_t Velocity; ///< Trigger or release velocity of note-on / note-off event. + uint8_t Channel; ///< MIDI channel (0..15) int8_t Layer; ///< Layer index (usually only used if a note-on event has to be postponed, e.g. due to shortage of free voices). int8_t ReleaseTrigger; ///< If new voice should be a release triggered voice (actually boolean field and usually only used if a note-on event has to be postponed, e.g. due to shortage of free voices). + void* pRegion; ///< Engine specific pointer to instrument region } Note; /// Control change event specifics struct _CC { uint8_t Controller; ///< MIDI controller number of control change event. uint8_t Value; ///< Controller Value of control change event. + uint8_t Channel; ///< MIDI channel (0..15) } CC; /// Pitchbend event specifics struct _Pitch { int16_t Pitch; ///< Pitch value of pitchbend event. + uint8_t Channel; ///< MIDI channel (0..15) } Pitch; /// MIDI system exclusive event specifics struct _Sysex {
View file
linuxsampler-1.0.0.tar.bz2/src/engines/common/LFOTriangleDiHarmonic.h -> linuxsampler-2342.tar.bz2/src/engines/common/LFOTriangleDiHarmonic.h
Changed
@@ -116,6 +116,27 @@ real1 = real2 = cos(phi); imag1 = imag2 = sin(phi); } + + /** + * Should be invoked after the LFO is triggered with StartLevel + * start_level_min. + * @param phase From 0 to 360 degrees. + */ + void setPhase(float phase) { + if (phase < 0) phase = 0; + if (phase > 360) phase = 360; + phase /= 360.0f; + + // FIXME: too heavy? + float steps = 1.0f / (c1 / (2.0f * M_PI)); // number of steps for one cycle + steps *= phase + 0.25f; + for (int i = 0; i < steps; i++) render(); + } + + void setFrequency(float Frequency, unsigned int SampleRate) { + c1 = 2.0f * M_PI * Frequency / (float) SampleRate; + c2 = 2.0f * M_PI * Frequency / (float) SampleRate * 3.0f; + } private: float c1;
View file
linuxsampler-1.0.0.tar.bz2/src/engines/common/LFOTriangleIntMath.h -> linuxsampler-2342.tar.bz2/src/engines/common/LFOTriangleIntMath.h
Changed
@@ -112,6 +112,26 @@ break; } } + + /** + * Should be invoked after the LFO is triggered. + * @param phase From 0 to 360 degrees. + */ + void setPhase(float phase) { + if (phase < 0) phase = 0; + if (phase > 360) phase = 360; + phase /= 360.0f; + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + unsigned int uiPhase = intLimit * phase + iLevel; + if (uiPhase > intLimit / 2) iLevel = uiPhase - intLimit; + else iLevel = uiPhase; + } + + void setFrequency(float Frequency, unsigned int SampleRate) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + } protected: int iLevel;
View file
linuxsampler-1.0.0.tar.bz2/src/engines/common/Makefile.am -> linuxsampler-2342.tar.bz2/src/engines/common/Makefile.am
Changed
@@ -1,4 +1,4 @@ -INCLUDES = $(all_includes) +INCLUDES = $(all_includes) $(SNDFILE_CFLAGS) $(GIG_CFLAGS) METASOURCES = AUTO AM_CXXFLAGS = -Wreturn-type -ffast-math $(CXX_CPU_SWITCH) @@ -7,8 +7,18 @@ liblinuxsamplercommonengine_la_SOURCES = \ BiquadFilter.h \ Event.cpp Event.h \ + Sample.h SampleManager.h SampleFile.cpp SampleFile.h \ + Stream.h StreamBase.cpp StreamBase.h \ + DiskThreadBase.cpp DiskThreadBase.h \ + Voice.h AbstractVoice.cpp AbstractVoice.h VoiceBase.h \ + SignalUnit.h SignalUnit.cpp SignalUnitRack.h ModulatorGraph.cpp \ + MidiKeyboardManager.h \ LFOBase.h \ LFOTriangleDiHarmonic.h \ LFOTriangleIntAbsMath.h \ LFOTriangleIntMath.h \ - Resampler.h + SineLFO.h PulseLFO.h SawLFO.h \ + Resampler.h \ + EG.h EG.cpp +liblinuxsamplercommonengine_la_LIBADD = $(SNDFILE_LIBS) +liblinuxsamplercommonengine_la_LDFLAGS = $(SNDFILE_CFLAGS)
View file
linuxsampler-2342.tar.bz2/src/engines/common/MidiKeyboardManager.h
Added
@@ -0,0 +1,645 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_MIDIKEYBOARDMANAGER_H__ +#define __LS_MIDIKEYBOARDMANAGER_H__ + +#include "Event.h" +#include "Stream.h" +#include "../../EventListeners.h" +#include "../../common/Pool.h" +#include "../../common/global_private.h" + +namespace LinuxSampler { + + /** + * This class is used as a listener, which is notified + * when MIDI keyboard events occur like note on, note off, etc. + * Note that all events are triggered even when the channel is muted + */ + class MidiKeyboardListener { + public: + /** Called before the engine start processing the note on event */ + virtual void PreProcessNoteOn(uint8_t key, uint8_t velocity) = 0; + + /** Called after the engine has processed the note on event */ + virtual void PostProcessNoteOn(uint8_t key, uint8_t velocity) = 0; + + /** Called before the engine start processing the note off event */ + virtual void PreProcessNoteOff(uint8_t key, uint8_t velocity) = 0; + + /** Called after the engine has processed the note off event */ + virtual void PostProcessNoteOff(uint8_t key, uint8_t velocity) = 0; + + /** Called before the engine start processing the sustain pedal up event */ + virtual void PreProcessSustainPedalUp() = 0; + + /** Called after the engine has processed the sustain pedal up event */ + virtual void PostProcessSustainPedalUp() = 0; + + /** Called before the engine start processing the sustain pedal down event */ + virtual void PreProcessSustainPedalDown() = 0; + + /** Called after the engine has processed the sustain pedal down event */ + virtual void PostProcessSustainPedalDown() = 0; + + /** Called before the engine start processing the sostenuto pedal up event */ + virtual void PreProcessSostenutoPedalUp() = 0; + + /** Called after the engine has processed the sostenuto pedal up event */ + virtual void PostProcessSostenutoPedalUp() = 0; + + /** Called before the engine start processing the sostenuto pedal down event */ + virtual void PreProcessSostenutoPedalDown() = 0; + + /** Called after the engine has processed the sostenuto pedal down event */ + virtual void PostProcessSostenutoPedalDown() = 0; + }; + + /** + * This class exists as convenience for creating listener objects. + * The methods in this class are empty. + */ + class MidiKeyboardAdapter : public MidiKeyboardListener { + public: + virtual void PreProcessNoteOn(uint8_t key, uint8_t velocity) { } + virtual void PostProcessNoteOn(uint8_t key, uint8_t velocity) { } + virtual void PreProcessNoteOff(uint8_t key, uint8_t velocity) { } + virtual void PostProcessNoteOff(uint8_t key, uint8_t velocity) { } + virtual void PreProcessSustainPedalUp() { } + virtual void PostProcessSustainPedalUp() { } + virtual void PreProcessSustainPedalDown() { } + virtual void PostProcessSustainPedalDown() { } + virtual void PreProcessSostenutoPedalUp() { } + virtual void PostProcessSostenutoPedalUp() { } + virtual void PreProcessSostenutoPedalDown() { } + virtual void PostProcessSostenutoPedalDown() { } + }; + + /** + * This is the base class for class MidiKeyboardManager::MidiKey. It is + * not intended to be instantiated directly. Instead it just defines + * the part of class MidiKey which is not dependant on a C++ template + * parameter. + */ + class MidiKeyBase { + public: + bool KeyPressed; ///< Is true if the respective MIDI key is currently pressed. + bool Active; ///< If the key contains active voices. + bool ReleaseTrigger; ///< If we have to launch release triggered voice(s) when the key is released + Pool<uint>::Iterator itSelf; ///< hack to allow fast deallocation of the key from the list of active keys + RTList<Event>* pEvents; ///< Key specific events (only Note-on, Note-off and sustain pedal currently) + int VoiceTheftsQueued; ///< Amount of voices postponed due to shortage of voices. + uint32_t* pRoundRobinIndex; ///< For the round robin dimension: current articulation for this key, will be incremented for each note on + uint8_t Velocity; ///< Latest Note-on velocity for this key + unsigned long NoteOnTime; ///< Time for latest Note-on event for this key + float Volume; ///< Individual volume level for this MIDI key (usually 1.0f unless Roland GS NRPN 0x1Ann was received, nn reflecting the note number, see EngineBase::ProcessHardcodedControllers()) + float PanLeft; ///< Individual volume balance (left channel coefficient) for this MIDI key (usually 1.0f unless Roland GS NRPN 0x1Cnn was received, nn reflecting the note number, see EngineBase::ProcessHardcodedControllers()) + float PanRight; ///< Individual volume balance (right channel coefficient) for this MIDI key (usually 1.0f unless Roland GS NRPN 0x1Cnn was received, nn reflecting the note number, see EngineBase::ProcessHardcodedControllers()) + optional<float> ReverbSend; ///< Optional individual reverb send level for this MIDI key (usually not set, unless Roland GS NRPN 0x1Dnn was received, nn reflecting the note number, see EngineBase::ProcessHardcodedControllers()) + optional<float> ChorusSend; ///< Optional individual chorus send level for this MIDI key (usually not set, unless Roland GS NRPN 0x1Enn was received, nn reflecting the note number, see EngineBase::ProcessHardcodedControllers()) + }; + + template <class V> + class MidiKeyboardManager { + public: + /** @brief Voice Stealing Algorithms + * + * Enumeration of all possible voice stealing algorithms. + */ + enum voice_steal_algo_t { + voice_steal_algo_none, ///< Voice stealing disabled. + voice_steal_algo_oldestvoiceonkey, ///< Try to kill the oldest voice from same key where the new voice should be spawned. + voice_steal_algo_oldestkey ///< Try to kill the oldest voice from the oldest active key. + }; + + + /** @brief MIDI key runtime informations + * + * Reflects runtime informations for one MIDI key. + */ + class MidiKey : public MidiKeyBase { + public: + RTList<V>* pActiveVoices; ///< Contains the active voices associated with the MIDI key. + + MidiKey() { + pActiveVoices = NULL; + KeyPressed = false; + Active = false; + ReleaseTrigger = false; + pEvents = NULL; + VoiceTheftsQueued = 0; + Volume = 1.0f; + PanLeft = 1.0f; + PanRight = 1.0f; + } + + void Reset() { + if (pActiveVoices) { + RTListVoiceIterator itVoice = pActiveVoices->first(); + RTListVoiceIterator itVoicesEnd = pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + itVoice->VoiceFreed(); + } + pActiveVoices->clear(); + } + if (pEvents) pEvents->clear(); + KeyPressed = false; + Active = false; + ReleaseTrigger = false; + itSelf = Pool<uint>::Iterator(); + VoiceTheftsQueued = 0; + Volume = 1.0f; + PanLeft = 1.0f; + PanRight = 1.0f; + ReverbSend = optional<float>::nothing; + ChorusSend = optional<float>::nothing; + } + }; + + typedef typename RTList<V>::Iterator RTListVoiceIterator; + typedef typename Pool<V>::Iterator PoolVoiceIterator; + + /** + * Override this class to iterate through all active keys/voices + * using ProcessActiveVoices() method. + */ + class VoiceHandler { + public: + /** + * @returns true if the voices on the specified key should be processed + * adn false to cancel the processing of the active voices for the + * specified key + */ + virtual bool Process(MidiKey* pMidiKey) = 0; + + virtual void Process(RTListVoiceIterator& itVoice) = 0; + }; + + class VoiceHandlerBase : public VoiceHandler { + public: + virtual bool Process(MidiKey* pMidiKey) { return true; } + virtual void Process(RTListVoiceIterator& itVoice) { } + }; + + MidiKey* pMIDIKeyInfo; ///< Contains all active voices sorted by MIDI key number and other informations to the respective MIDI key + Pool<uint>* pActiveKeys; ///< Holds all keys in it's allocation list with active voices. + bool SoloMode; ///< in Solo Mode we only play one voice (group) at a time + int SoloKey; ///< Currently 'active' solo key, that is the key to which the currently sounding voice belongs to (only if SoloMode is enabled) + bool SustainPedal; ///< true if sustain pedal is down + bool SostenutoPedal; ///< true if sostenuto pedal is down + int SostenutoKeys128; + int SostenutoKeyCount; + uint32_t RoundRobinIndexes128; + + MidiKeyboardManager() { + pMIDIKeyInfo = new MidiKey128; + pActiveKeys = new Pool<uint>(128); + SoloMode = false; + SustainPedal = false; + SostenutoPedal = false; + for (int i = 0 ; i < 128 ; i++) { + RoundRobinIndexesi = 0; + + // by default use one counter for each key (the + // gig engine will change this to one counter per + // region) + pMIDIKeyInfoi.pRoundRobinIndex = &RoundRobinIndexesi; + } + } + + virtual ~MidiKeyboardManager() { + listeners.RemoveAllListeners(); + if (pActiveKeys) delete pActiveKeys; + if (pMIDIKeyInfo) delete pMIDIKeyInfo; + } + + void Reset() { + SoloKey = -1; // no solo key active yet + + // reset key info + for (uint i = 0; i < 128; i++) pMIDIKeyInfoi.Reset(); + + // free all active keys + pActiveKeys->clear(); + } + + void AllocateActiveVoices(Pool<V>* pVoicePool) { + DeleteActiveVoices(); + + for (uint i = 0; i < 128; i++) { + pMIDIKeyInfoi.pActiveVoices = new RTList<V>(pVoicePool); + } + } + + void DeleteActiveVoices() { + for (uint i = 0; i < 128; i++) { + if (pMIDIKeyInfoi.pActiveVoices) { + delete pMIDIKeyInfoi.pActiveVoices; + pMIDIKeyInfoi.pActiveVoices = NULL; + } + } + } + + void AllocateEvents(Pool<Event>* pEventPool) { + DeleteEvents(); + + for (uint i = 0; i < 128; i++) { + pMIDIKeyInfoi.pEvents = new RTList<Event>(pEventPool); + } + } + + void DeleteEvents() { + for (uint i = 0; i < 128; i++) { + if (pMIDIKeyInfoi.pEvents) { + delete pMIDIKeyInfoi.pEvents; + pMIDIKeyInfoi.pEvents = NULL; + } + } + } + + void ClearAllActiveKeyEvents() { + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + for(; iuiKey != end; ++iuiKey) { + pMIDIKeyInfo*iuiKey.pEvents->clear(); // free all events on the key + } + } + + /** + * Removes the given voice from the MIDI key's list of active voices. + * This method will be called when a voice went inactive, e.g. because + * it finished to playback its sample, finished its release stage or + * just was killed. + * + * @param itVoice - points to the voice to be freed + */ + void FreeVoice(PoolVoiceIterator& itVoice) { + if (itVoice) { + MidiKey* pKey = &pMIDIKeyInfoitVoice->MIDIKey; + + // if the sample and dimension region belong to an + // instrument that is unloaded, tell the disk thread to + // release them + if (itVoice->Orphan) { + if(itVoice->pDiskThread != NULL) { + itVoice->pDiskThread->OrderDeletionOfRegion(itVoice->GetRegion()); + } + } + + // free the voice object + pKey->pActiveVoices->free(itVoice); + } + else std::cerr << "Couldn't release voice! (!itVoice)\n" << std::flush; + } + + /** + * Called when there's no more voice left on a key, this call will + * update the key info respectively. + * + * @param pEngineChannel - engine channel on which this event occured on + * @param pKey - key which is now inactive + */ + void FreeKey(MidiKey* pKey) { + if (pKey->pActiveVoices->isEmpty()) { + pKey->Active = false; + pActiveKeys->free(pKey->itSelf); // remove key from list of active keys + pKey->itSelf = RTList<uint>::Iterator(); + pKey->ReleaseTrigger = false; + pKey->pEvents->clear(); + dmsg(3,("Key has no more voices now\n")); + } + else dmsg(1,("MidiKeyboardManager: Oops, tried to free a key which contains voices.\n")); + } + + /** + * Free all keys which have no active voices left + */ + void FreeAllInactiveKyes() { + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + while (iuiKey != end) { // iterate through all active keys + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + ++iuiKey; + if (pKey->pActiveVoices->isEmpty()) FreeKey(pKey); + #if CONFIG_DEVMODE + else { // just a sanity check for debugging + RTListVoiceIterator itVoice = pKey->pActiveVoices->first(); + RTListVoiceIterator = pKey->pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + if (itVoice->itKillEvent) { + dmsg(1,("gig::Engine: ERROR, killed voice survived !!!\n")); + } + } + } + #endif // CONFIG_DEVMODE + } + } + + int StealVoice ( + Pool<Event>::Iterator& itNoteOnEvent, + RTListVoiceIterator* LastStolenVoice, + RTList<uint>::Iterator* LastStolenKey + ) { + RTListVoiceIterator itSelectedVoice; + + // Select one voice for voice stealing + switch (CONFIG_VOICE_STEAL_ALGO) { + + // try to pick the oldest voice on the key where the new + // voice should be spawned, if there is no voice on that + // key, or no voice left to kill, then procceed with + // 'oldestkey' algorithm + case voice_steal_algo_oldestvoiceonkey: { + MidiKey* pSelectedKey = &pMIDIKeyInfoitNoteOnEvent->Param.Note.Key; + itSelectedVoice = pSelectedKey->pActiveVoices->first(); + // proceed iterating if voice was created in this fragment cycle + while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; + // if we haven't found a voice then proceed with algorithm 'oldestkey' + if (itSelectedVoice && itSelectedVoice->IsStealable()) break; + } // no break - intentional ! + + // try to pick the oldest voice on the oldest active key + // from the same engine channel + // (caution: must stay after 'oldestvoiceonkey' algorithm !) + case voice_steal_algo_oldestkey: { + // if we already stole in this fragment, try to proceed on same key + if (*LastStolenVoice) { + itSelectedVoice = *LastStolenVoice; + do { + ++itSelectedVoice; + } while (itSelectedVoice && !itSelectedVoice->IsStealable()); // proceed iterating if voice was created in this fragment cycle + // found a "stealable" voice ? + if (itSelectedVoice && itSelectedVoice->IsStealable()) { + // remember which voice we stole, so we can simply proceed on next voice stealing + *LastStolenVoice = itSelectedVoice; + break; // selection succeeded + } + } + // get (next) oldest key + RTList<uint>::Iterator iuiSelectedKey = (*LastStolenKey) ? ++(*LastStolenKey) : pActiveKeys->first(); + while (iuiSelectedKey) { + MidiKey* pSelectedKey = &pMIDIKeyInfo*iuiSelectedKey; + itSelectedVoice = pSelectedKey->pActiveVoices->first(); + // proceed iterating if voice was created in this fragment cycle + while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; + // found a "stealable" voice ? + if (itSelectedVoice && itSelectedVoice->IsStealable()) { + // remember which voice on which key we stole, so we can simply proceed on next voice stealing + *LastStolenKey = iuiSelectedKey; + *LastStolenVoice = itSelectedVoice; + break; // selection succeeded + } + ++iuiSelectedKey; // get next oldest key + } + break; + } + + // don't steal anything + case voice_steal_algo_none: + default: { + dmsg(1,("No free voice (voice stealing disabled)!\n")); + return -1; + } + } + + if (!itSelectedVoice || !itSelectedVoice->IsStealable()) return -1; + + #if CONFIG_DEVMODE + if (!itSelectedVoice->IsActive()) { + dmsg(1,("gig::Engine: ERROR, tried to steal a voice which was not active !!!\n")); + return -1; + } + #endif // CONFIG_DEVMODE + + // now kill the selected voice + itSelectedVoice->Kill(itNoteOnEvent); + + return 0; + } + + /** + * Releases all voices. All voices will go into + * the release stage and thus it might take some time (e.g. dependant to + * their envelope release time) until they actually die. + * + * @param itReleaseEvent - event which caused this releasing of all voices + */ + void ReleaseAllVoices(Pool<Event>::Iterator& itReleaseEvent) { + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + while (iuiKey) { + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + ++iuiKey; + // append a 'release' event to the key's own event list + RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); + if (itNewEvent) { + *itNewEvent = *itReleaseEvent; // copy original event (to the key's event list) + itNewEvent->Type = Event::type_release; // transform event type + } + else dmsg(1,("Event pool emtpy!\n")); + } + } + /** + * Kill all active voices. + * @returns The number of voices. + */ + int KillAllVoices(Pool<Event>::Iterator& itKillEvent) { + int count = 0; + + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + for (; iuiKey != end; ++iuiKey) { // iterate through all active keys + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + RTListVoiceIterator itVoice = pKey->pActiveVoices->first(); + RTListVoiceIterator itVoicesEnd = pKey->pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + itVoice->Kill(itKillEvent); + count++; + } + } + + return count; + } + + /** + * Kill all voices the *die hard* way. + * @returns The number of pending stream deletions + */ + int KillAllVoicesImmediately() { + int iPendingStreamDeletions = 0; + + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + for (; iuiKey != end; ++iuiKey) { // iterate through all active keys + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + RTListVoiceIterator itVoice = pKey->pActiveVoices->first(); + RTListVoiceIterator itVoicesEnd = pKey->pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + // request a notification from disk thread side for stream deletion + const Stream::Handle hStream = itVoice->KillImmediately(true); + if (hStream != Stream::INVALID_HANDLE) { // voice actually used a stream + iPendingStreamDeletions++; + } + // free the voice to the voice pool and update key info + itVoice->VoiceFreed(); + FreeVoice(itVoice); + } + } + + return iPendingStreamDeletions; + } + + /** + * Mark all currently active voices as "orphans", which means that the regions and + * samples they use should be released to the instrument manager when the voices die. + */ + void MarkAllActiveVoicesAsOrphans() { + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + for (; iuiKey != end; ++iuiKey) { // iterate through all active keys + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + RTListVoiceIterator itVoice = pKey->pActiveVoices->first(); + RTListVoiceIterator itVoicesEnd = pKey->pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + itVoice->Orphan = true; + } + } + } + + void ProcessActiveVoices(VoiceHandler* pVoiceHandler) { + if (pVoiceHandler == NULL) return; + + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + RTList<uint>::Iterator end = pActiveKeys->end(); + for (; iuiKey != end; ++iuiKey) { // iterate through all active keys + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + if (!pVoiceHandler->Process(pKey)) continue; + + RTListVoiceIterator itVoice = pKey->pActiveVoices->first(); + RTListVoiceIterator itVoicesEnd = pKey->pActiveVoices->end(); + for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key + pVoiceHandler->Process(itVoice); + } + } + } + + void ProcessSustainPedalDown(Pool<Event>::Iterator& itEvent) { + // Cancel release process of all voices + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + for (; iuiKey; ++iuiKey) { + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + if (!pKey->KeyPressed) { + RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); + if (itNewEvent) { + *itNewEvent = *itEvent; // copy event to the key's own event list + itNewEvent->Type = Event::type_cancel_release; // transform event type + } + else dmsg(1,("Event pool emtpy!\n")); + } + } + } + + void ProcessSustainPedalUp(Pool<Event>::Iterator& itEvent) { + // release voices if their respective key is not pressed + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + for (; iuiKey; ++iuiKey) { + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + if (!pKey->KeyPressed && ShouldReleaseVoice(*iuiKey)) { + RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); + if (itNewEvent) { + *itNewEvent = *itEvent; // copy event to the key's own event list + itNewEvent->Type = Event::type_release; // transform event type + } + else dmsg(1,("Event pool emtpy!\n")); + } + } + } + + /** + * Determines whether the specified voice should be released. + * + * @param pEngineChannel - The engine channel on which the voice should be checked + * @param Key - The key number + * @returns true if the specified voice should be released, false otherwise. + */ + bool ShouldReleaseVoice(int Key) { + if (SustainPedal) return false; + + if (SostenutoPedal) { + for (int i = 0; i < SostenutoKeyCount; i++) + if (Key == SostenutoKeysi) return false; + } + + return true; + } + + void ProcessSostenutoPedalDown() { + SostenutoKeyCount = 0; + // Remeber the pressed keys + RTList<uint>::Iterator iuiKey = pActiveKeys->first(); + for (; iuiKey; ++iuiKey) { + MidiKey* pKey = &pMIDIKeyInfo*iuiKey; + if (pKey->KeyPressed && SostenutoKeyCount < 128) SostenutoKeysSostenutoKeyCount++ = *iuiKey; + } + } + + void ProcessSostenutoPedalUp(Pool<Event>::Iterator& itEvent) { + // release voices if the damper pedal is up and their respective key is not pressed + for (int i = 0; i < SostenutoKeyCount; i++) { + MidiKey* pKey = &pMIDIKeyInfoSostenutoKeysi; + if (!pKey->KeyPressed && !SustainPedal) { + RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); + if (itNewEvent) { + *itNewEvent = *itEvent; // copy event to the key's own event list + itNewEvent->Type = Event::type_release; // transform event type + } + else dmsg(1,("Event pool emtpy!\n")); + } + } + } + + void AddMidiKeyboardListener(MidiKeyboardListener* l) { listeners.AddListener(l); } + + void RemoveMidiKeyboardListener(MidiKeyboardListener* l) { listeners.RemoveListener(l); } + + protected: + class Listeners : public MidiKeyboardListener, public ListenerList<MidiKeyboardListener*> { + public: + REGISTER_FIRE_EVENT_METHOD_ARG2(PreProcessNoteOn, uint8_t, uint8_t) + REGISTER_FIRE_EVENT_METHOD_ARG2(PostProcessNoteOn, uint8_t, uint8_t) + REGISTER_FIRE_EVENT_METHOD_ARG2(PreProcessNoteOff, uint8_t, uint8_t) + REGISTER_FIRE_EVENT_METHOD_ARG2(PostProcessNoteOff, uint8_t, uint8_t) + REGISTER_FIRE_EVENT_METHOD(PreProcessSustainPedalUp) + REGISTER_FIRE_EVENT_METHOD(PostProcessSustainPedalUp) + REGISTER_FIRE_EVENT_METHOD(PreProcessSustainPedalDown) + REGISTER_FIRE_EVENT_METHOD(PostProcessSustainPedalDown) + REGISTER_FIRE_EVENT_METHOD(PreProcessSostenutoPedalUp) + REGISTER_FIRE_EVENT_METHOD(PostProcessSostenutoPedalUp) + REGISTER_FIRE_EVENT_METHOD(PreProcessSostenutoPedalDown) + REGISTER_FIRE_EVENT_METHOD(PostProcessSostenutoPedalDown) + } listeners; + }; +} // namespace LinuxSampler + +#endif /* __LS_MIDIKEYBOARDMANAGER_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/common/ModulatorGraph.cpp
Added
@@ -0,0 +1,144 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "SignalUnitRack.h" +#include "../../effects/EffectFactory.h" + +namespace LinuxSampler { + + /** + * Searches for know EQ effects and create one if the search succeed. + */ + EqSupport::EqSupport() { + pEffect = pEffect2 = NULL; + BandCount = 0; + GainIdxs = FreqIdxs = BandwidthIdxs = NULL; + + Install(); + } + + void EqSupport::Install() { + Uninstall(); + for (int i = 0; i < EffectFactory::AvailableEffectsCount(); i++) { + EffectInfo* pEffectInfo = EffectFactory::GetEffectInfo(i); + /*if (!pEffectInfo->Name().compare("tap_equalizer_bw")) { + try { pEffect = EffectFactory::Create(pEffectInfo); } + catch(Exception e) { std::cerr << e.Message(); continue; } + + BandCount = 8; + GainIdxs = new intBandCount; + FreqIdxs = new intBandCount; + BandwidthIdxs = new intBandCount; + for(int i = 0; i < BandCount; i++) { + GainIdxsi = i; + FreqIdxsi = i + 8; + BandwidthIdxsi = i + 16; + } + dmsg(1,("EQ support: %s\n", pEffectInfo->Description().c_str())); + break; + }*/ + + if (!pEffectInfo->Name().compare("triplePara")) { + try { + pEffect = EffectFactory::Create(pEffectInfo); + pEffect2 = EffectFactory::Create(pEffectInfo); + } catch(Exception e) { std::cerr << e.Message(); continue; } + + BandCount = 3; + GainIdxs = new intBandCount; + FreqIdxs = new intBandCount; + BandwidthIdxs = new intBandCount; + for(int i = 0; i < BandCount; i++) { + GainIdxsi = i*3 + 3; + FreqIdxsi = i*3 + 4; + BandwidthIdxsi = i*3 + 5; + } + + pEffect->InputControl(0)->SetValue(0); // Low-shelving gain (0dB) + pEffect->InputControl(12)->SetValue(0); // High-shelving gain (0dB) + + pEffect2->InputControl(0)->SetValue(0); // Low-shelving gain (0dB) + pEffect2->InputControl(12)->SetValue(0); // High-shelving gain (0dB) + + break; + } + } + + if (pEffect == NULL) return; + + Reset(); + } + + void EqSupport::PrintInfo() { + if (!HasSupport()) { + dmsg(1,("EQ support: no\n")); + } else { + dmsg(1,("EQ support: %s\n", pEffect->GetEffectInfo()->Description().c_str())); + } + } + + void EqSupport::SetGain(int band, float gain) { + if (!HasSupport()) return; + if (band < 0 || band >= BandCount) throw Exception("EQ support: invalid band"); + + EffectControl* ctrl = pEffect->InputControl(GainIdxsband); + gain = check(ctrl->MinValue(), ctrl->MaxValue(), gain); + ctrl->SetValue(gain); + if (pEffect2 != NULL) pEffect2->InputControl(GainIdxsband)->SetValue(gain); + } + + void EqSupport::SetFreq(int band, float freq) { + if (!HasSupport()) return; + if (band < 0 || band >= BandCount) throw Exception("EQ support: invalid band"); + + EffectControl* ctrl = pEffect->InputControl(FreqIdxsband); + freq = check(ctrl->MinValue(), ctrl->MaxValue(), freq); + ctrl->SetValue(freq); + if (pEffect2 != NULL) pEffect2->InputControl(FreqIdxsband)->SetValue(freq); + } + + void EqSupport::SetBandwidth(int band, float octaves) { + if (!HasSupport()) return; + if (band < 0 || band >= BandCount) throw Exception("EQ support: invalid band"); + + EffectControl* ctrl = pEffect->InputControl(BandwidthIdxsband); + octaves = check(ctrl->MinValue(), ctrl->MaxValue(), octaves); + ctrl->SetValue(octaves); + if (pEffect2 != NULL) pEffect2->InputControl(BandwidthIdxsband)->SetValue(octaves); + } + + void EqSupport::Uninstall() { + if (pEffect != NULL) EffectFactory::Destroy(pEffect); + if (pEffect2 != NULL) EffectFactory::Destroy(pEffect2); + if (GainIdxs != NULL) delete GainIdxs; + if (FreqIdxs != NULL) delete FreqIdxs; + if (BandwidthIdxs != NULL) delete BandwidthIdxs; + + pEffect = pEffect2 = NULL; + BandCount = 0; + GainIdxs = FreqIdxs = BandwidthIdxs = NULL; + } + + EqSupport::~EqSupport() { + Uninstall(); + } +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/common/PulseLFO.h
Added
@@ -0,0 +1,132 @@ +/*************************************************************************** + * * + * Copyright (C) 2005 Christian Schoenebeck * + * Copyright (C) 2011 Christian Schoenebeck and Grigor Iliev * + * * + * This library 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 library is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this library; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_PULSELFO_H__ +#define __LS_PULSELFO_H__ + +#include "LFOBase.h" + +namespace LinuxSampler { + + /** @brief Pulse LFO (int math implementation) + * + * This is a pulse Low Frequency Oscillator which uses pure integer + * math (without branches) to synthesize the pulse wave. + */ + template<range_type_t RANGE, int WIDTH /* in permilles */> + class PulseLFO : public LFOBase<RANGE> { + public: + + /** + * Constructor + * + * @param Max - maximum value of the output levels + */ + PulseLFO(float Max) : LFOBase<RANGE>::LFOBase(Max) { + } + + /** + * Calculates exactly one sample point of the LFO wave. + * + * @returns next LFO level + */ + inline float render() { + uiLevel += c; + if (RANGE == range_unsigned) + return uiLevel <= width ? normalizer : 0; + else /* signed range */ + return uiLevel <= width ? normalizer : -normalizer; + } + + /** + * Update LFO depth with a new external controller value. + * + * @param ExtControlValue - new external controller value + */ + inline void update(const uint16_t& ExtControlValue) { + const float max = this->InternalDepth + ExtControlValue * this->ExtControlDepthCoeff; + normalizer = max; + } + + /** + * Will be called by the voice when the key / voice was triggered. + * + * @param Frequency - frequency of the oscillator in Hz + * @param InternalDepth - firm, internal oscillator amplitude + * @param ExtControlDepth - defines how strong the external MIDI + * controller has influence on the + * oscillator amplitude + * @param FlipPhase - inverts the oscillator wave against + * a horizontal axis + * @param SampleRate - current sample rate of the engines + * audio output signal + * @param PulseWidth - the pulse width in percents + */ + void trigger(float Frequency, uint16_t InternalDepth, uint16_t ExtControlDepth, float PulseWidth, unsigned int SampleRate) { + this->InternalDepth = (InternalDepth / 1200.0f) * this->Max; + this->ExtControlDepthCoeff = (((float) ExtControlDepth / 1200.0f) / 127.0f) * this->Max; + + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + const float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + width = (PulseWidth / 100.0) * intLimit; + + uiLevel = 0; + } + + virtual void trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) { + trigger(Frequency, InternalDepth, ExtControlDepth, WIDTH / 10.0f, SampleRate); + } + + /** + * Should be invoked after the LFO is triggered. + * @param phase From 0 to 360 degrees. + */ + void setPhase(float phase) { + if (phase < 0) phase = 0; + if (phase > 360) phase = 360; + phase /= 360.0f; + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + uiLevel = intLimit * phase; + } + + void setFrequency(float Frequency, unsigned int SampleRate) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + } + + protected: + unsigned int uiLevel; + unsigned int width; + int c; + float normalizer; + }; + + template<range_type_t RANGE> + class SquareLFO : public PulseLFO<RANGE, 500> { + public: + SquareLFO(float Max) : PulseLFO<RANGE, 500>::PulseLFO(Max) { } + }; + +} // namespace LinuxSampler + +#endif // __LS_PULSELFO_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/Sample.h
Added
@@ -0,0 +1,249 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SAMPLE_H__ +#define __LS_SAMPLE_H__ + +#include "../../common/global.h" + +namespace LinuxSampler { + class Sample { + public: + + /** Pointer address and size of a buffer. */ + struct buffer_t { + void* pStart; ///< Points to the beginning of the buffer. + unsigned long Size; ///< Size of the actual data in the buffer in bytes. + + unsigned long NullExtensionSize; /*/< The buffer might be bigger than the actual data, if that's the case + that unused space at the end of the buffer is filled with NULLs and NullExtensionSize reflects + that unused buffer space in bytes. Those NULL extensions are mandatory for differential + algorithms that have to take the following data words into account, thus have to access past + the buffer's boundary. If you don't know what I'm talking about, just forget this variable. :) */ + buffer_t() { + pStart = NULL; + Size = 0; + NullExtensionSize = 0; + } + }; + + /** Reflects the current playback state for a sample. */ + class PlaybackState { + public: + unsigned long position; ///< Current position within the sample. + bool reverse; ///< If playback direction is currently backwards (in case there is a pingpong or reverse loop defined). + unsigned long loop_cycles_left; ///< How many times the loop has still to be passed, this value will be decremented with each loop cycle. + }; + + uint Offset; // The offset used to play the sample (in sample units) + + uint RAMCacheOffset; // The offset of the RAM cache from the sample start (in sample units) + + /* + * Specifies the maximum offset (in frames) that can be set without + * the need to offset the RAM cache. + */ + uint MaxOffset; + + Sample(): MaxOffset(2000), Offset(0), RAMCacheOffset(0) { } + virtual ~Sample() { } + + virtual String GetName() = 0; + virtual int GetSampleRate() = 0; + virtual int GetChannelCount() = 0; + + /** + * @returns The frame size in bytes + */ + virtual int GetFrameSize() = 0; + + /** + * @returns The total number of frames in this sample + */ + virtual long GetTotalFrameCount() = 0; + + /** + * Loads (and uncompresses if needed) the whole sample wave into RAM. Use + * ReleaseSampleData() to free the memory if you don't need the cached + * sample data anymore. + * + * @returns buffer_t structure with start address and size of the buffer + * in bytes + * @see ReleaseSampleData(), Read(), SetPos() + */ + virtual buffer_t LoadSampleData() = 0; + + /** + * Reads (uncompresses if needed) and caches the first \a FrameCount + * numbers of SamplePoints in RAM. Use ReleaseSampleData() to free the + * memory space if you don't need the cached samples anymore. There is no + * guarantee that exactly \a SampleCount samples will be cached; this is + * not an error. The size will be eventually truncated e.g. to the + * beginning of a frame of a compressed sample. This is done for + * efficiency reasons while streaming the wave by your sampler engine + * later. Read the <i>Size</i> member of the <i>buffer_t</i> structure + * that will be returned to determine the actual cached samples, but note + * that the size is given in bytes! You get the number of actually cached + * samples by dividing it by the frame size of the sample: + * @code + * buffer_t buf = pSample->LoadSampleData(acquired_samples); + * long cachedsamples = buf.Size / pSample->FrameSize; + * @endcode + * + * @param FrameCount - number of sample points to load into RAM + * @returns buffer_t structure with start address and size of + * the cached sample data in bytes + * @see ReleaseSampleData(), Read(), SetPos() + */ + virtual buffer_t LoadSampleData(unsigned long FrameCount) = 0; + + /** + * Loads (and uncompresses if needed) the whole sample wave into RAM. Use + * ReleaseSampleData() to free the memory if you don't need the cached + * sample data anymore. + * The method will add \a NullSamplesCount silence samples past the + * official buffer end (this won't affect the 'Size' member of the + * buffer_t structure, that means 'Size' always reflects the size of the + * actual sample data, the buffer might be bigger though). Silence + * samples past the official buffer are needed for differential + * algorithms that always have to take subsequent samples into account + * (resampling/interpolation would be an important example) and avoids + * memory access faults in such cases. + * + * @param NullSamplesCount - number of silence samples the buffer should + * be extended past it's data end + * @returns buffer_t structure with start address and + * size of the buffer in bytes + * @see ReleaseSampleData(), Read(), SetPos() + */ + virtual buffer_t LoadSampleDataWithNullSamplesExtension(uint NullFrameCount) = 0; + + /** + * Reads (uncompresses if needed) and caches the first \a SampleCount + * numbers of SamplePoints in RAM. Use ReleaseSampleData() to free the + * memory space if you don't need the cached samples anymore. There is no + * guarantee that exactly \a SampleCount samples will be cached; this is + * not an error. The size will be eventually truncated e.g. to the + * beginning of a frame of a compressed sample. This is done for + * efficiency reasons while streaming the wave by your sampler engine + * later. Read the <i>Size</i> member of the <i>buffer_t</i> structure + * that will be returned to determine the actual cached samples, but note + * that the size is given in bytes! You get the number of actually cached + * samples by dividing it by the frame size of the sample: + * @code + * buffer_t buf = pSample->LoadSampleDataWithNullSamplesExtension(acquired_samples, null_samples); + * long cachedsamples = buf.Size / pSample->FrameSize; + * @endcode + * The method will add \a NullSamplesCount silence samples past the + * official buffer end (this won't affect the 'Size' member of the + * buffer_t structure, that means 'Size' always reflects the size of the + * actual sample data, the buffer might be bigger though). Silence + * samples past the official buffer are needed for differential + * algorithms that always have to take subsequent samples into account + * (resampling/interpolation would be an important example) and avoids + * memory access faults in such cases. + * + * @param FrameCount - number of sample points to load into RAM + * @param NullFramesCount - number of silence samples the buffer should + * be extended past it's data end + * @returns buffer_t structure with start address and + * size of the cached sample data in bytes + * @see ReleaseSampleData(), Read() + */ + virtual buffer_t LoadSampleDataWithNullSamplesExtension(unsigned long FrameCount, uint NullFramesCount) = 0; + + /** + * Frees the cached sample from RAM if loaded with + * <i>LoadSampleData()</i> previously. + * + * @see LoadSampleData(); + */ + virtual void ReleaseSampleData() = 0; + + /** + * Returns current cached sample points. A buffer_t structure will be + * returned which contains address pointer to the begin of the cache and + * the size of the cached sample data in bytes. Use + * <i>LoadSampleData()</i> to cache a specific amount of sample points in + * RAM. + * + * @returns buffer_t structure with current cached sample points + * @see LoadSampleData(); + */ + virtual buffer_t GetCache() = 0; + + /** + * Reads \a FrameCount number of frames from the current + * position into the buffer pointed by \a pBuffer and increments the + * position within the sample. Use this method + * and <i>SetPos()</i> if you don't want to load the sample into RAM, + * thus for disk streaming. + * + * For 16 bit samples, the data in the buffer will be int16_t + * (using native endianness). For 24 bit, the buffer will + * contain 4 bytes per sample. + * + * @param pBuffer destination buffer + * @param SampleCount number of sample points to read + * @returns number of successfully read sample points + */ + virtual long Read(void* pBuffer, unsigned long FrameCount) = 0; + + /** + * Reads \a SampleCount number of sample points from the position stored + * in \a pPlaybackState into the buffer pointed by \a pBuffer and moves + * the position within the sample respectively, this method honors the + * looping informations of the sample (if any). Use this + * method if you don't want to load the sample into RAM, thus for disk + * streaming. All this methods needs to know to proceed with streaming + * for the next time you call this method is stored in \a pPlaybackState. + * You have to allocate and initialize the playback_state_t structure by + * yourself before you use it to stream a sample: + * @code + * PlaybackState playbackstate; + * playbackstate.position = 0; + * playbackstate.reverse = false; + * playbackstate.loop_cycles_left = pSample->LoopPlayCount; + * @endcode + * You don't have to take care of things like if there is actually a loop + * defined or if the current read position is located within a loop area. + * The method already handles such cases by itself. + * + * @param pBuffer destination buffer + * @param FrameCount number of sample points to read + * @param pPlaybackState will be used to store and reload the playback + * state for the next ReadAndLoop() call + * @returns number of successfully read sample points + */ + virtual unsigned long ReadAndLoop ( + void* pBuffer, + unsigned long FrameCount, + PlaybackState* pPlaybackState + ) = 0; + + virtual long SetPos(unsigned long FrameOffset) = 0; + virtual long GetPos() = 0; + }; +} // namespace LinuxSampler + +#endif // __LS_SAMPLE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/SampleFile.cpp
Added
@@ -0,0 +1,222 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 - 2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "SampleFile.h" +#include "../../common/global_private.h" +#include "../../common/Exception.h" + +#include <cstring> + +namespace LinuxSampler { + #if CONFIG_DEVMODE + int SampleFile_OpenFilesCount = 0; + #endif + + SampleFile::SampleFile(String File, bool DontClose) { + this->File = File; + this->pSndFile = NULL; + + SF_INFO sfInfo; + sfInfo.format = 0; + pSndFile = sf_open(File.c_str(), SFM_READ, &sfInfo); + if(pSndFile == NULL) throw Exception(File + ": Can't get sample info: " + String(sf_strerror (NULL))); + #if CONFIG_DEVMODE + std::cout << "Number of opened sample files: " << ++SampleFile_OpenFilesCount << std::endl; + #endif + SampleRate = sfInfo.samplerate; + ChannelCount = sfInfo.channels; + Format = sfInfo.format; + + switch(Format & SF_FORMAT_SUBMASK) { + case SF_FORMAT_PCM_S8: + case SF_FORMAT_PCM_U8: + case SF_FORMAT_DPCM_8: + FrameSize = ChannelCount; + break; + case SF_FORMAT_PCM_16: + case SF_FORMAT_DPCM_16: + FrameSize = 2 * ChannelCount; + break; + case SF_FORMAT_PCM_24: + case SF_FORMAT_DWVW_24: + FrameSize = 3 * ChannelCount; + break; + default: + FrameSize = 2 * ChannelCount; + } + TotalFrameCount = sfInfo.frames; + + Loops = 0; + LoopStart = 0; + LoopEnd = 0; + SF_INSTRUMENT instrument; + if (sf_command(pSndFile, SFC_GET_INSTRUMENT, + &instrument, sizeof(instrument)) != SF_FALSE) { + // TODO: instrument.basenote +#if HAVE_SF_INSTRUMENT_LOOPS + if (instrument.loop_count && instrument.loops0.mode != SF_LOOP_NONE) { + Loops = 1; + LoopStart = instrument.loops0.start; + LoopEnd = instrument.loops0.end; + } +#endif + } + if(!DontClose) Close(); + } + + SampleFile::~SampleFile() { + Close(); + ReleaseSampleData(); + } + + void SampleFile::Open() { + if(pSndFile) return; // Already opened + SF_INFO sfInfo; + sfInfo.format = 0; + pSndFile = sf_open(File.c_str(), SFM_READ, &sfInfo); + if(pSndFile == NULL) throw Exception(File + ": Can't load sample"); + #if CONFIG_DEVMODE + std::cout << "Number of opened sample files: " << ++SampleFile_OpenFilesCount << std::endl; + #endif + } + + void SampleFile::Close() { + if(pSndFile == NULL) return; + if(sf_close(pSndFile)) std::cerr << "Sample::Close() " << "Failed to close " << File << std::endl; + pSndFile = NULL; + #if CONFIG_DEVMODE + std::cout << "Number of opened sample files: " << --SampleFile_OpenFilesCount << std::endl; + #endif + } + + long SampleFile::SetPos(unsigned long FrameOffset) { + return SetPos(FrameOffset, SEEK_SET); + } + + long SampleFile::SetPos(unsigned long FrameCount, int Whence) { + if(pSndFile == NULL) { + std::cerr << "Sample::SetPos() " << File << " not opened" << std::endl; + return -1; + } + + return sf_seek(pSndFile, FrameCount, Whence); + } + + long SampleFile::GetPos() { + if(pSndFile == NULL) { + std::cerr << "Sample::GetPos() " << File << " not opened" << std::endl; + return -1; + } + + return sf_seek(pSndFile, 0, SEEK_CUR); + } + + Sample::buffer_t SampleFile::LoadSampleData() { + return LoadSampleDataWithNullSamplesExtension(GetTotalFrameCount(), 0); // 0 amount of NullSamples + } + + Sample::buffer_t SampleFile::LoadSampleData(unsigned long FrameCount) { + return LoadSampleDataWithNullSamplesExtension(FrameCount, 0); // 0 amount of NullSamples + } + + Sample::buffer_t SampleFile::LoadSampleDataWithNullSamplesExtension(uint NullFrameCount) { + return LoadSampleDataWithNullSamplesExtension(GetTotalFrameCount(), NullFrameCount); + } + + Sample::buffer_t SampleFile::LoadSampleDataWithNullSamplesExtension(unsigned long FrameCount, uint NullFramesCount) { + Open(); + if (FrameCount > GetTotalFrameCount()) FrameCount = GetTotalFrameCount(); + + if (Offset > MaxOffset && FrameCount < GetTotalFrameCount()) { + FrameCount = FrameCount + Offset > GetTotalFrameCount() ? GetTotalFrameCount() - Offset : FrameCount; + // Offset the RAM cache + RAMCacheOffset = Offset; + } + if (RAMCache.pStart) delete (int8_t*) RAMCache.pStart; + unsigned long allocationsize = (FrameCount + NullFramesCount) * this->FrameSize; + SetPos(RAMCacheOffset, SEEK_SET); // reset read position to playback start point + RAMCache.pStart = new int8_tallocationsize; + + RAMCache.Size = Read(RAMCache.pStart, FrameCount) * this->FrameSize; + RAMCache.NullExtensionSize = allocationsize - RAMCache.Size; + // fill the remaining buffer space with silence samples + memset((int8_t*)RAMCache.pStart + RAMCache.Size, 0, RAMCache.NullExtensionSize); + Close(); + return GetCache(); + } + + long SampleFile::Read(void* pBuffer, unsigned long FrameCount) { + Open(); + + if (GetPos() + FrameCount > GetTotalFrameCount()) FrameCount = GetTotalFrameCount() - GetPos(); // For the cases where a different sample end is specified (not the end of the file) + + // ogg files must be read with sf_readf, not sf_read_raw. On + // big endian machines, sf_readf_short is also used for 16 bit + // wav files, to get automatic endian conversion (for 24 bit + // samples this is handled in Synthesize::GetSample instead). + +#if WORDS_BIGENDIAN || HAVE_DECL_SF_FORMAT_VORBIS + if ( +#if WORDS_BIGENDIAN + FrameSize == 2 * ChannelCount +#else + (Format & SF_FORMAT_SUBMASK) == SF_FORMAT_VORBIS +#endif + ) { + return sf_readf_short(pSndFile, static_cast<short*>(pBuffer), FrameCount); + } else +#endif + { + int bytes = sf_read_raw(pSndFile, pBuffer, FrameCount * GetFrameSize()); + return bytes / GetFrameSize(); + } + } + + unsigned long SampleFile::ReadAndLoop ( + void* pBuffer, + unsigned long FrameCount, + PlaybackState* pPlaybackState + ) { + // TODO: + SetPos(pPlaybackState->position); + unsigned long count = Read(pBuffer, FrameCount); + pPlaybackState->position = GetPos(); + return count; + } + + void SampleFile::ReleaseSampleData() { + if (RAMCache.pStart) delete (int8_t*) RAMCache.pStart; + RAMCache.pStart = NULL; + RAMCache.Size = 0; + RAMCache.NullExtensionSize = 0; + } + + Sample::buffer_t SampleFile::GetCache() { + // return a copy of the buffer_t structure + buffer_t result; + result.Size = this->RAMCache.Size; + result.pStart = this->RAMCache.pStart; + result.NullExtensionSize = this->RAMCache.NullExtensionSize; + return result; + } +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/common/SampleFile.h
Added
@@ -0,0 +1,155 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 - 2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SAMPLEFILE_H__ +#define __LS_SAMPLEFILE_H__ + +#include "Sample.h" + +#include <sndfile.h> +#include "../../common/global.h" + +namespace LinuxSampler { + class SampleFile : public Sample { + public: + SampleFile(String File, bool DontClose = false); + virtual ~SampleFile(); + + String GetFile() { return File; } + + virtual String GetName() { return File; } + virtual int GetSampleRate() { return SampleRate; } + virtual int GetChannelCount() { return ChannelCount; } + virtual long GetTotalFrameCount() { return TotalFrameCount; } + virtual int GetFrameSize() { return FrameSize; } + virtual int GetLoops() { return Loops; } + virtual uint GetLoopStart() { return LoopStart; } + virtual uint GetLoopEnd() { return LoopEnd; } + + virtual buffer_t LoadSampleData(); + virtual buffer_t LoadSampleData(unsigned long FrameCount); + virtual buffer_t LoadSampleDataWithNullSamplesExtension(uint NullFrameCount); + virtual buffer_t LoadSampleDataWithNullSamplesExtension(unsigned long FrameCount, uint NullFramesCount); + virtual void ReleaseSampleData(); + virtual buffer_t GetCache(); + virtual long Read(void* pBuffer, unsigned long FrameCount); + + virtual unsigned long ReadAndLoop ( + void* pBuffer, + unsigned long FrameCount, + PlaybackState* pPlaybackState + ); + + virtual long SetPos(unsigned long FrameOffset); + virtual long GetPos(); + + void Open(); + void Close(); + + private: + String File; + int SampleRate; + int ChannelCount; + int Format; + int FrameSize; ///< In bytes + long TotalFrameCount; + int Loops; + uint LoopStart; + uint LoopEnd; + + SNDFILE* pSndFile; + + buffer_t RAMCache; ///< Buffers samples (already uncompressed) in RAM. + long SetPos(unsigned long FrameCount, int Whence); + }; + + template <class R> + class SampleFileBase : public SampleFile { + public: + SampleFileBase(String File, bool DontClose = false) : SampleFile(File, DontClose) { } + virtual ~SampleFileBase() { } + + + + /** + * Reads \a SampleCount number of sample points from the position stored + * in \a pPlaybackState into the buffer pointed by \a pBuffer and moves + * the position within the sample respectively, this method honors the + * looping informations of the sample (if any). Use this + * method if you don't want to load the sample into RAM, thus for disk + * streaming. All this methods needs to know to proceed with streaming + * for the next time you call this method is stored in \a pPlaybackState. + * You have to allocate and initialize the playback_state_t structure by + * yourself before you use it to stream a sample: + * @code + * PlaybackState playbackstate; + * playbackstate.position = 0; + * playbackstate.reverse = false; + * playbackstate.loop_cycles_left = pSample->LoopPlayCount; + * @endcode + * You don't have to take care of things like if there is actually a loop + * defined or if the current read position is located within a loop area. + * The method already handles such cases by itself. + * + * @param pBuffer destination buffer + * @param FrameCount number of sample points to read + * @param pPlaybackState will be used to store and reload the playback + * state for the next ReadAndLoop() call + * @returns number of successfully read sample points + */ + unsigned long ReadAndLoop ( + void* pBuffer, + unsigned long FrameCount, + PlaybackState* pPlaybackState, + R* pRegion + ) { + // TODO: startAddrsCoarseOffset, endAddrsCoarseOffset + unsigned long samplestoread = FrameCount, totalreadsamples = 0, readsamples, samplestoloopend; + uint8_t* pDst = (uint8_t*) pBuffer; + SetPos(pPlaybackState->position); + if (pRegion->HasLoop()) { + do { + if (GetPos() > pRegion->GetLoopEnd()) SetPos(pRegion->GetLoopStart()); + samplestoloopend = pRegion->GetLoopEnd() - GetPos(); + readsamples = Read(&pDsttotalreadsamples * GetFrameSize(), Min(samplestoread, samplestoloopend)); + samplestoread -= readsamples; + totalreadsamples += readsamples; + if (readsamples == samplestoloopend) { + SetPos(pRegion->GetLoopStart()); + } + } while (samplestoread && readsamples); + } else { + totalreadsamples = Read(pBuffer, FrameCount); + } + + pPlaybackState->position = GetPos(); + + return totalreadsamples; + } + + protected: + inline long Min(long A, long B) { return (A > B) ? B : A; } + }; +} // namespace LinuxSampler + +#endif // __LS_SAMPLEFILE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/SampleManager.h
Added
@@ -0,0 +1,176 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SAMPLEMANAGER_H__ +#define __LS_SAMPLEMANAGER_H__ + +#include <map> +#include <vector> +#include <set> + +#include "../../common/Exception.h" + +namespace LinuxSampler { + + /** + * Used to determine and manage the relations between samples and consumers (e.g. regions) + */ + template <class S /* Sample */, class C /* Sample Consumer */> + class SampleManager { + public: + /** + * Adds the specified sample to the sample manager + */ + void AddSample(S* pSample) { + if (pSample == NULL) return; + sampleMappSample; + } + + void RemoveSample(S* pSample) throw (Exception) { + if (sampleMap.find(pSample) == sampleMap.end()) return; + if (!sampleMappSample.empty()) { + throw Exception("Can't remove. Sample has consumers"); + } + + sampleMap.erase(sampleMap.find(pSample)); + } + + /** + * Adds pConsumer as consumer to the specified sample. + * The sample is automatically added to the sample manager if + * it is not added yet. This method does nothing if pConsumer is + * already added as consumer to pSample. + */ + void AddSampleConsumer(S* pSample, C* pConsumer) { + if (pSample == NULL || pConsumer == NULL) return; + if(sampleMappSample.find(pConsumer) != sampleMappSample.end()) return; + sampleMappSample.insert(pConsumer); + } + + std::vector<C*> GetConsumers(S* pSample) throw (Exception) { + if (sampleMap.find(pSample) == sampleMap.end()) { + throw Exception("SampleManager::GetConsumers: unknown sample"); + } + std::set<C*>* pConsumers = &sampleMappSample; + std::vector<C*> v; + v.insert(pConsumers->begin(), pConsumers->end()); + return v ; + } + + /** + * @return true if the specified consumer was in the list + * of consumers for the specified sample. + */ + bool RemoveSampleConsumer(S* pSample, C* pConsumer) throw (Exception) { + if (sampleMap.find(pSample) == sampleMap.end()) { + throw Exception("SampleManager::RemoveConsumer: unknown sample"); + } + + std::set<C*>* consumers = &sampleMappSample; + typename std::set<C*>::iterator it = consumers->find(pConsumer); + if (it != consumers->end()) { + consumers->erase(it); + return true; + } + return false; + } + + /** + * Determines whether pSample is managed by this sample manager + */ + bool HasSample(S* pSample) { + return sampleMap.find(pSample) != sampleMap.end(); + } + + bool HasSampleConsumers(S* pSample) throw (Exception) { + if (sampleMap.find(pSample) == sampleMap.end()) { + throw Exception("SampleManager::HasConsumers: unknown sample"); + } + + return !sampleMappSample.empty(); + } + + /** + * Determines whether pConsumer is consumer of pSample. + */ + bool IsSampleConsumerOf(S* pSample, C* pConsumer) { + if (sampleMap.find(pSample) == sampleMap.end()) { + throw Exception("SampleManager::IsSampleConsumerOf: unknown sample"); + } + + typename std::set<C*>::iterator it = sampleMappSample.find(pConsumer); + return it != sampleMappSample.end(); + } + + /** + * Sets that pSample is now in use by pConsumer. + */ + void SetSampleInUse(S* pSample, C* pConsumer) { + verifyPair(pSample, pConsumer, "SampleManager::SetSampleInUse"); + + bool inUse = !samplesInUseMappSample.empty(); + samplesInUseMappSample.insert(pConsumer); + if(!inUse) OnSampleInUse(pSample); + } + + /** + * Sets that pSample is now not in use by pConsumer. + */ + void SetSampleNotInUse(S* pSample, C* pConsumer) { + verifyPair(pSample, pConsumer, "SampleManager::SetSampleNotInUse"); + + bool inUse = !samplesInUseMappSample.empty(); + samplesInUseMappSample.erase(pConsumer); + bool inUseNew = !samplesInUseMappSample.empty(); + if(inUse && !inUseNew) OnSampleNotInUse(pSample); + } + + protected: + std::map<S*, std::set<C*> > sampleMap; + std::map<S*, std::set<C*> > samplesInUseMap; + + void verifyPair(S* pSample, C* pConsumer, String caller) { + if(!HasSample(pSample)) { + throw Exception(caller + ": unknown sample"); + } + + if(!IsSampleConsumerOf(pSample, pConsumer)) { + throw Exception("SampleManager::SetSampleInUse: unknown consumer"); + } + } + + /** + * Override this method to handle the state change (not in use -> in use) + * of the specified sample. + */ + virtual void OnSampleInUse(S* pSample) { } + + /** + * Override this method to handle the state change (in use -> not in use) + * of the specified sample. + */ + virtual void OnSampleNotInUse(S* pSample) { } + }; +} // namespace LinuxSampler + +#endif /* __LS_SAMPLEMANAGER_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/common/SawLFO.h
Added
@@ -0,0 +1,141 @@ +/*************************************************************************** + * * + * Copyright (C) 2005 Christian Schoenebeck * + * Copyright (C) 2011 Christian Schoenebeck and Grigor Iliev * + * * + * This library 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 library is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this library; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SAWLFO_H__ +#define __LS_SAWLFO_H__ + +#include "LFOBase.h" + +namespace LinuxSampler { + + /** @brief Saw LFO (int math implementation) + * + * This is a saw Low Frequency Oscillator which uses pure integer + * math (without branches) to synthesize the saw wave. + */ + template<range_type_t RANGE, bool SAWUP> + class SawLFO : public LFOBase<RANGE> { + public: + + /** + * Constructor + * + * @param Max - maximum value of the output levels + */ + SawLFO(float Max) : LFOBase<RANGE>::LFOBase(Max) { + } + + /** + * Calculates exactly one sample point of the LFO wave. + * + * @returns next LFO level + */ + inline float render() { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + + uiLevel += c; + if (RANGE == range_unsigned) + return normalizer * (float) (SAWUP ? uiLevel : intLimit - uiLevel); + else /* signed range */ + return normalizer * (float) (SAWUP ? uiLevel : intLimit - uiLevel) + offset; + } + + /** + * Update LFO depth with a new external controller value. + * + * @param ExtControlValue - new external controller value + */ + inline void update(const uint16_t& ExtControlValue) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + const float max = this->InternalDepth + ExtControlValue * this->ExtControlDepthCoeff; + if (RANGE == range_unsigned) { + normalizer = max / (float) intLimit; + } else { // signed range + normalizer = max / (float) intLimit * 2.0f; + offset = -max; + } + } + + /** + * Will be called by the voice when the key / voice was triggered. + * + * @param Frequency - frequency of the oscillator in Hz + * @param StartLevel - not implemented + * @param InternalDepth - firm, internal oscillator amplitude + * @param ExtControlDepth - defines how strong the external MIDI + * controller has influence on the + * oscillator amplitude + * @param FlipPhase - not implemented + * @param SampleRate - current sample rate of the engines + * audio output signal + */ + virtual void trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) { + this->InternalDepth = (InternalDepth / 1200.0f) * this->Max; + this->ExtControlDepthCoeff = (((float) ExtControlDepth / 1200.0f) / 127.0f) * this->Max; + + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + const float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + + uiLevel = 0; + } + + /** + * Should be invoked after the LFO is triggered. + * @param phase From 0 to 360 degrees. + */ + void setPhase(float phase) { + if (phase < 0) phase = 0; + if (phase > 360) phase = 360; + phase /= 360.0f; + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + uiLevel = intLimit * phase; + } + + void setFrequency(float Frequency, unsigned int SampleRate) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + } + + protected: + unsigned int uiLevel; + int c; + float offset; ///< only needed for signed range + float normalizer; + }; + + + template<range_type_t RANGE> + class SawUpLFO : public SawLFO<RANGE, true> { + public: + SawUpLFO(float Max) : SawLFO<RANGE, true>::SawLFO(Max) { } + }; + + template<range_type_t RANGE> + class SawDownLFO : public SawLFO<RANGE, false> { + public: + SawDownLFO(float Max) : SawLFO<RANGE, false>::SawLFO(Max) { } + }; + +} // namespace LinuxSampler + +#endif // __LS_SAWLFO_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/SignalUnit.cpp
Added
@@ -0,0 +1,30 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "SignalUnit.h" +#include "SignalUnitRack.h" + +namespace LinuxSampler { + bool SignalUnit::DelayStage() { + return (DelayTrigger() >= pRack->GetCurrentStep()); + } +} // namespace LinuxSampler
View file
linuxsampler-2342.tar.bz2/src/engines/common/SignalUnit.h
Added
@@ -0,0 +1,561 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SIGNALUNIT_H__ +#define __LS_SIGNALUNIT_H__ + +#include "../../common/ArrayList.h" +#include "../../common/Pool.h" + + +namespace LinuxSampler { + + template<typename T> + class FixedArray { + public: + FixedArray(int capacity) { + iSize = 0; + iCapacity = capacity; + pData = new TiCapacity; + } + + ~FixedArray() { + delete pData; + pData = NULL; + } + + inline int size() const { return iSize; } + inline int capacity() { return iCapacity; } + + void add(T element) { + if (iSize >= iCapacity) throw Exception("Array out of bounds"); + pDataiSize++ = element; + } + + + T& increment() { + if (iSize >= iCapacity) throw Exception("Array out of bounds"); + return pDataiSize++; + } + + void clear() { iSize = 0; } + + void copy(const FixedArray<T>& array) { + if(array.size() >= capacity()) throw Exception("Not enough space to copy array"); + for (int i = 0; i < array.size(); i++) pDatai = arrayi; + iSize = array.size(); + } + + inline T& operator(int idx) const { + return pDataidx; + } + + private: + T* pData; + int iSize; + int iCapacity; + }; + + class SignalUnitRack; + + /** + * A signal unit consist of internal signal generator (like envelope generator, + * low frequency oscillator, etc) with a number of generator parameters which + * influence/modulate/dynamically change the generator's signal in some manner. + * Each generator parameter (also called signal unit parameter) can receive + * signal from another signal unit and use this signal to dynamically change the + * behavior of the signal generator. In turn, the signal of this unit can be fed + * to another unit(s) and influence its parameters. + */ + class SignalUnit { + public: + + /** + * This class represents a parameter which will influence the signal + * unit to which it belongs in certain way. + * For example, let's say the signal unit is a low frequency oscillator + * with frequency 1Hz. If we want to modulate the LFO to start with 1Hz + * and increment its frequency to 5Hz in 1 second, we can add + * a parameter which signal source is an envelope + * generator with attack time of 1 second and coefficient 4. Thus, the + * normalized level of the EG will move from 0 to 1 in one second. + * On every time step (sample point) the normalized level + * will be multiplied by 4 (the parameter coefficient) and added to the + * LFO's frequency. + * So, after 1 second, the LFO frequency will be 1x4 + 1 = 5Hz. + * We can also add another parameter for modulating the LFO's pitch depth + * and so on. + */ + class Parameter { + public: + SignalUnit* pUnit; /* The source unit whose output signal + * will modulate the parameter. + */ + + float Coeff; // The modulation coefficient + + + Parameter() : Coeff(1), pUnit(NULL) { } + + /** + * @param unit The source unit used to influence this parameter. + * @param coeff The coefficient by which the normalized signal + * received from the source unit should be multiplied when a + * default transformation is done. + */ + Parameter(SignalUnit* unit, float coeff = 1) { + pUnit = unit; + Coeff = coeff; + } + + Parameter(const Parameter& Prm) { Copy(Prm); } + void operator=(const Parameter& Prm) { Copy(Prm); } + + void Copy(const Parameter& Prm) { + if (this == &Prm) return; + + pUnit = Prm.pUnit; + Coeff = Prm.Coeff; + } + + + /** + * Calculates the transformation for this parameter + * which should be applied to the parameter's value + * and multiplies by Coeff. + * This implementation of the method just multiplies by Coeff. + */ + virtual float Transform(float val) { + return val * Coeff; + } + + /** + * Gets the current value of the parameter. + * This implementation returns the current signal level of the + * source unit with applied transformation if the source unit is + * active, otherwise returns 1. + * Note that this method assume that pUnit is not NULL. + */ + virtual float GetValue() { + return pUnit->Active() ? Transform(pUnit->GetLevel()) : 1.0f; + } + }; + + + public: + ArrayList<SignalUnit::Parameter> Params; // The list of parameters which are modulating the signal unit + + SignalUnit(SignalUnitRack* rack): pRack(rack), bActive(false), Level(0.0f), bRecalculate(true), bCalculating(false), uiDelayTrigger(0) { } + SignalUnit(const SignalUnit& Unit): pRack(Unit.pRack) { Copy(Unit); } + void operator=(const SignalUnit& Unit) { Copy(Unit); } + virtual ~SignalUnit() { } + + void Copy(const SignalUnit& Unit) { + if (this == &Unit) return; + + bActive = Unit.bActive; + Level = Unit.Level; + Params = Unit.Params; + uiDelayTrigger = Unit.uiDelayTrigger; + bCalculating = false; + } + + /* + * Determines whether the unit is active. + * If the unit is not active, its level should be ignored. + * For endpoint unit this method determines whether + * the rendering should be stopped. + */ + virtual bool Active() { return bActive; } + + /** + * Override this method to process the current control change events. + * @param itEvent - iterator pointing to the event to be processed. + */ + virtual void ProcessCCEvent(uint8_t Controller, uint8_t Value) { } + + virtual void EnterReleaseStage() { } + + virtual void CancelRelease() { } + + /** + * Gets the normalized level of the unit for the current + * time step (sample point). The level is calculated if it's not + * calculated for the current step yet. Because the level depends on + * the parameters, their levels are calculated too. + */ + virtual float GetLevel() { + if (Params.empty() || !bRecalculate) return Level; + + if (bCalculating) { + std::cerr << "SignalUnit: Loop detected. Aborted!"; + return Level; + } + + bCalculating = true; + + for(int i = 0; i < Params.size(); i++) { + Paramsi.GetValue(); + } + + bRecalculate = bCalculating = false; + return Level; + } + + /** + * Will be called to increment the time with one sample point. + * The unit should recalculate or prepare for recalculation + * its current level on every call of this function. + * Note that it is not known whether all source signal unit's levels + * are recalculated before the call of this method. So, the calculations + * that depends on the unit's parameters should be postponed to + * the call of GetLevel(). + */ + virtual void Increment() { bRecalculate = true; } + + /** + * Initializes and triggers the unit. + * Note that when a voice is the owner of a unit rack, all settings + * should be reset when this method is called, because the sampler + * is reusing the voice objects. + */ + virtual void Trigger() = 0; + + /** + * When the signal unit rack is triggered, it triggers all signal + * units it holds. If for some reason the triggering of a unit + * should be delayed, this method can be set to return non-zero value + * specifying the delay in time steps. + * Note that this is only a helper method and the implementation + * should be done manually. + */ + virtual uint DelayTrigger() { return uiDelayTrigger; } + + /** + * A helper method which checks whether the delay + * stage is finished. + */ + bool DelayStage(); + + protected: + SignalUnitRack* const pRack; + + bool bActive; /* Don't use it to check the active state of the unit!!! + * Use Active() instead! */ + float Level; + bool bRecalculate; /* Determines whether the unit's level should be recalculated. */ + bool bCalculating; /* Determines whether the unit is in process of calculating + * its level. Used for preventing infinite loops. + */ + + uint uiDelayTrigger; /* in time steps */ + + }; + + class EndpointSignalUnit: public SignalUnit { + public: + EndpointSignalUnit(SignalUnitRack* rack): SignalUnit(rack) { } + + /** + * Gets the volume modulation value + * for the current time step (sample point). + */ + virtual float GetVolume() = 0; + + /** + * Gets the filter cutoff frequency modulation value + * for the current time step (sample point). + */ + virtual float GetFilterCutoff() = 0; + + /** + * Gets the pitch modulation value + * for the current time step (sample point). + */ + virtual float GetPitch() = 0; + + /** + * Gets the resonance modulation value + * for the current time step (sample point). + */ + virtual float GetResonance() = 0; + + /** Should return value in the range -100, 100 (L <-> R) */ + virtual float GetPan() = 0; + + virtual float CalculateFilterCutoff(float cutoff) { + cutoff *= GetFilterCutoff(); + return cutoff > 13500 ? 13500 : cutoff; + } + + virtual float CalculatePitch(float pitch) { + return GetPitch() * pitch; + } + + virtual float CalculateResonance(float res) { + return GetResonance() * res; + } + + /** Should return value in the range 0, 127 (L <-> R) */ + virtual uint8_t CaluclatePan(uint8_t pan) { + int p = pan + GetPan() * 0.63; + if (p < 0) return 0; + if (p > 127) return 127; + return p; + } + + /** + * Decreases the delay by Sample time steps. + * This method is used to delay the sample playback. + * While the endpoint unit is in delay stage the rack is not incremented. + */ + void DecreaseDelay(uint Samples) { + uiDelayTrigger -= Samples; + } + }; + + /** + * Used to smooth out the parameter changes. + */ + class Smoother { + protected: + uint timeSteps; // The number of time steps to reach the goal + uint currentTimeStep; + float goal; + float prev; + + public: + /** + * + * @param time The time (in seconds) to reach the goal + * @param sampleRate + * @param val The initial value + */ + void trigger(float time, float sampleRate, float val = 0) { + currentTimeStep = timeSteps = time * sampleRate; + prev = goal = val; + } + + /** + * Set the current value, which the smoother will not smooth out. + * If you want the value to be smoothen out, use update() instead. + */ + void setValue( float val) { + currentTimeStep = timeSteps; + prev = goal = val; + } + + /** + * Sets a new value. The render function will return + * values gradually approaching this value. + */ + void update(float val) { + if (val == goal) return; + + prev = prev + (goal - prev) * (currentTimeStep / (float)timeSteps); + goal = val; + currentTimeStep = 0; + } + + float render() { + if (currentTimeStep >= timeSteps) return goal; + return prev + (goal - prev) * (currentTimeStep++ / (float)timeSteps); + } + + bool isSmoothingOut() { return currentTimeStep < timeSteps; } + + float getGoal() { return goal; } + }; + + /** + * Continuous controller signal unit. + * The level of this unit corresponds to the controllers changes + * and their influences. + */ + class CCSignalUnit: public SignalUnit { + public: + /** Listener which will be notified when the level of the unit is changed. */ + class Listener { + public: + virtual void ValueChanged(CCSignalUnit* pUnit) = 0; + }; + + class CC { + public: + uint8_t Controller; ///< MIDI controller number. + uint8_t Value; ///< Controller Value. + short int Curve; ///< specifies the curve type + float Influence; + float Step; + + Smoother* pSmoother; + + CC ( + uint8_t Controller = 0, + float Influence = 0.0f, + short int Curve = -1, + Smoother* pSmoother = NULL, + float Step = 0 + ) { + this->Controller = Controller; + this->Value = 0; + this->Curve = Curve; + this->Influence = Influence; + this->pSmoother = pSmoother; + this->Step = Step; + } + + CC(const CC& cc) { Copy(cc); } + void operator=(const CC& cc) { Copy(cc); } + + void Copy(const CC& cc) { + Controller = cc.Controller; + Value = cc.Value; + Influence = cc.Influence; + Curve = cc.Curve; + pSmoother = cc.pSmoother; + Step = cc.Step; + } + }; + + protected: + RTList<CC>* pCtrls; // The MIDI controllers which modulates this signal unit. + Listener* pListener; + bool hasSmoothCtrls; // determines whether there are smooth controllers (used for optimization) + bool isSmoothingOut; // determines whether there is a CC which is in process of smoothing out (used for optimization) + + public: + + CCSignalUnit(SignalUnitRack* rack, Listener* l = NULL): SignalUnit(rack), pCtrls(NULL) { + pListener = l; + hasSmoothCtrls = isSmoothingOut = false; + } + + CCSignalUnit(const CCSignalUnit& Unit): SignalUnit(Unit.pRack), pCtrls(NULL) { Copy(Unit); } + void operator=(const CCSignalUnit& Unit) { Copy(Unit); } + + virtual ~CCSignalUnit() { + if (pCtrls != NULL) delete pCtrls; + } + + void Copy(const CCSignalUnit& Unit) { + if (pCtrls != NULL) delete pCtrls; + pCtrls = new RTList<CC>(*(Unit.pCtrls)); + if (pCtrls->poolIsEmpty() && pCtrls->count() < Unit.pCtrls->count()) { + std::cerr << "Maximum number of CC reached!" << std::endl; + } + + pListener = Unit.pListener; + hasSmoothCtrls = Unit.hasSmoothCtrls; + isSmoothingOut = Unit.isSmoothingOut; + SignalUnit::Copy(Unit); + } + + virtual void InitCCList(Pool<CC>* pCCPool, Pool<Smoother>* pSmootherPool) { + if (pCtrls != NULL) delete pCtrls; + pCtrls = new RTList<CC>(pCCPool); + } + + void AddCC(uint8_t Controller, float Influence, short int Curve = -1, Smoother* pSmoother = NULL, float Step = 0) { + if(pCtrls->poolIsEmpty()) { + std::cerr << "Maximum number of CC reached!" << std::endl; + return; + } + *(pCtrls->allocAppend()) = CC(Controller, Influence, Curve, pSmoother, Step); + if (pSmoother != NULL) hasSmoothCtrls = true; + } + + virtual void RemoveAllCCs() { pCtrls->clear(); } + + int GetCCCount() { return pCtrls->count(); } + + bool HasCCs() { return GetCCCount() > 0; } + + virtual void Increment() { + if (hasSmoothCtrls && isSmoothingOut) Calculate(); + } + + virtual void Trigger() { + Calculate(); + bActive = Level != 0; + } + + virtual void ProcessCCEvent(uint8_t Controller, uint8_t Value) { + bool recalculate = false; + + RTList<CC>::Iterator ctrl = pCtrls->first(); + RTList<CC>::Iterator end = pCtrls->end(); + for(; ctrl != end; ++ctrl) { + if (Controller != (*ctrl).Controller) continue; + if ((*ctrl).Value == Value) continue; + + (*ctrl).Value = Value; + + if ((*ctrl).Step > 0 && (*ctrl).pSmoother != NULL) { + float oldGoal = (*ctrl).pSmoother->getGoal(); + float newGoal = Normalize(Value, (*ctrl).Curve) * (*ctrl).Influence; + newGoal = ((int) (newGoal / (*ctrl).Step)) * (*ctrl).Step; + if (oldGoal != newGoal) (*ctrl).pSmoother->update(newGoal); + } + + if ((*ctrl).pSmoother != NULL && (*ctrl).Step <= 0) (*ctrl).pSmoother->update(Value); + if (!bActive) bActive = true; + recalculate = true; + } + + if (!(hasSmoothCtrls && isSmoothingOut) && recalculate) Calculate(); + } + + virtual void Calculate() { + float l = 0; + isSmoothingOut = false; + RTList<CC>::Iterator ctrl = pCtrls->first(); + RTList<CC>::Iterator end = pCtrls->end(); + for(; ctrl != end; ++ctrl) { + if ((*ctrl).pSmoother == NULL) { + float val = Normalize((*ctrl).Value, (*ctrl).Curve) * (*ctrl).Influence; + if ((*ctrl).Step > 0) val = ( (int)(val / (*ctrl).Step) ) * (*ctrl).Step; + l += val; + } else { + if ((*ctrl).pSmoother->isSmoothingOut()) isSmoothingOut = true; + + if ((*ctrl).Step > 0) { + l += (*ctrl).pSmoother->render(); + } else { + l += Normalize((*ctrl).pSmoother->render(), (*ctrl).Curve) * (*ctrl).Influence; + } + } + } + if (Level != l) { + Level = l; + if (pListener != NULL) pListener->ValueChanged(this); + } + } + + virtual float Normalize(uint8_t val, short int curve = -1) { + return val / 127.0f; + } + }; + +} // namespace LinuxSampler + +#endif /* __LS_SIGNALUNIT_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/common/SignalUnitRack.h
Added
@@ -0,0 +1,199 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 - 2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SIGNALUNITRACK_H__ +#define __LS_SIGNALUNITRACK_H__ + +#include "Event.h" +#include "SignalUnit.h" +#include "../../common/Pool.h" + + +namespace LinuxSampler { + + class EqSupport { + private: + int BandCount; + int* GainIdxs; ///< the indices of the gain controls + int* FreqIdxs; ///< the indices of the frequency controls + int* BandwidthIdxs; ///< the indices of the bandwidth controls + Effect* pEffect; + Effect* pEffect2; // If the effect is mono we'll need two effects + + inline float check(optional<float> minimum, optional<float> maximum, float value) { + if (minimum) { + float min = *minimum; + if (value < min) value = min; + } + if (maximum) { + float max = *maximum; + if (value > max) value = max; + } + + return value; + } + + public: + EqSupport(); + ~EqSupport(); + + void PrintInfo(); + + /** + * Searches for know EQ effects and create one if the search succeed. + * If the initialization is successful and EQ effect is selected, + * HasSupport() returns true; + */ + void Install(); + + void Uninstall(); + + /** Returns true if an EQ is created and is ready for use. */ + bool HasSupport() { return pEffect != NULL; } + + /** Reset the gains of all bands to 0dB. */ + void Reset() { + if (!HasSupport()) return; + for (int i = 0; i < BandCount; i++) { + pEffect->InputControl(GainIdxsi)->SetValue(0); // 0dB + if (pEffect2 != NULL) pEffect2->InputControl(GainIdxsi)->SetValue(0); // 0dB + } + } + + void InitEffect(AudioOutputDevice* pDevice) { + if (pEffect != NULL) pEffect->InitEffect(pDevice); + if (pEffect2 != NULL) pEffect2->InitEffect(pDevice); + } + + int GetBandCount() { return BandCount; } + + void SetGain(int band, float gain); + void SetFreq(int band, float freq); + void SetBandwidth(int band, float octaves); + + AudioChannel* GetInChannelLeft() { + return pEffect->InputChannel(0); + } + + AudioChannel* GetInChannelRight() { + return pEffect2 != NULL ? pEffect2->InputChannel(0) : pEffect->InputChannel(1); + } + + AudioChannel* GetOutChannelLeft() { + return pEffect->OutputChannel(0); + } + + AudioChannel* GetOutChannelRight() { + return pEffect2 != NULL ? pEffect2->OutputChannel(0) : pEffect->OutputChannel(1); + } + + void RenderAudio(uint Samples) { + pEffect->RenderAudio(Samples); + if (pEffect2 != NULL) pEffect2->RenderAudio(Samples); + } + }; + + + + class SignalUnitRack { + protected: + uint CurrentStep; // The current time step + bool bHasEq, releaseStageEntered; + + public: + FixedArray<SignalUnit*> Units; // A list of all signal units in this rack + + /** + * @param maxUnitCount We are using fixed size array because of the real-time safe requirements. + */ + SignalUnitRack(int maxUnitCount): CurrentStep(0), bHasEq(false), + releaseStageEntered(false), Units(maxUnitCount) { } + + uint GetCurrentStep() { return CurrentStep; } + + virtual EndpointSignalUnit* GetEndpointUnit() = 0; + + virtual void EnterFadeOutStage() = 0; + virtual void EnterFadeOutStage(int maxFadeOutSteps) = 0; + + /** + * Will be called to increment the time with one sample point. + * Each unit should recalculate its current level on every call of this function. + */ + virtual void Increment() { + CurrentStep++; + + for (int i = 0; i < Units.size(); i++) { + Unitsi->Increment(); + } + } + + virtual void ProcessCCEvent(RTList<Event>::Iterator& itEvent) { + if ( !(itEvent->Type == Event::type_control_change && itEvent->Param.CC.Controller) ) return; + for (int i = 0; i < Units.size(); i++) { + Unitsi->ProcessCCEvent(itEvent->Param.CC.Controller, itEvent->Param.CC.Value); + } + } + + /** Initializes and triggers the rack. */ + virtual void Trigger() { + releaseStageEntered = false; + CurrentStep = 0; + for (int i = 0; i < Units.size(); i++) { + Unitsi->Trigger(); + } + } + + /** + * When the rack belongs to a voice, this method is + * called when the voice enter the release stage. + */ + virtual void EnterReleaseStage() { + releaseStageEntered = true; + for (int i = 0; i < Units.size(); i++) { + Unitsi->EnterReleaseStage(); + } + } + + bool isReleaseStageEntered() { return releaseStageEntered; } + + /** + * When the rack belongs to a voice, this method is + * called when the voice is of type which ignore note off. + */ + virtual void CancelRelease() { + for (int i = 0; i < Units.size(); i++) { + Unitsi->CancelRelease(); + } + } + + /** + * Determines whether an equalization is applied to the voice. + * Used for optimization. + */ + bool HasEq() { return bHasEq; } + + virtual void UpdateEqSettings(EqSupport* pEqSupport) = 0; + }; +} // namespace LinuxSampler + +#endif /* __LS_SIGNALUNITRACK_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/common/SineLFO.h
Added
@@ -0,0 +1,122 @@ +/*************************************************************************** + * * + * Copyright (C) 2005 Christian Schoenebeck * + * Copyright (C) 2011 Christian Schoenebeck and Grigor Iliev * + * * + * This library 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 library is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this library; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SINELFO_H__ +#define __LS_SINELFO_H__ + +#include "LFOBase.h" + +namespace LinuxSampler { + + /** @brief sine LFO + */ + template<range_type_t RANGE> + class SineLFO : public LFOBase<RANGE> { + public: + + /** + * Constructor + * + * @param Max - maximum value of the output levels + */ + SineLFO(float Max) : LFOBase<RANGE>::LFOBase(Max) { + } + + /** + * Calculates exactly one sample point of the LFO wave. + * + * @returns next LFO level + */ + inline float render() { + uiLevel += c; + if (RANGE == range_unsigned) + return normalizer * (sin(c2 * (float)uiLevel) + 1.0f); + else /* signed range */ + return normalizer * sin(c2 * (float)uiLevel); + } + + /** + * Update LFO depth with a new external controller value. + * + * @param ExtControlValue - new external controller value + */ + inline void update(const uint16_t& ExtControlValue) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + const float max = this->InternalDepth + ExtControlValue * this->ExtControlDepthCoeff; + if (RANGE == range_unsigned) { + normalizer = max / 2.0f; + } else { // signed range + normalizer = max; + } + } + + /** + * Will be called by the voice when the key / voice was triggered. + * + * @param Frequency - frequency of the oscillator in Hz + * @param StartLevel - not implemented + * @param InternalDepth - firm, internal oscillator amplitude + * @param ExtControlDepth - defines how strong the external MIDI + * controller has influence on the + * oscillator amplitude + * @param FlipPhase - not implemented + * @param SampleRate - current sample rate of the engines + * audio output signal + */ + virtual void trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) { + this->InternalDepth = (InternalDepth / 1200.0f) * this->Max; + this->ExtControlDepthCoeff = (((float) ExtControlDepth / 1200.0f) / 127.0f) * this->Max; + + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + const float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + c2 = (2.0f * M_PI) / (float) intLimit; + + uiLevel = 0; + } + + /** + * @param phase 0 to 360 degrees + */ + void setPhase(float phase) { + if (phase < 0) phase = 0; + if (phase > 360) phase = 360; + phase /= 360.0f; + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + uiLevel = intLimit * phase; + } + + void setFrequency(float Frequency, unsigned int SampleRate) { + const unsigned int intLimit = (unsigned int) -1; // all 0xFFFF... + float r = Frequency / (float) SampleRate; // frequency alteration quotient + c = (int) (intLimit * r); + } + + protected: + unsigned int uiLevel; + int c; + float c2; + float normalizer; + }; + +} // namespace LinuxSampler + +#endif // __LS_SINELFO_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/Stream.h
Added
@@ -0,0 +1,156 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_STREAM_H__ +#define __LS_STREAM_H__ + +#include "../../common/global.h" +#include "../../common/RingBuffer.h" +#include "Sample.h" + +namespace LinuxSampler { + + /** @brief Buffered Disk Stream + * + * This encapsulation of a disk stream uses a ring buffer to allow + * thread safe refilling the stream's buffer with one thread (disk + * thread) and actual use / extraction of the audio data from the + * stream's buffer with another thread (audio thread). + */ + class Stream { + public: + // Member Types + typedef uint32_t OrderID_t; + typedef uint32_t Handle; ///< unique identifier of a relationship between one stream and a consumer (Voice) + enum { INVALID_HANDLE = 0 }; + enum state_t { ///< streams go through severe cyclic state transition (unused->active->end->unused->...) + state_unused, ///< stream is not in use, thus can still be launched + state_active, ///< stream provides data in it's buffer to be read and hasn't reached the end yet (this is the usual case) + state_end ///< stream end reached but still providing data in it's buffer to be read (after the client read all remaining data from the stream buffer, state will change automatically to state_unused) + }; + struct reference_t { ///< Defines the current relationship between the stream and a client (voice). + OrderID_t OrderID; ///< Unique identifier that identifies the creation order of a stream requested by a voice. + Handle hStream; ///< Unique identifier of the relationship between stream and client. + state_t State; ///< Current state of the stream that will be pretended to the client (the actual state of the stream might differ though, because the stream might already be in use by another client). + Stream* pStream; ///< Points to the assigned and activated stream or is NULL if the disk thread hasn't launched a stream yet. + }; + + class SampleDescription { + public: + int FrameSize; ///< Reflects the size (in bytes) of one single sample point + int ChannelsPerFrame; + int BytesPerSample; ///< Size of each sample per channel + int TotalSampleCount; + }; + + Stream(uint BufferSize, uint BufferWrapElements) { + this->pExportReference = NULL; + this->State = state_unused; + this->hThis = 0; + this->PlaybackState.position = 0; + this->PlaybackState.reverse = false; + this->pRingBuffer = new RingBuffer<uint8_t,false>(BufferSize * 3, BufferWrapElements * 3); + UnusedStreams++; + TotalStreams++; + } + + virtual ~Stream() { } + + // Methods + inline int GetReadSpace() { + return (pRingBuffer && State != state_unused) ? pRingBuffer->read_space() / SampleInfo.BytesPerSample : 0; + } + + inline int GetWriteSpace() { + return (pRingBuffer && State == state_active) ? pRingBuffer->write_space() / SampleInfo.BytesPerSample : 0; + } + + inline int GetWriteSpaceToEnd() { + return (pRingBuffer && State == state_active) ? pRingBuffer->write_space_to_end_with_wrap() / SampleInfo.BytesPerSample : 0; + } + + // adjusts the write space to avoid buffer boundaries which would lead to the wrap space + // within the buffer (needed for interpolation) getting filled only partially + // for more infos see the docs in ringbuffer.h at adjust_write_space_to_avoid_boundary() + inline int AdjustWriteSpaceToAvoidBoundary(int cnt, int capped_cnt) { + return pRingBuffer->adjust_write_space_to_avoid_boundary (cnt * SampleInfo.BytesPerSample, capped_cnt * SampleInfo.BytesPerSample) / SampleInfo.BytesPerSample; + } + + // gets the current read_ptr within the ringbuffer + inline uint8_t* GetReadPtr(void) { + return pRingBuffer->get_read_ptr(); + } + + inline void IncrementReadPos(uint Count) { + Count *= SampleInfo.BytesPerSample; + uint leftspace = pRingBuffer->read_space(); + pRingBuffer->increment_read_ptr(Min(Count, leftspace)); + if (State == state_end && Count >= leftspace) { + Reset(); // quit relation between consumer (voice) and stream and reset stream right after + } + } + + virtual int ReadAhead(unsigned long SampleCount) = 0; + virtual void WriteSilence(unsigned long SilenceSampleWords) = 0; + + // Static Method + inline static uint GetUnusedStreams() { return UnusedStreams; } + + template<class R, class IM> friend class DiskThreadBase; // only the disk thread should be able to launch and most important kill a disk stream to avoid race conditions + + protected: + // Attributes + RingBuffer<uint8_t,false>* pRingBuffer; + SampleDescription SampleInfo; + Sample::PlaybackState PlaybackState; + reference_t* pExportReference; + state_t State; + Handle hThis; + + // Static Attributes + static uint UnusedStreams; //< Reflects how many stream objects of all stream instances are currently not in use. + static uint TotalStreams; //< Reflects how many stream objects currently exist. + + // Methods + + virtual void Kill() { pExportReference = NULL; Reset(); } ///< Will be called by disk thread after a 'deletion' command from the audio thread (within the voice class) + inline Handle GetHandle() { return hThis; } + inline state_t GetState() { return State; } + + inline void SetState(state_t State) { + if (pExportReference) pExportReference->State = State; + this->State = State; + } + + virtual long Read(uint8_t* pBuf, long SamplesToRead) = 0; + virtual void Reset() = 0; + + private: + + // Methods + inline long Min(long a, long b) { return (a < b) ? a : b; } + }; +} // namespace LinuxSampler + +#endif // __LS_STREAM_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/StreamBase.cpp
Added
@@ -0,0 +1,33 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "StreamBase.h" + +#include "../../common/global_private.h" + +namespace LinuxSampler { + uint Stream::UnusedStreams = 0; + uint Stream::TotalStreams = 0; +} // namespace LinuxSampler +
View file
linuxsampler-2342.tar.bz2/src/engines/common/StreamBase.h
Added
@@ -0,0 +1,133 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_STREAMBASE_H__ +#define __LS_STREAMBASE_H__ + +#include "Stream.h" +#include "../../common/global.h" +#include "../../common/RingBuffer.h" +#include <iostream> + +namespace LinuxSampler { + + /** @brief Buffered Disk Stream + * + * This encapsulation of a disk stream uses a ring buffer to allow + * thread safe refilling the stream's buffer with one thread (disk + * thread) and actual use / extraction of the audio data from the + * stream's buffer with another thread (audio thread). + */ + template <class R> + class StreamBase : public Stream { + public: + // Methods + StreamBase(uint BufferSize, uint BufferWrapElements) : Stream(BufferSize, BufferWrapElements) { + this->pRegion = NULL; + this->SampleOffset = 0; + } + + virtual ~StreamBase() { + Reset(); + if (pRingBuffer) delete pRingBuffer; + UnusedStreams--; + TotalStreams--; + } + + /// Returns number of refilled sample points or a value < 0 on error. + virtual int ReadAhead(unsigned long SampleCount) { + if (this->State == state_unused) return -1; + if (this->State == state_end) return 0; + if (!SampleCount) return 0; + if (!pRingBuffer->write_space()) return 0; + + long samplestoread = SampleCount / SampleInfo.ChannelsPerFrame; + uint8_t* pBuf = pRingBuffer->get_write_ptr(); + long total_readsamples = Read(pBuf, samplestoread); + + // we must delay the increment_write_ptr_with_wrap() after the while() loop because we need to + // ensure that we read exactly SampleCount sample, otherwise the buffer wrapping code will fail + pRingBuffer->increment_write_ptr_with_wrap(total_readsamples * SampleInfo.FrameSize); + + return total_readsamples; + } + + virtual void WriteSilence(unsigned long SilenceSampleWords) { + memset(pRingBuffer->get_write_ptr(), 0, SilenceSampleWords * SampleInfo.BytesPerSample); + pRingBuffer->increment_write_ptr_with_wrap(SilenceSampleWords * SampleInfo.BytesPerSample); + } + + /// Called by disk thread to activate the disk stream. + void Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + R* pRgn, + SampleDescription SampleInfo, + Sample::PlaybackState PlaybackState, + unsigned long SampleOffset, + bool DoLoop + ) { + UnusedStreams--; + this->pExportReference = pExportReference; + this->hThis = hStream; + this->pRegion = pRgn; + this->SampleInfo = SampleInfo; + this->PlaybackState = PlaybackState; + this->SampleOffset = SampleOffset; + this->DoLoop = DoLoop; + SetState(state_active); + } + + protected: + // Attributes + unsigned long SampleOffset; + R* pRegion; + bool DoLoop; + + virtual void Reset() { + SampleOffset = 0; + pRegion = NULL; + PlaybackState.position = 0; + PlaybackState.reverse = false; + hThis = 0; + pRingBuffer->init(); // reset ringbuffer + if (State != state_unused) { + // we can't do 'SetPos(state_unused)' here, due to possible race conditions) + if (pExportReference) { + pExportReference->State = state_unused; + pExportReference = NULL; + } + State = state_unused; + UnusedStreams++; + } + } + + private: + + // Methods + + }; +} // namespace LinuxSampler + +#endif // __LS_STREAMBASE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/common/Voice.h
Added
@@ -0,0 +1,124 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2011 Christian Schoenebeck * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_VOICE_H__ +#define __LS_VOICE_H__ + +#include "Event.h" +#include "../gig/Filter.h" +#include "../../common/Pool.h" + +#include <gig.h> // TODO: remove gig dependency + +namespace LinuxSampler { + + class Voice { + public: + enum playback_state_t { + playback_state_end = 0, + playback_state_init = 1, + playback_state_ram = 2, + playback_state_disk = 3 + }; + + // Type bits. Mostly mutual exclusive, but a voice may both be of one shot type and require a release trigger at the same time. + enum type_t { + type_normal = 0, + type_release_trigger_required = 1 << 1, ///< If the key of this voice will be released, it causes a release triggered voice to be spawned + type_release_trigger = 1 << 2, ///< Release triggered voice which cannot be killed by releasing its key + type_one_shot = 1 << 3, ///< Voice should not be released by note off + type_controller_triggered = 1 << 4 ///< Voice is triggered by MIDI CC instead of a note on + }; + + struct PitchInfo { + float PitchBase; ///< Basic pitch depth, stays the same for the whole life time of the voice + float PitchBend; ///< Current pitch value of the pitchbend wheel + float PitchBendRange; ///< The pitch range of the pitchbend wheel, value is in cents / 8192 + }; + + struct EGInfo { + double Attack; + double Decay; + double Release; + }; + + struct SampleInfo { + uint SampleRate; + uint ChannelCount; + uint FrameSize; + uint TotalFrameCount; + uint BitDepth; + bool HasLoops; + uint LoopStart; + uint LoopLength; + uint LoopPlayCount; ///< Number of times the loop should be played (a value of 0 = infinite). + bool Unpitched; ///< sound which is not characterized by a perceived frequency + }; + + struct RegionInfo { + uint8_t UnityNote; ///< The MIDI key number of the recorded pitch of the sample + int16_t FineTune; + int Pan; ///< Panorama / Balance (-64..0..63 <-> left..middle..right) + uint SampleStartOffset; ///< Number of samples the sample start should be moved + + double EG2PreAttack; ///< Preattack value of the filter cutoff EG (in permilles) + double EG2Attack; ///< Attack time of the filter cutoff EG (in seconds) + double EG2Decay1; ///< Decay time of the filter cutoff EG (in seconds) + double EG2Decay2; ///< Only if (EG2InfiniteSustain == false): 2nd decay stage time of the filter cutoff EG (in seconds) + double EG2Sustain; ///< Sustain value of the filter cutoff EG (in permilles) + bool EG2InfiniteSustain; ///< If true, instead of going into Decay2 phase, Decay1 level will be hold until note will be released. + double EG2Release; ///< Release time of the filter cutoff EG (in seconds) + + double EG3Attack; ///< Attack time of the sample pitch EG (in seconds) + int EG3Depth; ///< Depth of the sample pitch EG (-1200 - +1200) + double ReleaseTriggerDecay; ///< How much release sample volume depends on note length. Release sample amplitude is multiplied with (1 - ReleaseTriggerDecay * note length). + + bool VCFEnabled; ///< If filter should be used. + Filter::vcf_type_t VCFType; ///< Defines the general filter characteristic (lowpass, highpass, bandpass, etc.). + uint8_t VCFResonance; ///< Firm internal filter resonance weight. + }; + + struct InstrumentInfo { + int FineTune; // in cents + uint PitchbendRange; ///< Number of semitones pitchbend controller can pitch + }; + + /// Reflects a MIDI controller + struct midi_ctrl { + uint8_t controller; ///< MIDI control change controller number + uint8_t value; ///< Current MIDI controller value + float fvalue; ///< Transformed / effective value (e.g. volume level or filter cutoff frequency) + }; + + Voice() { } + virtual ~Voice() { } + }; + + // |= operator for the type_t enum + inline Voice::type_t operator|=(Voice::type_t& lhs, Voice::type_t rhs) { + return lhs = static_cast<Voice::type_t>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs)); + } + +} // namespace LinuxSampler + +#endif /* __LS_VOICE_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/common/VoiceBase.h
Added
@@ -0,0 +1,250 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_VOICEBASE_H__ +#define __LS_VOICEBASE_H__ + +#include "AbstractVoice.h" + +namespace LinuxSampler { + + template <class EC /* Engine Channel */, class R /* Region */, class S /* Sample */, class D /* DiskThread */> + class VoiceBase : public AbstractVoice { + public: + D* pDiskThread; ///< Pointer to the disk thread, to be able to order a disk stream and later to delete the stream again + int RealSampleWordsLeftToRead; ///< Number of samples left to read, not including the silence added for the interpolator + + VoiceBase(SignalUnitRack* pRack = NULL): AbstractVoice(pRack) { + pRegion = NULL; + pDiskThread = NULL; + } + virtual ~VoiceBase() { } + + virtual R* GetRegion() { return pRegion; } + + virtual unsigned long GetSampleCacheSize() { + return pSample->GetCache().Size; + } + + /** + * Initializes and triggers the voice, a disk stream will be launched if + * needed. + * + * @param pEngineChannel - engine channel on which this voice was ordered + * @param itNoteOnEvent - event that caused triggering of this voice + * @param PitchBend - MIDI detune factor (-8192 ... +8191) + * @param pRegion - points to the region which provides sample wave(s) and articulation data + * @param VoiceType - type of this voice + * @param iKeyGroup - a value > 0 defines a key group in which this voice is member of + * @returns 0 on success, a value < 0 if the voice wasn't triggered + * (either due to an error or e.g. because no region is + * defined for the given key) + */ + virtual int Trigger ( + AbstractEngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int PitchBend, + R* pRegion, + type_t VoiceType, + int iKeyGroup + ) { + this->pRegion = pRegion; + this->pSample = pRegion->pSample; // sample won't change until the voice is finished + + return AbstractVoice::Trigger ( + pEngineChannel, itNoteOnEvent, PitchBend, VoiceType, iKeyGroup + ); + } + + virtual int OrderNewStream() { + int res = pDiskThread->OrderNewStream ( + &DiskStreamRef, pRegion, MaxRAMPos + GetRAMCacheOffset(), !RAMLoop + ); + + if (res < 0) { + dmsg(1,("Disk stream order failed!\n")); + KillImmediately(); + return -1; + } + + return 0; + } + + /** The offset of the RAM cache from the sample start (in sample units). */ + virtual int GetRAMCacheOffset() { return 0; } + + /** + * Renders the audio data for this voice for the current audio fragment. + * The sample input data can either come from RAM (cached sample or sample + * part) or directly from disk. The output signal will be rendered by + * resampling / interpolation. If this voice is a disk streaming voice and + * the voice completely played back the cached RAM part of the sample, it + * will automatically switch to disk playback for the next RenderAudio() + * call. + * + * @param Samples - number of samples to be rendered in this audio fragment cycle + */ + void Render(uint Samples) { + // select default values for synthesis mode bits + SYNTHESIS_MODE_SET_LOOP(SynthesisMode, false); + + switch (this->PlaybackState) { + + case Voice::playback_state_init: + this->PlaybackState = Voice::playback_state_ram; // we always start playback from RAM cache and switch then to disk if needed + // no break - continue with playback_state_ram + + case Voice::playback_state_ram: { + if (RAMLoop) SYNTHESIS_MODE_SET_LOOP(SynthesisMode, true); // enable looping + + // render current fragment + Synthesize(Samples, (sample_t*) pSample->GetCache().pStart, Delay); + + if (DiskVoice) { + // check if we reached the allowed limit of the sample RAM cache + if (finalSynthesisParameters.dPos > MaxRAMPos) { + dmsg(5,("VoiceBase: switching to disk playback (Pos=%f)\n", finalSynthesisParameters.dPos)); + this->PlaybackState = Voice::playback_state_disk; + } + } else if (finalSynthesisParameters.dPos >= pSample->GetCache().Size / SmplInfo.FrameSize) { + this->PlaybackState = Voice::playback_state_end; + } + } + break; + + case Voice::playback_state_disk: { + if (!DiskStreamRef.pStream) { + // check if the disk thread created our ordered disk stream in the meantime + DiskStreamRef.pStream = pDiskThread->AskForCreatedStream(DiskStreamRef.OrderID); + if (!DiskStreamRef.pStream) { + std::cout << stderr << "Disk stream not available in time!" << std::endl << std::flush; + KillImmediately(); + return; + } + DiskStreamRef.pStream->IncrementReadPos(SmplInfo.ChannelCount * (int(finalSynthesisParameters.dPos) - MaxRAMPos)); + finalSynthesisParameters.dPos -= int(finalSynthesisParameters.dPos); + RealSampleWordsLeftToRead = -1; // -1 means no silence has been added yet + } + + const int sampleWordsLeftToRead = DiskStreamRef.pStream->GetReadSpace(); + + // add silence sample at the end if we reached the end of the stream (for the interpolator) + if (DiskStreamRef.State == Stream::state_end) { + const int maxSampleWordsPerCycle = (GetEngine()->MaxSamplesPerCycle << CONFIG_MAX_PITCH) * SmplInfo.ChannelCount + 6; // +6 for the interpolator algorithm + if (sampleWordsLeftToRead <= maxSampleWordsPerCycle) { + // remember how many sample words there are before any silence has been added + if (RealSampleWordsLeftToRead < 0) RealSampleWordsLeftToRead = sampleWordsLeftToRead; + DiskStreamRef.pStream->WriteSilence(maxSampleWordsPerCycle - sampleWordsLeftToRead); + } + } + + sample_t* ptr = (sample_t*)DiskStreamRef.pStream->GetReadPtr(); // get the current read_ptr within the ringbuffer where we read the samples from + + // render current audio fragment + Synthesize(Samples, ptr, Delay); + + const int iPos = (int) finalSynthesisParameters.dPos; + const int readSampleWords = iPos * SmplInfo.ChannelCount; // amount of sample words actually been read + DiskStreamRef.pStream->IncrementReadPos(readSampleWords); + finalSynthesisParameters.dPos -= iPos; // just keep fractional part of playback position + + // change state of voice to 'end' if we really reached the end of the sample data + if (RealSampleWordsLeftToRead >= 0) { + RealSampleWordsLeftToRead -= readSampleWords; + if (RealSampleWordsLeftToRead <= 0) this->PlaybackState = Voice::playback_state_end; + } + } + break; + + case Voice::playback_state_end: + std::cerr << "VoiceBase::Render(): entered with playback_state_end, this is a bug!\n" << std::flush; + break; + } + + // Reset delay + Delay = 0; + + itTriggerEvent = Pool<Event>::Iterator(); + + // If sample stream or release stage finished, kill the voice + if (PlaybackState == Voice::playback_state_end || EG1Finished()) { + KillImmediately(); + } + } + + /** + * Immediately kill the voice. This method should not be used to kill + * a normal, active voice, because it doesn't take care of things like + * fading down the volume level to avoid clicks and regular processing + * until the kill event actually occured! + * + * If it's necessary to know when the voice's disk stream was actually + * deleted, then one can set the optional @a bRequestNotification + * parameter and this method will then return the handle of the disk + * stream (unique identifier) and one can use this handle to poll the + * disk thread if this stream has been deleted. In any case this method + * will return immediately and will not block until the stream actually + * was deleted. + * + * @param bRequestNotification - (optional) whether the disk thread shall + * provide a notification once it deleted + * the respective disk stream + * (default=false) + * @returns handle to the voice's disk stream or @c Stream::INVALID_HANDLE + * if the voice did not use a disk stream at all + * @see Kill() + */ + Stream::Handle KillImmediately(bool bRequestNotification = false) { + Stream::Handle hStream = Stream::INVALID_HANDLE; + if (DiskVoice && DiskStreamRef.State != Stream::state_unused) { + pDiskThread->OrderDeletionOfStream(&DiskStreamRef, bRequestNotification); + hStream = DiskStreamRef.hStream; + } + Reset(); + return hStream; + } + + protected: + S* pSample; ///< Pointer to the sample to be played back + R* pRegion; ///< Pointer to the articulation information of current region of this voice + + virtual MidiKeyBase* GetMidiKeyInfo(int MIDIKey) { + EC* pChannel = static_cast<EC*>(pEngineChannel); + return &pChannel->pMIDIKeyInfoMIDIKey; + } + + virtual unsigned long GetNoteOnTime(int MIDIKey) { + EC* pChannel = static_cast<EC*>(pEngineChannel); + return pChannel->pMIDIKeyInfoMIDIKey.NoteOnTime; + } + + void GetFirstEventOnKey(uint8_t MIDIKey, RTList<Event>::Iterator& itEvent) { + EC* pChannel = static_cast<EC*>(pEngineChannel); + itEvent = pChannel->pMIDIKeyInfoMIDIKey.pEvents->first(); + } + }; +} // namespace LinuxSampler + +#endif /* __LS_VOICEBASE_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/DiskThread.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/DiskThread.cpp
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * * * * 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 * @@ -21,469 +22,43 @@ * MA 02111-1307 USA * ***************************************************************************/ -#include <sstream> - #include "DiskThread.h" +#include "Stream.h" +#include "../../common/global_private.h" -namespace LinuxSampler { namespace gig { - - // *********** DiskThread ************** - // * - - +namespace LinuxSampler { // just a placeholder to mark a cell in the pickup array as 'reserved' - Stream* DiskThread::SLOT_RESERVED = (Stream*) &SLOT_RESERVED; - - - // ######################################################################### - // # Foreign Thread Section - // # (following code intended to be interface for audio thread) - - - /** - * Suspend disk thread, kill all active streams, clear all queues and the - * pickup array and reset all streams. Call this method to bring everything - * in the disk thread to day one. If the disk thread was running, it will be - * respawned right after everything was reset. - */ - void DiskThread::Reset() { - bool running = this->IsRunning(); - if (running) this->StopThread(); - for (int i = 0; i < Streams; i++) { - pStreamsi->Kill(); - } - for (int i = 1; i <= Streams; i++) { - pCreatedStreamsi = NULL; - } - GhostQueue->init(); - CreationQueue->init(); - DeletionQueue->init(); - DeletionNotificationQueue.init(); - - // make sure that all DimensionRegions are released - while (DeleteDimregQueue->read_space() > 0) { - ::gig::DimensionRegion* dimreg; - DeleteDimregQueue->pop(&dimreg); - pInstruments->HandBackDimReg(dimreg); - } - DeleteDimregQueue->init(); - SetActiveStreamCount(0); - ActiveStreamCountMax = 0; - if (running) this->StartThread(); // start thread only if it was running before - } - - String DiskThread::GetBufferFillBytes() { - bool activestreams = false; - std::stringstream ss; - for (uint i = 0; i < this->Streams; i++) { - if (pStreamsi->GetState() == Stream::state_unused) continue; - uint bufferfill = pStreamsi->GetReadSpace() * sizeof(sample_t); - uint streamid = (uint) pStreamsi->GetHandle(); - if (!streamid) continue; - - if (activestreams) ss << "," << streamid << '' << bufferfill; - else { - ss << '' << streamid << '' << bufferfill; - activestreams = true; - } - } - return ss.str(); - } - - String DiskThread::GetBufferFillPercentage() { - bool activestreams = false; - std::stringstream ss; - for (uint i = 0; i < this->Streams; i++) { - if (pStreamsi->GetState() == Stream::state_unused) continue; - uint bufferfill = (uint) ((float) pStreamsi->GetReadSpace() / (float) CONFIG_STREAM_BUFFER_SIZE * 100); - uint streamid = (uint) pStreamsi->GetHandle(); - if (!streamid) continue; - - if (activestreams) ss << "," << streamid << '' << bufferfill << '%'; - else { - ss << '' << streamid << '' << bufferfill; - activestreams = true; - } - } - return ss.str(); - } - - /** - * Returns -1 if command queue or pickup pool is full, 0 on success (will be - * called by audio thread within the voice class). - */ - int DiskThread::OrderNewStream(Stream::reference_t* pStreamRef, ::gig::DimensionRegion* pDimRgn, unsigned long SampleOffset, bool DoLoop) { - dmsg(4,("Disk Thread: new stream ordered\n")); - if (CreationQueue->write_space() < 1) { - dmsg(1,("DiskThread: Order queue full!\n")); - return -1; - } - - const Stream::OrderID_t newOrder = CreateOrderID(); - if (!newOrder) { - dmsg(1,("DiskThread: there was no free slot\n")); - return -1; // there was no free slot - } - - pStreamRef->State = Stream::state_active; - pStreamRef->OrderID = newOrder; - pStreamRef->hStream = CreateHandle(); - pStreamRef->pStream = NULL; // a stream has to be activated by the disk thread first - - create_command_t cmd; - cmd.OrderID = pStreamRef->OrderID; - cmd.hStream = pStreamRef->hStream; - cmd.pStreamRef = pStreamRef; - cmd.pDimRgn = pDimRgn; - cmd.SampleOffset = SampleOffset; - cmd.DoLoop = DoLoop; - - CreationQueue->push(&cmd); - return 0; - } - - /** - * Request the disk thread to delete the given disk stream. This method - * will return immediately, thus it won't block until the respective voice - * was actually deleted. (Called by audio thread within the Voice class). - * - * @param pStreamRef - stream that shall be deleted - * @param bRequestNotification - set to true in case you want to receive a - * notification once the stream has actually - * been deleted - * @returns 0 on success, -1 if command queue is full - * @see AskForDeletedStream() - */ - int DiskThread::OrderDeletionOfStream(Stream::reference_t* pStreamRef, bool bRequestNotification) { - dmsg(4,("Disk Thread: stream deletion ordered\n")); - if (DeletionQueue->write_space() < 1) { - dmsg(1,("DiskThread: Deletion queue full!\n")); - return -1; - } - - delete_command_t cmd; - cmd.pStream = pStreamRef->pStream; - cmd.hStream = pStreamRef->hStream; - cmd.OrderID = pStreamRef->OrderID; - cmd.bNotify = bRequestNotification; - - DeletionQueue->push(&cmd); - return 0; - } - - /** - * Tell the disk thread to release a dimension region that belongs - * to an instrument which isn't loaded anymore. The disk thread - * will hand back the dimension region to the instrument resource - * manager. (OrderDeletionOfDimreg is called from the audio thread - * when a voice dies.) - */ - int DiskThread::OrderDeletionOfDimreg(::gig::DimensionRegion* dimreg) { - dmsg(4,("Disk Thread: dimreg deletion ordered\n")); - if (DeleteDimregQueue->write_space() < 1) { - dmsg(1,("DiskThread: DeleteDimreg queue full!\n")); - return -1; - } - DeleteDimregQueue->push(&dimreg); - return 0; - } - - /** - * Tell the disk thread to do a program change on the specified - * EngineChannel. - */ - int DiskThread::OrderProgramChange(uint8_t Program, EngineChannel* pEngineChannel) { - program_change_command_t cmd; - cmd.Program = Program; - cmd.pEngineChannel = pEngineChannel; - - dmsg(4,("Disk Thread: program change ordered\n")); - if (ProgramChangeQueue.write_space() < 1) { - dmsg(1,("DiskThread: ProgramChange queue full!\n")); - return -1; - } - ProgramChangeQueue.push(&cmd); - return 0; - } - - /** - * Returns the pointer to a disk stream if the ordered disk stream - * represented by the \a StreamOrderID was already activated by the disk - * thread, returns NULL otherwise. If the call was successful, thus if it - * returned a valid stream pointer, the caller has to the store that pointer - * by himself, because it's not possible to call this method again with the - * same used order ID; this method is just intended for picking up an ordered - * disk stream. This method will usually be called by the voice class (within - * the audio thread). - * - * @param StreamOrderID - ID previously returned by OrderNewStream() - * @returns pointer to created stream object, NULL otherwise - */ - Stream* DiskThread::AskForCreatedStream(Stream::OrderID_t StreamOrderID) { - dmsg(4,("Disk Thread: been asked if stream already created, OrderID=%x ", StreamOrderID)); - Stream* pStream = pCreatedStreamsStreamOrderID; - if (pStream && pStream != SLOT_RESERVED) { - dmsg(4,("(yes created)\n")); - pCreatedStreamsStreamOrderID = NULL; // free the slot for a new order - return pStream; - } - dmsg(4,("(no not yet created)\n")); - return NULL; - } - - /** - * In case the original sender requested a notification with his stream - * deletion order, he can use this method to poll if the respective stream - * has actually been deleted. - * - * @returns handle / identifier of the deleted stream, or - * Stream::INVALID_HANDLE if no notification present - */ - Stream::Handle DiskThread::AskForDeletedStream() { - if (DeletionNotificationQueue.read_space()) { - Stream::Handle hStream; - DeletionNotificationQueue.pop(&hStream); - return hStream; - } else return Stream::INVALID_HANDLE; // no notification received yet - } - - - - // ######################################################################### - // # Disk Thread Only Section - // # (following code should only be executed by the disk thread) + template <> + LinuxSampler::Stream* LinuxSampler::DiskThreadBase< ::gig::DimensionRegion, gig::InstrumentResourceManager>::SLOT_RESERVED = (LinuxSampler::Stream*) &SLOT_RESERVED; +namespace gig { DiskThread::DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments) : - Thread(true, false, 1, -2), - pInstruments(pInstruments), - DeletionNotificationQueue(4*MaxStreams), - ProgramChangeQueue(100) + DiskThreadBase< ::gig::DimensionRegion, InstrumentResourceManager>(MaxStreams, BufferWrapElements, pInstruments) { DecompressionBuffer = ::gig::Sample::CreateDecompressionBuffer(CONFIG_STREAM_MAX_REFILL_SIZE); - CreationQueue = new RingBuffer<create_command_t,false>(4*MaxStreams); - DeletionQueue = new RingBuffer<delete_command_t,false>(4*MaxStreams); - GhostQueue = new RingBuffer<delete_command_t,false>(MaxStreams); - DeleteDimregQueue = new RingBuffer< ::gig::DimensionRegion*,false>(4*MaxStreams); - pStreams = new Stream*MaxStreams; - pCreatedStreams = new Stream*MaxStreams + 1; - Streams = MaxStreams; - RefillStreamsPerRun = CONFIG_REFILL_STREAMS_PER_RUN; - for (int i = 0; i < MaxStreams; i++) { - pStreamsi = new Stream(&DecompressionBuffer, CONFIG_STREAM_BUFFER_SIZE, BufferWrapElements); // 131072 sample words - } - for (int i = 1; i <= MaxStreams; i++) { - pCreatedStreamsi = NULL; - } - ActiveStreamCountMax = 0; + CreateAllStreams(MaxStreams, BufferWrapElements); } DiskThread::~DiskThread() { - for (int i = 0; i < Streams; i++) { - if (pStreamsi) delete pStreamsi; - } - if (CreationQueue) delete CreationQueue; - if (DeletionQueue) delete DeletionQueue; - if (GhostQueue) delete GhostQueue; - if (DeleteDimregQueue) delete DeleteDimregQueue; - if (pStreams) delete pStreams; - if (pCreatedStreams) delete pCreatedStreams; - ::gig::Sample::DestroyDecompressionBuffer(DecompressionBuffer); } - int DiskThread::Main() { - dmsg(3,("Disk thread running\n")); - while (true) { - #if !defined(WIN32) - pthread_testcancel(); // mandatory for OSX - #endif - #if CONFIG_PTHREAD_TESTCANCEL - TestCancel(); - #endif - IsIdle = true; // will be set to false if a stream got filled - - // if there are ghost streams, delete them - for (int i = 0; i < GhostQueue->read_space(); i++) { //FIXME: unefficient - delete_command_t ghostStream; - GhostQueue->pop(&ghostStream); - bool found = false; - for (int i = 0; i < this->Streams; i++) { - if (pStreamsi->GetHandle() == ghostStream.hStream) { - pStreamsi->Kill(); - found = true; - // if original sender requested a notification, let him know now - if (ghostStream.bNotify) - DeletionNotificationQueue.push(&ghostStream.hStream); - break; - } - } - if (!found) GhostQueue->push(&ghostStream); // put ghost stream handle back to the queue - } - - // if there are creation commands, create new streams - while (Stream::UnusedStreams > 0 && CreationQueue->read_space() > 0) { - create_command_t command; - CreationQueue->pop(&command); - CreateStream(command); - } - - // if there are deletion commands, delete those streams - while (Stream::UnusedStreams < Stream::TotalStreams && DeletionQueue->read_space() > 0) { - delete_command_t command; - DeletionQueue->pop(&command); - DeleteStream(command); - } - - // release DimensionRegions that belong to instruments - // that are no longer loaded - while (DeleteDimregQueue->read_space() > 0) { - ::gig::DimensionRegion* dimreg; - DeleteDimregQueue->pop(&dimreg); - pInstruments->HandBackDimReg(dimreg); - } - - // perform MIDI program change commands - while (ProgramChangeQueue.read_space() > 0) { - program_change_command_t cmd; - ProgramChangeQueue.pop(&cmd); - cmd.pEngineChannel->ExecuteProgramChange(cmd.Program); - } - RefillStreams(); // refill the most empty streams - - // if nothing was done during this iteration (eg no streambuffer - // filled with data) then sleep for 30ms - if (IsIdle) usleep(30000); - - int streamsInUsage = 0; - for (int i = Streams - 1; i >= 0; i--) { - if (pStreamsi->GetState() != Stream::state_unused) streamsInUsage++; - } - SetActiveStreamCount(streamsInUsage); - if (streamsInUsage > ActiveStreamCountMax) ActiveStreamCountMax = streamsInUsage; - } - - return EXIT_FAILURE; - } - - void DiskThread::CreateStream(create_command_t& Command) { - // search for unused stream - Stream* newstream = NULL; - for (int i = Streams - 1; i >= 0; i--) { - if (pStreamsi->GetState() == Stream::state_unused) { - newstream = pStreamsi; - break; - } - } - if (!newstream) { - std::cerr << "No unused stream found (OrderID:" << Command.OrderID << ") - report if this happens, this is a bug!\n" << std::flush; - return; - } - newstream->Launch(Command.hStream, Command.pStreamRef, Command.pDimRgn, Command.SampleOffset, Command.DoLoop); - dmsg(4,("new Stream launched by disk thread (OrderID:%d,StreamHandle:%d)\n", Command.OrderID, Command.hStream)); - if (pCreatedStreamsCommand.OrderID != SLOT_RESERVED) { - std::cerr << "DiskThread: Slot " << Command.OrderID << " already occupied! Please report this!\n" << std::flush; - newstream->Kill(); - return; - } - pCreatedStreamsCommand.OrderID = newstream; - } - - void DiskThread::DeleteStream(delete_command_t& Command) { - if (Command.pStream) { - Command.pStream->Kill(); - if (Command.bNotify) DeletionNotificationQueue.push(&Command.hStream); - } - else { // the stream wasn't created by disk thread or picked up by audio thread yet - - // if stream was created but not picked up yet - Stream* pStream = pCreatedStreamsCommand.OrderID; - if (pStream && pStream != SLOT_RESERVED) { - pStream->Kill(); - pCreatedStreamsCommand.OrderID = NULL; // free slot for new order - // if original sender requested a notification, let him know now - if (Command.bNotify) - DeletionNotificationQueue.push(&Command.hStream); - return; - } - - // the stream was not created yet - if (GhostQueue->write_space() > 0) { - GhostQueue->push(&Command); - } else { // error, queue full - if (Command.bNotify) { - dmsg(1,("DiskThread: GhostQueue full! (might lead to dead lock with instrument editor!)\n")); - } else { - dmsg(1,("DiskThread: GhostQueue full!\n")); - } - } - } - } - - void DiskThread::RefillStreams() { - // sort the streams by most empty stream - qsort(pStreams, Streams, sizeof(Stream*), CompareStreamWriteSpace); - - // refill the most empty streams - for (uint i = 0; i < RefillStreamsPerRun; i++) { - if (pStreamsi->GetState() == Stream::state_active) { - - //float filledpercentage = (float) pStreamsi->GetReadSpace() / 131072.0 * 100.0; - //dmsg(("\nbuffer fill: %.1f%\n", filledpercentage)); - - int writespace = pStreamsi->GetWriteSpaceToEnd(); - if (writespace == 0) break; - - int capped_writespace = writespace; - // if there is too much buffer space available then cut the read/write - // size to CONFIG_STREAM_MAX_REFILL_SIZE which is by default 65536 samples = 256KBytes - if (writespace > CONFIG_STREAM_MAX_REFILL_SIZE) capped_writespace = CONFIG_STREAM_MAX_REFILL_SIZE; - - // adjust the amount to read in order to ensure that the buffer wraps correctly - int read_amount = pStreamsi->AdjustWriteSpaceToAvoidBoundary(writespace, capped_writespace); - // if we wasn't able to refill one of the stream buffers by more than - // CONFIG_STREAM_MIN_REFILL_SIZE we'll send the disk thread to sleep later - if (pStreamsi->ReadAhead(read_amount) > CONFIG_STREAM_MIN_REFILL_SIZE) this->IsIdle = false; - } - } + LinuxSampler::Stream* DiskThread::CreateStream(long BufferSize, uint BufferWrapElements) { + return new Stream(&DecompressionBuffer, BufferSize, BufferWrapElements); // 131072 sample words } - /// Handle Generator - Stream::Handle DiskThread::CreateHandle() { - static uint32_t counter = 0; - if (counter == 0xffffffff) counter = 1; // we use '0' as 'invalid handle' only, so we skip 0 - else counter++; - return counter; + void DiskThread::LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::gig::DimensionRegion* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + Stream* pGigStream = dynamic_cast<Stream*>(pStream); + if(!pGigStream) throw Exception("Invalid stream type"); + pGigStream->Launch(hStream, pExportReference, pRgn, SampleOffset, DoLoop); } - - /// order ID Generator - Stream::OrderID_t DiskThread::CreateOrderID() { - static Stream::OrderID_t counter(0); - for (int i = 0; i < Streams; i++) { - if (counter == Streams) counter = 1; // we use '0' as 'invalid order' only, so we skip 0 - else counter++; - if (!pCreatedStreamscounter) { - pCreatedStreamscounter = SLOT_RESERVED; // mark this slot as reserved - return counter; // found empty slot - } - } - return 0; // no free slot - } - - - - // *********** C functions ************** - // * - - /** - * This is the comparison function the qsort algo uses to determine if a value is - * bigger than another one or special in our case; if the writespace of a stream - * is bigger than another one. - */ - int CompareStreamWriteSpace(const void* A, const void* B) { - Stream* a = *(Stream**) A; - Stream* b = *(Stream**) B; - return b->GetWriteSpace() - a->GetWriteSpace(); - } - }} // namespace LinuxSampler::gig +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/DiskThread.h -> linuxsampler-2342.tar.bz2/src/engines/gig/DiskThread.h
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * * * * 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 * @@ -22,103 +23,37 @@ ***************************************************************************/ #ifndef __LS_GIG_DISKTHREAD_H__ -#define __LS_GIG_DISKTHREAD_H__ - -#include "../../common/global_private.h" +#define __LS_GIG_DISKTHREAD_H__ +#include "../InstrumentManagerBase.h" +#include "../common/DiskThreadBase.h" +#include "InstrumentResourceManager.h" #include <gig.h> -#include "../../common/Thread.h" -#include "../../common/RingBuffer.h" -#include "../../common/atomic.h" -#include "Stream.h" -#include "Voice.h" - namespace LinuxSampler { namespace gig { - int CompareStreamWriteSpace(const void* a, const void* b); - - /** @brief Disk Reader Thread - * - * The disk reader thread is responsible for periodically refilling - * disk streams in parallel to the audio thread's rendering process. - * - * There is also a function for releasing parts of instruments not - * in use anymore (as this is not real time safe, the audio thread - * cannot do it directly). - */ - class DiskThread : public Thread { - public: - // Methods - DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments); - virtual ~DiskThread(); - void Reset(); - String GetBufferFillBytes(); - String GetBufferFillPercentage(); - int OrderNewStream(Stream::reference_t* pStreamRef, ::gig::DimensionRegion* pDimRgn, unsigned long SampleOffset, bool DoLoop); - int OrderDeletionOfStream(Stream::reference_t* pStreamRef, bool bRequestNotification = false); - int OrderDeletionOfDimreg(::gig::DimensionRegion* dimreg); - int OrderProgramChange(uint8_t Program, EngineChannel* pEngineChannel); - Stream* AskForCreatedStream(Stream::OrderID_t StreamOrderID); - Stream::Handle AskForDeletedStream(); - - // the number of streams currently in usage - // printed on the console the main thread (along with the active voice count) - uint GetActiveStreamCount() { return atomic_read(&ActiveStreamCount); } - void SetActiveStreamCount(uint Streams) { atomic_set(&ActiveStreamCount, Streams); } - int ActiveStreamCountMax; - + class DiskThread: public LinuxSampler::DiskThreadBase< ::gig::DimensionRegion, InstrumentResourceManager> { protected: ::gig::buffer_t DecompressionBuffer; ///< Used for thread safe streaming. - int Main(); ///< Implementation of virtual method from class Thread - - friend class Stream; - private: - // Private Types - struct create_command_t { - Stream::OrderID_t OrderID; - Stream::Handle hStream; - Stream::reference_t* pStreamRef; - ::gig::DimensionRegion* pDimRgn; - unsigned long SampleOffset; - bool DoLoop; - }; - struct delete_command_t { - Stream* pStream; - Stream::Handle hStream; - Stream::OrderID_t OrderID; - bool bNotify; - }; - struct program_change_command_t { - uint8_t Program; - EngineChannel* pEngineChannel; - }; - // Attributes - bool IsIdle; - uint Streams; - RingBuffer<create_command_t,false>* CreationQueue; ///< Contains commands to create streams - RingBuffer<delete_command_t,false>* DeletionQueue; ///< Contains commands to delete streams - RingBuffer<delete_command_t,false>* GhostQueue; ///< Contains handles to streams that are not used anymore and weren't deletable immediately - RingBuffer<Stream::Handle,false> DeletionNotificationQueue; ///< In case the original sender requested a notification for its stream deletion order, this queue will receive the handle of the respective stream once actually be deleted by the disk thread. - RingBuffer< ::gig::DimensionRegion*,false>* DeleteDimregQueue; ///< Contains dimension regions that are not used anymore and should be handed back to the instrument resource manager - RingBuffer<program_change_command_t,false> ProgramChangeQueue; ///< Contains requests for MIDI program change - unsigned int RefillStreamsPerRun; ///< How many streams should be refilled in each loop run - Stream** pStreams; ///< Contains all disk streams (whether used or unused) - Stream** pCreatedStreams; ///< This is where the voice (audio thread) picks up it's meanwhile hopefully created disk stream. - static Stream* SLOT_RESERVED; ///< This value is used to mark an entry in pCreatedStreams as reserved. - InstrumentResourceManager* pInstruments; ///< The instrument resource manager of the engine that is using this disk thread. Used by the dimension region deletion feature. + virtual LinuxSampler::Stream* CreateStream(long BufferSize, uint BufferWrapElements); - // Methods - void CreateStream(create_command_t& Command); - void DeleteStream(delete_command_t& Command); - void RefillStreams(); - Stream::Handle CreateHandle(); - Stream::OrderID_t CreateOrderID(); + virtual void LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::gig::DimensionRegion* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); - atomic_t ActiveStreamCount; + public: + DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments); + virtual ~DiskThread(); }; + }} // namespace LinuxSampler::gig -#endif // __LS_GIG_DISKTHREAD_H__ +#endif /* __LS_GIG_STREAM_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/EGADSR.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/EGADSR.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -27,18 +27,9 @@ namespace LinuxSampler { namespace gig { - EGADSR::EGADSR() { - enterEndStage(); - Level = 0.0; - CalculateFadeOutCoeff(CONFIG_EG_MIN_RELEASE_TIME, 44100.0); // even if the sample rate will be 192kHz it won't hurt at all - } - - void EGADSR::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { - const float killSteps = FadeOutTime * SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; - FadeOutCoeff = -1.0f / killSteps; - } - void EGADSR::update(event_t Event, uint SampleRate) { + if (atEnd(Event)) return; + if (Event == event_hold_end) HoldAttack = false; switch (Stage) { @@ -149,13 +140,6 @@ break; } break; - case stage_fadeout: - switch (Event) { - case event_stage_end: - enterEndStage(); - break; - } - break; } } @@ -180,6 +164,7 @@ ReleaseCoeff3 = ExpOffset * (1 - ReleaseCoeff2); ReleaseLevel2 = 0.25 * invVolume; + enterFirstStage(); enterAttackStage(PreAttack, AttackTime, SampleRate); } @@ -284,31 +269,4 @@ if (StepsLeft <= 0) enterFadeOutStage(); } - void EGADSR::enterFadeOutStage() { - Stage = stage_fadeout; - Segment = segment_lin; - StepsLeft = int(Level / (-FadeOutCoeff)); - Coeff = FadeOutCoeff; - if (StepsLeft <= 0) enterEndStage(); - } - - void EGADSR::enterFadeOutStage(int maxFadeOutSteps) { - Stage = stage_fadeout; - Segment = segment_lin; - StepsLeft = int(Level / (-FadeOutCoeff)); - if (StepsLeft > maxFadeOutSteps) { - StepsLeft = maxFadeOutSteps; - Coeff = -Level / maxFadeOutSteps; - } else { - Coeff = FadeOutCoeff; - } - if (StepsLeft <= 0) enterEndStage(); - } - - void EGADSR::enterEndStage() { - Stage = stage_end; - Segment = segment_end; - Level = 0; - } - }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/EGADSR.h -> linuxsampler-2342.tar.bz2/src/engines/gig/EGADSR.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -24,8 +24,7 @@ #ifndef __LS_GIG_EGADSR_H__ #define __LS_GIG_EGADSR_H__ -#include "../../common/global.h" -#include "../../common/RTMath.h" +#include "../common/EG.h" namespace LinuxSampler { namespace gig { @@ -36,39 +35,10 @@ * 'Decay_2', 'Sustain' and 'Release' for modulating arbitrary synthesis * parameters. */ -class EGADSR { +class EGADSR : public EG { public: /** - * Used to define what kind of segment the envelope currently is at. - */ - enum segment_t { - segment_end = 0, ///< final end state of envelope reached - segment_lin = 1, ///< envelope is currently at a linear segment - segment_exp = 2 ///< envelope is currently at a exponental segment - }; - - /** - * Used to inform the EG about an event. - */ - enum event_t { - event_stage_end, - event_release, - event_cancel_release, - event_hold_end - }; - - /** - * Constructor - */ - EGADSR(); - - /** - * Change fade out time. - */ - void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); - - /** * Will be called by the voice when the key / voice was triggered. * * @param PreAttack - Preattack value for the envelope @@ -97,34 +67,6 @@ void trigger(uint PreAttack, float AttackTime, bool HoldAttack, float Decay1Time, double Decay2Time, bool InfiniteSustain, uint SustainLevel, float ReleaseTime, float Volume, uint SampleRate); //FIXME: we should better use 'float' for SampleRate /** - * Returns true in case envelope hasn't reached its final end state yet. - */ - inline bool active() { - return (bool) Segment; - } - - /** - * Returns what kind of segment the envelope currently is at. - */ - inline segment_t getSegmentType() { - return Segment; - } - - /** - * Advance envelope by \a SamplePoints steps. - */ - inline void increment(int SamplePoints) { - StepsLeft = RTMath::Max(0, StepsLeft - SamplePoints); - } - - /** - * Returns amount of steps until the end of current envelope stage. - */ - inline int toStageEndLeft() { - return StepsLeft; - } - - /** * Should be called to inform the EG about an external event and * also whenever an envelope stage is completed. This will handle * the envelope's transition to the respective next stage. @@ -133,41 +75,6 @@ */ void update(event_t Event, uint SampleRate); - /** - * Calculates exactly one, the next sample point of EG - * (linear segment). Call this if envelope is currently in a linear - * segment. - * - * @returns next envelope level - */ - inline float processLin() { - return (Level += Coeff); - } - - /** - * Calculates exactly one, the next sample point of EG - * (exponential segment). Call this if envelope is currently in an - * exponential segment. - * - * @returns next envelope level - */ - inline float processExp() { - return (Level = Level * Coeff + Offset); - } - - /** - * Returns current envelope level without modifying anything. This - * might be needed once the envelope reached its final end state, - * because calling processLin() or processExp() at this point will - * result in undesired behavior. - */ - inline float getLevel() { - return Level; - } - - void enterFadeOutStage(); - void enterFadeOutStage(int maxFadeOutSteps); - private: enum stage_t { @@ -183,11 +90,6 @@ stage_end }; - float Level; - float Coeff; - float Offset; - int StepsLeft; - segment_t Segment; stage_t Stage; bool HoldAttack; bool InfiniteSustain; @@ -203,7 +105,6 @@ float ReleaseSlope; float invVolume; float ExpOffset; - float FadeOutCoeff; ///< very fast ramp down for e.g. voice stealing void enterAttackStage(const uint PreAttack, const float AttackTime, const uint SampleRate); void enterAttackHoldStage(); @@ -213,7 +114,6 @@ void enterSustainStage(); void enterReleasePart1Stage(); void enterReleasePart2Stage(); - void enterEndStage(); }; }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Engine.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/Engine.cpp
Changed
@@ -3,7 +3,8 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * * * * 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 * @@ -21,1246 +22,157 @@ * MA 02111-1307 USA * ***************************************************************************/ -#include <sstream> -#include "DiskThread.h" -#include "Voice.h" -#include "EGADSR.h" -#include "../EngineFactory.h" - #include "Engine.h" - -#include "../../common/global_private.h" +#include "EngineChannel.h" namespace LinuxSampler { namespace gig { - - InstrumentResourceManager Engine::instruments; - - std::map<AudioOutputDevice*,Engine*> Engine::engines; - - /** - * Get a gig::Engine object for the given gig::EngineChannel and the - * given AudioOutputDevice. All engine channels which are connected to - * the same audio output device will use the same engine instance. This - * method will be called by a gig::EngineChannel whenever it's - * connecting to a audio output device. - * - * @param pChannel - engine channel which acquires an engine object - * @param pDevice - the audio output device \a pChannel is connected to - */ - Engine* Engine::AcquireEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice) { - Engine* pEngine = NULL; - // check if there's already an engine for the given audio output device - if (engines.count(pDevice)) { - dmsg(4,("Using existing gig::Engine.\n")); - pEngine = enginespDevice; - - // Disable the engine while the new engine channel is - // added and initialized. The engine will be enabled again - // in EngineChannel::Connect. - pEngine->DisableAndLock(); - } else { // create a new engine (and disk thread) instance for the given audio output device - dmsg(4,("Creating new gig::Engine.\n")); - pEngine = (Engine*) EngineFactory::Create("gig"); - pEngine->Connect(pDevice); - enginespDevice = pEngine; - } - // register engine channel to the engine instance - pEngine->engineChannels.add(pChannel); - // remember index in the ArrayList - pChannel->iEngineIndexSelf = pEngine->engineChannels.size() - 1; - dmsg(4,("This gig::Engine has now %d EngineChannels.\n",pEngine->engineChannels.size())); - return pEngine; - } - - /** - * Once an engine channel is disconnected from an audio output device, - * it will immediately call this method to unregister itself from the - * engine instance and if that engine instance is not used by any other - * engine channel anymore, then that engine instance will be destroyed. - * - * @param pChannel - engine channel which wants to disconnect from it's - * engine instance - * @param pDevice - audio output device \a pChannel was connected to - */ - void Engine::FreeEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice) { - dmsg(4,("Disconnecting EngineChannel from gig::Engine.\n")); - Engine* pEngine = enginespDevice; - // unregister EngineChannel from the Engine instance - pEngine->engineChannels.remove(pChannel); - // if the used Engine instance is not used anymore, then destroy it - if (pEngine->engineChannels.empty()) { - pDevice->Disconnect(pEngine); - engines.erase(pDevice); - delete pEngine; - dmsg(4,("Destroying gig::Engine.\n")); - } - else dmsg(4,("This gig::Engine has now %d EngineChannels.\n",pEngine->engineChannels.size())); - } - - /** - * Constructor - */ - Engine::Engine() : SuspendedRegions(128) { - pAudioOutputDevice = NULL; - pDiskThread = NULL; - pEventGenerator = NULL; - pSysexBuffer = new RingBuffer<uint8_t,false>(CONFIG_SYSEX_BUFFER_SIZE, 0); - pEventQueue = new RingBuffer<Event,false>(CONFIG_MAX_EVENTS_PER_FRAGMENT, 0); - pEventPool = new Pool<Event>(CONFIG_MAX_EVENTS_PER_FRAGMENT); - pVoicePool = new Pool<Voice>(GLOBAL_MAX_VOICES); - pDimRegionPool0 = new Pool< ::gig::DimensionRegion*>(GLOBAL_MAX_VOICES); - pDimRegionPool1 = new Pool< ::gig::DimensionRegion*>(GLOBAL_MAX_VOICES); - pVoiceStealingQueue = new RTList<Event>(pEventPool); - pGlobalEvents = new RTList<Event>(pEventPool); - iMaxDiskStreams = GLOBAL_MAX_STREAMS; - FrameTime = 0; - - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - iterVoice->SetEngine(this); - } - pVoicePool->clear(); - - ResetInternal(); - ResetScaleTuning(); - ResetSuspendedRegions(); - } - - /** - * Destructor - */ - Engine::~Engine() { - MidiInputPort::RemoveSysexListener(this); - if (pDiskThread) { - dmsg(1,("Stopping disk thread...")); - pDiskThread->StopThread(); - delete pDiskThread; - dmsg(1,("OK\n")); - } - if (pEventQueue) delete pEventQueue; - if (pEventPool) delete pEventPool; - if (pVoicePool) { - pVoicePool->clear(); - delete pVoicePool; - } - if (pEventGenerator) delete pEventGenerator; - if (pVoiceStealingQueue) delete pVoiceStealingQueue; - if (pSysexBuffer) delete pSysexBuffer; - if (pGlobalEvents) delete pGlobalEvents; - if (pDimRegionPool0) delete pDimRegionPool0; - if (pDimRegionPool1) delete pDimRegionPool1; - ResetSuspendedRegions(); - Unregister(); - } - - void Engine::Enable() { - dmsg(3,("gig::Engine: enabling\n")); - EngineDisabled.PushAndUnlock(false, 2, 0, true); // set condition object 'EngineDisabled' to false (wait max. 2s) - dmsg(3,("gig::Engine: enabled (val=%d)\n", EngineDisabled.GetUnsafe())); - } - - /** - * Temporarily stop the engine to not do anything. The engine will just be - * frozen during that time, that means after enabling it again it will - * continue where it was, with all its voices and playback state it had at - * the point of disabling. Notice that the engine's (audio) thread will - * continue to run, it just remains in an inactive loop during that time. - * - * If you need to be sure that all voices and disk streams are killed as - * well, use @c SuspendAll() instead. - * - * @see Enable(), SuspendAll() - */ - void Engine::Disable() { - dmsg(3,("gig::Engine: disabling\n")); - bool* pWasDisabled = EngineDisabled.PushAndUnlock(true, 2); // wait max. 2s - if (!pWasDisabled) dmsg(3,("gig::Engine warning: Timeout waiting to disable engine.\n")); - } - - void Engine::DisableAndLock() { - dmsg(3,("gig::Engine: disabling\n")); - bool* pWasDisabled = EngineDisabled.Push(true, 2); // wait max. 2s - if (!pWasDisabled) dmsg(3,("gig::Engine warning: Timeout waiting to disable engine.\n")); - } - - /** - * Similar to @c Disable() but this method additionally kills all voices - * and disk streams and blocks until all voices and disk streams are actually - * killed / deleted. - * - * @e Note: only the original calling thread is able to re-enable the - * engine afterwards by calling @c ResumeAll() later on! - */ - void Engine::SuspendAll() { - dmsg(2,("gig::Engine: Suspending all ...\n")); - // stop the engine, so we can safely modify the engine's - // data structures from this foreign thread - DisableAndLock(); - // we could also use the respective class member variable here, - // but this is probably safer and cleaner - int iPendingStreamDeletions = 0; - // kill all voices on all engine channels the *die hard* way - for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { - EngineChannel* pEngineChannel = engineChannelsiChannel; - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - for (; iuiKey != end; ++iuiKey) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - // request a notification from disk thread side for stream deletion - const Stream::Handle hStream = itVoice->KillImmediately(true); - if (hStream != Stream::INVALID_HANDLE) { // voice actually used a stream - iPendingStreamDeletions++; - } - // free the voice to the voice pool and update key info - FreeVoice(pEngineChannel, itVoice); - } - } - } - // wait until all streams were actually deleted by the disk thread - while (iPendingStreamDeletions) { - while ( - iPendingStreamDeletions && - pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE - ) iPendingStreamDeletions--; - if (!iPendingStreamDeletions) break; - usleep(10000); // sleep for 10ms - } - dmsg(2,("gig::Engine: Everything suspended.\n")); - } - - /** - * At the moment same as calling @c Enable() directly, but this might - * change in future, so better call this method as counterpart to - * @c SuspendAll() instead of @c Enable() ! - */ - void Engine::ResumeAll() { - Enable(); - } - - /** - * Order the engine to stop rendering audio for the given region. - * Additionally this method will block until all voices and their disk - * streams associated with that region are actually killed / deleted, so - * one can i.e. safely modify the region with an instrument editor after - * returning from this method. - * - * @param pRegion - region the engine shall stop using - */ - void Engine::Suspend(::gig::Region* pRegion) { - dmsg(2,("gig::Engine: Suspending Region %x ...\n",pRegion)); - SuspendedRegionsMutex.Lock(); - SuspensionChangeOngoing.Set(true); - pPendingRegionSuspension = pRegion; - SuspensionChangeOngoing.WaitAndUnlockIf(true); - SuspendedRegionsMutex.Unlock(); - dmsg(2,("gig::Engine: Region %x suspended.",pRegion)); - } - - /** - * Orders the engine to resume playing back the given region, previously - * suspended with @c Suspend() . - * - * @param pRegion - region the engine shall be allowed to use again - */ - void Engine::Resume(::gig::Region* pRegion) { - dmsg(2,("gig::Engine: Resuming Region %x ...\n",pRegion)); - SuspendedRegionsMutex.Lock(); - SuspensionChangeOngoing.Set(true); - pPendingRegionResumption = pRegion; - SuspensionChangeOngoing.WaitAndUnlockIf(true); - SuspendedRegionsMutex.Unlock(); - dmsg(2,("gig::Engine: Region %x resumed.\n",pRegion)); - } - - /** - * Reset all voices and disk thread and clear input event queue and all - * control and status variables. - */ - void Engine::Reset() { - DisableAndLock(); - ResetInternal(); - ResetScaleTuning(); - Enable(); - } - - /** - * Reset all voices and disk thread and clear input event queue and all - * control and status variables. This method is protected by a mutex. - */ - void Engine::ResetInternal() { - ResetInternalMutex.Lock(); - - // make sure that the engine does not get any sysex messages - // while it's reseting - bool sysexDisabled = MidiInputPort::RemoveSysexListener(this); - SetVoiceCount(0); - ActiveVoiceCountMax = 0; - - // reset voice stealing parameters - pVoiceStealingQueue->clear(); - itLastStolenVoice = RTList<Voice>::Iterator(); - itLastStolenVoiceGlobally = RTList<Voice>::Iterator(); - iuiLastStolenKey = RTList<uint>::Iterator(); - iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); - pLastStolenChannel = NULL; - - // reset all voices - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - iterVoice->Reset(); - } - pVoicePool->clear(); - - // reset disk thread - if (pDiskThread) pDiskThread->Reset(); - - // delete all input events - pEventQueue->init(); - pSysexBuffer->init(); - if (sysexDisabled) MidiInputPort::AddSysexListener(this); - ResetInternalMutex.Unlock(); - } + Engine::Format Engine::GetEngineFormat() { return GIG; } /** - * Reset to normal, chromatic scale (means equal tempered). - */ - void Engine::ResetScaleTuning() { - memset(&ScaleTuning0, 0x00, 12); - } - - void Engine::ResetSuspendedRegions() { - SuspendedRegions.clear(); - iPendingStreamDeletions = 0; - pPendingRegionSuspension = pPendingRegionResumption = NULL; - SuspensionChangeOngoing.Set(false); - } - - /** - * Connect this engine instance with the given audio output device. - * This method will be called when an Engine instance is created. - * All of the engine's data structures which are dependant to the used - * audio output device / driver will be (re)allocated and / or - * adjusted appropriately. - * - * @param pAudioOut - audio output device to connect to - */ - void Engine::Connect(AudioOutputDevice* pAudioOut) { - // caution: don't ignore if connecting to the same device here, - // because otherwise SetMaxDiskStreams() implementation won't work anymore! - - pAudioOutputDevice = pAudioOut; - - ResetInternal(); - - // inform audio driver for the need of two channels - try { - pAudioOutputDevice->AcquireChannels(2); // gig engine only stereo - } - catch (AudioOutputException e) { - String msg = "Audio output device unable to provide 2 audio channels, cause: " + e.Message(); - throw Exception(msg); - } - - this->MaxSamplesPerCycle = pAudioOutputDevice->MaxSamplesPerCycle(); - this->SampleRate = pAudioOutputDevice->SampleRate(); - - MinFadeOutSamples = int(double(SampleRate) * CONFIG_EG_MIN_RELEASE_TIME) - 1; - if (MaxSamplesPerCycle < MinFadeOutSamples) { - std::cerr << "gig::Engine: WARNING, CONFIG_EG_MIN_RELEASE_TIME " - << "too big for current audio fragment size & sampling rate! " - << "May lead to click sounds if voice stealing chimes in!\n" << std::flush; - // force volume ramp downs at the beginning of each fragment - MinFadeOutSamples = MaxSamplesPerCycle; - // lower minimum release time - const float minReleaseTime = (float) MaxSamplesPerCycle / (float) SampleRate; - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - iterVoice->EG1.CalculateFadeOutCoeff(minReleaseTime, SampleRate); - } - pVoicePool->clear(); - } - - // (re)create disk thread - if (this->pDiskThread) { - dmsg(1,("Stopping disk thread...")); - this->pDiskThread->StopThread(); - delete this->pDiskThread; - dmsg(1,("OK\n")); - } - this->pDiskThread = - new DiskThread( - iMaxDiskStreams, - ((pAudioOut->MaxSamplesPerCycle() << CONFIG_MAX_PITCH) << 1) + 6, //FIXME: assuming stereo - &instruments - ); - - if (!pDiskThread) { - dmsg(0,("gig::Engine new diskthread = NULL\n")); - exit(EXIT_FAILURE); - } - - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - iterVoice->pDiskThread = this->pDiskThread; - dmsg(3,("d")); - } - pVoicePool->clear(); - - // (re)create event generator - if (pEventGenerator) delete pEventGenerator; - pEventGenerator = new EventGenerator(pAudioOut->SampleRate()); - - dmsg(1,("Starting disk thread...")); - pDiskThread->StartThread(); - dmsg(1,("OK\n")); - - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - if (!iterVoice->pDiskThread) { - dmsg(0,("Engine -> voice::trigger: !pDiskThread\n")); - exit(EXIT_FAILURE); - } - } - pVoicePool->clear(); - } - - /** - * Called by the engine's (audio) thread once per cycle to process requests - * from the outer world to suspend or resume a given @c gig::Region . - */ - void Engine::ProcessSuspensionsChanges() { - // process request for suspending one region - if (pPendingRegionSuspension) { - // kill all voices on all engine channels that use this region - for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { - EngineChannel* pEngineChannel = engineChannelsiChannel; - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - for (; iuiKey != end; ++iuiKey) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - // if current key is not associated with this region, skip this key - if (itVoice->pDimRgn->GetParent() != pPendingRegionSuspension) continue; - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - // request a notification from disk thread side for stream deletion - const Stream::Handle hStream = itVoice->KillImmediately(true); - if (hStream != Stream::INVALID_HANDLE) { // voice actually used a stream - iPendingStreamDeletions++; - } - //NOTE: maybe we should call FreeVoice() here, shouldn't cause a harm though I think, since the voices should be freed by RenderActiveVoices() in the render loop, they are probably just freed a bit later than they could/should be - } - } - } - // make sure the region is not yet on the list - bool bAlreadySuspended = false; - RTList< ::gig::Region*>::Iterator iter = SuspendedRegions.first(); - RTList< ::gig::Region*>::Iterator end = SuspendedRegions.end(); - for (; iter != end; ++iter) { // iterate through all suspended regions - if (*iter == pPendingRegionSuspension) { // found - bAlreadySuspended = true; - dmsg(1,("gig::Engine: attempt to suspend an already suspended region !!!\n")); - break; - } - } - if (!bAlreadySuspended) { - // put the region on the list of suspended regions - RTList< ::gig::Region*>::Iterator iter = SuspendedRegions.allocAppend(); - if (iter) { - *iter = pPendingRegionSuspension; - } else std::cerr << "gig::Engine: Could not suspend Region, list is full. This is a bug!!!\n" << std::flush; - } - // free request slot for next caller (and to make sure that - // we're not going to process the same request in the next cycle) - pPendingRegionSuspension = NULL; - // if no disk stream deletions are pending, awaken other side, as - // we're done in this case - if (!iPendingStreamDeletions) SuspensionChangeOngoing.Set(false); - } - - // process request for resuming one region - if (pPendingRegionResumption) { - // remove region from the list of suspended regions - RTList< ::gig::Region*>::Iterator iter = SuspendedRegions.first(); - RTList< ::gig::Region*>::Iterator end = SuspendedRegions.end(); - for (; iter != end; ++iter) { // iterate through all suspended regions - if (*iter == pPendingRegionResumption) { // found - SuspendedRegions.free(iter); - break; // done - } - } - // free request slot for next caller - pPendingRegionResumption = NULL; - // awake other side as we're done - SuspensionChangeOngoing.Set(false); - } - } - - /** - * Called by the engine's (audio) thread once per cycle to check if - * streams of voices that were killed due to suspension request have - * finally really been deleted by the disk thread. - */ - void Engine::ProcessPendingStreamDeletions() { - if (!iPendingStreamDeletions) return; - //TODO: or shall we better store a list with stream handles instead of a scalar amount of streams to be deleted? might be safer - while ( - iPendingStreamDeletions && - pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE - ) iPendingStreamDeletions--; - // just for safety ... - while (pDiskThread->AskForDeletedStream() != Stream::INVALID_HANDLE); - // now that all disk streams are deleted, awake other side as - // we're finally done with suspending the requested region - if (!iPendingStreamDeletions) SuspensionChangeOngoing.Set(false); - } - - /** - * Returns @c true if the given region is currently set to be suspended - * from being used, @c false otherwise. - */ - bool Engine::RegionSuspended(::gig::Region* pRegion) { - if (SuspendedRegions.isEmpty()) return false; - //TODO: or shall we use a sorted container instead of the RTList? might be faster ... or trivial ;-) - RTList< ::gig::Region*>::Iterator iter = SuspendedRegions.first(); - RTList< ::gig::Region*>::Iterator end = SuspendedRegions.end(); - for (; iter != end; ++iter) // iterate through all suspended regions - if (*iter == pRegion) return true; - return false; - } - - /** - * Clear all engine global event lists. - */ - void Engine::ClearEventLists() { - pGlobalEvents->clear(); - } - - /** - * Copy all events from the engine's global input queue buffer to the - * engine's internal event list. This will be done at the beginning of - * each audio cycle (that is each RenderAudio() call) to distinguish - * all global events which have to be processed in the current audio - * cycle. These events are usually just SysEx messages. Every - * EngineChannel has it's own input event queue buffer and event list - * to handle common events like NoteOn, NoteOff and ControlChange - * events. - * - * @param Samples - number of sample points to be processed in the - * current audio cycle - */ - void Engine::ImportEvents(uint Samples) { - RingBuffer<Event,false>::NonVolatileReader eventQueueReader = pEventQueue->get_non_volatile_reader(); - Event* pEvent; - while (true) { - // get next event from input event queue - if (!(pEvent = eventQueueReader.pop())) break; - // if younger event reached, ignore that and all subsequent ones for now - if (pEvent->FragmentPos() >= Samples) { - eventQueueReader--; - dmsg(2,("Younger Event, pos=%d ,Samples=%d!\n",pEvent->FragmentPos(),Samples)); - pEvent->ResetFragmentPos(); - break; - } - // copy event to internal event list - if (pGlobalEvents->poolIsEmpty()) { - dmsg(1,("Event pool emtpy!\n")); - break; - } - *pGlobalEvents->allocAppend() = *pEvent; - } - eventQueueReader.free(); // free all copied events from input queue - } - - /** - * Let this engine proceed to render the given amount of sample points. - * The engine will iterate through all engine channels and render audio - * for each engine channel independently. The calculated audio data of - * all voices of each engine channel will be placed into the audio sum - * buffers of the respective audio output device, connected to the - * respective engine channel. + * Reacts on supported control change commands (e.g. pitch bend wheel, + * modulation wheel, aftertouch). * - * @param Samples - number of sample points to be rendered - * @returns 0 on success + * @param pEngineChannel - engine channel on which this event occured on + * @param itControlChangeEvent - controller, value and time stamp of the event */ - int Engine::RenderAudio(uint Samples) { - dmsg(8,("RenderAudio(Samples=%d)\n", Samples)); - - // return if engine disabled - if (EngineDisabled.Pop()) { - dmsg(5,("gig::Engine: engine disabled (val=%d)\n",EngineDisabled.GetUnsafe())); - EngineDisabled.RttDone(); - return 0; - } - - // process requests for suspending / resuming regions (i.e. to avoid - // crashes while these regions are modified by an instrument editor) - ProcessSuspensionsChanges(); - - // update time of start and end of this audio fragment (as events' time stamps relate to this) - pEventGenerator->UpdateFragmentTime(Samples); - - // We only allow the given maximum number of voices to be spawned - // in each audio fragment. All subsequent request for spawning new - // voices in the same audio fragment will be ignored. - VoiceSpawnsLeft = MaxVoices(); - - // get all events from the engine's global input event queue which belong to the current fragment - // (these are usually just SysEx messages) - ImportEvents(Samples); - - // process engine global events (these are currently only MIDI System Exclusive messages) - { - RTList<Event>::Iterator itEvent = pGlobalEvents->first(); - RTList<Event>::Iterator end = pGlobalEvents->end(); - for (; itEvent != end; ++itEvent) { - switch (itEvent->Type) { - case Event::type_sysex: - dmsg(5,("Engine: Sysex received\n")); - ProcessSysex(itEvent); - break; - } - } - } - - // reset internal voice counter (just for statistic of active voices) - ActiveVoiceCountTemp = 0; - - // handle instrument change commands - bool instrumentChanged = false; - for (int i = 0; i < engineChannels.size(); i++) { - EngineChannel* pEngineChannel = engineChannelsi; - - // as we're going to (carefully) write some status to the - // synchronized struct, we cast away the const - EngineChannel::instrument_change_command_t& cmd = - const_cast<EngineChannel::instrument_change_command_t&>(pEngineChannel->InstrumentChangeCommandReader.Lock()); - - pEngineChannel->pDimRegionsInUse = cmd.pDimRegionsInUse; - pEngineChannel->pDimRegionsInUse->clear(); - - if (cmd.bChangeInstrument) { - // change instrument - dmsg(5,("Engine: instrument change command received\n")); - cmd.bChangeInstrument = false; - pEngineChannel->pInstrument = cmd.pInstrument; - instrumentChanged = true; - - // Iterate through all active voices and mark them as - // "orphans", which means that the dimension regions - // and samples they use should be released to the - // instrument resource manager when the voices die. - int i = 0; - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - while (iuiKey != end) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - ++iuiKey; - - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - itVoice->Orphan = true; - } - } - } - } - if (instrumentChanged) { - //TODO: this is a lazy solution ATM and not safe in case somebody is currently editing the instrument we're currently switching to (we should store all suspended regions on instrument manager side and when switching to another instrument copy that list to the engine's local list of suspensions - ResetSuspendedRegions(); - } - - // handle events on all engine channels - for (int i = 0; i < engineChannels.size(); i++) { - ProcessEvents(engineChannelsi, Samples); - } - - // render all 'normal', active voices on all engine channels - for (int i = 0; i < engineChannels.size(); i++) { - RenderActiveVoices(engineChannelsi, Samples); - } - - // now that all ordinary voices on ALL engine channels are rendered, render new stolen voices - RenderStolenVoices(Samples); - - // handle audio routing for engine channels with FX sends - for (int i = 0; i < engineChannels.size(); i++) { - if (engineChannelsi->fxSends.empty()) continue; // ignore if no FX sends - RouteAudio(engineChannelsi, Samples); - } - - // handle cleanup on all engine channels for the next audio fragment - for (int i = 0; i < engineChannels.size(); i++) { - PostProcess(engineChannelsi); - } - - - // empty the engine's event list for the next audio fragment - ClearEventLists(); - - // reset voice stealing for the next audio fragment - pVoiceStealingQueue->clear(); - - // just some statistics about this engine instance - SetVoiceCount(ActiveVoiceCountTemp); - if (VoiceCount() > ActiveVoiceCountMax) ActiveVoiceCountMax = VoiceCount(); - - // in case regions were previously suspended and we killed voices - // with disk streams due to that, check if those streams have finally - // been deleted by the disk thread - if (iPendingStreamDeletions) ProcessPendingStreamDeletions(); - - for (int i = 0; i < engineChannels.size(); i++) { - engineChannelsi->InstrumentChangeCommandReader.Unlock(); - } - FrameTime += Samples; + void Engine::ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ) { + dmsg(4,("Engine::ContinuousController cc=%d v=%d\n", itControlChangeEvent->Param.CC.Controller, itControlChangeEvent->Param.CC.Value)); - EngineDisabled.RttDone(); - return 0; - } + EngineChannel* pChannel = dynamic_cast<EngineChannel*>(pEngineChannel); + // handle the "control triggered" MIDI rule: a control change + // event can trigger a new note on or note off event + if (pChannel->pInstrument) { - /** - * Dispatch and handle all events in this audio fragment for the given - * engine channel. - * - * @param pEngineChannel - engine channel on which events should be - * processed - * @param Samples - amount of sample points to be processed in - * this audio fragment cycle - */ - void Engine::ProcessEvents(EngineChannel* pEngineChannel, uint Samples) { - // get all events from the engine channels's input event queue which belong to the current fragment - // (these are the common events like NoteOn, NoteOff, ControlChange, etc.) - pEngineChannel->ImportEvents(Samples); - - // process events - { - RTList<Event>::Iterator itEvent = pEngineChannel->pEvents->first(); - RTList<Event>::Iterator end = pEngineChannel->pEvents->end(); - for (; itEvent != end; ++itEvent) { - switch (itEvent->Type) { - case Event::type_note_on: - dmsg(5,("Engine: Note on received\n")); - ProcessNoteOn((EngineChannel*)itEvent->pEngineChannel, itEvent); - break; - case Event::type_note_off: - dmsg(5,("Engine: Note off received\n")); - ProcessNoteOff((EngineChannel*)itEvent->pEngineChannel, itEvent); - break; - case Event::type_control_change: - dmsg(5,("Engine: MIDI CC received\n")); - ProcessControlChange((EngineChannel*)itEvent->pEngineChannel, itEvent); - break; - case Event::type_pitchbend: - dmsg(5,("Engine: Pitchbend received\n")); - ProcessPitchbend((EngineChannel*)itEvent->pEngineChannel, itEvent); - break; - } - } - } + ::gig::MidiRule* rule; + for (int i = 0 ; (rule = pChannel->pInstrument->GetMidiRule(i)) ; i++) { - // reset voice stealing for the next engine channel (or next audio fragment) - itLastStolenVoice = RTList<Voice>::Iterator(); - itLastStolenVoiceGlobally = RTList<Voice>::Iterator(); - iuiLastStolenKey = RTList<uint>::Iterator(); - iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); - pLastStolenChannel = NULL; - } + if (::gig::MidiRuleCtrlTrigger* ctrlTrigger = + dynamic_cast< ::gig::MidiRuleCtrlTrigger*>(rule)) { + if (itControlChangeEvent->Param.CC.Controller == + ctrlTrigger->ControllerNumber) { - /** - * Render all 'normal' voices (that is voices which were not stolen in - * this fragment) on the given engine channel. - * - * @param pEngineChannel - engine channel on which audio should be - * rendered - * @param Samples - amount of sample points to be rendered in - * this audio fragment cycle - */ - void Engine::RenderActiveVoices(EngineChannel* pEngineChannel, uint Samples) { - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - uint voiceCount = 0; - uint streamCount = 0; - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - while (iuiKey != end) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - ++iuiKey; - - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - // now render current voice - itVoice->Render(Samples); - if (itVoice->IsActive()) { // still active - if (!itVoice->Orphan) { - *(pEngineChannel->pDimRegionsInUse->allocAppend()) = itVoice->pDimRgn; - } - ActiveVoiceCountTemp++; - voiceCount++; + uint8_t oldCCValue = pChannel->ControllerTable + itControlChangeEvent->Param.CC.Controller; + uint8_t newCCValue = itControlChangeEvent->Param.CC.Value; - if (itVoice->PlaybackState == Voice::playback_state_disk) { - if ((itVoice->DiskStreamRef).State != Stream::state_unused) streamCount++; - } - } else { // voice reached end, is now inactive - FreeVoice(pEngineChannel, itVoice); // remove voice from the list of active voices - } - } - } + for (int i = 0 ; i < ctrlTrigger->Triggers ; i++) { + ::gig::MidiRuleCtrlTrigger::trigger_t* pTrigger = + &ctrlTrigger->pTriggersi; - pEngineChannel->SetVoiceCount(voiceCount); - pEngineChannel->SetDiskStreamCount(streamCount); - } + // check if the controller has passed the + // trigger point in the right direction + if ((pTrigger->Descending && + oldCCValue > pTrigger->TriggerPoint && + newCCValue <= pTrigger->TriggerPoint) || + (!pTrigger->Descending && + oldCCValue < pTrigger->TriggerPoint && + newCCValue >= pTrigger->TriggerPoint)) { - /** - * Render all stolen voices (only voices which were stolen in this - * fragment) on the given engine channel. Stolen voices are rendered - * after all normal voices have been rendered; this is needed to render - * audio of those voices which were selected for voice stealing until - * the point were the stealing (that is the take over of the voice) - * actually happened. - * - * @param pEngineChannel - engine channel on which audio should be - * rendered - * @param Samples - amount of sample points to be rendered in - * this audio fragment cycle - */ - void Engine::RenderStolenVoices(uint Samples) { - RTList<Event>::Iterator itVoiceStealEvent = pVoiceStealingQueue->first(); - RTList<Event>::Iterator end = pVoiceStealingQueue->end(); - for (; itVoiceStealEvent != end; ++itVoiceStealEvent) { - EngineChannel* pEngineChannel = (EngineChannel*) itVoiceStealEvent->pEngineChannel; - if (!pEngineChannel->pInstrument) continue; // ignore if no instrument loaded - Pool<Voice>::Iterator itNewVoice = - LaunchVoice(pEngineChannel, itVoiceStealEvent, itVoiceStealEvent->Param.Note.Layer, itVoiceStealEvent->Param.Note.ReleaseTrigger, false, false); - if (itNewVoice) { - itNewVoice->Render(Samples); - if (itNewVoice->IsActive()) { // still active - *(pEngineChannel->pDimRegionsInUse->allocAppend()) = itNewVoice->pDimRgn; - ActiveVoiceCountTemp++; - pEngineChannel->SetVoiceCount(pEngineChannel->GetVoiceCount() + 1); - - if (itNewVoice->PlaybackState == Voice::playback_state_disk) { - if (itNewVoice->DiskStreamRef.State != Stream::state_unused) { - pEngineChannel->SetDiskStreamCount(pEngineChannel->GetDiskStreamCount() + 1); - } - } - } else { // voice reached end, is now inactive - FreeVoice(pEngineChannel, itNewVoice); // remove voice from the list of active voices - } - } - else dmsg(1,("gig::Engine: ERROR, voice stealing didn't work out!\n")); + RTList<Event>::Iterator itNewEvent = pGlobalEvents->allocAppend(); + if (itNewEvent) { + *itNewEvent = *itControlChangeEvent; + itNewEvent->Param.Note.Key = pTrigger->Key; - // we need to clear the key's event list explicitly here in case key was never active - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfoitVoiceStealEvent->Param.Note.Key; - pKey->VoiceTheftsQueued--; - if (!pKey->Active && !pKey->VoiceTheftsQueued) pKey->pEvents->clear(); - } - } + if (pTrigger->NoteOff || pTrigger->Velocity == 0) { + itNewEvent->Type = Event::type_note_off; + itNewEvent->Param.Note.Velocity = 100; - /** - * Will be called in case the respective engine channel sports FX send - * channels. In this particular case, engine channel local buffers are - * used to render and mix all voices to. This method is responsible for - * copying the audio data from those local buffers to the master audio - * output channels as well as to the FX send audio output channels with - * their respective FX send levels. - * - * @param pEngineChannel - engine channel from which audio should be - * routed - * @param Samples - amount of sample points to be routed in - * this audio fragment cycle - */ - void Engine::RouteAudio(EngineChannel* pEngineChannel, uint Samples) { - // route dry signal - { - AudioChannel* pDstL = pAudioOutputDevice->Channel(pEngineChannel->AudioDeviceChannelLeft); - AudioChannel* pDstR = pAudioOutputDevice->Channel(pEngineChannel->AudioDeviceChannelRight); - pEngineChannel->pChannelLeft->MixTo(pDstL, Samples); - pEngineChannel->pChannelRight->MixTo(pDstR, Samples); - } - // route FX send signal - { - for (int iFxSend = 0; iFxSend < pEngineChannel->GetFxSendCount(); iFxSend++) { - FxSend* pFxSend = pEngineChannel->GetFxSend(iFxSend); - for (int iChan = 0; iChan < 2; ++iChan) { - AudioChannel* pSource = - (iChan) - ? pEngineChannel->pChannelRight - : pEngineChannel->pChannelLeft; - const int iDstChan = pFxSend->DestinationChannel(iChan); - if (iDstChan < 0) { - dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination channel (%d->%d)", ((iChan) ? "R" : "L"), iChan, iDstChan)); - goto channel_cleanup; - } - AudioChannel* pDstChan = NULL; - if (pFxSend->DestinationMasterEffectChain() >= 0) { // fx send routed to an internal master effect - EffectChain* pEffectChain = - pAudioOutputDevice->MasterEffectChain( - pFxSend->DestinationMasterEffectChain() - ); - if (!pEffectChain) { - dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination effect chain %d", ((iChan) ? "R" : "L"), pFxSend->DestinationMasterEffectChain())); - goto channel_cleanup; - } - Effect* pEffect = - pEffectChain->GetEffect( - pFxSend->DestinationMasterEffect() - ); - if (!pEffect) { - dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination effect %d of effect chain %d", ((iChan) ? "R" : "L"), pFxSend->DestinationMasterEffect(), pFxSend->DestinationMasterEffectChain())); - goto channel_cleanup; - } - pDstChan = pEffect->InputChannel(iDstChan); - } else { // FX send routed directly to an audio output channel - pDstChan = pAudioOutputDevice->Channel(iDstChan); - } - if (!pDstChan) { - dmsg(1,("Engine::RouteAudio() Error: invalid FX send (%s) destination channel (%d->%d)", ((iChan) ? "R" : "L"), iChan, iDstChan)); - goto channel_cleanup; - } - pSource->MixTo(pDstChan, Samples, pFxSend->Level()); - } - } - } - channel_cleanup: - // reset buffers with silence (zero out) for the next audio cycle - pEngineChannel->pChannelLeft->Clear(); - pEngineChannel->pChannelRight->Clear(); - } + ProcessNoteOff(pEngineChannel, itNewEvent); + } else { + itNewEvent->Type = Event::type_note_on; + //TODO: if Velocity is 255, the triggered velocity should + // depend on how fast the controller is moving + itNewEvent->Param.Note.Velocity = + pTrigger->Velocity == 255 ? 100 : + pTrigger->Velocity; - /** - * Free all keys which have turned inactive in this audio fragment, from - * the list of active keys and clear all event lists on that engine - * channel. - * - * @param pEngineChannel - engine channel to cleanup - */ - void Engine::PostProcess(EngineChannel* pEngineChannel) { - // free all keys which have no active voices left - { - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - while (iuiKey != end) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - ++iuiKey; - if (pKey->pActiveVoices->isEmpty()) FreeKey(pEngineChannel, pKey); - #if CONFIG_DEVMODE - else { // just a sanity check for debugging - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - if (itVoice->itKillEvent) { - dmsg(1,("gig::Engine: ERROR, killed voice survived !!!\n")); + ProcessNoteOn(pEngineChannel, itNewEvent); + } + } + else dmsg(1,("Event pool emtpy!\n")); + } } } } - #endif // CONFIG_DEVMODE } } - // empty the engine channel's own event lists - pEngineChannel->ClearEventLists(); - } + // update controller value in the engine channel's controller table + pChannel->ControllerTableitControlChangeEvent->Param.CC.Controller = itControlChangeEvent->Param.CC.Value; - /** - * Will be called by the MIDI input device whenever a MIDI system - * exclusive message has arrived. - * - * @param pData - pointer to sysex data - * @param Size - lenght of sysex data (in bytes) - * @param pSender - the MIDI input port on which the SysEx message was - * received - */ - void Engine::SendSysex(void* pData, uint Size, MidiInputPort* pSender) { - Event event = pEventGenerator->CreateEvent(); - event.Type = Event::type_sysex; - event.Param.Sysex.Size = Size; - event.pEngineChannel = NULL; // as Engine global event - event.pMidiInputPort = pSender; - if (pEventQueue->write_space() > 0) { - if (pSysexBuffer->write_space() >= Size) { - // copy sysex data to input buffer - uint toWrite = Size; - uint8_t* pPos = (uint8_t*) pData; - while (toWrite) { - const uint writeNow = RTMath::Min(toWrite, pSysexBuffer->write_space_to_end()); - pSysexBuffer->write(pPos, writeNow); - toWrite -= writeNow; - pPos += writeNow; + ProcessHardcodedControllers(pEngineChannel, itControlChangeEvent); - } - // finally place sysex event into input event queue - pEventQueue->push(&event); - } - else dmsg(1,("Engine: Sysex message too large (%d byte) for input buffer (%d byte)!",Size,CONFIG_SYSEX_BUFFER_SIZE)); - } - else dmsg(1,("Engine: Input event queue full!")); + // handle FX send controllers + ProcessFxSendControllers(pChannel, itControlChangeEvent); } - /** - * Assigns and triggers a new voice for the respective MIDI key. - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itNoteOnEvent - key, velocity and time stamp of the event - */ - void Engine::ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent) { - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - if (!pEngineChannel->pInstrument) return; // ignore if no instrument loaded - - //HACK: we should better add the transpose value only to the most mandatory places (like for retrieving the region and calculating the tuning), because otherwise voices will unintendedly survive when changing transpose while playing - itNoteOnEvent->Param.Note.Key += pEngineChannel->GlobalTranspose; - - const int key = itNoteOnEvent->Param.Note.Key; - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfokey; - - // move note on event to the key's own event list - RTList<Event>::Iterator itNoteOnEventOnKeyList = itNoteOnEvent.moveToEndOf(pKey->pEvents); - - // if Solo Mode then kill all already active voices - if (pEngineChannel->SoloMode) { - Pool<uint>::Iterator itYoungestKey = pEngineChannel->pActiveKeys->last(); - if (itYoungestKey) { - const int iYoungestKey = *itYoungestKey; - const midi_key_info_t* pOtherKey = &pEngineChannel->pMIDIKeyInfoiYoungestKey; - if (pOtherKey->Active) { - // get final portamento position of currently active voice - if (pEngineChannel->PortamentoMode) { - RTList<Voice>::Iterator itVoice = pOtherKey->pActiveVoices->last(); - if (itVoice) itVoice->UpdatePortamentoPos(itNoteOnEventOnKeyList); - } - // kill all voices on the (other) key - RTList<Voice>::Iterator itVoiceToBeKilled = pOtherKey->pActiveVoices->first(); - RTList<Voice>::Iterator end = pOtherKey->pActiveVoices->end(); - for (; itVoiceToBeKilled != end; ++itVoiceToBeKilled) { - if (itVoiceToBeKilled->Type != Voice::type_release_trigger) - itVoiceToBeKilled->Kill(itNoteOnEventOnKeyList); - } - } - } - // set this key as 'currently active solo key' - pEngineChannel->SoloKey = key; - } - - // Change key dimension value if key is in keyswitching area - { - const ::gig::Instrument* pInstrument = pEngineChannel->pInstrument; - if (key >= pInstrument->DimensionKeyRange.low && key <= pInstrument->DimensionKeyRange.high) - pEngineChannel->CurrentKeyDimension = float(key - pInstrument->DimensionKeyRange.low) / - (pInstrument->DimensionKeyRange.high - pInstrument->DimensionKeyRange.low + 1); - } - - pKey->KeyPressed = true; // the MIDI key was now pressed down - pKey->Velocity = itNoteOnEventOnKeyList->Param.Note.Velocity; - pKey->NoteOnTime = FrameTime + itNoteOnEventOnKeyList->FragmentPos(); // will be used to calculate note length - - // cancel release process of voices on this key if needed - if (pKey->Active && !pEngineChannel->SustainPedal) { - RTList<Event>::Iterator itCancelReleaseEvent = pKey->pEvents->allocAppend(); - if (itCancelReleaseEvent) { - *itCancelReleaseEvent = *itNoteOnEventOnKeyList; // copy event - itCancelReleaseEvent->Type = Event::type_cancel_release; // transform event type - } - else dmsg(1,("Event pool emtpy!\n")); - } - - // allocate and trigger new voice(s) for the key - { - // first, get total amount of required voices (dependant on amount of layers) - ::gig::Region* pRegion = pEngineChannel->pInstrument->GetRegion(itNoteOnEventOnKeyList->Param.Note.Key); - if (pRegion && !RegionSuspended(pRegion)) { - int voicesRequired = pRegion->Layers; - // now launch the required amount of voices - for (int i = 0; i < voicesRequired; i++) - LaunchVoice(pEngineChannel, itNoteOnEventOnKeyList, i, false, true, true); - } + DiskThread* Engine::CreateDiskThread() { + return new DiskThread ( + iMaxDiskStreams, + ((pAudioOutputDevice->MaxSamplesPerCycle() << CONFIG_MAX_PITCH) << 1) + 6, //FIXME: assuming stereo + &instruments + ); + } + + void Engine::TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + // first, get total amount of required voices (dependant on amount of layers) + ::gig::Region* pRegion = pChannel->pInstrument->GetRegion(itNoteOnEvent->Param.Note.Key); + if (pRegion && !RegionSuspended(pRegion)) { + int voicesRequired = pRegion->Layers; + // now launch the required amount of voices + for (int i = 0; i < voicesRequired; i++) + LaunchVoice(pChannel, itNoteOnEvent, i, false, true, HandleKeyGroupConflicts); } - - // if neither a voice was spawned or postponed then remove note on event from key again - if (!pKey->Active && !pKey->VoiceTheftsQueued) - pKey->pEvents->free(itNoteOnEventOnKeyList); - - if (!pEngineChannel->SoloMode || pEngineChannel->PortamentoPos < 0.0f) pEngineChannel->PortamentoPos = (float) key; - pKey->RoundRobinIndex++; } - /** - * Releases the voices on the given key if sustain pedal is not pressed. - * If sustain is pressed, the release of the note will be postponed until - * sustain pedal will be released or voice turned inactive by itself (e.g. - * due to completion of sample playback). - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itNoteOffEvent - key, velocity and time stamp of the event - */ - void Engine::ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent) { - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - //HACK: we should better add the transpose value only to the most mandatory places (like for retrieving the region and calculating the tuning), because otherwise voices will unintendedly survive when changing transpose while playing - itNoteOffEvent->Param.Note.Key += pEngineChannel->GlobalTranspose; - - const int iKey = itNoteOffEvent->Param.Note.Key; - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfoiKey; - pKey->KeyPressed = false; // the MIDI key was now released - - // move event to the key's own event list - RTList<Event>::Iterator itNoteOffEventOnKeyList = itNoteOffEvent.moveToEndOf(pKey->pEvents); - - bool bShouldRelease = pKey->Active && ShouldReleaseVoice(pEngineChannel, itNoteOffEventOnKeyList->Param.Note.Key); - - // in case Solo Mode is enabled, kill all voices on this key and respawn a voice on the highest pressed key (if any) - if (pEngineChannel->SoloMode && pEngineChannel->pInstrument) { //TODO: this feels like too much code just for handling solo mode :P - bool bOtherKeysPressed = false; - if (iKey == pEngineChannel->SoloKey) { - pEngineChannel->SoloKey = -1; - // if there's still a key pressed down, respawn a voice (group) on the highest key - for (int i = 127; i > 0; i--) { - midi_key_info_t* pOtherKey = &pEngineChannel->pMIDIKeyInfoi; - if (pOtherKey->KeyPressed) { - bOtherKeysPressed = true; - // make the other key the new 'currently active solo key' - pEngineChannel->SoloKey = i; - // get final portamento position of currently active voice - if (pEngineChannel->PortamentoMode) { - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - if (itVoice) itVoice->UpdatePortamentoPos(itNoteOffEventOnKeyList); - } - // create a pseudo note on event - RTList<Event>::Iterator itPseudoNoteOnEvent = pOtherKey->pEvents->allocAppend(); - if (itPseudoNoteOnEvent) { - // copy event - *itPseudoNoteOnEvent = *itNoteOffEventOnKeyList; - // transform event to a note on event - itPseudoNoteOnEvent->Type = Event::type_note_on; - itPseudoNoteOnEvent->Param.Note.Key = i; - itPseudoNoteOnEvent->Param.Note.Velocity = pOtherKey->Velocity; - // allocate and trigger new voice(s) for the other key - { - // first, get total amount of required voices (dependant on amount of layers) - ::gig::Region* pRegion = pEngineChannel->pInstrument->GetRegion(i); - if (pRegion) { - int voicesRequired = pRegion->Layers; - // now launch the required amount of voices - for (int iLayer = 0; iLayer < voicesRequired; iLayer++) - LaunchVoice(pEngineChannel, itPseudoNoteOnEvent, iLayer, false, true, false); - } - } - // if neither a voice was spawned or postponed then remove note on event from key again - if (!pOtherKey->Active && !pOtherKey->VoiceTheftsQueued) - pOtherKey->pEvents->free(itPseudoNoteOnEvent); - - } else dmsg(1,("Could not respawn voice, no free event left\n")); - break; // done - } - } - } - if (bOtherKeysPressed) { - if (pKey->Active) { // kill all voices on this key - bShouldRelease = false; // no need to release, as we kill it here - RTList<Voice>::Iterator itVoiceToBeKilled = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator end = pKey->pActiveVoices->end(); - for (; itVoiceToBeKilled != end; ++itVoiceToBeKilled) { - if (itVoiceToBeKilled->Type != Voice::type_release_trigger) - itVoiceToBeKilled->Kill(itNoteOffEventOnKeyList); - } - } - } else pEngineChannel->PortamentoPos = -1.0f; - } - - // if no solo mode (the usual case) or if solo mode and no other key pressed, then release voices on this key if needed - if (bShouldRelease) { - itNoteOffEventOnKeyList->Type = Event::type_release; // transform event type - - // spawn release triggered voice(s) if needed - if (pKey->ReleaseTrigger && pEngineChannel->pInstrument) { - // first, get total amount of required voices (dependant on amount of layers) - ::gig::Region* pRegion = pEngineChannel->pInstrument->GetRegion(itNoteOffEventOnKeyList->Param.Note.Key); - if (pRegion) { - int voicesRequired = pRegion->Layers; - - // MIDI note-on velocity is used instead of note-off velocity - itNoteOffEventOnKeyList->Param.Note.Velocity = pKey->Velocity; - - // now launch the required amount of voices - for (int i = 0; i < voicesRequired; i++) - LaunchVoice(pEngineChannel, itNoteOffEventOnKeyList, i, true, false, false); //FIXME: for the moment we don't perform voice stealing for release triggered samples - } - pKey->ReleaseTrigger = false; - } + void Engine::TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + MidiKey* pKey = &pChannel->pMIDIKeyInfoitNoteOffEvent->Param.Note.Key; + // first, get total amount of required voices (dependant on amount of layers) + ::gig::Region* pRegion = pChannel->pInstrument->GetRegion(itNoteOffEvent->Param.Note.Key); + if (pRegion) { + int voicesRequired = pRegion->Layers; + + // MIDI note-on velocity is used instead of note-off velocity + itNoteOffEvent->Param.Note.Velocity = pKey->Velocity; + + // now launch the required amount of voices + for (int i = 0; i < voicesRequired; i++) + LaunchVoice(pChannel, itNoteOffEvent, i, true, false, false); //FIXME: for the moment we don't perform voice stealing for release triggered samples } - - // if neither a voice was spawned or postponed on this key then remove note off event from key again - if (!pKey->Active && !pKey->VoiceTheftsQueued) - pKey->pEvents->free(itNoteOffEventOnKeyList); } - /** - * Moves pitchbend event from the general (input) event list to the engine - * channel's event list. It will actually processed later by the - * respective voice. - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itPitchbendEvent - absolute pitch value and time stamp of the event - */ - void Engine::ProcessPitchbend(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent) { - pEngineChannel->Pitch = itPitchbendEvent->Param.Pitch.Pitch; // store current pitch value - } - - /** - * Allocates and triggers a new voice. This method will usually be - * called by the ProcessNoteOn() method and by the voices itself - * (e.g. to spawn further voices on the same key for layered sounds). - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itNoteOnEvent - key, velocity and time stamp of the event - * @param iLayer - layer index for the new voice (optional - only - * in case of layered sounds of course) - * @param ReleaseTriggerVoice - if new voice is a release triggered voice - * (optional, default = false) - * @param VoiceStealing - if voice stealing should be performed - * when there is no free voice - * (optional, default = true) - * @param HandleKeyGroupConflicts - if voices should be killed due to a - * key group conflict - * @returns pointer to new voice or NULL if there was no free voice or - * if the voice wasn't triggered (for example when no region is - * defined for the given key). - */ - Pool<Voice>::Iterator Engine::LaunchVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int iLayer, bool ReleaseTriggerVoice, bool VoiceStealing, bool HandleKeyGroupConflicts) { - int MIDIKey = itNoteOnEvent->Param.Note.Key; - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfoMIDIKey; - ::gig::Region* pRegion = pEngineChannel->pInstrument->GetRegion(MIDIKey); + Pool<Voice>::Iterator Engine::LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + int MIDIKey = itNoteOnEvent->Param.Note.Key; + EngineChannel::MidiKey* pKey = &pChannel->pMIDIKeyInfoMIDIKey; + ::gig::Region* pRegion = pChannel->pInstrument->GetRegion(MIDIKey); // if nothing defined for this key if (!pRegion) return Pool<Voice>::Iterator(); // nothing to do - // only mark the first voice of a layered voice (group) to be in a - // key group, so the layered voices won't kill each other - int iKeyGroup = (iLayer == 0 && !ReleaseTriggerVoice) ? pRegion->KeyGroup : 0; - - // handle key group (a.k.a. exclusive group) conflicts - if (HandleKeyGroupConflicts) { - if (iKeyGroup) { // if this voice / key belongs to a key group - uint** ppKeyGroup = &pEngineChannel->ActiveKeyGroupsiKeyGroup; - if (*ppKeyGroup) { // if there's already an active key in that key group - midi_key_info_t* pOtherKey = &pEngineChannel->pMIDIKeyInfo**ppKeyGroup; - // kill all voices on the (other) key - RTList<Voice>::Iterator itVoiceToBeKilled = pOtherKey->pActiveVoices->first(); - RTList<Voice>::Iterator end = pOtherKey->pActiveVoices->end(); - for (; itVoiceToBeKilled != end; ++itVoiceToBeKilled) { - if (itVoiceToBeKilled->Type != Voice::type_release_trigger) { - itVoiceToBeKilled->Kill(itNoteOnEvent); - --VoiceSpawnsLeft; //FIXME: just a hack, we should better check in StealVoice() if the voice was killed due to key conflict - } - } - } - } - } + int iKeyGroup = pRegion->KeyGroup; + // only need to send a group event from the first voice in a layered region, + // as all layers in a region always belongs to the same key group + if (HandleKeyGroupConflicts && iLayer == 0) pChannel->HandleKeyGroupConflicts(iKeyGroup, itNoteOnEvent); Voice::type_t VoiceType = Voice::type_normal; @@ -1280,90 +192,92 @@ DimValuesi = itNoteOnEvent->Param.Note.Velocity; break; case ::gig::dimension_channelaftertouch: - DimValuesi = pEngineChannel->ControllerTable128; + DimValuesi = pChannel->ControllerTable128; break; case ::gig::dimension_releasetrigger: VoiceType = (ReleaseTriggerVoice) ? Voice::type_release_trigger : (!iLayer) ? Voice::type_release_trigger_required : Voice::type_normal; DimValuesi = (uint) ReleaseTriggerVoice; break; case ::gig::dimension_keyboard: - DimValuesi = (uint) (pEngineChannel->CurrentKeyDimension * pRegion->pDimensionDefinitionsi.zones); + DimValuesi = (uint) (pChannel->CurrentKeyDimension * pRegion->pDimensionDefinitionsi.zones); break; case ::gig::dimension_roundrobin: - DimValuesi = (uint) pEngineChannel->pMIDIKeyInfoMIDIKey.RoundRobinIndex; // incremented for each note on + DimValuesi = uint(*pChannel->pMIDIKeyInfoMIDIKey.pRoundRobinIndex % pRegion->pDimensionDefinitionsi.zones); // RoundRobinIndex is incremented for each note on in this Region + break; + case ::gig::dimension_roundrobinkeyboard: + DimValuesi = uint(pChannel->RoundRobinIndex % pRegion->pDimensionDefinitionsi.zones); // RoundRobinIndex is incremented for each note on break; case ::gig::dimension_random: - RandomSeed = RandomSeed * 1103515245 + 12345; // classic pseudo random number generator - DimValuesi = (uint) RandomSeed >> (32 - pRegion->pDimensionDefinitionsi.bits); // highest bits are most random + DimValuesi = uint(Random() * pRegion->pDimensionDefinitionsi.zones); break; case ::gig::dimension_modwheel: - DimValuesi = pEngineChannel->ControllerTable1; + DimValuesi = pChannel->ControllerTable1; break; case ::gig::dimension_breath: - DimValuesi = pEngineChannel->ControllerTable2; + DimValuesi = pChannel->ControllerTable2; break; case ::gig::dimension_foot: - DimValuesi = pEngineChannel->ControllerTable4; + DimValuesi = pChannel->ControllerTable4; break; case ::gig::dimension_portamentotime: - DimValuesi = pEngineChannel->ControllerTable5; + DimValuesi = pChannel->ControllerTable5; break; case ::gig::dimension_effect1: - DimValuesi = pEngineChannel->ControllerTable12; + DimValuesi = pChannel->ControllerTable12; break; case ::gig::dimension_effect2: - DimValuesi = pEngineChannel->ControllerTable13; + DimValuesi = pChannel->ControllerTable13; break; case ::gig::dimension_genpurpose1: - DimValuesi = pEngineChannel->ControllerTable16; + DimValuesi = pChannel->ControllerTable16; break; case ::gig::dimension_genpurpose2: - DimValuesi = pEngineChannel->ControllerTable17; + DimValuesi = pChannel->ControllerTable17; break; case ::gig::dimension_genpurpose3: - DimValuesi = pEngineChannel->ControllerTable18; + DimValuesi = pChannel->ControllerTable18; break; case ::gig::dimension_genpurpose4: - DimValuesi = pEngineChannel->ControllerTable19; + DimValuesi = pChannel->ControllerTable19; break; case ::gig::dimension_sustainpedal: - DimValuesi = pEngineChannel->ControllerTable64; + DimValuesi = pChannel->ControllerTable64; break; case ::gig::dimension_portamento: - DimValuesi = pEngineChannel->ControllerTable65; + DimValuesi = pChannel->ControllerTable65; break; case ::gig::dimension_sostenutopedal: - DimValuesi = pEngineChannel->ControllerTable66; + DimValuesi = pChannel->ControllerTable66; break; case ::gig::dimension_softpedal: - DimValuesi = pEngineChannel->ControllerTable67; + DimValuesi = pChannel->ControllerTable67; break; case ::gig::dimension_genpurpose5: - DimValuesi = pEngineChannel->ControllerTable80; + DimValuesi = pChannel->ControllerTable80; break; case ::gig::dimension_genpurpose6: - DimValuesi = pEngineChannel->ControllerTable81; + DimValuesi = pChannel->ControllerTable81; break; case ::gig::dimension_genpurpose7: - DimValuesi = pEngineChannel->ControllerTable82; + DimValuesi = pChannel->ControllerTable82; break; case ::gig::dimension_genpurpose8: - DimValuesi = pEngineChannel->ControllerTable83; + DimValuesi = pChannel->ControllerTable83; break; case ::gig::dimension_effect1depth: - DimValuesi = pEngineChannel->ControllerTable91; + DimValuesi = pChannel->ControllerTable91; break; case ::gig::dimension_effect2depth: - DimValuesi = pEngineChannel->ControllerTable92; + DimValuesi = pChannel->ControllerTable92; break; case ::gig::dimension_effect3depth: - DimValuesi = pEngineChannel->ControllerTable93; + DimValuesi = pChannel->ControllerTable93; break; case ::gig::dimension_effect4depth: - DimValuesi = pEngineChannel->ControllerTable94; + DimValuesi = pChannel->ControllerTable94; break; case ::gig::dimension_effect5depth: - DimValuesi = pEngineChannel->ControllerTable95; + DimValuesi = pChannel->ControllerTable95; break; case ::gig::dimension_none: std::cerr << "gig::Engine::LaunchVoice() Error: dimension=none\n" << std::flush; @@ -1376,7 +290,7 @@ // return if this is a release triggered voice and there is no // releasetrigger dimension (could happen if an instrument // change has occured between note on and off) - if (ReleaseTriggerVoice && VoiceType != Voice::type_release_trigger) return Pool<Voice>::Iterator(); + if (ReleaseTriggerVoice && !(VoiceType & Voice::type_release_trigger)) return Pool<Voice>::Iterator(); ::gig::DimensionRegion* pDimRgn = pRegion->GetDimensionRegionByValue(DimValues); @@ -1385,892 +299,27 @@ // allocate a new voice for the key Pool<Voice>::Iterator itNewVoice = pKey->pActiveVoices->allocAppend(); - if (itNewVoice) { - // launch the new voice - if (itNewVoice->Trigger(pEngineChannel, itNoteOnEvent, pEngineChannel->Pitch, pDimRgn, VoiceType, iKeyGroup) < 0) { - dmsg(4,("Voice not triggered\n")); - pKey->pActiveVoices->free(itNewVoice); - } - else { // on success - --VoiceSpawnsLeft; - if (!pKey->Active) { // mark as active key - pKey->Active = true; - pKey->itSelf = pEngineChannel->pActiveKeys->allocAppend(); - *pKey->itSelf = itNoteOnEvent->Param.Note.Key; - } - if (itNewVoice->KeyGroup) { - uint** ppKeyGroup = &pEngineChannel->ActiveKeyGroupsitNewVoice->KeyGroup; - *ppKeyGroup = &*pKey->itSelf; // put key as the (new) active key to its key group - } - if (itNewVoice->Type == Voice::type_release_trigger_required) pKey->ReleaseTrigger = true; // mark key for the need of release triggered voice(s) - return itNewVoice; // success - } - } - else if (VoiceStealing) { - // try to steal one voice - int result = StealVoice(pEngineChannel, itNoteOnEvent); - if (!result) { // voice stolen successfully - // put note-on event into voice-stealing queue, so it will be reprocessed after killed voice died - RTList<Event>::Iterator itStealEvent = pVoiceStealingQueue->allocAppend(); - if (itStealEvent) { - *itStealEvent = *itNoteOnEvent; // copy event - itStealEvent->Param.Note.Layer = iLayer; - itStealEvent->Param.Note.ReleaseTrigger = ReleaseTriggerVoice; - pKey->VoiceTheftsQueued++; - } - else dmsg(1,("Voice stealing queue full!\n")); - } - } - - return Pool<Voice>::Iterator(); // no free voice or error - } - - /** - * Will be called by LaunchVoice() method in case there are no free - * voices left. This method will select and kill one old voice for - * voice stealing and postpone the note-on event until the selected - * voice actually died. - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itNoteOnEvent - key, velocity and time stamp of the event - * @returns 0 on success, a value < 0 if no active voice could be picked for voice stealing - */ - int Engine::StealVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent) { - if (VoiceSpawnsLeft <= 0) { - dmsg(1,("Max. voice thefts per audio fragment reached (you may raise CONFIG_MAX_VOICES).\n")); - return -1; - } - if (!pEventPool->poolIsEmpty()) { - - RTList<Voice>::Iterator itSelectedVoice; - - // Select one voice for voice stealing - switch (CONFIG_VOICE_STEAL_ALGO) { - - // try to pick the oldest voice on the key where the new - // voice should be spawned, if there is no voice on that - // key, or no voice left to kill, then procceed with - // 'oldestkey' algorithm - case voice_steal_algo_oldestvoiceonkey: { - midi_key_info_t* pSelectedKey = &pEngineChannel->pMIDIKeyInfoitNoteOnEvent->Param.Note.Key; - itSelectedVoice = pSelectedKey->pActiveVoices->first(); - // proceed iterating if voice was created in this fragment cycle - while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; - // if we haven't found a voice then proceed with algorithm 'oldestkey' - if (itSelectedVoice && itSelectedVoice->IsStealable()) break; - } // no break - intentional ! - - // try to pick the oldest voice on the oldest active key - // from the same engine channel - // (caution: must stay after 'oldestvoiceonkey' algorithm !) - case voice_steal_algo_oldestkey: { - // if we already stole in this fragment, try to proceed on same key - if (this->itLastStolenVoice) { - itSelectedVoice = this->itLastStolenVoice; - do { - ++itSelectedVoice; - } while (itSelectedVoice && !itSelectedVoice->IsStealable()); // proceed iterating if voice was created in this fragment cycle - // found a "stealable" voice ? - if (itSelectedVoice && itSelectedVoice->IsStealable()) { - // remember which voice we stole, so we can simply proceed on next voice stealing - this->itLastStolenVoice = itSelectedVoice; - break; // selection succeeded - } - } - // get (next) oldest key - RTList<uint>::Iterator iuiSelectedKey = (this->iuiLastStolenKey) ? ++this->iuiLastStolenKey : pEngineChannel->pActiveKeys->first(); - while (iuiSelectedKey) { - midi_key_info_t* pSelectedKey = &pEngineChannel->pMIDIKeyInfo*iuiSelectedKey; - itSelectedVoice = pSelectedKey->pActiveVoices->first(); - // proceed iterating if voice was created in this fragment cycle - while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; - // found a "stealable" voice ? - if (itSelectedVoice && itSelectedVoice->IsStealable()) { - // remember which voice on which key we stole, so we can simply proceed on next voice stealing - this->iuiLastStolenKey = iuiSelectedKey; - this->itLastStolenVoice = itSelectedVoice; - break; // selection succeeded - } - ++iuiSelectedKey; // get next oldest key - } - break; - } - - // don't steal anything - case voice_steal_algo_none: - default: { - dmsg(1,("No free voice (voice stealing disabled)!\n")); - return -1; - } - } - - // if we couldn't steal a voice from the same engine channel then - // steal oldest voice on the oldest key from any other engine channel - // (the smaller engine channel number, the higher priority) - if (!itSelectedVoice || !itSelectedVoice->IsStealable()) { - EngineChannel* pSelectedChannel; - int iChannelIndex; - // select engine channel - if (pLastStolenChannel) { - pSelectedChannel = pLastStolenChannel; - iChannelIndex = pSelectedChannel->iEngineIndexSelf; - } else { // pick the engine channel followed by this engine channel - iChannelIndex = (pEngineChannel->iEngineIndexSelf + 1) % engineChannels.size(); - pSelectedChannel = engineChannelsiChannelIndex; - } - - // if we already stole in this fragment, try to proceed on same key - if (this->itLastStolenVoiceGlobally) { - itSelectedVoice = this->itLastStolenVoiceGlobally; - do { - ++itSelectedVoice; - } while (itSelectedVoice && !itSelectedVoice->IsStealable()); // proceed iterating if voice was created in this fragment cycle - } - - #if CONFIG_DEVMODE - EngineChannel* pBegin = pSelectedChannel; // to detect endless loop - #endif // CONFIG_DEVMODE - - // did we find a 'stealable' voice? - if (itSelectedVoice && itSelectedVoice->IsStealable()) { - // remember which voice we stole, so we can simply proceed on next voice stealing - this->itLastStolenVoiceGlobally = itSelectedVoice; - } else while (true) { // iterate through engine channels - // get (next) oldest key - RTList<uint>::Iterator iuiSelectedKey = (this->iuiLastStolenKeyGlobally) ? ++this->iuiLastStolenKeyGlobally : pSelectedChannel->pActiveKeys->first(); - this->iuiLastStolenKeyGlobally = RTList<uint>::Iterator(); // to prevent endless loop (see line above) - while (iuiSelectedKey) { - midi_key_info_t* pSelectedKey = &pSelectedChannel->pMIDIKeyInfo*iuiSelectedKey; - itSelectedVoice = pSelectedKey->pActiveVoices->first(); - // proceed iterating if voice was created in this fragment cycle - while (itSelectedVoice && !itSelectedVoice->IsStealable()) ++itSelectedVoice; - // found a "stealable" voice ? - if (itSelectedVoice && itSelectedVoice->IsStealable()) { - // remember which voice on which key on which engine channel we stole, so we can simply proceed on next voice stealing - this->iuiLastStolenKeyGlobally = iuiSelectedKey; - this->itLastStolenVoiceGlobally = itSelectedVoice; - this->pLastStolenChannel = pSelectedChannel; - goto stealable_voice_found; // selection succeeded - } - ++iuiSelectedKey; // get next key on current engine channel - } - // get next engine channel - iChannelIndex = (iChannelIndex + 1) % engineChannels.size(); - pSelectedChannel = engineChannelsiChannelIndex; - - #if CONFIG_DEVMODE - if (pSelectedChannel == pBegin) { - dmsg(1,("FATAL ERROR: voice stealing endless loop!\n")); - dmsg(1,("VoiceSpawnsLeft=%d.\n", VoiceSpawnsLeft)); - dmsg(1,("Exiting.\n")); - exit(-1); - } - #endif // CONFIG_DEVMODE - } - } - - // jump point if a 'stealable' voice was found - stealable_voice_found: - - #if CONFIG_DEVMODE - if (!itSelectedVoice->IsActive()) { - dmsg(1,("gig::Engine: ERROR, tried to steal a voice which was not active !!!\n")); - return -1; - } - #endif // CONFIG_DEVMODE - - // now kill the selected voice - itSelectedVoice->Kill(itNoteOnEvent); - - --VoiceSpawnsLeft; - - return 0; // success - } - else { - dmsg(1,("Event pool emtpy!\n")); - return -1; - } - } - - /** - * Removes the given voice from the MIDI key's list of active voices. - * This method will be called when a voice went inactive, e.g. because - * it finished to playback its sample, finished its release stage or - * just was killed. - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itVoice - points to the voice to be freed - */ - void Engine::FreeVoice(EngineChannel* pEngineChannel, Pool<Voice>::Iterator& itVoice) { - if (itVoice) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfoitVoice->MIDIKey; - - uint keygroup = itVoice->KeyGroup; - - // if the sample and dimension region belong to an - // instrument that is unloaded, tell the disk thread to - // release them - if (itVoice->Orphan) { - pDiskThread->OrderDeletionOfDimreg(itVoice->pDimRgn); - } - - // free the voice object - pVoicePool->free(itVoice); - - // if no other voices left and member of a key group, remove from key group - if (pKey->pActiveVoices->isEmpty() && keygroup) { - uint** ppKeyGroup = &pEngineChannel->ActiveKeyGroupskeygroup; - if (*ppKeyGroup == &*pKey->itSelf) *ppKeyGroup = NULL; // remove key from key group - } - } - else std::cerr << "Couldn't release voice! (!itVoice)\n" << std::flush; - } - - /** - * Called when there's no more voice left on a key, this call will - * update the key info respectively. - * - * @param pEngineChannel - engine channel on which this event occured on - * @param pKey - key which is now inactive - */ - void Engine::FreeKey(EngineChannel* pEngineChannel, midi_key_info_t* pKey) { - if (pKey->pActiveVoices->isEmpty()) { - pKey->Active = false; - pEngineChannel->pActiveKeys->free(pKey->itSelf); // remove key from list of active keys - pKey->itSelf = RTList<uint>::Iterator(); - pKey->ReleaseTrigger = false; - pKey->pEvents->clear(); - dmsg(3,("Key has no more voices now\n")); - } - else dmsg(1,("gig::Engine: Oops, tried to free a key which contains voices.\n")); - } - - /** - * Reacts on supported control change commands (e.g. pitch bend wheel, - * modulation wheel, aftertouch). - * - * @param pEngineChannel - engine channel on which this event occured on - * @param itControlChangeEvent - controller, value and time stamp of the event - */ - void Engine::ProcessControlChange(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itControlChangeEvent) { - dmsg(4,("Engine::ContinuousController cc=%d v=%d\n", itControlChangeEvent->Param.CC.Controller, itControlChangeEvent->Param.CC.Value)); - - // handle the "control triggered" MIDI rule: a control change - // event can trigger a new note on or note off event - if (pEngineChannel->pInstrument) { - - ::gig::MidiRule* rule; - for (int i = 0 ; (rule = pEngineChannel->pInstrument->GetMidiRule(i)) ; i++) { - - if (::gig::MidiRuleCtrlTrigger* ctrlTrigger = - dynamic_cast< ::gig::MidiRuleCtrlTrigger*>(rule)) { - if (itControlChangeEvent->Param.CC.Controller == - ctrlTrigger->ControllerNumber) { - - uint8_t oldCCValue = pEngineChannel->ControllerTable - itControlChangeEvent->Param.CC.Controller; - uint8_t newCCValue = itControlChangeEvent->Param.CC.Value; - - for (int i = 0 ; i < ctrlTrigger->Triggers ; i++) { - ::gig::MidiRuleCtrlTrigger::trigger_t* pTrigger = - &ctrlTrigger->pTriggersi; - - // check if the controller has passed the - // trigger point in the right direction - if ((pTrigger->Descending && - oldCCValue > pTrigger->TriggerPoint && - newCCValue <= pTrigger->TriggerPoint) || - (!pTrigger->Descending && - oldCCValue < pTrigger->TriggerPoint && - newCCValue >= pTrigger->TriggerPoint)) { - - RTList<Event>::Iterator itNewEvent = pGlobalEvents->allocAppend(); - if (itNewEvent) { - *itNewEvent = *itControlChangeEvent; - itNewEvent->Param.Note.Key = pTrigger->Key; - - if (pTrigger->NoteOff || pTrigger->Velocity == 0) { - itNewEvent->Type = Event::type_note_off; - itNewEvent->Param.Note.Velocity = 100; - - ProcessNoteOff(pEngineChannel, itNewEvent); - } else { - itNewEvent->Type = Event::type_note_on; - //TODO: if Velocity is 255, the triggered velocity should - // depend on how fast the controller is moving - itNewEvent->Param.Note.Velocity = - pTrigger->Velocity == 255 ? 100 : - pTrigger->Velocity; - - ProcessNoteOn(pEngineChannel, itNewEvent); - } - } - else dmsg(1,("Event pool emtpy!\n")); - } - } - } - } - } - } - - // update controller value in the engine channel's controller table - pEngineChannel->ControllerTableitControlChangeEvent->Param.CC.Controller = itControlChangeEvent->Param.CC.Value; - // handle hard coded MIDI controllers - switch (itControlChangeEvent->Param.CC.Controller) { - case 5: { // portamento time - pEngineChannel->PortamentoTime = (float) itControlChangeEvent->Param.CC.Value / 127.0f * (float) CONFIG_PORTAMENTO_TIME_MAX + (float) CONFIG_PORTAMENTO_TIME_MIN; - break; - } - case 6: { // data entry (currently only used for RPN controllers) - if (pEngineChannel->GetMidiRpnController() == 2) { // coarse tuning in half tones - int transpose = (int) itControlChangeEvent->Param.CC.Value - 64; - // limit to +- two octaves for now - transpose = RTMath::Min(transpose, 24); - transpose = RTMath::Max(transpose, -24); - pEngineChannel->GlobalTranspose = transpose; - // workaround, so we won't have hanging notes - ReleaseAllVoices(pEngineChannel, itControlChangeEvent); - } - // to avoid other MIDI CC #6 messages to be misenterpreted as RPN controller data - pEngineChannel->ResetMidiRpnController(); - break; - } - case 7: { // volume - //TODO: not sample accurate yet - pEngineChannel->MidiVolume = VolumeCurveitControlChangeEvent->Param.CC.Value; - pEngineChannel->bStatusChanged = true; // engine channel status has changed, so set notify flag - break; - } - case 10: { // panpot - //TODO: not sample accurate yet - pEngineChannel->GlobalPanLeft = PanCurve128 - itControlChangeEvent->Param.CC.Value; - pEngineChannel->GlobalPanRight = PanCurveitControlChangeEvent->Param.CC.Value; - pEngineChannel->iLastPanRequest = itControlChangeEvent->Param.CC.Value; - break; - } - case 64: { // sustain - if (itControlChangeEvent->Param.CC.Value >= 64 && !pEngineChannel->SustainPedal) { - dmsg(4,("DAMPER (RIGHT) PEDAL DOWN\n")); - pEngineChannel->SustainPedal = true; - - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - // cancel release process of voices if necessary - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - for (; iuiKey; ++iuiKey) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - if (!pKey->KeyPressed) { - RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); - if (itNewEvent) { - *itNewEvent = *itControlChangeEvent; // copy event to the key's own event list - itNewEvent->Type = Event::type_cancel_release; // transform event type - } - else dmsg(1,("Event pool emtpy!\n")); - } - } - } - if (itControlChangeEvent->Param.CC.Value < 64 && pEngineChannel->SustainPedal) { - dmsg(4,("DAMPER (RIGHT) PEDAL UP\n")); - pEngineChannel->SustainPedal = false; - - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - // release voices if their respective key is not pressed - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - for (; iuiKey; ++iuiKey) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - if (!pKey->KeyPressed && ShouldReleaseVoice(pEngineChannel, *iuiKey)) { - RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); - if (itNewEvent) { - *itNewEvent = *itControlChangeEvent; // copy event to the key's own event list - itNewEvent->Type = Event::type_release; // transform event type - } - else dmsg(1,("Event pool emtpy!\n")); - } - } - } - break; - } - case 65: { // portamento on / off - const bool bPortamento = itControlChangeEvent->Param.CC.Value >= 64; - if (bPortamento != pEngineChannel->PortamentoMode) - KillAllVoices(pEngineChannel, itControlChangeEvent); - pEngineChannel->PortamentoMode = bPortamento; - break; - } - case 66: { // sostenuto - if (itControlChangeEvent->Param.CC.Value >= 64 && !pEngineChannel->SostenutoPedal) { - dmsg(4,("SOSTENUTO (CENTER) PEDAL DOWN\n")); - pEngineChannel->SostenutoPedal = true; - - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - SostenutoKeyCount = 0; - // Remeber the pressed keys - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - for (; iuiKey; ++iuiKey) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - if (pKey->KeyPressed && SostenutoKeyCount < 128) SostenutoKeysSostenutoKeyCount++ = *iuiKey; - } - } - if (itControlChangeEvent->Param.CC.Value < 64 && pEngineChannel->SostenutoPedal) { - dmsg(4,("SOSTENUTO (CENTER) PEDAL UP\n")); - pEngineChannel->SostenutoPedal = false; - - #if !CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) return; // skip if sampler channel is muted - #endif - - // release voices if the damper pedal is up and their respective key is not pressed - for (int i = 0; i < SostenutoKeyCount; i++) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfoSostenutoKeysi; - if (!pKey->KeyPressed && !pEngineChannel->SustainPedal) { - RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); - if (itNewEvent) { - *itNewEvent = *itControlChangeEvent; // copy event to the key's own event list - itNewEvent->Type = Event::type_release; // transform event type - } - else dmsg(1,("Event pool emtpy!\n")); - } - } - } - break; - } - case 100: { // RPN controller LSB - pEngineChannel->SetMidiRpnControllerLsb(itControlChangeEvent->Param.CC.Value); - break; - } - case 101: { // RPN controller MSB - pEngineChannel->SetMidiRpnControllerMsb(itControlChangeEvent->Param.CC.Value); - break; - } + int res = InitNewVoice ( + pChannel, pDimRgn, itNoteOnEvent, VoiceType, iLayer, + iKeyGroup, ReleaseTriggerVoice, VoiceStealing, itNewVoice + ); + if (!res) return itNewVoice; - - // Channel Mode Messages - - case 120: { // all sound off - KillAllVoices(pEngineChannel, itControlChangeEvent); - break; - } - case 121: { // reset all controllers - pEngineChannel->ResetControllers(); - break; - } - case 123: { // all notes off - #if CONFIG_PROCESS_ALL_NOTES_OFF - ReleaseAllVoices(pEngineChannel, itControlChangeEvent); - #endif // CONFIG_PROCESS_ALL_NOTES_OFF - break; - } - case 126: { // mono mode on - if (!pEngineChannel->SoloMode) - KillAllVoices(pEngineChannel, itControlChangeEvent); - pEngineChannel->SoloMode = true; - break; - } - case 127: { // poly mode on - if (pEngineChannel->SoloMode) - KillAllVoices(pEngineChannel, itControlChangeEvent); - pEngineChannel->SoloMode = false; - break; - } - } - - // handle FX send controllers - if (!pEngineChannel->fxSends.empty()) { - for (int iFxSend = 0; iFxSend < pEngineChannel->GetFxSendCount(); iFxSend++) { - FxSend* pFxSend = pEngineChannel->GetFxSend(iFxSend); - if (pFxSend->MidiController() == itControlChangeEvent->Param.CC.Controller) { - pFxSend->SetLevel(itControlChangeEvent->Param.CC.Value); - pFxSend->SetInfoChanged(true); - } - } - } - } - - /** - * Reacts on MIDI system exclusive messages. - * - * @param itSysexEvent - sysex data size and time stamp of the sysex event - */ - void Engine::ProcessSysex(Pool<Event>::Iterator& itSysexEvent) { - RingBuffer<uint8_t,false>::NonVolatileReader reader = pSysexBuffer->get_non_volatile_reader(); - - uint8_t exclusive_status, id; - if (!reader.pop(&exclusive_status)) goto free_sysex_data; - if (!reader.pop(&id)) goto free_sysex_data; - if (exclusive_status != 0xF0) goto free_sysex_data; - - switch (id) { - case 0x7f: { // (Realtime) Universal Sysex (GM Standard) - uint8_t sysex_channel, sub_id1, sub_id2, val_msb, val_lsb;; - if (!reader.pop(&sysex_channel)) goto free_sysex_data; - if (!reader.pop(&sub_id1)) goto free_sysex_data; - if (!reader.pop(&sub_id2)) goto free_sysex_data; - if (!reader.pop(&val_lsb)) goto free_sysex_data; - if (!reader.pop(&val_msb)) goto free_sysex_data; - //TODO: for now we simply ignore the sysex channel, seldom used anyway - switch (sub_id1) { - case 0x04: // Device Control - switch (sub_id2) { - case 0x01: { // Master Volume - const double volume = - double((uint(val_msb)<<7) | uint(val_lsb)) / 16383.0; - #if CONFIG_MASTER_VOLUME_SYSEX_BY_PORT - // apply volume to all sampler channels that - // are connected to the same MIDI input port - // this sysex message arrived on - for (int i = 0; i < engineChannels.size(); ++i) { - EngineChannel* pEngineChannel = engineChannelsi; - if (pEngineChannel->GetMidiInputPort() == - itSysexEvent->pMidiInputPort) - { - pEngineChannel->Volume(volume); - } - } - #else - // apply volume globally to the whole sampler - GLOBAL_VOLUME = volume; - #endif // CONFIG_MASTER_VOLUME_SYSEX_BY_PORT - break; - } - } - break; - } - break; - } - case 0x41: { // Roland - dmsg(3,("Roland Sysex\n")); - uint8_t device_id, model_id, cmd_id; - if (!reader.pop(&device_id)) goto free_sysex_data; - if (!reader.pop(&model_id)) goto free_sysex_data; - if (!reader.pop(&cmd_id)) goto free_sysex_data; - if (model_id != 0x42 /*GS*/) goto free_sysex_data; - if (cmd_id != 0x12 /*DT1*/) goto free_sysex_data; - - // command address - uint8_t addr3; // 2 byte addr MSB, followed by 1 byte addr LSB) - const RingBuffer<uint8_t,false>::NonVolatileReader checksum_reader = reader; // so we can calculate the check sum later - if (reader.read(&addr0, 3) != 3) goto free_sysex_data; - if (addr0 == 0x40 && addr1 == 0x00) { // System Parameters - dmsg(3,("\tSystem Parameter\n")); - if (addr2 == 0x7f) { // GS reset - for (int i = 0; i < engineChannels.size(); ++i) { - EngineChannel* pEngineChannel = engineChannelsi; - if (pEngineChannel->GetMidiInputPort() == itSysexEvent->pMidiInputPort) { - KillAllVoices(pEngineChannel, itSysexEvent); - pEngineChannel->ResetControllers(); - } - } - } - } - else if (addr0 == 0x40 && addr1 == 0x01) { // Common Parameters - dmsg(3,("\tCommon Parameter\n")); - } - else if (addr0 == 0x40 && (addr1 & 0xf0) == 0x10) { // Part Parameters (1) - dmsg(3,("\tPart Parameter\n")); - switch (addr2) { - case 0x40: { // scale tuning - dmsg(3,("\t\tScale Tuning\n")); - uint8_t scale_tunes12; // detuning of all 12 semitones of an octave - if (reader.read(&scale_tunes0, 12) != 12) goto free_sysex_data; - uint8_t checksum; - if (!reader.pop(&checksum)) goto free_sysex_data; - #if CONFIG_ASSERT_GS_SYSEX_CHECKSUM - if (GSCheckSum(checksum_reader, 12)) goto free_sysex_data; - #endif // CONFIG_ASSERT_GS_SYSEX_CHECKSUM - for (int i = 0; i < 12; i++) scale_tunesi -= 64; - AdjustScale((int8_t*) scale_tunes); - dmsg(3,("\t\t\tNew scale applied.\n")); - break; - } - case 0x15: { // chromatic / drumkit mode - dmsg(3,("\t\tMIDI Instrument Map Switch\n")); - uint8_t part = addr1 & 0x0f; - uint8_t map; - if (!reader.pop(&map)) goto free_sysex_data; - for (int i = 0; i < engineChannels.size(); ++i) { - EngineChannel* pEngineChannel = engineChannelsi; - if ( - (pEngineChannel->midiChannel == part || - pEngineChannel->midiChannel == midi_chan_all) && - pEngineChannel->GetMidiInputPort() == itSysexEvent->pMidiInputPort - ) { - try { - pEngineChannel->SetMidiInstrumentMap(map); - } catch (Exception e) { - dmsg(2,("\t\t\tCould not apply MIDI instrument map %d to part %d: %s\n", map, part, e.Message().c_str())); - goto free_sysex_data; - } catch (...) { - dmsg(2,("\t\t\tCould not apply MIDI instrument map %d to part %d (unknown exception)\n", map, part)); - goto free_sysex_data; - } - } - } - dmsg(3,("\t\t\tApplied MIDI instrument map %d to part %d.\n", map, part)); - break; - } - } - } - else if (addr0 == 0x40 && (addr1 & 0xf0) == 0x20) { // Part Parameters (2) - } - else if (addr0 == 0x41) { // Drum Setup Parameters - } - break; - } - } - - free_sysex_data: // finally free sysex data - pSysexBuffer->increment_read_ptr(itSysexEvent->Param.Sysex.Size); - } - - /** - * Calculates the Roland GS sysex check sum. - * - * @param AddrReader - reader which currently points to the first GS - * command address byte of the GS sysex message in - * question - * @param DataSize - size of the GS message data (in bytes) - */ - uint8_t Engine::GSCheckSum(const RingBuffer<uint8_t,false>::NonVolatileReader AddrReader, uint DataSize) { - RingBuffer<uint8_t,false>::NonVolatileReader reader = AddrReader; - uint bytes = 3 /*addr*/ + DataSize; - uint8_t addr_and_databytes; - reader.read(&addr_and_data0, bytes); - uint8_t sum = 0; - for (uint i = 0; i < bytes; i++) sum += addr_and_datai; - return 128 - sum % 128; - } - - /** - * Allows to tune each of the twelve semitones of an octave. - * - * @param ScaleTunes - detuning of all twelve semitones (in cents) - */ - void Engine::AdjustScale(int8_t ScaleTunes12) { - memcpy(&this->ScaleTuning0, &ScaleTunes0, 12); //TODO: currently not sample accurate - } - - /** - * Releases all voices on an engine channel. All voices will go into - * the release stage and thus it might take some time (e.g. dependant to - * their envelope release time) until they actually die. - * - * @param pEngineChannel - engine channel on which all voices should be released - * @param itReleaseEvent - event which caused this releasing of all voices - */ - void Engine::ReleaseAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itReleaseEvent) { - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - while (iuiKey) { - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - ++iuiKey; - // append a 'release' event to the key's own event list - RTList<Event>::Iterator itNewEvent = pKey->pEvents->allocAppend(); - if (itNewEvent) { - *itNewEvent = *itReleaseEvent; // copy original event (to the key's event list) - itNewEvent->Type = Event::type_release; // transform event type - } - else dmsg(1,("Event pool emtpy!\n")); - } - } - - /** - * Kills all voices on an engine channel as soon as possible. Voices - * won't get into release state, their volume level will be ramped down - * as fast as possible. - * - * @param pEngineChannel - engine channel on which all voices should be killed - * @param itKillEvent - event which caused this killing of all voices - */ - void Engine::KillAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itKillEvent) { - RTList<uint>::Iterator iuiKey = pEngineChannel->pActiveKeys->first(); - RTList<uint>::Iterator end = pEngineChannel->pActiveKeys->end(); - while (iuiKey != end) { // iterate through all active keys - midi_key_info_t* pKey = &pEngineChannel->pMIDIKeyInfo*iuiKey; - ++iuiKey; - RTList<Voice>::Iterator itVoice = pKey->pActiveVoices->first(); - RTList<Voice>::Iterator itVoicesEnd = pKey->pActiveVoices->end(); - for (; itVoice != itVoicesEnd; ++itVoice) { // iterate through all voices on this key - itVoice->Kill(itKillEvent); - --VoiceSpawnsLeft; //FIXME: just a temporary workaround, we should check the cause in StealVoice() instead - } - } - } - - /** - * Determines whether the specified voice should be released. - * - * @param pEngineChannel - The engine channel on which the voice should be checked - * @param Key - The key number - * @returns true if the specified should be released, false otherwise. - */ - bool Engine::ShouldReleaseVoice(EngineChannel* pEngineChannel, int Key) { - if (pEngineChannel->SustainPedal) return false; - - if (pEngineChannel->SostenutoPedal) { - for (int i = 0; i < SostenutoKeyCount; i++) - if (Key == SostenutoKeysi) return false; - } - - return true; - } - - uint Engine::VoiceCount() { - return atomic_read(&ActiveVoiceCount); - } - - void Engine::SetVoiceCount(uint Count) { - atomic_set(&ActiveVoiceCount, Count); - } - - uint Engine::VoiceCountMax() { - return ActiveVoiceCountMax; - } - - int Engine::MaxVoices() { - return pVoicePool->poolSize(); - } - - void Engine::SetMaxVoices(int iVoices) throw (Exception) { - if (iVoices < 1) - throw Exception("Maximum voices for an engine cannot be set lower than 1"); - - SuspendAll(); - - // NOTE: we need to clear pDimRegionsInUse before deleting pDimRegionPool, - // otherwise memory corruption will occur if there are active voices (see bug #118) - for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { - engineChannelsiChannel->ClearDimRegionsInUse(); - } - - if (pDimRegionPool0) delete pDimRegionPool0; - if (pDimRegionPool1) delete pDimRegionPool1; - - pDimRegionPool0 = new Pool< ::gig::DimensionRegion*>(iVoices); - pDimRegionPool1 = new Pool< ::gig::DimensionRegion*>(iVoices); - - for (int iChannel = 0; iChannel < engineChannels.size(); iChannel++) { - engineChannelsiChannel->ResetDimRegionsInUse(); - } - - try { - pVoicePool->resizePool(iVoices); - } catch (...) { - throw Exception("FATAL: Could not resize voice pool!"); - } - - for (RTList<Voice>::Iterator iterVoice = pVoicePool->allocAppend(); iterVoice == pVoicePool->last(); iterVoice = pVoicePool->allocAppend()) { - iterVoice->SetEngine(this); - iterVoice->pDiskThread = this->pDiskThread; - } - pVoicePool->clear(); - - ResumeAll(); + return Pool<Voice>::Iterator(); // no free voice or error } bool Engine::DiskStreamSupported() { return true; } - uint Engine::DiskStreamCount() { - return (pDiskThread) ? pDiskThread->GetActiveStreamCount() : 0; - } - - uint Engine::DiskStreamCountMax() { - return (pDiskThread) ? pDiskThread->ActiveStreamCountMax : 0; - } - - int Engine::MaxDiskStreams() { - return iMaxDiskStreams; - } - - void Engine::SetMaxDiskStreams(int iStreams) throw (Exception) { - if (iStreams < 0) - throw Exception("Maximum disk streams for an engine cannot be set lower than 0"); - - SuspendAll(); - - iMaxDiskStreams = iStreams; - - // reconnect to audio output device, because that will automatically - // recreate the disk thread with the required amount of streams - if (pAudioOutputDevice) Connect(pAudioOutputDevice); - - ResumeAll(); - } - - String Engine::DiskStreamBufferFillBytes() { - return pDiskThread->GetBufferFillBytes(); - } - - String Engine::DiskStreamBufferFillPercentage() { - return pDiskThread->GetBufferFillPercentage(); - } - - String Engine::EngineName() { - return LS_GIG_ENGINE_NAME; - } - String Engine::Description() { - return "Gigasampler Format Engine"; + return "GigaSampler Format Engine"; } String Engine::Version() { - String s = "$Revision: 1.104 $"; + String s = "$Revision: 1.110 $"; return s.substr(11, s.size() - 13); // cut dollar signs, spaces and CVS macro keyword } - InstrumentManager* Engine::GetInstrumentManager() { - return &instruments; - } - - // static constant initializers - const Engine::FloatTable Engine::VolumeCurve(InitVolumeCurve()); - const Engine::FloatTable Engine::PanCurve(InitPanCurve()); - const Engine::FloatTable Engine::CrossfadeCurve(InitCrossfadeCurve()); - - float* Engine::InitVolumeCurve() { - // line-segment approximation - const float segments = { - 0, 0, 2, 0.0046, 16, 0.016, 31, 0.051, 45, 0.115, 54.5, 0.2, - 64.5, 0.39, 74, 0.74, 92, 1.03, 114, 1.94, 119.2, 2.2, 127, 2.2 - }; - return InitCurve(segments); - } - - float* Engine::InitPanCurve() { - // line-segment approximation - const float segments = { - 0, 0, 1, 0, - 2, 0.05, 31.5, 0.7, 51, 0.851, 74.5, 1.12, - 127, 1.41, 128, 1.41 - }; - return InitCurve(segments, 129); - } - - float* Engine::InitCrossfadeCurve() { - // line-segment approximation - const float segments = { - 0, 0, 1, 0.03, 10, 0.1, 51, 0.58, 127, 1 - }; - return InitCurve(segments); - } - - float* Engine::InitCurve(const float* segments, int size) { - float* y = new floatsize; - for (int x = 0 ; x < size ; x++) { - if (x > segments2) segments += 2; - yx = segments1 + (x - segments0) * - (segments3 - segments1) / (segments2 - segments0); - } - return y; - } - }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Engine.h -> linuxsampler-2342.tar.bz2/src/engines/gig/Engine.h
Changed
@@ -3,7 +3,8 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2010 Christian Schoenebeck and Grigor Iliev * * * * 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 * @@ -22,180 +23,58 @@ ***************************************************************************/ #ifndef __LS_GIG_ENGINE_H__ -#define __LS_GIG_ENGINE_H__ +#define __LS_GIG_ENGINE_H__ -#include "../../common/global.h" - -#include <map> +#include "DiskThread.h" +#include "../EngineBase.h" +#include "Voice.h" #include <gig.h> -#include "EngineGlobals.h" -#include "../../common/RingBuffer.h" -#include "../../common/Pool.h" -#include "../../common/ArrayList.h" -#include "../../common/Condition.h" -#include "../../common/ConditionServer.h" -#include "../../common/atomic.h" -#include "../Engine.h" -#include "../common/Event.h" -#include "../../network/lscp.h" -#include "EngineChannel.h" - -// identifier of this sampler engine -#define LS_GIG_ENGINE_NAME "GIG" - namespace LinuxSampler { namespace gig { - // just symbol prototyping - class Voice; - class DiskThread; - class InstrumentResourceManager; - class midi_key_info_t; - class EngineChannel; - - /** - * Sampler engine for the Gigasampler format. - */ - class Engine : public LinuxSampler::Engine { + class Engine: public LinuxSampler::EngineBase<Voice, ::gig::Region, ::gig::DimensionRegion, DiskThread, InstrumentResourceManager, ::gig::Instrument> { public: - // methods - Engine(); - virtual ~Engine(); - void Connect(AudioOutputDevice* pAudioOut); - void SuspendAll(); - void ResumeAll(); - void Suspend(::gig::Region* pRegion); - void Resume(::gig::Region* pRegion); - + Engine() { } + virtual ~Engine() { } // implementation of abstract methods derived from class 'LinuxSampler::Engine' - virtual int RenderAudio(uint Samples); - virtual void SendSysex(void* pData, uint Size, MidiInputPort* pSender); - virtual void Reset(); - virtual void Enable(); - virtual void Disable(); - virtual uint VoiceCount(); - virtual uint VoiceCountMax(); - virtual int MaxVoices(); - virtual void SetMaxVoices(int iVoices) throw (Exception); - virtual bool DiskStreamSupported(); - virtual uint DiskStreamCount(); - virtual uint DiskStreamCountMax(); - virtual int MaxDiskStreams(); - virtual void SetMaxDiskStreams(int iStreams) throw (Exception); - virtual String DiskStreamBufferFillBytes(); - virtual String DiskStreamBufferFillPercentage(); - virtual String Description(); - virtual String Version(); - virtual String EngineName(); - virtual InstrumentManager* GetInstrumentManager(); - - void SetVoiceCount(uint Count); - - // Simple array wrapper just to make sure memory is freed - // when liblinuxsampler is unloaded - class FloatTable { - private: - const float* array; - public: - FloatTable(const float* array) : array(array) { } - ~FloatTable() { delete array; } - const float& operator(int i) const { return arrayi; } - }; - - static const FloatTable VolumeCurve; ///< Table that maps volume control change values 0..127 to amplitude. Unity gain is at 90. - static const FloatTable PanCurve; ///< Table that maps pan control change values 0..128 to right channel amplitude. Unity gain is at 64 (center). - static const FloatTable CrossfadeCurve; ///< Table that maps crossfade control change values 0..127 to amplitude. Unity gain is at 127. - - //protected: - static InstrumentResourceManager instruments; + virtual bool DiskStreamSupported(); + virtual String Description(); + virtual String Version(); - AudioOutputDevice* pAudioOutputDevice; - uint SampleRate; ///< Sample rate of the engines output audio signal (in Hz) - uint MaxSamplesPerCycle; ///< Size of each audio output buffer - DiskThread* pDiskThread; - RingBuffer<Event,false>* pEventQueue; ///< Input event queue for engine global events (e.g. SysEx messages). - Pool<Voice>* pVoicePool; ///< Contains all voices that can be activated. - EventGenerator* pEventGenerator; - RTList<Event>* pVoiceStealingQueue; ///< All voice-launching events which had to be postponed due to free voice shortage. - RTList<Event>* pGlobalEvents; ///< All engine global events for the current audio fragment (usually only SysEx messages). - Pool<Event>* pEventPool; ///< Contains all Event objects that can be used. - RingBuffer<uint8_t,false>* pSysexBuffer; ///< Input buffer for MIDI system exclusive messages. - int ActiveVoiceCountTemp; ///< number of currently active voices (for internal usage, will be used for incrementation) - int ActiveVoiceCountMax; ///< the maximum voice usage since application start - int VoiceSpawnsLeft; ///< We only allow CONFIG_MAX_VOICES voices to be spawned per audio fragment, we use this variable to ensure this limit. - RTList<Voice>::Iterator itLastStolenVoice; ///< Only for voice stealing: points to the last voice which was theft in current audio fragment, NULL otherwise. - RTList<uint>::Iterator iuiLastStolenKey; ///< Only for voice stealing: key number of last key on which the last voice was theft in current audio fragment, NULL otherwise. - EngineChannel* pLastStolenChannel; ///< Only for voice stealing: points to the engine channel on which the previous voice was stolen in this audio fragment. - RTList<Voice>::Iterator itLastStolenVoiceGlobally; ///< Same as itLastStolenVoice, but engine globally - RTList<uint>::Iterator iuiLastStolenKeyGlobally; ///< Same as iuiLastStolenKey, but engine globally - bool SuspensionRequested; - ConditionServer EngineDisabled; - int8_t ScaleTuning12; ///< contains optional detune factors (-64..+63 cents) for all 12 semitones of an octave - int MinFadeOutSamples; ///< The number of samples needed to make an instant fade out (e.g. for voice stealing) without leading to clicks. - uint32_t RandomSeed; ///< State of the random number generator used by the random dimension. - Mutex ResetInternalMutex; ///< Mutex to protect the ResetInternal function for concurrent usage (e.g. by the lscp and instrument loader threads). - Pool< ::gig::DimensionRegion*>* pDimRegionPool2; ///< Double buffered pool, used by the engine channels to keep track of dimension regions in use. + virtual Format GetEngineFormat(); - void ProcessEvents(EngineChannel* pEngineChannel, uint Samples); - void RenderActiveVoices(EngineChannel* pEngineChannel, uint Samples); - void RenderStolenVoices(uint Samples); - void RouteAudio(EngineChannel* pEngineChannel, uint Samples); - void PostProcess(EngineChannel* pEngineChannel); - void ClearEventLists(); - void ImportEvents(uint Samples); - void ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent); - void ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent); - void ProcessPitchbend(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent); - void ProcessControlChange(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itControlChangeEvent); - void ProcessSysex(Pool<Event>::Iterator& itSysexEvent); - void ProcessSuspensionsChanges(); - void ProcessPendingStreamDeletions(); - Pool<Voice>::Iterator LaunchVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int iLayer, bool ReleaseTriggerVoice, bool VoiceStealing, bool HandleKeyGroupConflicts); - int StealVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent); - void FreeVoice(EngineChannel* pEngineChannel, Pool<Voice>::Iterator& itVoice); - void FreeKey(EngineChannel* pEngineChannel, midi_key_info_t* pKey); - void ResetInternal(); - void ResetScaleTuning(); - void ResetSuspendedRegions(); - - static Engine* AcquireEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice); - static void FreeEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice); - - void DisableAndLock(); // FIXME: should at least be protected + virtual void ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ); friend class Voice; - private: - Pool< ::gig::Region*> SuspendedRegions; - Mutex SuspendedRegionsMutex; - Condition SuspensionChangeOngoing; - ::gig::Region* pPendingRegionSuspension; - ::gig::Region* pPendingRegionResumption; - int iPendingStreamDeletions; - - ArrayList<EngineChannel*> engineChannels; ///< All engine channels of a gig::Engine instance. - - static std::map<AudioOutputDevice*,Engine*> engines; ///< All instances of gig::Engine. - int SostenutoKeys128; - int SostenutoKeyCount; - - uint8_t GSCheckSum(const RingBuffer<uint8_t,false>::NonVolatileReader AddrReader, uint DataSize); - void AdjustScale(int8_t ScaleTunes12); - void ReleaseAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itReleaseEvent); - void KillAllVoices(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itKillEvent); - bool ShouldReleaseVoice(EngineChannel* pEngineChannel, int Key); - bool RegionSuspended(::gig::Region* pRegion); - static float* InitVolumeCurve(); - static float* InitPanCurve(); - static float* InitCrossfadeCurve(); - static float* InitCurve(const float* segments, int size = 128); - - unsigned long FrameTime; ///< Time in frames of the start of the current audio fragment - - atomic_t ActiveVoiceCount; ///< number of currently active voices - int iMaxDiskStreams; + protected: + virtual DiskThread* CreateDiskThread(); + + virtual Pool<Voice>::Iterator LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ); + + virtual void TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ); + + void TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ); }; }} // namespace LinuxSampler::gig -#endif // __LS_GIG_ENGINE_H__ +#endif /* __LS_GIG_ENGINE_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/EngineChannel.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/EngineChannel.cpp
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2008 Christian Schoenebeck * + * Copyright (C) 2009-2012 Christian Schoenebeck and Grigor Iliev * * * * 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 * @@ -22,165 +23,51 @@ ***************************************************************************/ #include "EngineChannel.h" - -#include "../../common/global_private.h" -#include "../../Sampler.h" +#include "Engine.h" namespace LinuxSampler { namespace gig { - - EngineChannel::EngineChannel() : - InstrumentChangeCommandReader(InstrumentChangeCommand), - virtualMidiDevicesReader_AudioThread(virtualMidiDevices), - virtualMidiDevicesReader_MidiThread(virtualMidiDevices) - { - pMIDIKeyInfo = new midi_key_info_t128; - pEngine = NULL; - pInstrument = NULL; - pEvents = NULL; // we allocate when we retrieve the right Engine object - pEventQueue = new RingBuffer<Event,false>(CONFIG_MAX_EVENTS_PER_FRAGMENT, 0); - pActiveKeys = new Pool<uint>(128); - for (uint i = 0; i < 128; i++) { - pMIDIKeyInfoi.pActiveVoices = NULL; // we allocate when we retrieve the right Engine object - pMIDIKeyInfoi.KeyPressed = false; - pMIDIKeyInfoi.Active = false; - pMIDIKeyInfoi.ReleaseTrigger = false; - pMIDIKeyInfoi.pEvents = NULL; // we allocate when we retrieve the right Engine object - pMIDIKeyInfoi.VoiceTheftsQueued = 0; - pMIDIKeyInfoi.RoundRobinIndex = 0; - } - InstrumentIdx = -1; - InstrumentStat = -1; - pChannelLeft = NULL; - pChannelRight = NULL; - AudioDeviceChannelLeft = -1; - AudioDeviceChannelRight = -1; - pMidiInputPort = NULL; - midiChannel = midi_chan_all; - ResetControllers(); - SoloMode = false; - PortamentoMode = false; - PortamentoTime = CONFIG_PORTAMENTO_TIME_DEFAULT; - - // reset the instrument change command struct (need to be done - // twice, as it is double buffered) - { - instrument_change_command_t& cmd = InstrumentChangeCommand.GetConfigForUpdate(); - cmd.pDimRegionsInUse = NULL; - cmd.pInstrument = NULL; - cmd.bChangeInstrument = false; - } - { - instrument_change_command_t& cmd = InstrumentChangeCommand.SwitchConfig(); - cmd.pDimRegionsInUse = NULL; - cmd.pInstrument = NULL; - cmd.bChangeInstrument = false; - } + EngineChannel::EngineChannel() { + } EngineChannel::~EngineChannel() { DisconnectAudioOutputDevice(); - // In case the channel was removed before the instrument was // fully loaded, try to give back instrument again (see bug #113) - instrument_change_command_t& cmd = ChangeInstrument(NULL); + InstrumentChangeCmd< ::gig::DimensionRegion, ::gig::Instrument>& cmd = ChangeInstrument(NULL); if (cmd.pInstrument) { - Engine::instruments.HandBack(cmd.pInstrument, this); + Engine::instruments.HandBack(cmd.pInstrument, this); } /////// - - if (pEventQueue) delete pEventQueue; - if (pActiveKeys) delete pActiveKeys; - if (pMIDIKeyInfo) delete pMIDIKeyInfo; - RemoveAllFxSends(); - } - - /** - * Implementation of virtual method from abstract EngineChannel interface. - * This method will periodically be polled (e.g. by the LSCP server) to - * check if some engine channel parameter has changed since the last - * StatusChanged() call. - * - * This method can also be used to mark the engine channel as changed - * from outside, e.g. by a MIDI input device. The optional argument - * \a nNewStatus can be used for this. - * - * TODO: This "poll method" is just a lazy solution and might be - * replaced in future. - * @param bNewStatus - (optional, default: false) sets the new status flag - * @returns true if engine channel status has changed since last - * StatusChanged() call - */ - bool EngineChannel::StatusChanged(bool bNewStatus) { - bool b = bStatusChanged; - bStatusChanged = bNewStatus; - return b; } - void EngineChannel::Reset() { - if (pEngine) pEngine->DisableAndLock(); - ResetInternal(); - ResetControllers(); - if (pEngine) { - pEngine->Enable(); - pEngine->Reset(); - } - } + AbstractEngine::Format EngineChannel::GetEngineFormat() { return AbstractEngine::GIG; } - /** - * This method is not thread safe! - */ + /** This method is not thread safe! */ void EngineChannel::ResetInternal() { CurrentKeyDimension = 0; - - // reset key info - for (uint i = 0; i < 128; i++) { - if (pMIDIKeyInfoi.pActiveVoices) - pMIDIKeyInfoi.pActiveVoices->clear(); - if (pMIDIKeyInfoi.pEvents) - pMIDIKeyInfoi.pEvents->clear(); - pMIDIKeyInfoi.KeyPressed = false; - pMIDIKeyInfoi.Active = false; - pMIDIKeyInfoi.ReleaseTrigger = false; - pMIDIKeyInfoi.itSelf = Pool<uint>::Iterator(); - pMIDIKeyInfoi.VoiceTheftsQueued = 0; - } - SoloKey = -1; // no solo key active yet - PortamentoPos = -1.0f; // no portamento active yet - - // reset all key groups - std::map<uint,uint*>::iterator iter = ActiveKeyGroups.begin(); - for (; iter != ActiveKeyGroups.end(); iter++) iter->second = NULL; - - // free all active keys - pActiveKeys->clear(); - - // delete all input events - pEventQueue->init(); - - if (pEngine) pEngine->ResetInternal(); - - // status of engine channel has changed, so set notify flag - bStatusChanged = true; - } - - LinuxSampler::Engine* EngineChannel::GetEngine() { - return pEngine; + EngineChannelBase<Voice, ::gig::DimensionRegion, ::gig::Instrument>::ResetInternal(); } /** - * More or less a workaround to set the instrument name, index and load - * status variable to zero percent immediately, that is without blocking - * the calling thread. It might be used in future for other preparations - * as well though. + * Will be called by the MIDIIn Thread to signal that a program + * change should be performed. As a program change isn't + * real-time safe, the actual change is performed by the disk + * thread. * - * @param FileName - file name of the Gigasampler instrument file - * @param Instrument - index of the instrument in the .gig file - * @see LoadInstrument() + * @param Program - MIDI program change number */ - void EngineChannel::PrepareLoadInstrument(const char* FileName, uint Instrument) { - InstrumentFile = FileName; - InstrumentIdx = Instrument; - InstrumentStat = 0; + void EngineChannel::SendProgramChange(uint8_t Program) { + SetMidiProgram(Program); + Engine* engine = dynamic_cast<Engine*>(pEngine); + if(engine == NULL) return; + + if(engine->GetDiskThread()) { + uint32_t merged = (GetMidiBankMsb() << 16) | (GetMidiBankLsb() << 8) | Program; + engine->GetDiskThread()->OrderProgramChange(merged, this); + } else { + // TODO: + } } /** @@ -192,18 +79,20 @@ * @see PrepareLoadInstrument() */ void EngineChannel::LoadInstrument() { + InstrumentResourceManager* pInstrumentManager = dynamic_cast<InstrumentResourceManager*>(pEngine->GetInstrumentManager()); + // make sure we don't trigger any new notes with an old // instrument - instrument_change_command_t& cmd = ChangeInstrument(0); + InstrumentChangeCmd< ::gig::DimensionRegion, ::gig::Instrument>& cmd = ChangeInstrument(0); if (cmd.pInstrument) { // give old instrument back to instrument manager, but // keep the dimension regions and samples that are in use - Engine::instruments.HandBackInstrument(cmd.pInstrument, this, cmd.pDimRegionsInUse); + pInstrumentManager->HandBackInstrument(cmd.pInstrument, this, cmd.pRegionsInUse); } - cmd.pDimRegionsInUse->clear(); + cmd.pRegionsInUse->clear(); // delete all key groups - ActiveKeyGroups.clear(); + DeleteGroupEventLists(); // request gig instrument from instrument manager ::gig::Instrument* newInstrument; @@ -211,7 +100,8 @@ InstrumentManager::instrument_id_t instrid; instrid.FileName = InstrumentFile; instrid.Index = InstrumentIdx; - newInstrument = Engine::instruments.Borrow(instrid, this); + + newInstrument = pInstrumentManager->Borrow(instrid, this); if (!newInstrument) { throw InstrumentManagerException("resource was not created"); } @@ -234,744 +124,51 @@ throw Exception("gig::Engine error: Failed to load instrument, cause: Unknown exception while trying to parse gig file."); } - // rebuild ActiveKeyGroups map with key groups of current instrument - for (::gig::Region* pRegion = newInstrument->GetFirstRegion(); pRegion; pRegion = newInstrument->GetNextRegion()) - if (pRegion->KeyGroup) ActiveKeyGroupspRegion->KeyGroup = NULL; - - InstrumentIdxName = newInstrument->pInfo->Name; - InstrumentStat = 100; - - ChangeInstrument(newInstrument); - - StatusChanged(true); - } - - - /** - * Changes the instrument for an engine channel. - * - * @param pInstrument - new instrument - * @returns the resulting instrument change command after the - * command switch, containing the old instrument and - * the dimregions it is using - */ - EngineChannel::instrument_change_command_t& EngineChannel::ChangeInstrument(::gig::Instrument* pInstrument) { - instrument_change_command_t& cmd = InstrumentChangeCommand.GetConfigForUpdate(); - cmd.pInstrument = pInstrument; - cmd.bChangeInstrument = true; - - return InstrumentChangeCommand.SwitchConfig(); - } - - /** - * Will be called by the InstrumentResourceManager when the instrument - * we are currently using on this EngineChannel is going to be updated, - * so we can stop playback before that happens. - */ - void EngineChannel::ResourceToBeUpdated(::gig::Instrument* pResource, void*& pUpdateArg) { - dmsg(3,("gig::Engine: Received instrument update message.\n")); - if (pEngine) pEngine->DisableAndLock(); - ResetInternal(); - this->pInstrument = NULL; - } - - /** - * Will be called by the InstrumentResourceManager when the instrument - * update process was completed, so we can continue with playback. - */ - void EngineChannel::ResourceUpdated(::gig::Instrument* pOldResource, ::gig::Instrument* pNewResource, void* pUpdateArg) { - this->pInstrument = pNewResource; //TODO: there are couple of engine parameters we should update here as well if the instrument was updated (see LoadInstrument()) - if (pEngine) pEngine->Enable(); - bStatusChanged = true; // status of engine has changed, so set notify flag - } - - /** - * Will be called by the InstrumentResourceManager on progress changes - * while loading or realoading an instrument for this EngineChannel. - * - * @param fProgress - current progress as value between 0.0 and 1.0 - */ - void EngineChannel::OnResourceProgress(float fProgress) { - this->InstrumentStat = int(fProgress * 100.0f); - dmsg(7,("gig::EngineChannel: progress %d%", InstrumentStat)); - bStatusChanged = true; // status of engine has changed, so set notify flag - } - - void EngineChannel::Connect(AudioOutputDevice* pAudioOut) { - if (pEngine) { - if (pEngine->pAudioOutputDevice == pAudioOut) return; - DisconnectAudioOutputDevice(); - } - pEngine = Engine::AcquireEngine(this, pAudioOut); - ResetInternal(); - pEvents = new RTList<Event>(pEngine->pEventPool); - - // reset the instrument change command struct (need to be done - // twice, as it is double buffered) - { - instrument_change_command_t& cmd = InstrumentChangeCommand.GetConfigForUpdate(); - cmd.pDimRegionsInUse = new RTList< ::gig::DimensionRegion*>(pEngine->pDimRegionPool0); - cmd.pInstrument = 0; - cmd.bChangeInstrument = false; - } - { - instrument_change_command_t& cmd = InstrumentChangeCommand.SwitchConfig(); - cmd.pDimRegionsInUse = new RTList< ::gig::DimensionRegion*>(pEngine->pDimRegionPool1); - cmd.pInstrument = 0; - cmd.bChangeInstrument = false; - } - - if (pInstrument != NULL) { - pInstrument = NULL; - InstrumentStat = -1; - InstrumentIdx = -1; - InstrumentIdxName = ""; - InstrumentFile = ""; - bStatusChanged = true; - } - - for (uint i = 0; i < 128; i++) { - pMIDIKeyInfoi.pActiveVoices = new RTList<Voice>(pEngine->pVoicePool); - pMIDIKeyInfoi.pEvents = new RTList<Event>(pEngine->pEventPool); - } - AudioDeviceChannelLeft = 0; - AudioDeviceChannelRight = 1; - if (fxSends.empty()) { // render directly into the AudioDevice's output buffers - pChannelLeft = pAudioOut->Channel(AudioDeviceChannelLeft); - pChannelRight = pAudioOut->Channel(AudioDeviceChannelRight); - } else { // use local buffers for rendering and copy later - // ensure the local buffers have the correct size - if (pChannelLeft) delete pChannelLeft; - if (pChannelRight) delete pChannelRight; - pChannelLeft = new AudioChannel(0, pAudioOut->MaxSamplesPerCycle()); - pChannelRight = new AudioChannel(1, pAudioOut->MaxSamplesPerCycle()); - } - if (pEngine->EngineDisabled.GetUnsafe()) pEngine->Enable(); - MidiInputPort::AddSysexListener(pEngine); - } - - void EngineChannel::DisconnectAudioOutputDevice() { - if (pEngine) { // if clause to prevent disconnect loops - - ResetInternal(); - - // delete the structures used for instrument change - RTList< ::gig::DimensionRegion*>* d = InstrumentChangeCommand.GetConfigForUpdate().pDimRegionsInUse; - if (d) delete d; - EngineChannel::instrument_change_command_t& cmd = InstrumentChangeCommand.SwitchConfig(); - d = cmd.pDimRegionsInUse; - if (d) delete d; - - if (cmd.pInstrument) { - // release the currently loaded instrument - Engine::instruments.HandBack(cmd.pInstrument, this); - } - - if (pEvents) { - delete pEvents; - pEvents = NULL; - } - for (uint i = 0; i < 128; i++) { - if (pMIDIKeyInfoi.pActiveVoices) { - delete pMIDIKeyInfoi.pActiveVoices; - pMIDIKeyInfoi.pActiveVoices = NULL; - } - if (pMIDIKeyInfoi.pEvents) { - delete pMIDIKeyInfoi.pEvents; - pMIDIKeyInfoi.pEvents = NULL; - } - } - AudioOutputDevice* oldAudioDevice = pEngine->pAudioOutputDevice; - pEngine = NULL; - Engine::FreeEngine(this, oldAudioDevice); - AudioDeviceChannelLeft = -1; - AudioDeviceChannelRight = -1; - if (!fxSends.empty()) { // free the local rendering buffers - if (pChannelLeft) delete pChannelLeft; - if (pChannelRight) delete pChannelRight; - } - pChannelLeft = NULL; - pChannelRight = NULL; - } - } - - AudioOutputDevice* EngineChannel::GetAudioOutputDevice() { - return (pEngine) ? pEngine->pAudioOutputDevice : NULL; - } - - void EngineChannel::SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel) { - if (!pEngine || !pEngine->pAudioOutputDevice) throw AudioOutputException("No audio output device connected yet."); - - AudioChannel* pChannel = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannel); - if (!pChannel) throw AudioOutputException("Invalid audio output device channel " + ToString(AudioDeviceChannel)); - switch (EngineAudioChannel) { - case 0: // left output channel - if (fxSends.empty()) pChannelLeft = pChannel; - AudioDeviceChannelLeft = AudioDeviceChannel; - break; - case 1: // right output channel - if (fxSends.empty()) pChannelRight = pChannel; - AudioDeviceChannelRight = AudioDeviceChannel; - break; - default: - throw AudioOutputException("Invalid engine audio channel " + ToString(EngineAudioChannel)); - } - - bStatusChanged = true; - } - - int EngineChannel::OutputChannel(uint EngineAudioChannel) { - switch (EngineAudioChannel) { - case 0: // left channel - return AudioDeviceChannelLeft; - case 1: // right channel - return AudioDeviceChannelRight; - default: - throw AudioOutputException("Invalid engine audio channel " + ToString(EngineAudioChannel)); - } - } - - void EngineChannel::Connect(MidiInputPort* pMidiPort, midi_chan_t MidiChannel) { - if (!pMidiPort || pMidiPort == this->pMidiInputPort) return; - DisconnectMidiInputPort(); - this->pMidiInputPort = pMidiPort; - this->midiChannel = MidiChannel; - pMidiPort->Connect(this, MidiChannel); - } - - void EngineChannel::DisconnectMidiInputPort() { - MidiInputPort* pOldPort = this->pMidiInputPort; - this->pMidiInputPort = NULL; - if (pOldPort) pOldPort->Disconnect(this); - } - - MidiInputPort* EngineChannel::GetMidiInputPort() { - return pMidiInputPort; - } - - midi_chan_t EngineChannel::MidiChannel() { - return midiChannel; - } - - FxSend* EngineChannel::AddFxSend(uint8_t MidiCtrl, String Name) throw (Exception) { - if (pEngine) pEngine->DisableAndLock(); - FxSend* pFxSend = new FxSend(this, MidiCtrl, Name); - if (fxSends.empty()) { - if (pEngine && pEngine->pAudioOutputDevice) { - AudioOutputDevice* pDevice = pEngine->pAudioOutputDevice; - // create local render buffers - pChannelLeft = new AudioChannel(0, pDevice->MaxSamplesPerCycle()); - pChannelRight = new AudioChannel(1, pDevice->MaxSamplesPerCycle()); - } else { - // postpone local render buffer creation until audio device is assigned - pChannelLeft = NULL; - pChannelRight = NULL; - } - } - fxSends.push_back(pFxSend); - if (pEngine) pEngine->Enable(); - fireFxSendCountChanged(GetSamplerChannel()->Index(), GetFxSendCount()); - - return pFxSend; - } - - FxSend* EngineChannel::GetFxSend(uint FxSendIndex) { - return (FxSendIndex < fxSends.size()) ? fxSendsFxSendIndex : NULL; - } - - uint EngineChannel::GetFxSendCount() { - return fxSends.size(); - } - - void EngineChannel::RemoveFxSend(FxSend* pFxSend) { - if (pEngine) pEngine->DisableAndLock(); - for ( - std::vector<FxSend*>::iterator iter = fxSends.begin(); - iter != fxSends.end(); iter++ - ) { - if (*iter == pFxSend) { - delete pFxSend; - fxSends.erase(iter); - if (fxSends.empty()) { - // destroy local render buffers - if (pChannelLeft) delete pChannelLeft; - if (pChannelRight) delete pChannelRight; - // fallback to render directly into AudioOutputDevice's buffers - if (pEngine && pEngine->pAudioOutputDevice) { - pChannelLeft = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelLeft); - pChannelRight = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelRight); - } else { // we update the pointers later - pChannelLeft = NULL; - pChannelRight = NULL; - } - } - break; - } - } - if (pEngine) pEngine->Enable(); - fireFxSendCountChanged(GetSamplerChannel()->Index(), GetFxSendCount()); - } - - /** - * Will be called by the MIDIIn Thread to let the audio thread trigger a new - * voice for the given key. This method is meant for real time rendering, - * that is an event will immediately be created with the current system - * time as time stamp. - * - * @param Key - MIDI key number of the triggered key - * @param Velocity - MIDI velocity value of the triggered key - */ - void EngineChannel::SendNoteOn(uint8_t Key, uint8_t Velocity) { - if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(); - event.Type = Event::type_note_on; - event.Param.Note.Key = Key; - event.Param.Note.Velocity = Velocity; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - // inform connected virtual MIDI devices if any ... - // (e.g. virtual MIDI keyboard in instrument editor(s)) - ArrayList<VirtualMidiDevice*>& devices = - const_cast<ArrayList<VirtualMidiDevice*>&>( - virtualMidiDevicesReader_MidiThread.Lock() - ); - for (int i = 0; i < devices.size(); i++) { - devicesi->SendNoteOnToDevice(Key, Velocity); - } - virtualMidiDevicesReader_MidiThread.Unlock(); - } - } - - /** - * Will be called by the MIDIIn Thread to let the audio thread trigger a new - * voice for the given key. This method is meant for offline rendering - * and / or for cases where the exact position of the event in the current - * audio fragment is already known. - * - * @param Key - MIDI key number of the triggered key - * @param Velocity - MIDI velocity value of the triggered key - * @param FragmentPos - sample point position in the current audio - * fragment to which this event belongs to - */ - void EngineChannel::SendNoteOn(uint8_t Key, uint8_t Velocity, int32_t FragmentPos) { - if (FragmentPos < 0) { - dmsg(1,("EngineChannel::SendNoteOn(): negative FragmentPos! Seems MIDI driver is buggy!")); - } - else if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); - event.Type = Event::type_note_on; - event.Param.Note.Key = Key; - event.Param.Note.Velocity = Velocity; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - // inform connected virtual MIDI devices if any ... - // (e.g. virtual MIDI keyboard in instrument editor(s)) - ArrayList<VirtualMidiDevice*>& devices = - const_cast<ArrayList<VirtualMidiDevice*>&>( - virtualMidiDevicesReader_MidiThread.Lock() - ); - for (int i = 0; i < devices.size(); i++) { - devicesi->SendNoteOnToDevice(Key, Velocity); - } - virtualMidiDevicesReader_MidiThread.Unlock(); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread to release - * voice(s) on the given key. This method is meant for real time rendering, - * that is an event will immediately be created with the current system - * time as time stamp. - * - * @param Key - MIDI key number of the released key - * @param Velocity - MIDI release velocity value of the released key - */ - void EngineChannel::SendNoteOff(uint8_t Key, uint8_t Velocity) { - if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(); - event.Type = Event::type_note_off; - event.Param.Note.Key = Key; - event.Param.Note.Velocity = Velocity; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - // inform connected virtual MIDI devices if any ... - // (e.g. virtual MIDI keyboard in instrument editor(s)) - ArrayList<VirtualMidiDevice*>& devices = - const_cast<ArrayList<VirtualMidiDevice*>&>( - virtualMidiDevicesReader_MidiThread.Lock() - ); - for (int i = 0; i < devices.size(); i++) { - devicesi->SendNoteOffToDevice(Key, Velocity); - } - virtualMidiDevicesReader_MidiThread.Unlock(); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread to release - * voice(s) on the given key. This method is meant for offline rendering - * and / or for cases where the exact position of the event in the current - * audio fragment is already known. - * - * @param Key - MIDI key number of the released key - * @param Velocity - MIDI release velocity value of the released key - * @param FragmentPos - sample point position in the current audio - * fragment to which this event belongs to - */ - void EngineChannel::SendNoteOff(uint8_t Key, uint8_t Velocity, int32_t FragmentPos) { - if (FragmentPos < 0) { - dmsg(1,("EngineChannel::SendNoteOff(): negative FragmentPos! Seems MIDI driver is buggy!")); - } - else if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); - event.Type = Event::type_note_off; - event.Param.Note.Key = Key; - event.Param.Note.Velocity = Velocity; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - // inform connected virtual MIDI devices if any ... - // (e.g. virtual MIDI keyboard in instrument editor(s)) - ArrayList<VirtualMidiDevice*>& devices = - const_cast<ArrayList<VirtualMidiDevice*>&>( - virtualMidiDevicesReader_MidiThread.Lock() - ); - for (int i = 0; i < devices.size(); i++) { - devicesi->SendNoteOffToDevice(Key, Velocity); - } - virtualMidiDevicesReader_MidiThread.Unlock(); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread to change - * the pitch value for all voices. This method is meant for real time - * rendering, that is an event will immediately be created with the - * current system time as time stamp. - * - * @param Pitch - MIDI pitch value (-8192 ... +8191) - */ - void EngineChannel::SendPitchbend(int Pitch) { - if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(); - event.Type = Event::type_pitchbend; - event.Param.Pitch.Pitch = Pitch; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread to change - * the pitch value for all voices. This method is meant for offline - * rendering and / or for cases where the exact position of the event in - * the current audio fragment is already known. - * - * @param Pitch - MIDI pitch value (-8192 ... +8191) - * @param FragmentPos - sample point position in the current audio - * fragment to which this event belongs to - */ - void EngineChannel::SendPitchbend(int Pitch, int32_t FragmentPos) { - if (FragmentPos < 0) { - dmsg(1,("EngineChannel::SendPitchBend(): negative FragmentPos! Seems MIDI driver is buggy!")); - } - else if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); - event.Type = Event::type_pitchbend; - event.Param.Pitch.Pitch = Pitch; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread that a - * continuous controller value has changed. This method is meant for real - * time rendering, that is an event will immediately be created with the - * current system time as time stamp. - * - * @param Controller - MIDI controller number of the occured control change - * @param Value - value of the control change - */ - void EngineChannel::SendControlChange(uint8_t Controller, uint8_t Value) { - if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(); - event.Type = Event::type_control_change; - event.Param.CC.Controller = Controller; - event.Param.CC.Value = Value; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - } - } - - /** - * Will be called by the MIDIIn Thread to signal the audio thread that a - * continuous controller value has changed. This method is meant for - * offline rendering and / or for cases where the exact position of the - * event in the current audio fragment is already known. - * - * @param Controller - MIDI controller number of the occured control change - * @param Value - value of the control change - * @param FragmentPos - sample point position in the current audio - * fragment to which this event belongs to - */ - void EngineChannel::SendControlChange(uint8_t Controller, uint8_t Value, int32_t FragmentPos) { - if (FragmentPos < 0) { - dmsg(1,("EngineChannel::SendControlChange(): negative FragmentPos! Seems MIDI driver is buggy!")); - } - else if (pEngine) { - Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); - event.Type = Event::type_control_change; - event.Param.CC.Controller = Controller; - event.Param.CC.Value = Value; - event.pEngineChannel = this; - if (this->pEventQueue->write_space() > 0) this->pEventQueue->push(&event); - else dmsg(1,("EngineChannel: Input event queue full!")); - } - } - - /** - * Will be called by the MIDIIn Thread to signal that a program - * change should be performed. As a program change isn't - * real-time safe, the actual change is performed by the disk - * thread. - * - * @param Program - MIDI program change number - */ - void EngineChannel::SendProgramChange(uint8_t Program) { - if (pEngine) { - pEngine->pDiskThread->OrderProgramChange(Program, this); - } - } - - void EngineChannel::ClearEventLists() { - pEvents->clear(); - // empty MIDI key specific event lists - { - RTList<uint>::Iterator iuiKey = pActiveKeys->first(); - RTList<uint>::Iterator end = pActiveKeys->end(); - for(; iuiKey != end; ++iuiKey) { - pMIDIKeyInfo*iuiKey.pEvents->clear(); // free all events on the key - } - } - } + RoundRobinIndex = 0; + for (int i = 0 ; i < 128 ; i++) pMIDIKeyInfoi.pRoundRobinIndex = NULL; - void EngineChannel::ResetControllers() { - Pitch = 0; - SustainPedal = false; - SostenutoPedal = false; - GlobalVolume = 1.0f; - MidiVolume = 1.0; - GlobalPanLeft = 1.0f; - GlobalPanRight = 1.0f; - iLastPanRequest = 64; - GlobalTranspose = 0; - // set all MIDI controller values to zero - memset(ControllerTable, 0x00, 129); - // reset all FX Send levels - for ( - std::vector<FxSend*>::iterator iter = fxSends.begin(); - iter != fxSends.end(); iter++ - ) { - (*iter)->Reset(); - } - } + // rebuild ActiveKeyGroups map with key groups of current + // instrument and set the round robin pointers to use one + // counter for each region + int region = 0; + for (::gig::Region* pRegion = newInstrument->GetFirstRegion(); pRegion; pRegion = newInstrument->GetNextRegion()) { + AddGroup(pRegion->KeyGroup); - /** - * Copy all events from the engine channel's input event queue buffer to - * the internal event list. This will be done at the beginning of each - * audio cycle (that is each RenderAudio() call) to distinguish all - * events which have to be processed in the current audio cycle. Each - * EngineChannel has it's own input event queue for the common channel - * specific events (like NoteOn, NoteOff and ControlChange events). - * Beside that, the engine also has a input event queue for global - * events (usually SysEx messages). - * - * @param Samples - number of sample points to be processed in the - * current audio cycle - */ - void EngineChannel::ImportEvents(uint Samples) { - // import events from pure software MIDI "devices" - // (e.g. virtual keyboard in instrument editor) - { - const int FragmentPos = 0; // randomly chosen, we don't care about jitter for virtual MIDI devices - Event event = pEngine->pEventGenerator->CreateEvent(FragmentPos); - VirtualMidiDevice::event_t devEvent; // the event format we get from the virtual MIDI device - // as we're going to (carefully) write some status to the - // synchronized struct, we cast away the const - ArrayList<VirtualMidiDevice*>& devices = - const_cast<ArrayList<VirtualMidiDevice*>&>(virtualMidiDevicesReader_AudioThread.Lock()); - // iterate through all virtual MIDI devices - for (int i = 0; i < devices.size(); i++) { - VirtualMidiDevice* pDev = devicesi; - // I think we can simply flush the whole FIFO(s), the user shouldn't be so fast ;-) - while (pDev->GetMidiEventFromDevice(devEvent)) { - event.Type = - (devEvent.Type == VirtualMidiDevice::EVENT_TYPE_NOTEON) ? - Event::type_note_on : Event::type_note_off; - event.Param.Note.Key = devEvent.Key; - event.Param.Note.Velocity = devEvent.Velocity; - event.pEngineChannel = this; - // copy event to internal event list - if (pEvents->poolIsEmpty()) { - dmsg(1,("Event pool emtpy!\n")); - goto exitVirtualDevicesLoop; - } - *pEvents->allocAppend() = event; - } + RoundRobinIndexesregion = 0; + for (int iKey = pRegion->KeyRange.low; iKey <= pRegion->KeyRange.high; iKey++) { + pMIDIKeyInfoiKey.pRoundRobinIndex = &RoundRobinIndexesregion; } + region++; } - exitVirtualDevicesLoop: - virtualMidiDevicesReader_AudioThread.Unlock(); - // import events from the regular MIDI devices - RingBuffer<Event,false>::NonVolatileReader eventQueueReader = pEventQueue->get_non_volatile_reader(); - Event* pEvent; - while (true) { - // get next event from input event queue - if (!(pEvent = eventQueueReader.pop())) break; - // if younger event reached, ignore that and all subsequent ones for now - if (pEvent->FragmentPos() >= Samples) { - eventQueueReader--; - dmsg(2,("Younger Event, pos=%d ,Samples=%d!\n",pEvent->FragmentPos(),Samples)); - pEvent->ResetFragmentPos(); - break; - } - // copy event to internal event list - if (pEvents->poolIsEmpty()) { - dmsg(1,("Event pool emtpy!\n")); - break; - } - *pEvents->allocAppend() = *pEvent; - } - eventQueueReader.free(); // free all copied events from input queue - } + InstrumentIdxName = newInstrument->pInfo->Name; + InstrumentStat = 100; - void EngineChannel::RemoveAllFxSends() { - if (pEngine) pEngine->DisableAndLock(); - if (!fxSends.empty()) { // free local render buffers - if (pChannelLeft) { - delete pChannelLeft; - if (pEngine && pEngine->pAudioOutputDevice) { - // fallback to render directly to the AudioOutputDevice's buffer - pChannelLeft = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelLeft); - } else pChannelLeft = NULL; - } - if (pChannelRight) { - delete pChannelRight; - if (pEngine && pEngine->pAudioOutputDevice) { - // fallback to render directly to the AudioOutputDevice's buffer - pChannelRight = pEngine->pAudioOutputDevice->Channel(AudioDeviceChannelRight); - } else pChannelRight = NULL; - } - } - for (int i = 0; i < fxSends.size(); i++) delete fxSendsi; - fxSends.clear(); - if (pEngine) pEngine->Enable(); - } + ChangeInstrument(newInstrument); - void EngineChannel::Connect(VirtualMidiDevice* pDevice) { - // double buffer ... double work ... - { - ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.GetConfigForUpdate(); - devices.add(pDevice); - } - { - ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.SwitchConfig(); - devices.add(pDevice); - } + StatusChanged(true); } - void EngineChannel::Disconnect(VirtualMidiDevice* pDevice) { - // double buffer ... double work ... + void EngineChannel::ProcessKeySwitchChange(int key) { + // Change key dimension value if key is in keyswitching area { - ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.GetConfigForUpdate(); - devices.remove(pDevice); + if (key >= pInstrument->DimensionKeyRange.low && key <= pInstrument->DimensionKeyRange.high) + CurrentKeyDimension = float(key - pInstrument->DimensionKeyRange.low) / + (pInstrument->DimensionKeyRange.high - pInstrument->DimensionKeyRange.low + 1); } - { - ArrayList<VirtualMidiDevice*>& devices = virtualMidiDevices.SwitchConfig(); - devices.remove(pDevice); - } - } - - float EngineChannel::Volume() { - return GlobalVolume; } - - void EngineChannel::Volume(float f) { - GlobalVolume = f; - bStatusChanged = true; // status of engine channel has changed, so set notify flag - } - - float EngineChannel::Pan() { - return float(iLastPanRequest - 64) / 64.0f; - } - - void EngineChannel::Pan(float f) { - int iMidiPan = int(f * 64.0f) + 64; - if (iMidiPan > 127) iMidiPan = 127; - else if (iMidiPan < 0) iMidiPan = 0; - GlobalPanLeft = Engine::PanCurve128 - iMidiPan; - GlobalPanRight = Engine::PanCurveiMidiPan; - iLastPanRequest = iMidiPan; - } - - uint EngineChannel::Channels() { - return 2; - } - + String EngineChannel::InstrumentFileName() { - return InstrumentFile; - } - - String EngineChannel::InstrumentName() { - return InstrumentIdxName; - } - - int EngineChannel::InstrumentIndex() { - return InstrumentIdx; - } - - int EngineChannel::InstrumentStatus() { - return InstrumentStat; - } - - String EngineChannel::EngineName() { - return LS_GIG_ENGINE_NAME; - } - - void EngineChannel::ClearDimRegionsInUse() { - { - instrument_change_command_t& cmd = InstrumentChangeCommand.GetConfigForUpdate(); - if(cmd.pDimRegionsInUse != NULL) cmd.pDimRegionsInUse->clear(); - } - { - instrument_change_command_t& cmd = InstrumentChangeCommand.SwitchConfig(); - if(cmd.pDimRegionsInUse != NULL) cmd.pDimRegionsInUse->clear(); - } - } - - void EngineChannel::ResetDimRegionsInUse() { - { - instrument_change_command_t& cmd = InstrumentChangeCommand.GetConfigForUpdate(); - if(cmd.pDimRegionsInUse != NULL) { - delete cmd.pDimRegionsInUse; - cmd.pDimRegionsInUse = new RTList< ::gig::DimensionRegion*>(pEngine->pDimRegionPool0); - } - } - { - instrument_change_command_t& cmd = InstrumentChangeCommand.SwitchConfig(); - if(cmd.pDimRegionsInUse != NULL) { - delete cmd.pDimRegionsInUse; - cmd.pDimRegionsInUse = new RTList< ::gig::DimensionRegion*>(pEngine->pDimRegionPool1); - } - } + return EngineChannelBase<Voice, ::gig::DimensionRegion, ::gig::Instrument>::InstrumentFileName(); + } + + String EngineChannel::InstrumentFileName(int index) { + if (index == 0) return InstrumentFileName(); + if (!pInstrument || !pInstrument->GetParent()) return ""; + DLS::File* pMainFile = dynamic_cast<DLS::File*>(pInstrument->GetParent()); + if (!pMainFile) return ""; + RIFF::File* pExtensionFile = pMainFile->GetExtensionFile(index); + return (pExtensionFile) ? pExtensionFile->GetFileName() : ""; } }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/EngineChannel.h -> linuxsampler-2342.tar.bz2/src/engines/gig/EngineChannel.h
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2012 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * * * * 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 * @@ -22,150 +23,39 @@ ***************************************************************************/ #ifndef __LS_GIG_ENGINECHANNEL_H__ -#define __LS_GIG_ENGINECHANNEL_H__ +#define __LS_GIG_ENGINECHANNEL_H__ -#include "../common/Event.h" -#include "../EngineChannel.h" -#include "../../common/RingBuffer.h" -#include "../../common/ArrayList.h" -#include "../../drivers/audio/AudioChannel.h" -#include "EngineGlobals.h" -#include "Engine.h" +#include "../AbstractEngine.h" +#include "../EngineChannelBase.h" +#include "../EngineChannelFactory.h" #include "Voice.h" -#include "InstrumentResourceManager.h" +#include <gig.h> namespace LinuxSampler { namespace gig { - - // just symbol prototyping - class midi_key_info_t; - class Voice; - - /** @brief Engine Channel of a gig::Engine - * - * Encapsulates a engine channel for the Gigasampler format capable - * sampler engine. - */ - class EngineChannel : public LinuxSampler::EngineChannel, public InstrumentConsumer { + class EngineChannel: public LinuxSampler::EngineChannelBase<Voice, ::gig::DimensionRegion, ::gig::Instrument> { public: - EngineChannel(); - virtual ~EngineChannel(); - - // implementation of abstract methods derived from interface class 'LinuxSampler::EngineChannel' - virtual void PrepareLoadInstrument(const char* FileName, uint Instrument); - virtual void LoadInstrument(); - virtual void Reset(); - virtual void SendNoteOn(uint8_t Key, uint8_t Velocity); - virtual void SendNoteOn(uint8_t Key, uint8_t Velocity, int32_t FragmentPos); - virtual void SendNoteOff(uint8_t Key, uint8_t Velocity); - virtual void SendNoteOff(uint8_t Key, uint8_t Velocity, int32_t FragmentPos); - virtual void SendPitchbend(int Pitch); - virtual void SendPitchbend(int Pitch, int32_t FragmentPos); - virtual void SendControlChange(uint8_t Controller, uint8_t Value); - virtual void SendControlChange(uint8_t Controller, uint8_t Value, int32_t FragmentPos); - virtual void SendProgramChange(uint8_t Program); - virtual bool StatusChanged(bool bNewStatus = false); - virtual float Volume(); - virtual void Volume(float f); - virtual float Pan(); - virtual void Pan(float f); - virtual uint Channels(); - virtual void Connect(AudioOutputDevice* pAudioOut); - virtual void DisconnectAudioOutputDevice(); - virtual AudioOutputDevice* GetAudioOutputDevice(); - virtual void SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel); - virtual int OutputChannel(uint EngineAudioChannel); - virtual void Connect(MidiInputPort* pMidiPort, midi_chan_t MidiChannel); - virtual void DisconnectMidiInputPort(); - virtual MidiInputPort* GetMidiInputPort(); - virtual midi_chan_t MidiChannel(); - virtual String InstrumentFileName(); - virtual String InstrumentName(); - virtual int InstrumentIndex(); - virtual int InstrumentStatus(); - virtual LinuxSampler::Engine* GetEngine(); - virtual String EngineName(); - virtual FxSend* AddFxSend(uint8_t MidiCtrl, String Name = "") throw (Exception); - virtual FxSend* GetFxSend(uint FxSendIndex); - virtual uint GetFxSendCount(); - virtual void RemoveFxSend(FxSend* pFxSend); - virtual void Connect(VirtualMidiDevice* pDevice); - virtual void Disconnect(VirtualMidiDevice* pDevice); - - // implementation of abstract methods derived from interface class 'InstrumentConsumer' - virtual void ResourceToBeUpdated(::gig::Instrument* pResource, void*& pUpdateArg); - virtual void ResourceUpdated(::gig::Instrument* pOldResource, ::gig::Instrument* pNewResource, void* pUpdateArg); - virtual void OnResourceProgress(float fProgress); - - //protected: - Engine* pEngine; - AudioChannel* pChannelLeft; ///< encapsulates the audio rendering buffer (left) - AudioChannel* pChannelRight; ///< encapsulates the audio rendering buffer (right) - int AudioDeviceChannelLeft; ///< audio device channel number to which the left channel is connected to - int AudioDeviceChannelRight; ///< audio device channel number to which the right channel is connected to - MidiInputPort* pMidiInputPort; ///< Points to the connected MIDI input port or NULL if none assigned. - midi_chan_t midiChannel; ///< MIDI channel(s) on which this engine channel listens to. - RingBuffer<Event,false>* pEventQueue; ///< Input event queue. - RTList<Event>* pEvents; ///< All engine channel specific events for the current audio fragment. - uint8_t ControllerTable129; ///< Reflects the current values (0-127) of all MIDI controllers for this engine / sampler channel. Number 128 is for channel pressure (mono aftertouch). - midi_key_info_t* pMIDIKeyInfo; ///< Contains all active voices sorted by MIDI key number and other informations to the respective MIDI key - Pool<uint>* pActiveKeys; ///< Holds all keys in it's allocation list with active voices. - std::map<uint,uint*> ActiveKeyGroups; ///< Contains active keys (in case they belong to a key group) ordered by key group ID. - ::gig::Instrument* pInstrument; - bool SustainPedal; ///< true if sustain pedal is down - bool SostenutoPedal; ///< true if sostenuto pedal is down - bool SoloMode; ///< in Solo Mode we only play one voice (group) at a time - int SoloKey; ///< Currently 'active' solo key, that is the key to which the currently sounding voice belongs to (only if SoloMode is enabled) - bool PortamentoMode; ///< in Portamento Mode we slide the pitch from the last note to the current note. - float PortamentoTime; ///< How long it will take to glide from the previous note to the current (in seconds) - float PortamentoPos; ///< Current position on the keyboard, that is integer and fractional part (only used if PortamentoMode is on) - double GlobalVolume; ///< Master volume factor set through the C++ API / LSCP (a value < 1.0 means attenuation, a value > 1.0 means amplification) - double MidiVolume; ///< Volume factor altered by MIDI CC#7 (a value < 1.0 means attenuation, a value > 1.0 means amplification) - float GlobalPanLeft; - float GlobalPanRight; - int Pitch; ///< Current (absolute) MIDI pitch value. - float CurrentKeyDimension; ///< Current value (0-1.0) for the keyboard dimension, altered by pressing a keyswitching key. - String InstrumentFile; - int InstrumentIdx; - String InstrumentIdxName; - int InstrumentStat; - int iEngineIndexSelf; ///< Reflects the index of this EngineChannel in the Engine's ArrayList. - bool bStatusChanged; ///< true in case an engine parameter has changed (e.g. new instrument, another volumet) - std::vector<FxSend*> fxSends; - int GlobalTranspose; ///< amount of semi tones all notes should be transposed - int iLastPanRequest; ///< just for the return value of Pan(), so we don't have to make an injective function + virtual void SendProgramChange(uint8_t Program); + virtual void LoadInstrument(); + virtual void ResetInternal(); + virtual String InstrumentFileName(); + virtual String InstrumentFileName(int index); - /// Command used by the instrument loader thread to - /// request an instrument change on a channel. - struct instrument_change_command_t { - bool bChangeInstrument; ///< Set to true by the loader when the channel should change instrument. - ::gig::Instrument* pInstrument; ///< The new instrument. Also used by the loader to read the previously loaded instrument. - RTList< ::gig::DimensionRegion*>* pDimRegionsInUse; ///< List of dimension regions in use by the currently loaded instrument. Continuously updated by the audio thread. - }; - SynchronizedConfig<instrument_change_command_t> InstrumentChangeCommand; - SynchronizedConfig<instrument_change_command_t>::Reader InstrumentChangeCommandReader; + virtual AbstractEngine::Format GetEngineFormat(); - RTList< ::gig::DimensionRegion*>* pDimRegionsInUse; ///< temporary pointer into the instrument change command, used by the audio thread + friend class Voice; + friend class Engine; + friend class LinuxSampler::EngineChannelFactory; - SynchronizedConfig< ArrayList<VirtualMidiDevice*> > virtualMidiDevices; - SynchronizedConfig< ArrayList<VirtualMidiDevice*> >::Reader virtualMidiDevicesReader_AudioThread; - SynchronizedConfig< ArrayList<VirtualMidiDevice*> >::Reader virtualMidiDevicesReader_MidiThread; + protected: + EngineChannel(); + virtual ~EngineChannel(); - void ResetControllers(); - void ClearEventLists(); - void ImportEvents(uint Samples); + float CurrentKeyDimension; ///< Current value (0-1.0) for the keyboard dimension, altered by pressing a keyswitching key. - friend class Engine; - friend class Voice; - friend class InstrumentResourceManager; + virtual void ProcessKeySwitchChange(int key); - private: - void ResetInternal(); - void RemoveAllFxSends(); - void ClearDimRegionsInUse(); - void ResetDimRegionsInUse(); - instrument_change_command_t& ChangeInstrument(::gig::Instrument* pInstrument); }; }} // namespace LinuxSampler::gig -#endif // __LS_GIG_ENGINECHANNEL_H__ +#endif /* __LS_GIG_ENGINECHANNEL_H__ */
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/EngineGlobals.h -> linuxsampler-2342.tar.bz2/src/engines/gig/EngineGlobals.h
Changed
@@ -41,23 +41,6 @@ voice_steal_algo_oldestkey ///< Try to kill the oldest voice from the oldest active key. }; - /** @brief MIDI key runtime informations - * - * Reflects runtime informations for one MIDI key. - */ - struct midi_key_info_t { - RTList<Voice>* pActiveVoices; ///< Contains the active voices associated with the MIDI key. - bool KeyPressed; ///< Is true if the respective MIDI key is currently pressed. - bool Active; ///< If the key contains active voices. - bool ReleaseTrigger; ///< If we have to launch release triggered voice(s) when the key is released - Pool<uint>::Iterator itSelf; ///< hack to allow fast deallocation of the key from the list of active keys - RTList<Event>* pEvents; ///< Key specific events (only Note-on, Note-off and sustain pedal currently) - int VoiceTheftsQueued; ///< Amount of voices postponed due to shortage of voices. - uint8_t RoundRobinIndex; ///< For the round robin dimension: current articulation for this key, will be incremented for each note on - uint8_t Velocity; ///< Latest Note-on velocity for this key - unsigned long NoteOnTime; ///< Time for latest Note-on event for this key - }; - }} // namespace LinuxSampler::gig #endif // __LS_GIG_ENGINEGLOBALS_H__
View file
linuxsampler-2342.tar.bz2/src/engines/gig/Filter.cpp
Added
@@ -0,0 +1,41 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 Andreas Persson * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#include "Filter.h" + +namespace LinuxSampler { + const LowpassFilter1p Filter::lp1p; + const LowpassFilter Filter::lp2p; + const LowpassFilter4p Filter::lp4p; + const LowpassFilter6p Filter::lp6p; + const BandpassFilter Filter::bp2p; + const BandrejectFilter Filter::br2p; + const HighpassFilter1p Filter::hp1p; + const HighpassFilter Filter::hp2p; + const HighpassFilter4p Filter::hp4p; + const HighpassFilter6p Filter::hp6p; + const gig::HighpassFilter Filter::HPFilter; + const gig::BandpassFilter Filter::BPFilter; + const gig::LowpassFilter Filter::LPFilter; + const gig::BandrejectFilter Filter::BRFilter; + const gig::LowpassTurboFilter Filter::LPTFilter; +}
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Filter.h -> linuxsampler-2342.tar.bz2/src/engines/gig/Filter.h
Changed
@@ -4,7 +4,7 @@ * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * * Copyright (C) 2005 Christian Schoenebeck * - * Copyright (C) 2006 Christian Schoenebeck and Andreas Persson * + * Copyright (C) 2006-2011 Christian Schoenebeck and Andreas Persson * * * * 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 * @@ -29,196 +29,661 @@ #include <gig.h> -namespace LinuxSampler { namespace gig { +#include <cmath> - class FilterBase { +/* TODO: This file contains both generic filters (used by the sfz + engine) and gig specific filters. It should probably be split up, + and the generic parts should be moved out of the gig directory. */ + +/* + * The formulas for the biquad coefficients come from Robert + * Bristow-Johnson's Audio EQ Cookbook. The one pole filter formulas + * come from a post on musicdsp.org. The one poles, biquads and + * cascaded biquads are modeled after output from Dimension LE and SFZ + * Player. The gig filters are modeled after output from GigaStudio. + */ +namespace LinuxSampler { + + /** + * Filter state and parameters for a biquad filter. + */ + class BiquadFilterData { public: - virtual float Apply(float x) = 0; - virtual void SetParameters(float f1, float f2, float scale) = 0; - virtual ~FilterBase() {} + float b0, b1, b2; + float a1, a2; - virtual void Reset() { - y1 = y2 = y3 = x1 = x2 = x3 = 0; - } + float x1, x2; + float y1, y2; + }; - private: - float y1, y2, y3; + /** + * Filter state and parameters for cascaded biquad filters and gig + * engine filters. + */ + class FilterData : public BiquadFilterData + { + public: + union { + // gig filter parameters + struct { + float a3; + float x3; + float y3; - protected: - float a1, a2, a3, x1, x2, x3; + float scale; + float b20; + float y21, y22, y23; + }; + // cascaded biquad parameters + struct { + BiquadFilterData d2; + BiquadFilterData d3; + }; + }; + }; - void KillDenormal(float& f) { + /** + * Abstract base class for all filter implementations. + */ + class FilterBase { + public: + virtual float Apply(FilterData& d, float x) const = 0; + virtual void SetParameters(FilterData& d, float fc, float r, + float fs) const = 0; + virtual void Reset(FilterData& d) const = 0; + protected: + void KillDenormal(float& f) const { f += 1e-18f; f -= 1e-18f; } + }; + + /** + * One-pole lowpass filter. + */ + class LowpassFilter1p : public FilterBase { + public: + LowpassFilter1p() { } - float ApplyA(float x) { - float y = x - a1 * y1 - a2 * y2 - a3 * y3; + float Apply(FilterData& d, float x) const { + float y = x + d.a1 * (x - d.y1); // d.b0 * x - d.a1 * d.y1; KillDenormal(y); - y3 = y2; - y2 = y1; - y1 = y; + d.y1 = y; return y; } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float c = 2 - cos(omega); + d.a1 = -(c - sqrt(c * c - 1)); + // d.b0 = 1 + d.a1; + } + + void Reset(FilterData& d) const { + d.y1 = 0; + } }; - class LowpassFilter : public FilterBase { + /** + * One pole highpass filter. + */ + class HighpassFilter1p : public FilterBase { + public: + HighpassFilter1p() { } + + float Apply(FilterData& d, float x) const { + // d.b0 * x + d.b1 * d.x1 - d.a1 * d.y1; + float y = d.a1 * (-x + d.x1 - d.y1); + KillDenormal(y); + d.x1 = x; + d.y1 = y; + return y; + } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float c = 2 - cos(omega); + d.a1 = -(c - sqrt(c * c - 1)); + // d.b0 = -d.a1 + // d.b1 = d.a1 + } + + void Reset(FilterData& d) const { + d.x1 = 0; + d.y1 = 0; + } + }; + + /** + * Base class for biquad filter implementations. + */ + class BiquadFilter : public FilterBase { protected: - float b0; + float ApplyBQ(BiquadFilterData& d, float x) const { + float y = d.b0 * x + d.b1 * d.x1 + d.b2 * d.x2 + + d.a1 * d.y1 + d.a2 * d.y2; + KillDenormal(y); + d.x2 = d.x1; + d.x1 = x; + d.y2 = d.y1; + d.y1 = y; + return y; + } + public: - float Apply(float x) { - return ApplyA(b0 * x); + float Apply(FilterData& d, float x) const { + return ApplyBQ(d, x); } - void SetParameters(float f1, float f2, float scale) { - float f1_2 = f1 * f1; - b0 = f1_2 * scale; - a1 = f2; - a2 = f1_2 - 1; - a3 = -f2; + void Reset(FilterData& d) const { + d.x1 = d.x2 = 0; + d.y1 = d.y2 = 0; } }; - class BandpassFilter : public FilterBase { - float b0, b2; + /** + * Base class for cascaded double biquad filter (four poles). + */ + class DoubleBiquadFilter : public BiquadFilter { public: - float Apply(float x) { - float y = ApplyA(b0 * x + b2 * x2); - x2 = x1; - x1 = x; - return y; + float Apply(FilterData& d, float x) const { + return ApplyBQ(d.d2, BiquadFilter::Apply(d, x)); } - void SetParameters(float f1, float f2, float scale) { - b0 = f1 * scale; - b2 = -b0; - a1 = f2; - a2 = f1 * f1 - 1; - a3 = -f2; + void Reset(FilterData& d) const { + BiquadFilter::Reset(d); + d.d2.x1 = d.d2.x2 = 0; + d.d2.y1 = d.d2.y2 = 0; } }; - class HighpassFilter : public FilterBase { - float scale; + /** + * Base class for cascaded triple biquad filter (six poles). + */ + class TripleBiquadFilter : public DoubleBiquadFilter { public: - float Apply(float x) { - float y = ApplyA(-x + x1 + x2 - x3); - x3 = x2; - x2 = x1; - x1 = x; - return y * scale; + float Apply(FilterData& d, float x) const { + return ApplyBQ(d.d3, DoubleBiquadFilter::Apply(d, x)); } - void SetParameters(float f1, float f2, float scale) { - a1 = f2; - a2 = f1 * f1 - 1; - a3 = -f2; - this->scale = scale; + void Reset(FilterData& d) const { + DoubleBiquadFilter::Reset(d); + d.d3.x1 = d.d3.x2 = 0; + d.d3.y1 = d.d3.y2 = 0; } }; - class BandrejectFilter : public FilterBase { - float scale, b2; + + /** @brief Lowpass Filter + * + * Lowpass filter based on biquad filter implementation. + */ + class LowpassFilter : public BiquadFilter { public: - float Apply(float x) { - float y = ApplyA(x - x1 + b2 * x2 + x3); - x3 = x2; - x2 = x1; - x1 = x; - return y * scale; + LowpassFilter() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2 * exp(-M_LN10 / 20 * r); + float a0r = 1.0 / (1.0 + alpha); + + d.b0 = a0r * (1.0 - cs) * 0.5; + d.b1 = a0r * (1.0 - cs); + d.b2 = a0r * (1.0 - cs) * 0.5; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); } + }; + + /** @brief Four pole lowpass filter + * + * Lowpass filter based on two cascaded biquad filters. + */ + class LowpassFilter4p : public DoubleBiquadFilter { + public: + LowpassFilter4p() { } - void SetParameters(float f1, float f2, float scale) { - b2 = f1 * f1 - 1; - a1 = f2; - a2 = b2; - a3 = -f2; - this->scale = scale; + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2; + float a0r = 1.0 / (1.0 + alpha); + + d.b0 = a0r * (1.0 - cs) * 0.5; + d.b1 = a0r * (1.0 - cs); + d.b2 = a0r * (1.0 - cs) * 0.5; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); + + alpha *= exp(-M_LN10 / 20 * r); + a0r = 1.0 / (1.0 + alpha); + + d.d2.b0 = a0r * (1.0 - cs) * 0.5; + d.d2.b1 = a0r * (1.0 - cs); + d.d2.b2 = a0r * (1.0 - cs) * 0.5; + d.d2.a1 = a0r * (2.0 * cs); + d.d2.a2 = a0r * (alpha - 1.0); } }; - class LowpassTurboFilter : public LowpassFilter { - float b20, y21, y22, y23; + /** @brief Six pole lowpass filter + * + * Lowpass filter based on three cascaded biquad filters. + */ + class LowpassFilter6p : public TripleBiquadFilter { public: - float Apply(float x) { - float y = b20 * LowpassFilter::Apply(x) - - a1 * y21 - a2 * y22 - a3 * y23; + LowpassFilter6p() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2; + float a0r = 1.0 / (1.0 + alpha); + + d.b0 = d.d2.b0 = a0r * (1.0 - cs) * 0.5; + d.b1 = d.d2.b1 = a0r * (1.0 - cs); + d.b2 = d.d2.b2 = a0r * (1.0 - cs) * 0.5; + d.a1 = d.d2.a1 = a0r * (2.0 * cs); + d.a2 = d.d2.a2 = a0r * (alpha - 1.0); + + alpha *= exp(-M_LN10 / 20 * r); + a0r = 1.0 / (1.0 + alpha); + + d.d3.b0 = a0r * (1.0 - cs) * 0.5; + d.d3.b1 = a0r * (1.0 - cs); + d.d3.b2 = a0r * (1.0 - cs) * 0.5; + d.d3.a1 = a0r * (2.0 * cs); + d.d3.a2 = a0r * (alpha - 1.0); + } + }; + + /** @brief Bandpass filter + * + * Bandpass filter based on biquad filter implementation. + */ + class BandpassFilter : public BiquadFilter { + public: + BandpassFilter() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2 * exp(-M_LN10 / 20 * r); + + float a0r = 1.0 / (1.0 + alpha); + d.b0 = a0r * alpha; + d.b1 = 0.0; + d.b2 = a0r * -alpha; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); + } + }; + + /** @brief Bandreject filter + * + * Bandreject filter based on biquad filter implementation. + */ + class BandrejectFilter : public BiquadFilter { + public: + BandrejectFilter() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2 * exp(-M_LN10 / 20 * r); + + float a0r = 1.0 / (1.0 + alpha); + d.b0 = a0r; + d.b1 = a0r * (-2.0 * cs); + d.b2 = a0r; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); + } + }; + + /** @brief Highpass filter + * + * Highpass filter based on biquad filter implementation. + */ + class HighpassFilter : public BiquadFilter { + public: + HighpassFilter() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2 * exp(-M_LN10 / 20 * r); + + float a0r = 1.0 / (1.0 + alpha); + d.b0 = a0r * (1.0 + cs) * 0.5; + d.b1 = a0r * -(1.0 + cs); + d.b2 = a0r * (1.0 + cs) * 0.5; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); + } + }; + + /** @brief Four pole highpass filter + * + * Highpass filter based on three cascaded biquad filters. + */ + class HighpassFilter4p : public DoubleBiquadFilter { + public: + HighpassFilter4p() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2; + + float a0r = 1.0 / (1.0 + alpha); + d.b0 = a0r * (1.0 + cs) * 0.5; + d.b1 = a0r * -(1.0 + cs); + d.b2 = a0r * (1.0 + cs) * 0.5; + d.a1 = a0r * (2.0 * cs); + d.a2 = a0r * (alpha - 1.0); + + alpha *= exp(-M_LN10 / 20 * r); + a0r = 1.0 / (1.0 + alpha); + + d.d2.b0 = a0r * (1.0 + cs) * 0.5; + d.d2.b1 = a0r * -(1.0 + cs); + d.d2.b2 = a0r * (1.0 + cs) * 0.5; + d.d2.a1 = a0r * (2.0 * cs); + d.d2.a2 = a0r * (alpha - 1.0); + } + }; + + /** @brief Six pole highpass filter + * + * Highpass filter based on three cascaded biquad filters. + */ + class HighpassFilter6p : public TripleBiquadFilter { + public: + HighpassFilter6p() { } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + float omega = 2.0 * M_PI * fc / fs; + float sn = sin(omega); + float cs = cos(omega); + float alpha = sn * M_SQRT1_2; + + float a0r = 1.0 / (1.0 + alpha); + d.b0 = d.d2.b0 = a0r * (1.0 + cs) * 0.5; + d.b1 = d.d2.b1 = a0r * -(1.0 + cs); + d.b2 = d.d2.b2 = a0r * (1.0 + cs) * 0.5; + d.a1 = d.d2.a1 = a0r * (2.0 * cs); + d.a2 = d.d2.a2 = a0r * (alpha - 1.0); + + alpha *= exp(-M_LN10 / 20 * r); + a0r = 1.0 / (1.0 + alpha); + + d.d3.b0 = a0r * (1.0 + cs) * 0.5; + d.d3.b1 = a0r * -(1.0 + cs); + d.d3.b2 = a0r * (1.0 + cs) * 0.5; + d.d3.a1 = a0r * (2.0 * cs); + d.d3.a2 = a0r * (alpha - 1.0); + } + }; + +namespace gig { + + /** + * Base class for the gig engine filters. + */ + class GigFilter : public FilterBase { + public: + void Reset(FilterData& d) const { + d.x1 = d.x2 = d.x3 = 0; + d.y1 = d.y2 = d.y3 = 0; + } + protected: + float ApplyA(FilterData& d, float x) const { + float y = x - d.a1 * d.y1 - d.a2 * d.y2 - d.a3 * d.y3; KillDenormal(y); - y23 = y22; - y22 = y21; - y21 = y; + d.y3 = d.y2; + d.y2 = d.y1; + d.y1 = y; + return y; + } + }; + +#define GIG_PARAM_INIT \ + float f1 = fc * 0.0075279; \ + float f2 = f1 - 1 + r * fc * (-5.5389e-5 + 1.1982e-7 * fc); \ + float scale = r < 51 ? 1.0f : 1.3762f - 0.0075073f * r + + class LowpassFilter : public GigFilter { + public: + LowpassFilter() { } + + float Apply(FilterData& d, float x) const { + return ApplyA(d, d.b0 * x); + } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + GIG_PARAM_INIT; + + float f1_2 = f1 * f1; + d.b0 = f1_2 * scale; + d.a1 = f2; + d.a2 = f1_2 - 1; + d.a3 = -f2; + } + }; + + class BandpassFilter : public GigFilter { + public: + BandpassFilter() { } + float Apply(FilterData& d, float x) const { + float y = ApplyA(d, d.b0 * x + d.b2 * d.x2); + d.x2 = d.x1; + d.x1 = x; return y; } - void SetParameters(float f1, float f2, float scale) { - LowpassFilter::SetParameters(f1, f2, scale); - b20 = b0 * 0.5; + void SetParameters(FilterData& d, float fc, float r, float fs) const { + GIG_PARAM_INIT; + + d.b0 = f1 * scale; + d.b2 = -d.b0; + d.a1 = f2; + d.a2 = f1 * f1 - 1; + d.a3 = -f2; + } + }; + + class HighpassFilter : public GigFilter { + public: + HighpassFilter() { } + + float Apply(FilterData& d, float x) const { + float y = ApplyA(d, -x + d.x1 + d.x2 - d.x3); + d.x3 = d.x2; + d.x2 = d.x1; + d.x1 = x; + return y * d.scale; + } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + GIG_PARAM_INIT; + + d.a1 = f2; + d.a2 = f1 * f1 - 1; + d.a3 = -f2; + d.scale = scale; + } + }; + + class BandrejectFilter : public GigFilter { + public: + BandrejectFilter() { } + + float Apply(FilterData& d, float x) const { + float y = ApplyA(d, x - d.x1 + d.b2 * d.x2 + d.x3); + d.x3 = d.x2; + d.x2 = d.x1; + d.x1 = x; + return y * d.scale; + } + + void SetParameters(FilterData& d, float fc, float r, float fs) const { + GIG_PARAM_INIT; + + d.b2 = f1 * f1 - 1; + d.a1 = f2; + d.a2 = d.b2; + d.a3 = -f2; + d.scale = scale; + } + }; + + class LowpassTurboFilter : public LowpassFilter { + public: + LowpassTurboFilter() { } + + float Apply(FilterData& d, float x) const { + float y = d.b20 * LowpassFilter::Apply(d, x) + - d.a1 * d.y21 - d.a2 * d.y22 - d.a3 * d.y23; + KillDenormal(y); + d.y23 = d.y22; + d.y22 = d.y21; + d.y21 = y; + return y; } - void Reset() { - LowpassFilter::Reset(); - y21 = y22 = y23 = 0; + void SetParameters(FilterData& d, float fc, float r, float fs) const { + LowpassFilter::SetParameters(d, fc, r, fs); + d.b20 = d.b0 * 0.5; } }; +} //namespace gig + /** - * These are filters similar to the ones from Gigasampler. + * Main filter class. */ class Filter { protected: - HighpassFilter HPFilter; - BandpassFilter BPFilter; - LowpassFilter LPFilter; - BandrejectFilter BRFilter; - LowpassTurboFilter LPTFilter; - FilterBase* pFilter; + static const LowpassFilter1p lp1p; + static const LowpassFilter lp2p; + static const LowpassFilter4p lp4p; + static const LowpassFilter6p lp6p; + static const BandpassFilter bp2p; + static const BandrejectFilter br2p; + static const HighpassFilter1p hp1p; + static const HighpassFilter hp2p; + static const HighpassFilter4p hp4p; + static const HighpassFilter6p hp6p; + /** + * These are filters similar to the ones from Gigasampler. + */ + static const gig::HighpassFilter HPFilter; + static const gig::BandpassFilter BPFilter; + static const gig::LowpassFilter LPFilter; + static const gig::BandrejectFilter BRFilter; + static const gig::LowpassTurboFilter LPTFilter; + + FilterData d; + const FilterBase* pFilter; public: Filter() { // set filter type to 'lowpass' by default pFilter = &LPFilter; + pFilter->Reset(d); } - void SetType(::gig::vcf_type_t FilterType) { + enum vcf_type_t { + vcf_type_gig_lowpass = ::gig::vcf_type_lowpass, + vcf_type_gig_lowpassturbo = ::gig::vcf_type_lowpassturbo, + vcf_type_gig_bandpass = ::gig::vcf_type_bandpass, + vcf_type_gig_highpass = ::gig::vcf_type_highpass, + vcf_type_gig_bandreject = ::gig::vcf_type_bandreject, + vcf_type_1p_lowpass, + vcf_type_1p_highpass, + vcf_type_2p_lowpass, + vcf_type_2p_highpass, + vcf_type_2p_bandpass, + vcf_type_2p_bandreject, + vcf_type_4p_lowpass, + vcf_type_4p_highpass, + vcf_type_6p_lowpass, + vcf_type_6p_highpass + }; + + void SetType(vcf_type_t FilterType) { switch (FilterType) { - case ::gig::vcf_type_highpass: + case vcf_type_gig_highpass: pFilter = &HPFilter; break; - case ::gig::vcf_type_bandreject: + case vcf_type_gig_bandreject: pFilter = &BRFilter; break; - case ::gig::vcf_type_bandpass: + case vcf_type_gig_bandpass: pFilter = &BPFilter; break; - case ::gig::vcf_type_lowpassturbo: + case vcf_type_gig_lowpassturbo: pFilter = &LPTFilter; break; + case vcf_type_1p_lowpass: + pFilter = &lp1p; + break; + case vcf_type_1p_highpass: + pFilter = &hp1p; + break; + case vcf_type_2p_lowpass: + pFilter = &lp2p; + break; + case vcf_type_2p_highpass: + pFilter = &hp2p; + break; + case vcf_type_2p_bandpass: + pFilter = &bp2p; + break; + case vcf_type_2p_bandreject: + pFilter = &br2p; + break; + case vcf_type_4p_lowpass: + pFilter = &lp4p; + break; + case vcf_type_4p_highpass: + pFilter = &hp4p; + break; + case vcf_type_6p_lowpass: + pFilter = &lp6p; + break; + case vcf_type_6p_highpass: + pFilter = &hp6p; + break; default: pFilter = &LPFilter; } + pFilter->Reset(d); } void SetParameters(float cutoff, float resonance, float fs) { - float f1 = cutoff * 0.0075279; - float f2 = f1 - 1 + resonance * cutoff * (-5.5389e-5 + 1.1982e-7 * cutoff); - float scale = resonance < 51 ? 1.0f : 1.3762f - 0.0075073f * resonance; - pFilter->SetParameters(f1, f2, scale); + pFilter->SetParameters(d, cutoff, resonance, fs); } void Reset() { - HPFilter.Reset(); - BPFilter.Reset(); - LPFilter.Reset(); - BRFilter.Reset(); - LPTFilter.Reset(); + return pFilter->Reset(d); } float Apply(float in) { - return pFilter->Apply(in); + return pFilter->Apply(d, in); } }; -}} //namespace LinuxSampler::gig +} //namespace LinuxSampler #endif // __LS_GIG_FILTER_H__
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/InstrumentResourceManager.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/InstrumentResourceManager.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -24,26 +24,14 @@ #include <sstream> #include "InstrumentResourceManager.h" +#include "EngineChannel.h" +#include "Engine.h" #include "../../common/global_private.h" #include "../../plugins/InstrumentEditorFactory.h" -// We need to know the maximum number of sample points which are going to -// be processed for each render cycle of the audio output driver, to know -// how much initial sample points we need to cache into RAM. If the given -// sampler channel does not have an audio output device assigned yet -// though, we simply use this default value. -#define GIG_RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE 128 - namespace LinuxSampler { namespace gig { - // data stored as long as an instrument resource exists - struct instr_entry_t { - InstrumentManager::instrument_id_t ID; - ::gig::File* pGig; - uint MaxSamplesPerCycle; ///< if some engine requests an already allocated instrument with a higher value, we have to reallocate the instrument - }; - // some data needed for the libgig callback function struct progress_callback_arg_t { InstrumentResourceManager* pManager; @@ -88,19 +76,6 @@ pArg->pManager->DispatchResourceProgressEvent(*pArg->pInstrumentKey, localProgress); } - std::vector<InstrumentResourceManager::instrument_id_t> InstrumentResourceManager::Instruments() { - return Entries(); - } - - InstrumentManager::mode_t InstrumentResourceManager::GetMode(const instrument_id_t& ID) { - return static_cast<InstrumentManager::mode_t>(AvailabilityMode(ID)); - } - - void InstrumentResourceManager::SetMode(const instrument_id_t& ID, InstrumentManager::mode_t Mode) { - dmsg(2,("gig::InstrumentResourceManager: setting mode for %s (Index=%d) to %d\n",ID.FileName.c_str(),ID.Index,Mode)); - SetAvailabilityMode(ID, static_cast<ResourceManager<InstrumentManager::instrument_id_t, ::gig::Instrument>::mode_t>(Mode)); - } - String InstrumentResourceManager::GetInstrumentName(instrument_id_t ID) { Lock(); ::gig::Instrument* pInstrument = Resource(ID, false); @@ -154,7 +129,7 @@ ::RIFF::File* riff = NULL; ::gig::File* gig = NULL; try { - if(!loaded) { + if (!loaded) { riff = new ::RIFF::File(ID.FileName); gig = new ::gig::File(riff); gig->SetAutoLoad(false); // avoid time consuming samples scanning @@ -271,11 +246,11 @@ } // NOTE: for now connect the virtual MIDI keyboard of the instrument editor (if any) with all engine channels that have the same instrument as the editor was opened for ( other ideas ? ) Lock(); - std::set<gig::EngineChannel*> engineChannels = + std::set<EngineChannel*> engineChannels = GetEngineChannelsUsing(pInstrument, false/*don't lock again*/); - std::set<gig::EngineChannel*>::iterator iter = engineChannels.begin(); - std::set<gig::EngineChannel*>::iterator end = engineChannels.end(); - for (; iter != end; ++iter) (*iter)->Connect(pVirtualMidiDevice); + std::set<EngineChannel*>::iterator iter = engineChannels.begin(); + std::set<EngineChannel*>::iterator end = engineChannels.end(); + for (; iter != end; ++iter) (static_cast<AbstractEngineChannel*>(*iter))->Connect(pVirtualMidiDevice); Unlock(); return pEditor; @@ -322,10 +297,10 @@ if (pVirtualMidiDevice) { Lock(); // NOTE: see note in LaunchInstrumentEditor() - std::set<gig::EngineChannel*> engineChannels = + std::set<EngineChannel*> engineChannels = GetEngineChannelsUsing(pInstrument, false/*don't lock again*/); - std::set<gig::EngineChannel*>::iterator iter = engineChannels.begin(); - std::set<gig::EngineChannel*>::iterator end = engineChannels.end(); + std::set<EngineChannel*>::iterator iter = engineChannels.begin(); + std::set<EngineChannel*>::iterator end = engineChannels.end(); for (; iter != end; ++iter) (*iter)->Disconnect(pVirtualMidiDevice); Unlock(); } else { @@ -432,10 +407,10 @@ ::gig::Instrument* pInstrument = (::gig::Instrument*) pRegion->GetParent(); Lock(); - std::set<gig::Engine*> engines = + std::set<Engine*> engines = GetEnginesUsing(pInstrument, false/*don't lock again*/); - std::set<gig::Engine*>::iterator iter = engines.begin(); - std::set<gig::Engine*>::iterator end = engines.end(); + std::set<Engine*>::iterator iter = engines.begin(); + std::set<Engine*>::iterator end = engines.end(); for (; iter != end; ++iter) (*iter)->Suspend(pRegion); Unlock(); } else if (sStructType == "gig::DimensionRegion") { @@ -449,10 +424,10 @@ ::gig::Instrument* pInstrument = (::gig::Instrument*) pRegion->GetParent(); Lock(); - std::set<gig::Engine*> engines = + std::set<Engine*> engines = GetEnginesUsing(pInstrument, false/*don't lock again*/); - std::set<gig::Engine*>::iterator iter = engines.begin(); - std::set<gig::Engine*>::iterator end = engines.end(); + std::set<Engine*>::iterator iter = engines.begin(); + std::set<Engine*>::iterator end = engines.end(); for (; iter != end; ++iter) (*iter)->Suspend(pRegion); Unlock(); } else { @@ -485,10 +460,10 @@ GetInstrumentsCurrentlyUsedOf(pFile, false/*don't lock again*/); for (int i = 0; i < instruments.size(); i++) { if (SampleReferencedByInstrument(pSample, instrumentsi)) { - std::set<gig::EngineChannel*> engineChannels = + std::set<EngineChannel*> engineChannels = GetEngineChannelsUsing(instrumentsi, false/*don't lock again*/); - std::set<gig::EngineChannel*>::iterator iter = engineChannels.begin(); - std::set<gig::EngineChannel*>::iterator end = engineChannels.end(); + std::set<EngineChannel*>::iterator iter = engineChannels.begin(); + std::set<EngineChannel*>::iterator end = engineChannels.end(); for (; iter != end; ++iter) CacheInitialSamples(pSample, *iter); } @@ -501,10 +476,10 @@ ::gig::Instrument* pInstrument = (::gig::Instrument*) pRegion->GetParent(); Lock(); - std::set<gig::Engine*> engines = + std::set<Engine*> engines = GetEnginesUsing(pInstrument, false/*don't lock again*/); - std::set<gig::Engine*>::iterator iter = engines.begin(); - std::set<gig::Engine*>::iterator end = engines.end(); + std::set<Engine*>::iterator iter = engines.begin(); + std::set<Engine*>::iterator end = engines.end(); for (; iter != end; ++iter) (*iter)->Resume(pRegion); Unlock(); } else if (sStructType == "gig::DimensionRegion") { @@ -516,10 +491,10 @@ ::gig::Instrument* pInstrument = (::gig::Instrument*) pRegion->GetParent(); Lock(); - std::set<gig::Engine*> engines = + std::set<Engine*> engines = GetEnginesUsing(pInstrument, false/*don't lock again*/); - std::set<gig::Engine*>::iterator iter = engines.begin(); - std::set<gig::Engine*>::iterator end = engines.end(); + std::set<Engine*>::iterator iter = engines.begin(); + std::set<Engine*>::iterator end = engines.end(); for (; iter != end; ++iter) (*iter)->Resume(pRegion); Unlock(); } else { @@ -555,9 +530,9 @@ ::gig::Sample* pSample = (::gig::Sample*) pNewSample; ::gig::File* pFile = (::gig::File*) pSample->GetParent(); // get all engines that use that same gig::File - std::set<gig::Engine*> engines = GetEnginesUsing(pFile, false/*don't lock again*/); - std::set<gig::Engine*>::iterator iter = engines.begin(); - std::set<gig::Engine*>::iterator end = engines.end(); + std::set<Engine*> engines = GetEnginesUsing(pFile, false/*don't lock again*/); + std::set<Engine*>::iterator iter = engines.begin(); + std::set<Engine*>::iterator end = engines.end(); for (; iter != end; ++iter) CacheInitialSamples(pSample, *iter); Unlock(); @@ -566,7 +541,7 @@ ::gig::Instrument* InstrumentResourceManager::Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg) { // get gig file from internal gig file manager - ::gig::File* pGig = Gigs.Borrow(Key.FileName, (GigConsumer*) Key.Index); // conversion kinda hackish :/ + ::gig::File* pGig = Gigs.Borrow(Key.FileName, reinterpret_cast<GigConsumer*>(Key.Index)); // conversion kinda hackish :/ // we pass this to the progress callback mechanism of libgig progress_callback_arg_t callbackArg; @@ -587,6 +562,8 @@ pGig->GetFirstSample(); // just to force complete instrument loading dmsg(1,("OK\n")); + uint maxSamplesPerCycle = GetMaxSamplesPerCycle(pConsumer); + // cache initial samples points (for actually needed samples) dmsg(1,("Caching initial samples...")); uint iRegion = 0; // just for progress calculation @@ -598,10 +575,10 @@ if (pRgn->GetSample() && !pRgn->GetSample()->GetCache().Size) { dmsg(2,("C")); - CacheInitialSamples(pRgn->GetSample(), (gig::EngineChannel*) pConsumer); + CacheInitialSamples(pRgn->GetSample(), maxSamplesPerCycle); } for (uint i = 0; i < pRgn->DimensionRegions; i++) { - CacheInitialSamples(pRgn->pDimensionRegionsi->pSample, (gig::EngineChannel*) pConsumer); + CacheInitialSamples(pRgn->pDimensionRegionsi->pSample, maxSamplesPerCycle); } pRgn = pInstrument->GetNextRegion(); @@ -614,86 +591,38 @@ instr_entry_t* pEntry = new instr_entry_t; pEntry->ID.FileName = Key.FileName; pEntry->ID.Index = Key.Index; - pEntry->pGig = pGig; - - gig::EngineChannel* pEngineChannel = dynamic_cast<gig::EngineChannel*>(pConsumer); - // and we save this to check if we need to reallocate for a engine with higher value of 'MaxSamplesPerSecond' - pEntry->MaxSamplesPerCycle = - (!pEngineChannel) ? 0 /* don't care for instrument editors */ : - (pEngineChannel->GetEngine()) ? - dynamic_cast<gig::Engine*>(pEngineChannel->GetEngine())->pAudioOutputDevice->MaxSamplesPerCycle() - : GIG_RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE; + pEntry->pFile = pGig; + + // and we save this to check if we need to reallocate for an engine with higher value of 'MaxSamplesPerSecond' + pEntry->MaxSamplesPerCycle = maxSamplesPerCycle; + pArg = pEntry; return pInstrument; } - void InstrumentResourceManager::Destroy( ::gig::Instrument* pResource, void* pArg) { + void InstrumentResourceManager::Destroy(::gig::Instrument* pResource, void* pArg) { instr_entry_t* pEntry = (instr_entry_t*) pArg; // we don't need the .gig file here anymore - Gigs.HandBack(pEntry->pGig, (GigConsumer*) pEntry->ID.Index); // conversion kinda hackish :/ + Gigs.HandBack(pEntry->pFile, reinterpret_cast<GigConsumer*>(pEntry->ID.Index)); // conversion kinda hackish :/ delete pEntry; } - void InstrumentResourceManager::OnBorrow(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, void*& pArg) { - instr_entry_t* pEntry = (instr_entry_t*) pArg; - gig::EngineChannel* pEngineChannel = dynamic_cast<gig::EngineChannel*>(pConsumer); - uint maxSamplesPerCycle = - (pEngineChannel && pEngineChannel->GetEngine()) ? dynamic_cast<gig::Engine*>(pEngineChannel->GetEngine())->pAudioOutputDevice->MaxSamplesPerCycle() - : GIG_RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE; - if (pEntry->MaxSamplesPerCycle < maxSamplesPerCycle) { - Update(pResource, pConsumer); - } - } - - /** - * Give back an instrument. This should be used instead of - * HandBack if there are some dimension regions that are still in - * use. (When an instrument is changed, the voices currently - * playing are allowed to keep playing with the old instrument - * until note off arrives. New notes will use the new instrument.) - */ - void InstrumentResourceManager::HandBackInstrument(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, - RTList< ::gig::DimensionRegion*>* pDimRegionsInUse) { - DimRegInfoMutex.Lock(); - for (RTList< ::gig::DimensionRegion*>::Iterator i = pDimRegionsInUse->first() ; i != pDimRegionsInUse->end() ; i++) { - DimRegInfo*i.refCount++; - SampleRefCount(*i)->pSample++; - } - HandBack(pResource, pConsumer, true); - DimRegInfoMutex.Unlock(); + void InstrumentResourceManager::DeleteRegionIfNotUsed(::gig::DimensionRegion* pRegion, region_info_t* pRegInfo) { + // TODO: we could delete Region and Instrument here if they have become unused } - /** - * Give back a dimension region that belongs to an instrument that - * was previously handed back. - */ - void InstrumentResourceManager::HandBackDimReg(::gig::DimensionRegion* pDimReg) { - DimRegInfoMutex.Lock(); - dimreg_info_t& dimRegInfo = DimRegInfopDimReg; - int dimRegRefCount = --dimRegInfo.refCount; - int sampleRefCount = --SampleRefCountpDimReg->pSample; - if (dimRegRefCount == 0) { - ::gig::File* gig = dimRegInfo.file; - ::RIFF::File* riff = dimRegInfo.riff; - DimRegInfo.erase(pDimReg); - // TODO: we could delete Region and Instrument here if - // they have become unused - - if (sampleRefCount == 0) { - SampleRefCount.erase(pDimReg->pSample); - - if (gig) { - gig->DeleteSample(pDimReg->pSample); - if (!gig->GetFirstSample()) { - dmsg(2,("No more samples in use - freeing gig\n")); - delete gig; - delete riff; - } - } + void InstrumentResourceManager::DeleteSampleIfNotUsed(::gig::Sample* pSample, region_info_t* pRegInfo) { + ::gig::File* gig = pRegInfo->file; + ::RIFF::File* riff = static_cast< ::RIFF::File*>(pRegInfo->pArg); + if (gig) { + gig->DeleteSample(pSample); + if (!gig->GetFirstSample()) { + dmsg(2,("No more samples in use - freeing gig\n")); + delete gig; + delete riff; } } - DimRegInfoMutex.Unlock(); } /** @@ -704,10 +633,10 @@ * (may be NULL, in this case default amount of samples * will be cached) */ - void InstrumentResourceManager::CacheInitialSamples(::gig::Sample* pSample, gig::EngineChannel* pEngineChannel) { - gig::Engine* pEngine = + void InstrumentResourceManager::CacheInitialSamples(::gig::Sample* pSample, EngineChannel* pEngineChannel) { + Engine* pEngine = (pEngineChannel && pEngineChannel->GetEngine()) ? - dynamic_cast<gig::Engine*>(pEngineChannel->GetEngine()) : NULL; + dynamic_cast<Engine*>(pEngineChannel->GetEngine()) : NULL; CacheInitialSamples(pSample, pEngine); } @@ -722,7 +651,14 @@ * (may be NULL, in this case default amount of samples * will be cached) */ - void InstrumentResourceManager::CacheInitialSamples(::gig::Sample* pSample, gig::Engine* pEngine) { + void InstrumentResourceManager::CacheInitialSamples(::gig::Sample* pSample, AbstractEngine* pEngine) { + uint maxSamplesPerCycle = + (pEngine) ? pEngine->pAudioOutputDevice->MaxSamplesPerCycle() : + DefaultMaxSamplesPerCycle(); + CacheInitialSamples(pSample, maxSamplesPerCycle); + } + + void InstrumentResourceManager::CacheInitialSamples(::gig::Sample* pSample, uint maxSamplesPerCycle) { if (!pSample) { dmsg(4,("gig::InstrumentResourceManager: Skipping sample (pSample == NULL)\n")); return; @@ -735,9 +671,6 @@ // number of '0' samples (silence samples) behind the official buffer // border, to allow the interpolator do it's work even at the end of // the sample. - const uint maxSamplesPerCycle = - (pEngine) ? pEngine->pAudioOutputDevice->MaxSamplesPerCycle() - : GIG_RESOURCE_MANAGER_DEFAULT_MAX_SAMPLES_PER_CYCLE; const uint neededSilenceSamples = (maxSamplesPerCycle << CONFIG_MAX_PITCH) + 3; const uint currentlyCachedSilenceSamples = pSample->GetCache().NullExtensionSize / pSample->FrameSize; if (currentlyCachedSilenceSamples < neededSilenceSamples) { @@ -787,14 +720,14 @@ * @param bLock - whether we should lock (mutex) the instrument manager * during this call and unlock at the end of this call */ - std::set<gig::EngineChannel*> InstrumentResourceManager::GetEngineChannelsUsing(::gig::Instrument* pInstrument, bool bLock) { + std::set<EngineChannel*> InstrumentResourceManager::GetEngineChannelsUsing(::gig::Instrument* pInstrument, bool bLock) { if (bLock) Lock(); - std::set<gig::EngineChannel*> result; + std::set<EngineChannel*> result; std::set<ResourceConsumer< ::gig::Instrument>*> consumers = ConsumersOf(pInstrument); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator iter = consumers.begin(); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator end = consumers.end(); for (; iter != end; ++iter) { - gig::EngineChannel* pEngineChannel = dynamic_cast<gig::EngineChannel*>(*iter); + EngineChannel* pEngineChannel = dynamic_cast<EngineChannel*>(*iter); if (!pEngineChannel) continue; result.insert(pEngineChannel); } @@ -810,16 +743,16 @@ * @param bLock - whether we should lock (mutex) the instrument manager * during this call and unlock at the end of this call */ - std::set<gig::Engine*> InstrumentResourceManager::GetEnginesUsing(::gig::Instrument* pInstrument, bool bLock) { + std::set<Engine*> InstrumentResourceManager::GetEnginesUsing(::gig::Instrument* pInstrument, bool bLock) { if (bLock) Lock(); - std::set<gig::Engine*> result; + std::set<Engine*> result; std::set<ResourceConsumer< ::gig::Instrument>*> consumers = ConsumersOf(pInstrument); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator iter = consumers.begin(); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator end = consumers.end(); for (; iter != end; ++iter) { - gig::EngineChannel* pEngineChannel = dynamic_cast<gig::EngineChannel*>(*iter); + EngineChannel* pEngineChannel = dynamic_cast<EngineChannel*>(*iter); if (!pEngineChannel) continue; - gig::Engine* pEngine = dynamic_cast<gig::Engine*>(pEngineChannel->GetEngine()); + Engine* pEngine = dynamic_cast<Engine*>(pEngineChannel->GetEngine()); if (!pEngine) continue; result.insert(pEngine); } @@ -835,23 +768,23 @@ * @param bLock - whether we should lock (mutex) the instrument manager * during this call and unlock at the end of this call */ - std::set<gig::Engine*> InstrumentResourceManager::GetEnginesUsing(::gig::File* pFile, bool bLock) { + std::set<Engine*> InstrumentResourceManager::GetEnginesUsing(::gig::File* pFile, bool bLock) { if (bLock) Lock(); // get all instruments (currently in usage) that use that same gig::File std::vector< ::gig::Instrument*> instrumentsOfInterest = GetInstrumentsCurrentlyUsedOf(pFile, false/*don't lock again*/); // get all engines that use that same gig::File - std::set<gig::Engine*> result; + std::set<Engine*> result; { for (int i = 0; i < instrumentsOfInterest.size(); i++) { std::set<ResourceConsumer< ::gig::Instrument>*> consumers = ConsumersOf(instrumentsOfInteresti); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator iter = consumers.begin(); std::set<ResourceConsumer< ::gig::Instrument>*>::iterator end = consumers.end(); for (; iter != end; ++iter) { - gig::EngineChannel* pEngineChannel = dynamic_cast<gig::EngineChannel*>(*iter); + EngineChannel* pEngineChannel = dynamic_cast<EngineChannel*>(*iter); if (!pEngineChannel) continue; - gig::Engine* pEngine = dynamic_cast<gig::Engine*>(pEngineChannel->GetEngine()); + Engine* pEngine = dynamic_cast<Engine*>(pEngineChannel->GetEngine()); if (!pEngine) continue; // the unique, sorted container std::set makes // sure we won't have duplicates @@ -905,8 +838,8 @@ // get all engines that use that same gig::Instrument suspendedEngines = GetEnginesUsing(pInstrument, true/*lock*/); // finally, completely suspend all engines that use that same gig::Instrument - std::set<gig::Engine*>::iterator iter = suspendedEngines.begin(); - std::set<gig::Engine*>::iterator end = suspendedEngines.end(); + std::set<Engine*>::iterator iter = suspendedEngines.begin(); + std::set<Engine*>::iterator end = suspendedEngines.end(); for (; iter != end; ++iter) (*iter)->SuspendAll(); } @@ -929,8 +862,8 @@ // get all engines that use that same gig::File suspendedEngines = GetEnginesUsing(pFile, true/*lock*/); // finally, completely suspend all engines that use that same gig::File - std::set<gig::Engine*>::iterator iter = suspendedEngines.begin(); - std::set<gig::Engine*>::iterator end = suspendedEngines.end(); + std::set<Engine*>::iterator iter = suspendedEngines.begin(); + std::set<Engine*>::iterator end = suspendedEngines.end(); for (; iter != end; ++iter) (*iter)->SuspendAll(); } @@ -965,7 +898,7 @@ } void InstrumentResourceManager::GigResourceManager::Destroy(::gig::File* pResource, void* pArg) { - dmsg(1,("Freeing gig file from memory...")); + dmsg(1,("Freeing gig file '%s' from memory ...", pResource->GetFileName().c_str())); // Delete as much as possible of the gig file. Some of the // dimension regions and samples may still be in use - these @@ -986,11 +919,11 @@ for (int i = 0 ; i < region->DimensionRegions ; i++) { ::gig::DimensionRegion *d = region->pDimensionRegionsi; - std::map< ::gig::DimensionRegion*, dimreg_info_t>::iterator iter = parent->DimRegInfo.find(d); - if (iter != parent->DimRegInfo.end()) { - dimreg_info_t& dimRegInfo = (*iter).second; + std::map< ::gig::DimensionRegion*, region_info_t>::iterator iter = parent->RegionInfo.find(d); + if (iter != parent->RegionInfo.end()) { + region_info_t& dimRegInfo = (*iter).second; dimRegInfo.file = pResource; - dimRegInfo.riff = (::RIFF::File*)pArg; + dimRegInfo.pArg = (::RIFF::File*)pArg; deleteFile = deleteInstrument = deleteRegion = false; } }
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/InstrumentResourceManager.h -> linuxsampler-2342.tar.bz2/src/engines/gig/InstrumentResourceManager.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * 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 * @@ -28,8 +28,9 @@ #include <gig.h> -#include "../../common/global.h" +#include "../../common/Pool.h" #include "../../common/ResourceManager.h" +#include "../InstrumentManagerBase.h" #include "../../drivers/audio/AudioOutputDevice.h" #include "../InstrumentManager.h" #include "../../common/ArrayList.h" @@ -42,15 +43,11 @@ }} // namespace LinuxSampler::gig -#include "EngineChannel.h" -#include "Engine.h" #include "../../plugins/InstrumentEditor.h" namespace LinuxSampler { namespace gig { - - // just symbol prototyping - class EngineChannel; class Engine; + class EngineChannel; /** @brief Gig instrument manager * @@ -63,16 +60,13 @@ * instrument / file is not needed anymore, then it will be freed from * memory. */ - class InstrumentResourceManager : public InstrumentManager, public ResourceManager<InstrumentManager::instrument_id_t, ::gig::Instrument>, public InstrumentEditorListener { + class InstrumentResourceManager : public InstrumentManagerBase< ::gig::File, ::gig::Instrument, ::gig::DimensionRegion, ::gig::Sample>, public InstrumentEditorListener { public: InstrumentResourceManager() : Gigs(this) {} virtual ~InstrumentResourceManager() {} static void OnInstrumentLoadingProgress(::gig::progress_t* pProgress); // implementation of derived abstract methods from 'InstrumentManager' - virtual std::vector<instrument_id_t> Instruments(); - virtual InstrumentManager::mode_t GetMode(const instrument_id_t& ID); - virtual void SetMode(const instrument_id_t& ID, InstrumentManager::mode_t Mode); virtual String GetInstrumentName(instrument_id_t ID); virtual String GetInstrumentDataStructureName(instrument_id_t ID); virtual String GetInstrumentDataStructureVersion(instrument_id_t ID); @@ -88,10 +82,6 @@ virtual void OnDataStructureChanged(void* pStruct, String sStructType, InstrumentEditor* pSender); virtual void OnSampleReferenceChanged(void* pOldSample, void* pNewSample, InstrumentEditor* pSender); - void HandBackInstrument(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, - RTList< ::gig::DimensionRegion*>* pDimRegionsInUse); - void HandBackDimReg(::gig::DimensionRegion* pDimReg); - #if 0 // currently unused : void TrySendNoteOnToEditors(uint8_t Key, uint8_t Velocity, ::gig::Instrument* pInstrument); void TrySendNoteOffToEditors(uint8_t Key, uint8_t Velocity, ::gig::Instrument* pInstrument); @@ -101,8 +91,13 @@ // implementation of derived abstract methods from 'ResourceManager' virtual ::gig::Instrument* Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg); virtual void Destroy(::gig::Instrument* pResource, void* pArg); - virtual void OnBorrow(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, void*& pArg); + virtual void DeleteRegionIfNotUsed(::gig::DimensionRegion* pRegion, region_info_t* pRegInfo); + virtual void DeleteSampleIfNotUsed(::gig::Sample* pSample, region_info_t* pRegInfo); private: + void CacheInitialSamples(::gig::Sample* pSample, AbstractEngine* pEngine); + void CacheInitialSamples(::gig::Sample* pSample, EngineChannel* pEngineChannel); + void CacheInitialSamples(::gig::Sample* pSample, uint maxSamplesPerCycle); + typedef ResourceConsumer< ::gig::File> GigConsumer; class GigResourceManager : public ResourceManager<String, ::gig::File> { @@ -118,27 +113,16 @@ InstrumentResourceManager* parent; } Gigs; - void CacheInitialSamples(::gig::Sample* pSample, gig::EngineChannel* pEngineChannel); - void CacheInitialSamples(::gig::Sample* pSample, gig::Engine* pEngine); void UncacheInitialSamples(::gig::Sample* pSample); std::vector< ::gig::Instrument*> GetInstrumentsCurrentlyUsedOf(::gig::File* pFile, bool bLock); - std::set<gig::EngineChannel*> GetEngineChannelsUsing(::gig::Instrument* pInstrument, bool bLock); - std::set<gig::Engine*> GetEnginesUsing(::gig::Instrument* pInstrument, bool bLock); - std::set<gig::Engine*> GetEnginesUsing(::gig::File* pFile, bool bLock); + std::set<EngineChannel*> GetEngineChannelsUsing(::gig::Instrument* pInstrument, bool bLock); + std::set<Engine*> GetEnginesUsing(::gig::Instrument* pInstrument, bool bLock); + std::set<Engine*> GetEnginesUsing(::gig::File* pFile, bool bLock); bool SampleReferencedByInstrument(::gig::Sample* pSample, ::gig::Instrument* pInstrument); void SuspendEnginesUsing(::gig::Instrument* pInstrument); void SuspendEnginesUsing(::gig::File* pFile); void ResumeAllEngines(); - struct dimreg_info_t { - int refCount; - ::gig::File* file; - ::RIFF::File* riff; - }; - Mutex DimRegInfoMutex; ///< protects the DimRegInfo and SampleRefCount maps from concurrent access by the instrument loader and disk threads - std::map< ::gig::DimensionRegion*, dimreg_info_t> DimRegInfo; ///< contains dimension regions that are still in use but belong to released instrument - std::map< ::gig::Sample*, int> SampleRefCount; ///< contains samples that are still in use but belong to a released instrument - Mutex InstrumentEditorProxiesMutex; ///< protects the 'InstrumentEditorProxies' map ArrayList<InstrumentConsumer*> InstrumentEditorProxies; ///< here we store the objects that react on instrument specific notifications on behalf of the respective instrument editor std::set<Engine*> suspendedEngines; ///< all engines currently completely suspended
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Makefile.am -> linuxsampler-2342.tar.bz2/src/engines/gig/Makefile.am
Changed
@@ -10,7 +10,7 @@ EGADSR.cpp EGADSR.h \ EGDecay.cpp EGDecay.h \ Engine.cpp Engine.h \ - Filter.h \ + Filter.h Filter.cpp \ InstrumentResourceManager.cpp InstrumentResourceManager.h \ Stream.cpp Stream.h \ Voice.cpp Voice.h \
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Stream.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/Stream.cpp
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * * * * 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 * @@ -22,30 +23,34 @@ ***************************************************************************/ #include "Stream.h" - #include "../../common/global_private.h" namespace LinuxSampler { namespace gig { - uint Stream::UnusedStreams = 0; - uint Stream::TotalStreams = 0; - - /// Returns number of refilled sample points or a value < 0 on error. - int Stream::ReadAhead(unsigned long SampleCount) { - if (this->State == state_unused) return -1; - if (this->State == state_end) return 0; - if (!SampleCount) return 0; - if (!pRingBuffer->write_space()) return 0; + Stream::Stream ( + ::gig::buffer_t* pDecompressionBuffer, + uint BufferSize, + uint BufferWrapElements) : LinuxSampler::StreamBase< ::gig::DimensionRegion>(BufferSize, BufferWrapElements) + { + this->pDecompressionBuffer = pDecompressionBuffer; + } - ::gig::Sample* pSample = pDimRgn->pSample; + long Stream::Read(uint8_t* pBuf, long SamplesToRead) { + ::gig::Sample* pSample = pRegion->pSample; long total_readsamples = 0, readsamples = 0; - long samplestoread = SampleCount / pSample->Channels; - uint8_t* pBuf = pRingBuffer->get_write_ptr(); bool endofsamplereached; // refill the disk stream buffer if (this->DoLoop) { // honor looping - total_readsamples = pSample->ReadAndLoop(pBuf, samplestoread, &this->PlaybackState, pDimRgn, pDecompressionBuffer); + ::gig::playback_state_t pbs; + pbs.position = PlaybackState.position; + pbs.reverse = PlaybackState.reverse; + pbs.loop_cycles_left = PlaybackState.loop_cycles_left; + + total_readsamples = pSample->ReadAndLoop(pBuf, SamplesToRead, &pbs, pRegion, pDecompressionBuffer); + PlaybackState.position = pbs.position; + PlaybackState.reverse = pbs.reverse; + PlaybackState.loop_cycles_left = pbs.loop_cycles_left; endofsamplereached = (this->PlaybackState.position >= pSample->SamplesTotal); dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->PlaybackState.position)); } @@ -54,10 +59,10 @@ pSample->SetPos(this->SampleOffset); // recover old position do { - readsamples = pSample->Read(&pBuftotal_readsamples * pSample->FrameSize, samplestoread, pDecompressionBuffer); - samplestoread -= readsamples; + readsamples = pSample->Read(&pBuftotal_readsamples * pSample->FrameSize, SamplesToRead, pDecompressionBuffer); + SamplesToRead -= readsamples; total_readsamples += readsamples; - } while (samplestoread && readsamples > 0); + } while (SamplesToRead && readsamples > 0); // we have to store the position within the sample, because other streams might use the same sample this->SampleOffset = pSample->GetPos(); @@ -66,10 +71,6 @@ dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->SampleOffset)); } - // we must delay the increment_write_ptr_with_wrap() after the while() loop because we need to - // ensure that we read exactly SampleCount sample, otherwise the buffer wrapping code will fail - pRingBuffer->increment_write_ptr_with_wrap(total_readsamples * pSample->FrameSize); - // update stream state if (endofsamplereached) SetState(state_end); else SetState(state_active); @@ -77,45 +78,27 @@ return total_readsamples; } - void Stream::WriteSilence(unsigned long SilenceSampleWords) { - memset(pRingBuffer->get_write_ptr(), 0, SilenceSampleWords * BytesPerSample); - pRingBuffer->increment_write_ptr_with_wrap(SilenceSampleWords * BytesPerSample); - } - - Stream::Stream( ::gig::buffer_t* pDecompressionBuffer, uint BufferSize, uint BufferWrapElements) { - this->pExportReference = NULL; - this->State = state_unused; - this->hThis = 0; - this->pDimRgn = NULL; - this->SampleOffset = 0; - this->PlaybackState.position = 0; - this->PlaybackState.reverse = false; - this->pRingBuffer = new RingBuffer<uint8_t,false>(BufferSize * 3, BufferWrapElements * 3); - this->pDecompressionBuffer = pDecompressionBuffer; - UnusedStreams++; - TotalStreams++; - } - - Stream::~Stream() { - Reset(); - if (pRingBuffer) delete pRingBuffer; - UnusedStreams--; - TotalStreams--; - } - - /// Called by disk thread to activate the disk stream. - void Stream::Launch(Stream::Handle hStream, reference_t* pExportReference, ::gig::DimensionRegion* pDimRgn, unsigned long SampleOffset, bool DoLoop) { - UnusedStreams--; - this->pExportReference = pExportReference; - this->hThis = hStream; - this->pDimRgn = pDimRgn; - this->SampleOffset = SampleOffset; - this->PlaybackState.position = SampleOffset; - this->PlaybackState.reverse = false; - this->PlaybackState.loop_cycles_left = pDimRgn->pSample->LoopPlayCount; - this->DoLoop = DoLoop; - BytesPerSample = pDimRgn->pSample->BitDepth / 8; - SetState(state_active); + void Stream::Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::gig::DimensionRegion* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + SampleDescription info; + info.ChannelsPerFrame = pRgn->pSample->Channels; + info.FrameSize = pRgn->pSample->FrameSize; + info.BytesPerSample = pRgn->pSample->BitDepth / 8; + info.TotalSampleCount = pRgn->pSample->SamplesTotal; + + Sample::PlaybackState playbackState; + playbackState.position = SampleOffset; + playbackState.reverse = false; + playbackState.loop_cycles_left = pRgn->pSample->LoopPlayCount; + + LinuxSampler::StreamBase< ::gig::DimensionRegion>::Launch ( + hStream, pExportReference, pRgn, info, playbackState, SampleOffset, DoLoop + ); } }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Stream.h -> linuxsampler-2342.tar.bz2/src/engines/gig/Stream.h
Changed
@@ -2,8 +2,9 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * * * * 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 * @@ -22,131 +23,32 @@ ***************************************************************************/ #ifndef __LS_GIG_STREAM_H__ -#define __LS_GIG_STREAM_H__ - -#include "../../common/global.h" +#define __LS_GIG_STREAM_H__ +#include "../common/StreamBase.h" #include <gig.h> -#include "../../common/RingBuffer.h" - namespace LinuxSampler { namespace gig { - /** @brief Buffered Disk Stream - * - * This encapsulation of a disk stream uses a ring buffer to allow - * thread safe refilling the stream's buffer with one thread (disk - * thread) and actual use / extraction of the audio data from the - * stream's buffer with another thread (audio thread). - */ - class Stream { - public: - // Member Types - typedef uint32_t OrderID_t; - typedef uint32_t Handle; ///< unique identifier of a relationship between one stream and a consumer (Voice) - enum { INVALID_HANDLE = 0 }; - enum state_t { ///< streams go through severe cyclic state transition (unused->active->end->unused->...) - state_unused, ///< stream is not in use, thus can still be launched - state_active, ///< stream provides data in it's buffer to be read and hasn't reached the end yet (this is the usual case) - state_end ///< stream end reached but still providing data in it's buffer to be read (after the client read all remaining data from the stream buffer, state will change automatically to state_unused) - }; - struct reference_t { ///< Defines the current relationship between the stream and a client (voice). - OrderID_t OrderID; ///< Unique identifier that identifies the creation order of a stream requested by a voice. - Handle hStream; ///< Unique identifier of the relationship between stream and client. - state_t State; ///< Current state of the stream that will be pretended to the client (the actual state of the stream might differ though, because the stream might already be in use by another client). - Stream* pStream; ///< Points to the assigned and activated stream or is NULL if the disk thread hasn't launched a stream yet. - }; - - // Methods - Stream( ::gig::buffer_t* pDecompressionBuffer, uint BufferSize, uint BufferWrapElements); - virtual ~Stream(); - int ReadAhead(unsigned long SampleCount); - void WriteSilence(unsigned long SilenceSampleWords); - - inline int GetReadSpace() { - return (pRingBuffer && State != state_unused) ? pRingBuffer->read_space() / BytesPerSample : 0; - } - - inline int GetWriteSpace() { - return (pRingBuffer && State == state_active) ? pRingBuffer->write_space() / BytesPerSample : 0; - } - - inline int GetWriteSpaceToEnd() { - return (pRingBuffer && State == state_active) ? pRingBuffer->write_space_to_end_with_wrap() / BytesPerSample : 0; - } - - // adjusts the write space to avoid buffer boundaries which would lead to the wrap space - // within the buffer (needed for interpolation) getting filled only partially - // for more infos see the docs in ringbuffer.h at adjust_write_space_to_avoid_boundary() - inline int AdjustWriteSpaceToAvoidBoundary(int cnt, int capped_cnt) { - return pRingBuffer->adjust_write_space_to_avoid_boundary(cnt * BytesPerSample, capped_cnt * BytesPerSample) / BytesPerSample; - } - - // gets the current read_ptr within the ringbuffer - inline uint8_t* GetReadPtr(void) { - return pRingBuffer->get_read_ptr(); - } - - inline void IncrementReadPos(uint Count) { - Count *= BytesPerSample; - uint leftspace = pRingBuffer->read_space(); - pRingBuffer->increment_read_ptr(Min(Count, leftspace)); - if (State == state_end && Count >= leftspace) { - Reset(); // quit relation between consumer (voice) and stream and reset stream right after - } - } - - // Static Method - inline static uint GetUnusedStreams() { return UnusedStreams; } - protected: - // Methods - void Launch(Stream::Handle hStream, reference_t* pExportReference, ::gig::DimensionRegion* pDimRgn, unsigned long SampleOffset, bool DoLoop); - inline void Kill() { pExportReference = NULL; Reset(); } ///< Will be called by disk thread after a 'deletion' command from the audio thread (within the voice class) - inline Stream::Handle GetHandle() { return hThis; } - inline Stream::state_t GetState() { return State; } - friend class DiskThread; // only the disk thread should be able to launch and most important kill a disk stream to avoid race conditions + class Stream: public LinuxSampler::StreamBase< ::gig::DimensionRegion> { private: - // Attributes - reference_t* pExportReference; - state_t State; - Stream::Handle hThis; - unsigned long SampleOffset; - ::gig::DimensionRegion* pDimRgn; - ::gig::playback_state_t PlaybackState; - RingBuffer<uint8_t,false>* pRingBuffer; - bool DoLoop; - ::gig::buffer_t* pDecompressionBuffer; - int BytesPerSample; - - // Static Attributes - static uint UnusedStreams; //< Reflects how many stream objects of all stream instances are currently not in use. - static uint TotalStreams; //< Reflects how many stream objects currently exist. + ::gig::buffer_t* pDecompressionBuffer; - // Methods - inline void Reset() { - SampleOffset = 0; - pDimRgn = NULL; - PlaybackState.position = 0; - PlaybackState.reverse = false; - hThis = 0; - pRingBuffer->init(); // reset ringbuffer - if (State != state_unused) { - // we can't do 'SetPos(state_unused)' here, due to possible race conditions) - if (pExportReference) { - pExportReference->State = state_unused; - pExportReference = NULL; - } - State = state_unused; - UnusedStreams++; - } - } - inline void SetState(state_t State) { - if (pExportReference) pExportReference->State = State; - this->State = State; - } - inline long Min(long a, long b) { return (a < b) ? a : b; } + public: + Stream( ::gig::buffer_t* pDecompressionBuffer, uint BufferSize, uint BufferWrapElements); + virtual long Read(uint8_t* pBuf, long SamplesToRead); + + void Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::gig::DimensionRegion* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); }; + }} // namespace LinuxSampler::gig -#endif // __LS_GIG_STREAM_H__ +#endif /* __LS_GIG_STREAM_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Synthesizer.h -> linuxsampler-2342.tar.bz2/src/engines/gig/Synthesizer.h
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2011 Christian Schoenebeck * * * * 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 * @@ -35,7 +35,9 @@ #define SYNTHESIS_MODE_SET_LOOP(iMode,bVal) if (bVal) iMode |= 0x04; else iMode &= ~0x04 /* (un)set mode bit 2 */ #define SYNTHESIS_MODE_SET_CHANNELS(iMode,bVal) if (bVal) iMode |= 0x08; else iMode &= ~0x08 /* (un)set mode bit 3 */ #define SYNTHESIS_MODE_SET_BITDEPTH24(iMode,bVal) if (bVal) iMode |= 0x10; else iMode &= ~0x10 /* (un)set mode bit 4 */ +//TODO: the Asm implementation mode is currently not implemented anymore, since Asm synthesis code is currently broken! #define SYNTHESIS_MODE_SET_IMPLEMENTATION(iMode,bVal) if (bVal) iMode |= 0x20; else iMode &= ~0x20 /* (un)set mode bit 5 */ +//TODO: the profiling mode is currently not implemented anymore! #define SYNTHESIS_MODE_SET_PROFILING(iMode,bVal) if (bVal) iMode |= 0x40; else iMode &= ~0x40 /* (un)set mode bit 6 */ #define SYNTHESIS_MODE_GET_INTERPOLATE(iMode) iMode & 0x01 @@ -167,7 +169,7 @@ double dPos = pFinalParam->dPos; float fPitch = pFinalParam->fFinalPitch; if (USEFILTER) { - Filter filterL = pFinalParam->filterLeft; + Filter& filterL = pFinalParam->filterLeft; for (int i = 0; i < uiToGo; ++i) { samplePoint = Interpolate1StepMonoCPP(pSrc, &dPos, fPitch); samplePoint = filterL.Apply(samplePoint); @@ -193,7 +195,7 @@ } else { // no interpolation int pos_offset = (int) pFinalParam->dPos; if (USEFILTER) { - Filter filterL = pFinalParam->filterLeft; + Filter& filterL = pFinalParam->filterLeft; for (int i = 0; i < uiToGo; ++i) { samplePoint = getSample(pSrc, i + pos_offset); samplePoint = filterL.Apply(samplePoint); @@ -225,8 +227,8 @@ double dPos = pFinalParam->dPos; float fPitch = pFinalParam->fFinalPitch; if (USEFILTER) { - Filter filterL = pFinalParam->filterLeft; - Filter filterR = pFinalParam->filterRight; + Filter& filterL = pFinalParam->filterLeft; + Filter& filterR = pFinalParam->filterRight; for (int i = 0; i < uiToGo; ++i) { samplePoint = Interpolate1StepStereoCPP(pSrc, &dPos, fPitch); samplePoint.left = filterL.Apply(samplePoint.left); @@ -253,8 +255,8 @@ } else { // no interpolation int pos_offset = ((int) pFinalParam->dPos) << 1; if (USEFILTER) { - Filter filterL = pFinalParam->filterLeft; - Filter filterR = pFinalParam->filterRight; + Filter& filterL = pFinalParam->filterLeft; + Filter& filterR = pFinalParam->filterRight; for (int i = 0, ii = 0; i < uiToGo; ++i, ii+=2) { samplePoint.left = getSample(pSrc, ii + pos_offset); samplePoint.right = getSample(pSrc, ii + pos_offset + 1);
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Voice.cpp -> linuxsampler-2342.tar.bz2/src/engines/gig/Voice.cpp
Changed
@@ -3,7 +3,8 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * * * * 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 * @@ -24,983 +25,466 @@ #include "../../common/Features.h" #include "Synthesizer.h" #include "Profiler.h" +#include "Engine.h" +#include "EngineChannel.h" #include "Voice.h" namespace LinuxSampler { namespace gig { Voice::Voice() { - pEngine = NULL; - pDiskThread = NULL; - PlaybackState = playback_state_end; - pLFO1 = new LFOUnsigned(1.0f); // amplitude EG (0..1 range) - pLFO2 = new LFOUnsigned(1.0f); // filter EG (0..1 range) - pLFO3 = new LFOSigned(1200.0f); // pitch EG (-1200..+1200 range) - KeyGroup = 0; - SynthesisMode = 0; // set all mode bits to 0 first - // select synthesis implementation (asm core is not supported ATM) - #if 0 // CONFIG_ASM && ARCH_X86 - SYNTHESIS_MODE_SET_IMPLEMENTATION(SynthesisMode, Features::supportsMMX() && Features::supportsSSE()); - #else - SYNTHESIS_MODE_SET_IMPLEMENTATION(SynthesisMode, false); - #endif - SYNTHESIS_MODE_SET_PROFILING(SynthesisMode, Profiler::isEnabled()); - - finalSynthesisParameters.filterLeft.Reset(); - finalSynthesisParameters.filterRight.Reset(); + pEngine = NULL; + pEG1 = &EG1; + pEG2 = &EG2; } Voice::~Voice() { - if (pLFO1) delete pLFO1; - if (pLFO2) delete pLFO2; - if (pLFO3) delete pLFO3; } - void Voice::SetEngine(Engine* pEngine) { - this->pEngine = pEngine; - this->pDiskThread = pEngine->pDiskThread; + EngineChannel* Voice::GetGigEngineChannel() { + return static_cast<EngineChannel*>(pEngineChannel); + } + + void Voice::SetEngine(LinuxSampler::Engine* pEngine) { + Engine* engine = static_cast<Engine*>(pEngine); + this->pEngine = engine; + this->pDiskThread = engine->pDiskThread; dmsg(6,("Voice::SetEngine()\n")); } - /** - * Initializes and triggers the voice, a disk stream will be launched if - * needed. - * - * @param pEngineChannel - engine channel on which this voice was ordered - * @param itNoteOnEvent - event that caused triggering of this voice - * @param PitchBend - MIDI detune factor (-8192 ... +8191) - * @param pDimRgn - points to the dimension region which provides sample wave(s) and articulation data - * @param VoiceType - type of this voice - * @param iKeyGroup - a value > 0 defines a key group in which this voice is member of - * @returns 0 on success, a value < 0 if the voice wasn't triggered - * (either due to an error or e.g. because no region is - * defined for the given key) - */ - int Voice::Trigger(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int PitchBend, ::gig::DimensionRegion* pDimRgn, type_t VoiceType, int iKeyGroup) { - this->pEngineChannel = pEngineChannel; - this->pDimRgn = pDimRgn; - Orphan = false; - - #if CONFIG_DEVMODE - if (itNoteOnEvent->FragmentPos() > pEngine->MaxSamplesPerCycle) { // just a sanity check for debugging - dmsg(1,("Voice::Trigger(): ERROR, TriggerDelay > Totalsamples\n")); - } - #endif // CONFIG_DEVMODE - - Type = VoiceType; - MIDIKey = itNoteOnEvent->Param.Note.Key; - PlaybackState = playback_state_init; // mark voice as triggered, but no audio rendered yet - Delay = itNoteOnEvent->FragmentPos(); - itTriggerEvent = itNoteOnEvent; - itKillEvent = Pool<Event>::Iterator(); - KeyGroup = iKeyGroup; - pSample = pDimRgn->pSample; // sample won't change until the voice is finished - - // calculate volume - const double velocityAttenuation = pDimRgn->GetVelocityAttenuation(itNoteOnEvent->Param.Note.Velocity); - - // For 16 bit samples, we downscale by 32768 to convert from - // int16 value range to DSP value range (which is - // -1.0..1.0). For 24 bit, we downscale from int32. - float volume = velocityAttenuation / (pSample->BitDepth == 16 ? 32768.0f : 32768.0f * 65536.0f); - - volume *= pDimRgn->SampleAttenuation * pEngineChannel->GlobalVolume * GLOBAL_VOLUME; - - // the volume of release triggered samples depends on note length - if (Type == type_release_trigger) { - float noteLength = float(pEngine->FrameTime + Delay - - pEngineChannel->pMIDIKeyInfoMIDIKey.NoteOnTime) / pEngine->SampleRate; - float attenuation = 1 - 0.01053 * (256 >> pDimRgn->ReleaseTriggerDecay) * noteLength; - if (attenuation <= 0) return -1; - volume *= attenuation; + Voice::SampleInfo Voice::GetSampleInfo() { + SampleInfo si; + si.SampleRate = pSample->SamplesPerSecond; + si.ChannelCount = pSample->Channels; + si.FrameSize = pSample->FrameSize; + si.BitDepth = pSample->BitDepth; + si.TotalFrameCount = pSample->SamplesTotal; + + si.HasLoops = pRegion->SampleLoops; + si.LoopStart = (si.HasLoops) ? pRegion->pSampleLoops0.LoopStart : 0; + si.LoopLength = (si.HasLoops) ? pRegion->pSampleLoops0.LoopLength : 0; + si.LoopPlayCount = pSample->LoopPlayCount; + si.Unpitched = !pRegion->PitchTrack; + + return si; + } + + Voice::RegionInfo Voice::GetRegionInfo() { + RegionInfo ri; + ri.UnityNote = pRegion->UnityNote; + ri.FineTune = pRegion->FineTune; + ri.Pan = pRegion->Pan; + ri.SampleStartOffset = pRegion->SampleStartOffset; + + ri.EG2PreAttack = pRegion->EG2PreAttack; + ri.EG2Attack = pRegion->EG2Attack; + ri.EG2Decay1 = pRegion->EG2Decay1; + ri.EG2Decay2 = pRegion->EG2Decay2; + ri.EG2Sustain = pRegion->EG2Sustain; + ri.EG2InfiniteSustain = pRegion->EG2InfiniteSustain; + ri.EG2Release = pRegion->EG2Release; + + ri.EG3Attack = pRegion->EG3Attack; + ri.EG3Depth = pRegion->EG3Depth; + ri.VCFEnabled = pRegion->VCFEnabled; + ri.VCFType = Filter::vcf_type_t(pRegion->VCFType); + ri.VCFResonance = pRegion->VCFResonance; + + ri.ReleaseTriggerDecay = 0.01053 * (256 >> pRegion->ReleaseTriggerDecay); + + return ri; + } + + Voice::InstrumentInfo Voice::GetInstrumentInfo() { + InstrumentInfo ii; + ii.FineTune = GetGigEngineChannel()->pInstrument->FineTune; + ii.PitchbendRange = GetGigEngineChannel()->pInstrument->PitchbendRange; + + return ii; + } + + double Voice::GetSampleAttenuation() { + return pRegion->SampleAttenuation; + } + + double Voice::GetVelocityAttenuation(uint8_t MIDIKeyVelocity) { + return pRegion->GetVelocityAttenuation(MIDIKeyVelocity); + } + + double Voice::GetVelocityRelease(uint8_t MIDIKeyVelocity) { + return pRegion->GetVelocityRelease(MIDIKeyVelocity); + } + + void Voice::ProcessCCEvent(RTList<Event>::Iterator& itEvent) { + if (itEvent->Type == Event::type_control_change && itEvent->Param.CC.Controller) { // if (valid) MIDI control change event + if (pRegion->AttenuationController.type == ::gig::attenuation_ctrl_t::type_controlchange && + itEvent->Param.CC.Controller == pRegion->AttenuationController.controller_number) { + CrossfadeSmoother.update(AbstractEngine::CrossfadeCurveCrossfadeAttenuation(itEvent->Param.CC.Value)); + } } + } - // select channel mode (mono or stereo) - SYNTHESIS_MODE_SET_CHANNELS(SynthesisMode, pSample->Channels == 2); - // select bit depth (16 or 24) - SYNTHESIS_MODE_SET_BITDEPTH24(SynthesisMode, pSample->BitDepth == 24); + void Voice::ProcessCutoffEvent(RTList<Event>::Iterator& itEvent) { + int ccvalue = itEvent->Param.CC.Value; + if (VCFCutoffCtrl.value == ccvalue) return; + VCFCutoffCtrl.value = ccvalue; + if (pRegion->VCFCutoffControllerInvert) ccvalue = 127 - ccvalue; + if (ccvalue < pRegion->VCFVelocityScale) ccvalue = pRegion->VCFVelocityScale; + float cutoff = CutoffBase * float(ccvalue); + if (cutoff > 127.0f) cutoff = 127.0f; - // get starting crossfade volume level + VCFCutoffCtrl.fvalue = cutoff; // needed for initialization of fFinalCutoff next time + fFinalCutoff = cutoff; + } + + double Voice::CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity) { float crossfadeVolume; - switch (pDimRgn->AttenuationController.type) { + switch (pRegion->AttenuationController.type) { case ::gig::attenuation_ctrl_t::type_channelaftertouch: - crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(pEngineChannel->ControllerTable128); + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetGigEngineChannel()->ControllerTable128); break; case ::gig::attenuation_ctrl_t::type_velocity: - crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(itNoteOnEvent->Param.Note.Velocity); + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(MIDIKeyVelocity); break; case ::gig::attenuation_ctrl_t::type_controlchange: //FIXME: currently not sample accurate - crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(pEngineChannel->ControllerTablepDimRgn->AttenuationController.controller_number); + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetGigEngineChannel()->ControllerTablepRegion->AttenuationController.controller_number); break; case ::gig::attenuation_ctrl_t::type_none: // no crossfade defined default: crossfadeVolume = 1.0f; } - VolumeLeft = volume * Engine::PanCurve64 - pDimRgn->Pan; - VolumeRight = volume * Engine::PanCurve64 + pDimRgn->Pan; - - float subfragmentRate = pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; - CrossfadeSmoother.trigger(crossfadeVolume, subfragmentRate); - VolumeSmoother.trigger(pEngineChannel->MidiVolume, subfragmentRate); - PanLeftSmoother.trigger(pEngineChannel->GlobalPanLeft, subfragmentRate); - PanRightSmoother.trigger(pEngineChannel->GlobalPanRight, subfragmentRate); - - finalSynthesisParameters.dPos = pDimRgn->SampleStartOffset; // offset where we should start playback of sample (0 - 2000 sample points) - Pos = pDimRgn->SampleStartOffset; - - // Check if the sample needs disk streaming or is too short for that - long cachedsamples = pSample->GetCache().Size / pSample->FrameSize; - DiskVoice = cachedsamples < pSample->SamplesTotal; - - const DLS::sample_loop_t& loopinfo = pDimRgn->pSampleLoops0; - - if (DiskVoice) { // voice to be streamed from disk - if (cachedsamples > (pEngine->MaxSamplesPerCycle << CONFIG_MAX_PITCH)) { - MaxRAMPos = cachedsamples - (pEngine->MaxSamplesPerCycle << CONFIG_MAX_PITCH) / pSample->Channels; //TODO: this calculation is too pessimistic and may better be moved to Render() method, so it calculates MaxRAMPos dependent to the current demand of sample points to be rendered (e.g. in case of JACK) - } else { - // The cache is too small to fit a max sample buffer. - // Setting MaxRAMPos to 0 will probably cause a click - // in the audio, but it's better than not handling - // this case at all, which would have caused the - // unsigned MaxRAMPos to be set to a negative number. - MaxRAMPos = 0; - } - - // check if there's a loop defined which completely fits into the cached (RAM) part of the sample - RAMLoop = (pDimRgn->SampleLoops && (loopinfo.LoopStart + loopinfo.LoopLength) <= MaxRAMPos); + return crossfadeVolume; + } - if (pDiskThread->OrderNewStream(&DiskStreamRef, pDimRgn, MaxRAMPos, !RAMLoop) < 0) { - dmsg(1,("Disk stream order failed!\n")); - KillImmediately(); - return -1; - } - dmsg(4,("Disk voice launched (cached samples: %d, total Samples: %d, MaxRAMPos: %d, RAMLooping: %s)\n", cachedsamples, pSample->SamplesTotal, MaxRAMPos, (RAMLoop) ? "yes" : "no")); - } - else { // RAM only voice - MaxRAMPos = cachedsamples; - RAMLoop = (pDimRgn->SampleLoops != 0); - dmsg(4,("RAM only voice launched (Looping: %s)\n", (RAMLoop) ? "yes" : "no")); - } - if (RAMLoop) { - loop.uiTotalCycles = pSample->LoopPlayCount; - loop.uiCyclesLeft = pSample->LoopPlayCount; - loop.uiStart = loopinfo.LoopStart; - loop.uiEnd = loopinfo.LoopStart + loopinfo.LoopLength; - loop.uiSize = loopinfo.LoopLength; + double Voice::GetEG1ControllerValue(uint8_t MIDIKeyVelocity) { + double eg1controllervalue = 0; + switch (pRegion->EG1Controller.type) { + case ::gig::eg1_ctrl_t::type_none: // no controller defined + eg1controllervalue = 0; + break; + case ::gig::eg1_ctrl_t::type_channelaftertouch: + eg1controllervalue = GetGigEngineChannel()->ControllerTable128; + break; + case ::gig::eg1_ctrl_t::type_velocity: + eg1controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg1_ctrl_t::type_controlchange: // MIDI control change controller + eg1controllervalue = GetGigEngineChannel()->ControllerTablepRegion->EG1Controller.controller_number; + break; } + if (pRegion->EG1ControllerInvert) eg1controllervalue = 127 - eg1controllervalue; - // calculate initial pitch value - { - double pitchbasecents = pEngineChannel->pInstrument->FineTune + pDimRgn->FineTune + pEngine->ScaleTuningMIDIKey % 12; + return eg1controllervalue; + } - // GSt behaviour: maximum transpose up is 40 semitones. If - // MIDI key is more than 40 semitones above unity note, - // the transpose is not done. - if (pDimRgn->PitchTrack && (MIDIKey - (int) pDimRgn->UnityNote) < 40) pitchbasecents += (MIDIKey - (int) pDimRgn->UnityNote) * 100; + Voice::EGInfo Voice::CalculateEG1ControllerInfluence(double eg1ControllerValue) { + EGInfo eg; + // (eg1attack is different from the others) + eg.Attack = (pRegion->EG1ControllerAttackInfluence) ? + 1 + 0.031 * (double) (pRegion->EG1ControllerAttackInfluence == 1 ? + 1 : 1 << pRegion->EG1ControllerAttackInfluence) * eg1ControllerValue : 1.0; + eg.Decay = (pRegion->EG1ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerDecayInfluence) * eg1ControllerValue : 1.0; + eg.Release = (pRegion->EG1ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerReleaseInfluence) * eg1ControllerValue : 1.0; - this->PitchBase = RTMath::CentsToFreqRatioUnlimited(pitchbasecents) * (double(pSample->SamplesPerSecond) / double(pEngine->SampleRate)); - this->PitchBendRange = 1.0 / 8192.0 * 100.0 * pEngineChannel->pInstrument->PitchbendRange; - this->PitchBend = RTMath::CentsToFreqRatio(PitchBend * PitchBendRange); - } + return eg; + } - // the length of the decay and release curves are dependent on the velocity - const double velrelease = 1 / pDimRgn->GetVelocityRelease(itNoteOnEvent->Param.Note.Velocity); - - // setup EG 1 (VCA EG) - { - // get current value of EG1 controller - double eg1controllervalue; - switch (pDimRgn->EG1Controller.type) { - case ::gig::eg1_ctrl_t::type_none: // no controller defined - eg1controllervalue = 0; - break; - case ::gig::eg1_ctrl_t::type_channelaftertouch: - eg1controllervalue = pEngineChannel->ControllerTable128; - break; - case ::gig::eg1_ctrl_t::type_velocity: - eg1controllervalue = itNoteOnEvent->Param.Note.Velocity; - break; - case ::gig::eg1_ctrl_t::type_controlchange: // MIDI control change controller - eg1controllervalue = pEngineChannel->ControllerTablepDimRgn->EG1Controller.controller_number; - break; - } - if (pDimRgn->EG1ControllerInvert) eg1controllervalue = 127 - eg1controllervalue; - - // calculate influence of EG1 controller on EG1's parameters - // (eg1attack is different from the others) - double eg1attack = (pDimRgn->EG1ControllerAttackInfluence) ? - 1 + 0.031 * (double) (pDimRgn->EG1ControllerAttackInfluence == 1 ? - 1 : 1 << pDimRgn->EG1ControllerAttackInfluence) * eg1controllervalue : 1.0; - double eg1decay = (pDimRgn->EG1ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pDimRgn->EG1ControllerDecayInfluence) * eg1controllervalue : 1.0; - double eg1release = (pDimRgn->EG1ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pDimRgn->EG1ControllerReleaseInfluence) * eg1controllervalue : 1.0; - - EG1.trigger(pDimRgn->EG1PreAttack, - pDimRgn->EG1Attack * eg1attack, - pDimRgn->EG1Hold, - pDimRgn->EG1Decay1 * eg1decay * velrelease, - pDimRgn->EG1Decay2 * eg1decay * velrelease, - pDimRgn->EG1InfiniteSustain, - pDimRgn->EG1Sustain, - pDimRgn->EG1Release * eg1release * velrelease, - velocityAttenuation, - pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + double Voice::GetEG2ControllerValue(uint8_t MIDIKeyVelocity) { + double eg2controllervalue = 0; + switch (pRegion->EG2Controller.type) { + case ::gig::eg2_ctrl_t::type_none: // no controller defined + eg2controllervalue = 0; + break; + case ::gig::eg2_ctrl_t::type_channelaftertouch: + eg2controllervalue = GetGigEngineChannel()->ControllerTable128; + break; + case ::gig::eg2_ctrl_t::type_velocity: + eg2controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg2_ctrl_t::type_controlchange: // MIDI control change controller + eg2controllervalue = GetGigEngineChannel()->ControllerTablepRegion->EG2Controller.controller_number; + break; } + if (pRegion->EG2ControllerInvert) eg2controllervalue = 127 - eg2controllervalue; -#ifdef CONFIG_INTERPOLATE_VOLUME - // setup initial volume in synthesis parameters -#ifdef CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) { - finalSynthesisParameters.fFinalVolumeLeft = 0; - finalSynthesisParameters.fFinalVolumeRight = 0; - } - else -#else - { - float finalVolume = pEngineChannel->MidiVolume * crossfadeVolume * EG1.getLevel(); + return eg2controllervalue; + } - finalSynthesisParameters.fFinalVolumeLeft = finalVolume * VolumeLeft * pEngineChannel->GlobalPanLeft; - finalSynthesisParameters.fFinalVolumeRight = finalVolume * VolumeRight * pEngineChannel->GlobalPanRight; - } -#endif -#endif - - // setup EG 2 (VCF Cutoff EG) - { - // get current value of EG2 controller - double eg2controllervalue; - switch (pDimRgn->EG2Controller.type) { - case ::gig::eg2_ctrl_t::type_none: // no controller defined - eg2controllervalue = 0; - break; - case ::gig::eg2_ctrl_t::type_channelaftertouch: - eg2controllervalue = pEngineChannel->ControllerTable128; - break; - case ::gig::eg2_ctrl_t::type_velocity: - eg2controllervalue = itNoteOnEvent->Param.Note.Velocity; - break; - case ::gig::eg2_ctrl_t::type_controlchange: // MIDI control change controller - eg2controllervalue = pEngineChannel->ControllerTablepDimRgn->EG2Controller.controller_number; - break; - } - if (pDimRgn->EG2ControllerInvert) eg2controllervalue = 127 - eg2controllervalue; - - // calculate influence of EG2 controller on EG2's parameters - double eg2attack = (pDimRgn->EG2ControllerAttackInfluence) ? 1 + 0.00775 * (double) (1 << pDimRgn->EG2ControllerAttackInfluence) * eg2controllervalue : 1.0; - double eg2decay = (pDimRgn->EG2ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pDimRgn->EG2ControllerDecayInfluence) * eg2controllervalue : 1.0; - double eg2release = (pDimRgn->EG2ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pDimRgn->EG2ControllerReleaseInfluence) * eg2controllervalue : 1.0; - - EG2.trigger(pDimRgn->EG2PreAttack, - pDimRgn->EG2Attack * eg2attack, - false, - pDimRgn->EG2Decay1 * eg2decay * velrelease, - pDimRgn->EG2Decay2 * eg2decay * velrelease, - pDimRgn->EG2InfiniteSustain, - pDimRgn->EG2Sustain, - pDimRgn->EG2Release * eg2release * velrelease, - velocityAttenuation, - pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } + Voice::EGInfo Voice::CalculateEG2ControllerInfluence(double eg2ControllerValue) { + EGInfo eg; + eg.Attack = (pRegion->EG2ControllerAttackInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerAttackInfluence) * eg2ControllerValue : 1.0; + eg.Decay = (pRegion->EG2ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerDecayInfluence) * eg2ControllerValue : 1.0; + eg.Release = (pRegion->EG2ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerReleaseInfluence) * eg2ControllerValue : 1.0; + return eg; + } - // setup EG 3 (VCO EG) - { - // if portamento mode is on, we dedicate EG3 purely for portamento, otherwise if portamento is off we do as told by the patch - bool bPortamento = pEngineChannel->PortamentoMode && pEngineChannel->PortamentoPos >= 0.0f; - float eg3depth = (bPortamento) - ? RTMath::CentsToFreqRatio((pEngineChannel->PortamentoPos - (float) MIDIKey) * 100) - : RTMath::CentsToFreqRatio(pDimRgn->EG3Depth); - float eg3time = (bPortamento) - ? pEngineChannel->PortamentoTime - : pDimRgn->EG3Attack; - EG3.trigger(eg3depth, eg3time, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - dmsg(5,("PortamentoPos=%f, depth=%f, time=%f\n", pEngineChannel->PortamentoPos, eg3depth, eg3time)); + void Voice::InitLFO1() { + uint16_t lfo1_internal_depth; + switch (pRegion->LFO1Controller) { + case ::gig::lfo1_ctrl_internal: + lfo1_internal_depth = pRegion->LFO1InternalDepth; + pLFO1->ExtController = 0; // no external controller + bLFO1Enabled = (lfo1_internal_depth > 0); + break; + case ::gig::lfo1_ctrl_modwheel: + lfo1_internal_depth = 0; + pLFO1->ExtController = 1; // MIDI controller 1 + bLFO1Enabled = (pRegion->LFO1ControlDepth > 0); + break; + case ::gig::lfo1_ctrl_breath: + lfo1_internal_depth = 0; + pLFO1->ExtController = 2; // MIDI controller 2 + bLFO1Enabled = (pRegion->LFO1ControlDepth > 0); + break; + case ::gig::lfo1_ctrl_internal_modwheel: + lfo1_internal_depth = pRegion->LFO1InternalDepth; + pLFO1->ExtController = 1; // MIDI controller 1 + bLFO1Enabled = (lfo1_internal_depth > 0 || pRegion->LFO1ControlDepth > 0); + break; + case ::gig::lfo1_ctrl_internal_breath: + lfo1_internal_depth = pRegion->LFO1InternalDepth; + pLFO1->ExtController = 2; // MIDI controller 2 + bLFO1Enabled = (lfo1_internal_depth > 0 || pRegion->LFO1ControlDepth > 0); + break; + default: + lfo1_internal_depth = 0; + pLFO1->ExtController = 0; // no external controller + bLFO1Enabled = false; } - - - // setup LFO 1 (VCA LFO) - { - uint16_t lfo1_internal_depth; - switch (pDimRgn->LFO1Controller) { - case ::gig::lfo1_ctrl_internal: - lfo1_internal_depth = pDimRgn->LFO1InternalDepth; - pLFO1->ExtController = 0; // no external controller - bLFO1Enabled = (lfo1_internal_depth > 0); - break; - case ::gig::lfo1_ctrl_modwheel: - lfo1_internal_depth = 0; - pLFO1->ExtController = 1; // MIDI controller 1 - bLFO1Enabled = (pDimRgn->LFO1ControlDepth > 0); - break; - case ::gig::lfo1_ctrl_breath: - lfo1_internal_depth = 0; - pLFO1->ExtController = 2; // MIDI controller 2 - bLFO1Enabled = (pDimRgn->LFO1ControlDepth > 0); - break; - case ::gig::lfo1_ctrl_internal_modwheel: - lfo1_internal_depth = pDimRgn->LFO1InternalDepth; - pLFO1->ExtController = 1; // MIDI controller 1 - bLFO1Enabled = (lfo1_internal_depth > 0 || pDimRgn->LFO1ControlDepth > 0); - break; - case ::gig::lfo1_ctrl_internal_breath: - lfo1_internal_depth = pDimRgn->LFO1InternalDepth; - pLFO1->ExtController = 2; // MIDI controller 2 - bLFO1Enabled = (lfo1_internal_depth > 0 || pDimRgn->LFO1ControlDepth > 0); - break; - default: - lfo1_internal_depth = 0; - pLFO1->ExtController = 0; // no external controller - bLFO1Enabled = false; - } - if (bLFO1Enabled) { - pLFO1->trigger(pDimRgn->LFO1Frequency, - start_level_min, - lfo1_internal_depth, - pDimRgn->LFO1ControlDepth, - pDimRgn->LFO1FlipPhase, - pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - pLFO1->update(pLFO1->ExtController ? pEngineChannel->ControllerTablepLFO1->ExtController : 0); - } + if (bLFO1Enabled) { + pLFO1->trigger(pRegion->LFO1Frequency, + start_level_min, + lfo1_internal_depth, + pRegion->LFO1ControlDepth, + pRegion->LFO1FlipPhase, + pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + pLFO1->update(pLFO1->ExtController ? GetGigEngineChannel()->ControllerTablepLFO1->ExtController : 0); } + } - - // setup LFO 2 (VCF Cutoff LFO) - { - uint16_t lfo2_internal_depth; - switch (pDimRgn->LFO2Controller) { - case ::gig::lfo2_ctrl_internal: - lfo2_internal_depth = pDimRgn->LFO2InternalDepth; - pLFO2->ExtController = 0; // no external controller - bLFO2Enabled = (lfo2_internal_depth > 0); - break; - case ::gig::lfo2_ctrl_modwheel: - lfo2_internal_depth = 0; - pLFO2->ExtController = 1; // MIDI controller 1 - bLFO2Enabled = (pDimRgn->LFO2ControlDepth > 0); - break; - case ::gig::lfo2_ctrl_foot: - lfo2_internal_depth = 0; - pLFO2->ExtController = 4; // MIDI controller 4 - bLFO2Enabled = (pDimRgn->LFO2ControlDepth > 0); - break; - case ::gig::lfo2_ctrl_internal_modwheel: - lfo2_internal_depth = pDimRgn->LFO2InternalDepth; - pLFO2->ExtController = 1; // MIDI controller 1 - bLFO2Enabled = (lfo2_internal_depth > 0 || pDimRgn->LFO2ControlDepth > 0); - break; - case ::gig::lfo2_ctrl_internal_foot: - lfo2_internal_depth = pDimRgn->LFO2InternalDepth; - pLFO2->ExtController = 4; // MIDI controller 4 - bLFO2Enabled = (lfo2_internal_depth > 0 || pDimRgn->LFO2ControlDepth > 0); - break; - default: - lfo2_internal_depth = 0; - pLFO2->ExtController = 0; // no external controller - bLFO2Enabled = false; - } - if (bLFO2Enabled) { - pLFO2->trigger(pDimRgn->LFO2Frequency, - start_level_max, - lfo2_internal_depth, - pDimRgn->LFO2ControlDepth, - pDimRgn->LFO2FlipPhase, - pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - pLFO2->update(pLFO2->ExtController ? pEngineChannel->ControllerTablepLFO2->ExtController : 0); - } + void Voice::InitLFO2() { + uint16_t lfo2_internal_depth; + switch (pRegion->LFO2Controller) { + case ::gig::lfo2_ctrl_internal: + lfo2_internal_depth = pRegion->LFO2InternalDepth; + pLFO2->ExtController = 0; // no external controller + bLFO2Enabled = (lfo2_internal_depth > 0); + break; + case ::gig::lfo2_ctrl_modwheel: + lfo2_internal_depth = 0; + pLFO2->ExtController = 1; // MIDI controller 1 + bLFO2Enabled = (pRegion->LFO2ControlDepth > 0); + break; + case ::gig::lfo2_ctrl_foot: + lfo2_internal_depth = 0; + pLFO2->ExtController = 4; // MIDI controller 4 + bLFO2Enabled = (pRegion->LFO2ControlDepth > 0); + break; + case ::gig::lfo2_ctrl_internal_modwheel: + lfo2_internal_depth = pRegion->LFO2InternalDepth; + pLFO2->ExtController = 1; // MIDI controller 1 + bLFO2Enabled = (lfo2_internal_depth > 0 || pRegion->LFO2ControlDepth > 0); + break; + case ::gig::lfo2_ctrl_internal_foot: + lfo2_internal_depth = pRegion->LFO2InternalDepth; + pLFO2->ExtController = 4; // MIDI controller 4 + bLFO2Enabled = (lfo2_internal_depth > 0 || pRegion->LFO2ControlDepth > 0); + break; + default: + lfo2_internal_depth = 0; + pLFO2->ExtController = 0; // no external controller + bLFO2Enabled = false; } - - - // setup LFO 3 (VCO LFO) - { - uint16_t lfo3_internal_depth; - switch (pDimRgn->LFO3Controller) { - case ::gig::lfo3_ctrl_internal: - lfo3_internal_depth = pDimRgn->LFO3InternalDepth; - pLFO3->ExtController = 0; // no external controller - bLFO3Enabled = (lfo3_internal_depth > 0); - break; - case ::gig::lfo3_ctrl_modwheel: - lfo3_internal_depth = 0; - pLFO3->ExtController = 1; // MIDI controller 1 - bLFO3Enabled = (pDimRgn->LFO3ControlDepth > 0); - break; - case ::gig::lfo3_ctrl_aftertouch: - lfo3_internal_depth = 0; - pLFO3->ExtController = 128; - bLFO3Enabled = true; - break; - case ::gig::lfo3_ctrl_internal_modwheel: - lfo3_internal_depth = pDimRgn->LFO3InternalDepth; - pLFO3->ExtController = 1; // MIDI controller 1 - bLFO3Enabled = (lfo3_internal_depth > 0 || pDimRgn->LFO3ControlDepth > 0); - break; - case ::gig::lfo3_ctrl_internal_aftertouch: - lfo3_internal_depth = pDimRgn->LFO3InternalDepth; - pLFO1->ExtController = 128; - bLFO3Enabled = (lfo3_internal_depth > 0 || pDimRgn->LFO3ControlDepth > 0); - break; - default: - lfo3_internal_depth = 0; - pLFO3->ExtController = 0; // no external controller - bLFO3Enabled = false; - } - if (bLFO3Enabled) { - pLFO3->trigger(pDimRgn->LFO3Frequency, - start_level_mid, - lfo3_internal_depth, - pDimRgn->LFO3ControlDepth, - false, - pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - pLFO3->update(pLFO3->ExtController ? pEngineChannel->ControllerTablepLFO3->ExtController : 0); - } + if (bLFO2Enabled) { + pLFO2->trigger(pRegion->LFO2Frequency, + start_level_max, + lfo2_internal_depth, + pRegion->LFO2ControlDepth, + pRegion->LFO2FlipPhase, + pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + pLFO2->update(pLFO2->ExtController ? GetGigEngineChannel()->ControllerTablepLFO2->ExtController : 0); } + } + void Voice::InitLFO3() { + uint16_t lfo3_internal_depth; + switch (pRegion->LFO3Controller) { + case ::gig::lfo3_ctrl_internal: + lfo3_internal_depth = pRegion->LFO3InternalDepth; + pLFO3->ExtController = 0; // no external controller + bLFO3Enabled = (lfo3_internal_depth > 0); + break; + case ::gig::lfo3_ctrl_modwheel: + lfo3_internal_depth = 0; + pLFO3->ExtController = 1; // MIDI controller 1 + bLFO3Enabled = (pRegion->LFO3ControlDepth > 0); + break; + case ::gig::lfo3_ctrl_aftertouch: + lfo3_internal_depth = 0; + pLFO3->ExtController = 128; + bLFO3Enabled = true; + break; + case ::gig::lfo3_ctrl_internal_modwheel: + lfo3_internal_depth = pRegion->LFO3InternalDepth; + pLFO3->ExtController = 1; // MIDI controller 1 + bLFO3Enabled = (lfo3_internal_depth > 0 || pRegion->LFO3ControlDepth > 0); + break; + case ::gig::lfo3_ctrl_internal_aftertouch: + lfo3_internal_depth = pRegion->LFO3InternalDepth; + pLFO3->ExtController = 128; + bLFO3Enabled = (lfo3_internal_depth > 0 || pRegion->LFO3ControlDepth > 0); + break; + default: + lfo3_internal_depth = 0; + pLFO3->ExtController = 0; // no external controller + bLFO3Enabled = false; + } + if (bLFO3Enabled) { + pLFO3->trigger(pRegion->LFO3Frequency, + start_level_mid, + lfo3_internal_depth, + pRegion->LFO3ControlDepth, + false, + pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + pLFO3->update(pLFO3->ExtController ? GetGigEngineChannel()->ControllerTablepLFO3->ExtController : 0); + } + } - #if CONFIG_FORCE_FILTER - const bool bUseFilter = true; - #else // use filter only if instrument file told so - const bool bUseFilter = pDimRgn->VCFEnabled; - #endif // CONFIG_FORCE_FILTER - SYNTHESIS_MODE_SET_FILTER(SynthesisMode, bUseFilter); - if (bUseFilter) { - #ifdef CONFIG_OVERRIDE_CUTOFF_CTRL - VCFCutoffCtrl.controller = CONFIG_OVERRIDE_CUTOFF_CTRL; - #else // use the one defined in the instrument file - switch (pDimRgn->VCFCutoffController) { - case ::gig::vcf_cutoff_ctrl_modwheel: - VCFCutoffCtrl.controller = 1; - break; - case ::gig::vcf_cutoff_ctrl_effect1: - VCFCutoffCtrl.controller = 12; - break; - case ::gig::vcf_cutoff_ctrl_effect2: - VCFCutoffCtrl.controller = 13; - break; - case ::gig::vcf_cutoff_ctrl_breath: - VCFCutoffCtrl.controller = 2; - break; - case ::gig::vcf_cutoff_ctrl_foot: - VCFCutoffCtrl.controller = 4; - break; - case ::gig::vcf_cutoff_ctrl_sustainpedal: - VCFCutoffCtrl.controller = 64; - break; - case ::gig::vcf_cutoff_ctrl_softpedal: - VCFCutoffCtrl.controller = 67; - break; - case ::gig::vcf_cutoff_ctrl_genpurpose7: - VCFCutoffCtrl.controller = 82; - break; - case ::gig::vcf_cutoff_ctrl_genpurpose8: - VCFCutoffCtrl.controller = 83; - break; - case ::gig::vcf_cutoff_ctrl_aftertouch: - VCFCutoffCtrl.controller = 128; - break; - case ::gig::vcf_cutoff_ctrl_none: - default: - VCFCutoffCtrl.controller = 0; - break; - } - #endif // CONFIG_OVERRIDE_CUTOFF_CTRL - - #ifdef CONFIG_OVERRIDE_RESONANCE_CTRL - VCFResonanceCtrl.controller = CONFIG_OVERRIDE_RESONANCE_CTRL; - #else // use the one defined in the instrument file - switch (pDimRgn->VCFResonanceController) { - case ::gig::vcf_res_ctrl_genpurpose3: - VCFResonanceCtrl.controller = 18; - break; - case ::gig::vcf_res_ctrl_genpurpose4: - VCFResonanceCtrl.controller = 19; - break; - case ::gig::vcf_res_ctrl_genpurpose5: - VCFResonanceCtrl.controller = 80; - break; - case ::gig::vcf_res_ctrl_genpurpose6: - VCFResonanceCtrl.controller = 81; - break; - case ::gig::vcf_res_ctrl_none: - default: - VCFResonanceCtrl.controller = 0; - } - #endif // CONFIG_OVERRIDE_RESONANCE_CTRL - - #ifndef CONFIG_OVERRIDE_FILTER_TYPE - finalSynthesisParameters.filterLeft.SetType(pDimRgn->VCFType); - finalSynthesisParameters.filterRight.SetType(pDimRgn->VCFType); - #else // override filter type - finalSynthesisParameters.filterLeft.SetType(CONFIG_OVERRIDE_FILTER_TYPE); - finalSynthesisParameters.filterRight.SetType(CONFIG_OVERRIDE_FILTER_TYPE); - #endif // CONFIG_OVERRIDE_FILTER_TYPE - - VCFCutoffCtrl.value = pEngineChannel->ControllerTableVCFCutoffCtrl.controller; - VCFResonanceCtrl.value = pEngineChannel->ControllerTableVCFResonanceCtrl.controller; - - // calculate cutoff frequency - float cutoff = pDimRgn->GetVelocityCutoff(itNoteOnEvent->Param.Note.Velocity); - if (pDimRgn->VCFKeyboardTracking) { - cutoff *= exp((itNoteOnEvent->Param.Note.Key - pDimRgn->VCFKeyboardTrackingBreakpoint) * 0.057762265f); // (ln(2) / 12) - } - CutoffBase = cutoff; - - int cvalue; - if (VCFCutoffCtrl.controller) { - cvalue = pEngineChannel->ControllerTableVCFCutoffCtrl.controller; - if (pDimRgn->VCFCutoffControllerInvert) cvalue = 127 - cvalue; - // VCFVelocityScale in this case means Minimum cutoff - if (cvalue < pDimRgn->VCFVelocityScale) cvalue = pDimRgn->VCFVelocityScale; - } - else { - cvalue = pDimRgn->VCFCutoff; - } - cutoff *= float(cvalue); - if (cutoff > 127.0f) cutoff = 127.0f; - - // calculate resonance - float resonance = (float) (VCFResonanceCtrl.controller ? VCFResonanceCtrl.value : pDimRgn->VCFResonance); + float Voice::CalculateCutoffBase(uint8_t MIDIKeyVelocity) { + float cutoff = pRegion->GetVelocityCutoff(MIDIKeyVelocity); + if (pRegion->VCFKeyboardTracking) { + cutoff *= RTMath::CentsToFreqRatioUnlimited((MIDIKey - pRegion->VCFKeyboardTrackingBreakpoint) * 100); + } + return cutoff; + } - VCFCutoffCtrl.fvalue = cutoff; - VCFResonanceCtrl.fvalue = resonance; + float Voice::CalculateFinalCutoff(float cutoffBase) { + int cvalue; + if (VCFCutoffCtrl.controller) { + cvalue = GetGigEngineChannel()->ControllerTableVCFCutoffCtrl.controller; + if (pRegion->VCFCutoffControllerInvert) cvalue = 127 - cvalue; + // VCFVelocityScale in this case means Minimum cutoff + if (cvalue < pRegion->VCFVelocityScale) cvalue = pRegion->VCFVelocityScale; } else { - VCFCutoffCtrl.controller = 0; - VCFResonanceCtrl.controller = 0; + cvalue = pRegion->VCFCutoff; } + float fco = cutoffBase * float(cvalue); + if (fco > 127.0f) fco = 127.0f; - return 0; // success + return fco; } - /** - * Renders the audio data for this voice for the current audio fragment. - * The sample input data can either come from RAM (cached sample or sample - * part) or directly from disk. The output signal will be rendered by - * resampling / interpolation. If this voice is a disk streaming voice and - * the voice completely played back the cached RAM part of the sample, it - * will automatically switch to disk playback for the next RenderAudio() - * call. - * - * @param Samples - number of samples to be rendered in this audio fragment cycle - */ - void Voice::Render(uint Samples) { - - // select default values for synthesis mode bits - SYNTHESIS_MODE_SET_LOOP(SynthesisMode, false); - - switch (this->PlaybackState) { - - case playback_state_init: - this->PlaybackState = playback_state_ram; // we always start playback from RAM cache and switch then to disk if needed - // no break - continue with playback_state_ram - - case playback_state_ram: { - if (RAMLoop) SYNTHESIS_MODE_SET_LOOP(SynthesisMode, true); // enable looping - - // render current fragment - Synthesize(Samples, (sample_t*) pSample->GetCache().pStart, Delay); - - if (DiskVoice) { - // check if we reached the allowed limit of the sample RAM cache - if (finalSynthesisParameters.dPos > MaxRAMPos) { - dmsg(5,("Voice: switching to disk playback (Pos=%f)\n", finalSynthesisParameters.dPos)); - this->PlaybackState = playback_state_disk; - } - } else if (finalSynthesisParameters.dPos >= pSample->GetCache().Size / pSample->FrameSize) { - this->PlaybackState = playback_state_end; - } - } - break; - - case playback_state_disk: { - if (!DiskStreamRef.pStream) { - // check if the disk thread created our ordered disk stream in the meantime - DiskStreamRef.pStream = pDiskThread->AskForCreatedStream(DiskStreamRef.OrderID); - if (!DiskStreamRef.pStream) { - std::cout << stderr << "Disk stream not available in time!" << std::endl << std::flush; - KillImmediately(); - return; - } - DiskStreamRef.pStream->IncrementReadPos(pSample->Channels * (int(finalSynthesisParameters.dPos) - MaxRAMPos)); - finalSynthesisParameters.dPos -= int(finalSynthesisParameters.dPos); - RealSampleWordsLeftToRead = -1; // -1 means no silence has been added yet - } - - const int sampleWordsLeftToRead = DiskStreamRef.pStream->GetReadSpace(); - - // add silence sample at the end if we reached the end of the stream (for the interpolator) - if (DiskStreamRef.State == Stream::state_end) { - const int maxSampleWordsPerCycle = (pEngine->MaxSamplesPerCycle << CONFIG_MAX_PITCH) * pSample->Channels + 6; // +6 for the interpolator algorithm - if (sampleWordsLeftToRead <= maxSampleWordsPerCycle) { - // remember how many sample words there are before any silence has been added - if (RealSampleWordsLeftToRead < 0) RealSampleWordsLeftToRead = sampleWordsLeftToRead; - DiskStreamRef.pStream->WriteSilence(maxSampleWordsPerCycle - sampleWordsLeftToRead); - } - } - - sample_t* ptr = (sample_t*)DiskStreamRef.pStream->GetReadPtr(); // get the current read_ptr within the ringbuffer where we read the samples from - - // render current audio fragment - Synthesize(Samples, ptr, Delay); - - const int iPos = (int) finalSynthesisParameters.dPos; - const int readSampleWords = iPos * pSample->Channels; // amount of sample words actually been read - DiskStreamRef.pStream->IncrementReadPos(readSampleWords); - finalSynthesisParameters.dPos -= iPos; // just keep fractional part of playback position - - // change state of voice to 'end' if we really reached the end of the sample data - if (RealSampleWordsLeftToRead >= 0) { - RealSampleWordsLeftToRead -= readSampleWords; - if (RealSampleWordsLeftToRead <= 0) this->PlaybackState = playback_state_end; - } - } - break; - - case playback_state_end: - std::cerr << "gig::Voice::Render(): entered with playback_state_end, this is a bug!\n" << std::flush; + uint8_t Voice::GetVCFCutoffCtrl() { + uint8_t ctrl; + switch (pRegion->VCFCutoffController) { + case ::gig::vcf_cutoff_ctrl_modwheel: + ctrl = 1; + break; + case ::gig::vcf_cutoff_ctrl_effect1: + ctrl = 12; + break; + case ::gig::vcf_cutoff_ctrl_effect2: + ctrl = 13; + break; + case ::gig::vcf_cutoff_ctrl_breath: + ctrl = 2; + break; + case ::gig::vcf_cutoff_ctrl_foot: + ctrl = 4; + break; + case ::gig::vcf_cutoff_ctrl_sustainpedal: + ctrl = 64; + break; + case ::gig::vcf_cutoff_ctrl_softpedal: + ctrl = 67; + break; + case ::gig::vcf_cutoff_ctrl_genpurpose7: + ctrl = 82; + break; + case ::gig::vcf_cutoff_ctrl_genpurpose8: + ctrl = 83; + break; + case ::gig::vcf_cutoff_ctrl_aftertouch: + ctrl = 128; + break; + case ::gig::vcf_cutoff_ctrl_none: + default: + ctrl = 0; break; } - // Reset delay - Delay = 0; - - itTriggerEvent = Pool<Event>::Iterator(); - - // If sample stream or release stage finished, kill the voice - if (PlaybackState == playback_state_end || EG1.getSegmentType() == EGADSR::segment_end) KillImmediately(); + return ctrl; } - /** - * Resets voice variables. Should only be called if rendering process is - * suspended / not running. - */ - void Voice::Reset() { - finalSynthesisParameters.filterLeft.Reset(); - finalSynthesisParameters.filterRight.Reset(); - DiskStreamRef.pStream = NULL; - DiskStreamRef.hStream = 0; - DiskStreamRef.State = Stream::state_unused; - DiskStreamRef.OrderID = 0; - PlaybackState = playback_state_end; - itTriggerEvent = Pool<Event>::Iterator(); - itKillEvent = Pool<Event>::Iterator(); - } - - /** - * Process given list of MIDI note on, note off and sustain pedal events - * for the given time. - * - * @param itEvent - iterator pointing to the next event to be processed - * @param End - youngest time stamp where processing should be stopped - */ - void Voice::processTransitionEvents(RTList<Event>::Iterator& itEvent, uint End) { - for (; itEvent && itEvent->FragmentPos() <= End; ++itEvent) { - if (itEvent->Type == Event::type_release) { - EG1.update(EGADSR::event_release, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - EG2.update(EGADSR::event_release, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } else if (itEvent->Type == Event::type_cancel_release) { - EG1.update(EGADSR::event_cancel_release, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - EG2.update(EGADSR::event_cancel_release, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } - } - } - - /** - * Process given list of MIDI control change and pitch bend events for - * the given time. - * - * @param itEvent - iterator pointing to the next event to be processed - * @param End - youngest time stamp where processing should be stopped - */ - void Voice::processCCEvents(RTList<Event>::Iterator& itEvent, uint End) { - for (; itEvent && itEvent->FragmentPos() <= End; ++itEvent) { - if (itEvent->Type == Event::type_control_change && - itEvent->Param.CC.Controller) { // if (valid) MIDI control change event - if (itEvent->Param.CC.Controller == VCFCutoffCtrl.controller) { - processCutoffEvent(itEvent); - } - if (itEvent->Param.CC.Controller == VCFResonanceCtrl.controller) { - processResonanceEvent(itEvent); - } - if (itEvent->Param.CC.Controller == pLFO1->ExtController) { - pLFO1->update(itEvent->Param.CC.Value); - } - if (itEvent->Param.CC.Controller == pLFO2->ExtController) { - pLFO2->update(itEvent->Param.CC.Value); - } - if (itEvent->Param.CC.Controller == pLFO3->ExtController) { - pLFO3->update(itEvent->Param.CC.Value); - } - if (pDimRgn->AttenuationController.type == ::gig::attenuation_ctrl_t::type_controlchange && - itEvent->Param.CC.Controller == pDimRgn->AttenuationController.controller_number) { - CrossfadeSmoother.update(Engine::CrossfadeCurveCrossfadeAttenuation(itEvent->Param.CC.Value)); - } - if (itEvent->Param.CC.Controller == 7) { // volume - VolumeSmoother.update(Engine::VolumeCurveitEvent->Param.CC.Value); - } else if (itEvent->Param.CC.Controller == 10) { // panpot - PanLeftSmoother.update(Engine::PanCurve128 - itEvent->Param.CC.Value); - PanRightSmoother.update(Engine::PanCurveitEvent->Param.CC.Value); - } - } else if (itEvent->Type == Event::type_pitchbend) { // if pitch bend event - processPitchEvent(itEvent); - } + uint8_t Voice::GetVCFResonanceCtrl() { + uint8_t ctrl; + switch (pRegion->VCFResonanceController) { + case ::gig::vcf_res_ctrl_genpurpose3: + ctrl = 18; + break; + case ::gig::vcf_res_ctrl_genpurpose4: + ctrl = 19; + break; + case ::gig::vcf_res_ctrl_genpurpose5: + ctrl = 80; + break; + case ::gig::vcf_res_ctrl_genpurpose6: + ctrl = 81; + break; + case ::gig::vcf_res_ctrl_none: + default: + ctrl = 0; } - } - void Voice::processPitchEvent(RTList<Event>::Iterator& itEvent) { - PitchBend = RTMath::CentsToFreqRatio(itEvent->Param.Pitch.Pitch * PitchBendRange); + return ctrl; } - void Voice::processCutoffEvent(RTList<Event>::Iterator& itEvent) { - int ccvalue = itEvent->Param.CC.Value; - if (VCFCutoffCtrl.value == ccvalue) return; - VCFCutoffCtrl.value == ccvalue; - if (pDimRgn->VCFCutoffControllerInvert) ccvalue = 127 - ccvalue; - if (ccvalue < pDimRgn->VCFVelocityScale) ccvalue = pDimRgn->VCFVelocityScale; - float cutoff = CutoffBase * float(ccvalue); - if (cutoff > 127.0f) cutoff = 127.0f; - - VCFCutoffCtrl.fvalue = cutoff; // needed for initialization of fFinalCutoff next time - fFinalCutoff = cutoff; + void Voice::TriggerEG1(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { + EG1.trigger(pRegion->EG1PreAttack, + pRegion->EG1Attack * egInfo.Attack, + pRegion->EG1Hold, + pRegion->EG1Decay1 * egInfo.Decay * velrelease, + pRegion->EG1Decay2 * egInfo.Decay * velrelease, + pRegion->EG1InfiniteSustain, + pRegion->EG1Sustain, + pRegion->EG1Release * egInfo.Release * velrelease, + velocityAttenuation, + sampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); } - void Voice::processResonanceEvent(RTList<Event>::Iterator& itEvent) { - // convert absolute controller value to differential - const int ctrldelta = itEvent->Param.CC.Value - VCFResonanceCtrl.value; - VCFResonanceCtrl.value = itEvent->Param.CC.Value; - const float resonancedelta = (float) ctrldelta; - fFinalResonance += resonancedelta; - // needed for initialization of parameter - VCFResonanceCtrl.fvalue = itEvent->Param.CC.Value; + void Voice::TriggerEG2(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { + EG2.trigger(uint(RgnInfo.EG2PreAttack), + RgnInfo.EG2Attack * egInfo.Attack, + false, + RgnInfo.EG2Decay1 * egInfo.Decay * velrelease, + RgnInfo.EG2Decay2 * egInfo.Decay * velrelease, + RgnInfo.EG2InfiniteSustain, + uint(RgnInfo.EG2Sustain), + RgnInfo.EG2Release * egInfo.Release * velrelease, + velocityAttenuation, + sampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); } - /** - * Synthesizes the current audio fragment for this voice. - * - * @param Samples - number of sample points to be rendered in this audio - * fragment cycle - * @param pSrc - pointer to input sample data - * @param Skip - number of sample points to skip in output buffer - */ - void Voice::Synthesize(uint Samples, sample_t* pSrc, uint Skip) { - finalSynthesisParameters.pOutLeft = &pEngineChannel->pChannelLeft->Buffer()Skip; - finalSynthesisParameters.pOutRight = &pEngineChannel->pChannelRight->Buffer()Skip; - finalSynthesisParameters.pSrc = pSrc; - - RTList<Event>::Iterator itCCEvent = pEngineChannel->pEvents->first(); - RTList<Event>::Iterator itNoteEvent = pEngineChannel->pMIDIKeyInfoMIDIKey.pEvents->first(); - - if (itTriggerEvent) { // skip events that happened before this voice was triggered - while (itCCEvent && itCCEvent->FragmentPos() <= Skip) ++itCCEvent; - // we can't simply compare the timestamp here, because note events - // might happen on the same time stamp, so we have to deal on the - // actual sequence the note events arrived instead (see bug #112) - for (; itNoteEvent; ++itNoteEvent) { - if (itTriggerEvent == itNoteEvent) { - ++itNoteEvent; - break; - } - } - } - - uint killPos; - if (itKillEvent) { - int maxFadeOutPos = Samples - pEngine->MinFadeOutSamples; - if (maxFadeOutPos < 0) { - // There's not enough space in buffer to do a fade out - // from max volume (this can only happen for audio - // drivers that use Samples < MaxSamplesPerCycle). - // End the EG1 here, at pos 0, with a shorter max fade - // out time. - EG1.enterFadeOutStage(Samples / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - itKillEvent = Pool<Event>::Iterator(); - } else { - killPos = RTMath::Min(itKillEvent->FragmentPos(), maxFadeOutPos); - } - } - - uint i = Skip; - while (i < Samples) { - int iSubFragmentEnd = RTMath::Min(i + CONFIG_DEFAULT_SUBFRAGMENT_SIZE, Samples); - - // initialize all final synthesis parameters - fFinalCutoff = VCFCutoffCtrl.fvalue; - fFinalResonance = VCFResonanceCtrl.fvalue; - - // process MIDI control change and pitchbend events for this subfragment - processCCEvents(itCCEvent, iSubFragmentEnd); - - finalSynthesisParameters.fFinalPitch = PitchBase * PitchBend; - float fFinalVolume = VolumeSmoother.render() * CrossfadeSmoother.render(); -#ifdef CONFIG_PROCESS_MUTED_CHANNELS - if (pEngineChannel->GetMute()) fFinalVolume = 0; -#endif - - // process transition events (note on, note off & sustain pedal) - processTransitionEvents(itNoteEvent, iSubFragmentEnd); - - // if the voice was killed in this subfragment, or if the - // filter EG is finished, switch EG1 to fade out stage - if ((itKillEvent && killPos <= iSubFragmentEnd) || - (SYNTHESIS_MODE_GET_FILTER(SynthesisMode) && - EG2.getSegmentType() == EGADSR::segment_end)) { - EG1.enterFadeOutStage(); - itKillEvent = Pool<Event>::Iterator(); - } - - // process envelope generators - switch (EG1.getSegmentType()) { - case EGADSR::segment_lin: - fFinalVolume *= EG1.processLin(); - break; - case EGADSR::segment_exp: - fFinalVolume *= EG1.processExp(); - break; - case EGADSR::segment_end: - fFinalVolume *= EG1.getLevel(); - break; // noop - } - switch (EG2.getSegmentType()) { - case EGADSR::segment_lin: - fFinalCutoff *= EG2.processLin(); - break; - case EGADSR::segment_exp: - fFinalCutoff *= EG2.processExp(); - break; - case EGADSR::segment_end: - fFinalCutoff *= EG2.getLevel(); - break; // noop - } - if (EG3.active()) finalSynthesisParameters.fFinalPitch *= EG3.render(); - - // process low frequency oscillators - if (bLFO1Enabled) fFinalVolume *= (1.0f - pLFO1->render()); - if (bLFO2Enabled) fFinalCutoff *= pLFO2->render(); - if (bLFO3Enabled) finalSynthesisParameters.fFinalPitch *= RTMath::CentsToFreqRatio(pLFO3->render()); - - // limit the pitch so we don't read outside the buffer - finalSynthesisParameters.fFinalPitch = RTMath::Min(finalSynthesisParameters.fFinalPitch, float(1 << CONFIG_MAX_PITCH)); + void Voice::ProcessGroupEvent(RTList<Event>::Iterator& itEvent) { + dmsg(4,("Voice %x processGroupEvents event type=%d", this, itEvent->Type)); - // if filter enabled then update filter coefficients - if (SYNTHESIS_MODE_GET_FILTER(SynthesisMode)) { - finalSynthesisParameters.filterLeft.SetParameters(fFinalCutoff, fFinalResonance, pEngine->SampleRate); - finalSynthesisParameters.filterRight.SetParameters(fFinalCutoff, fFinalResonance, pEngine->SampleRate); - } - - // do we need resampling? - const float __PLUS_ONE_CENT = 1.000577789506554859250142541782224725466f; - const float __MINUS_ONE_CENT = 0.9994225441413807496009516495583113737666f; - const bool bResamplingRequired = !(finalSynthesisParameters.fFinalPitch <= __PLUS_ONE_CENT && - finalSynthesisParameters.fFinalPitch >= __MINUS_ONE_CENT); - SYNTHESIS_MODE_SET_INTERPOLATE(SynthesisMode, bResamplingRequired); - - // prepare final synthesis parameters structure - finalSynthesisParameters.uiToGo = iSubFragmentEnd - i; -#ifdef CONFIG_INTERPOLATE_VOLUME - finalSynthesisParameters.fFinalVolumeDeltaLeft = - (fFinalVolume * VolumeLeft * PanLeftSmoother.render() - - finalSynthesisParameters.fFinalVolumeLeft) / finalSynthesisParameters.uiToGo; - finalSynthesisParameters.fFinalVolumeDeltaRight = - (fFinalVolume * VolumeRight * PanRightSmoother.render() - - finalSynthesisParameters.fFinalVolumeRight) / finalSynthesisParameters.uiToGo; -#else - finalSynthesisParameters.fFinalVolumeLeft = - fFinalVolume * VolumeLeft * PanLeftSmoother.render(); - finalSynthesisParameters.fFinalVolumeRight = - fFinalVolume * VolumeRight * PanRightSmoother.render(); -#endif - // render audio for one subfragment - RunSynthesisFunction(SynthesisMode, &finalSynthesisParameters, &loop); - - // stop the rendering if volume EG is finished - if (EG1.getSegmentType() == EGADSR::segment_end) break; - - const double newPos = Pos + (iSubFragmentEnd - i) * finalSynthesisParameters.fFinalPitch; - - // increment envelopes' positions - if (EG1.active()) { - - // if sample has a loop and loop start has been reached in this subfragment, send a special event to EG1 to let it finish the attack hold stage - if (pDimRgn->SampleLoops && Pos <= pDimRgn->pSampleLoops0.LoopStart && pDimRgn->pSampleLoops0.LoopStart < newPos) { - EG1.update(EGADSR::event_hold_end, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } - - EG1.increment(1); - if (!EG1.toStageEndLeft()) EG1.update(EGADSR::event_stage_end, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } - if (EG2.active()) { - EG2.increment(1); - if (!EG2.toStageEndLeft()) EG2.update(EGADSR::event_stage_end, pEngine->SampleRate / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); - } - EG3.increment(1); - if (!EG3.toEndLeft()) EG3.update(); // neutralize envelope coefficient if end reached - - Pos = newPos; - i = iSubFragmentEnd; - } - } - - /** @brief Update current portamento position. - * - * Will be called when portamento mode is enabled to get the final - * portamento position of this active voice from where the next voice(s) - * might continue to slide on. - * - * @param itNoteOffEvent - event which causes this voice to die soon - */ - void Voice::UpdatePortamentoPos(Pool<Event>::Iterator& itNoteOffEvent) { - const float fFinalEG3Level = EG3.level(itNoteOffEvent->FragmentPos()); - pEngineChannel->PortamentoPos = (float) MIDIKey + RTMath::FreqRatioToCents(fFinalEG3Level) * 0.01f; - } + // TODO: The SustainPedal condition could be wrong, maybe the + // check should be if this Voice is in release stage or is a + // release sample instead. Need to test this in GSt. + if (itEvent->Param.Note.Key != MIDIKey || + !GetGigEngineChannel()->SustainPedal) { + dmsg(4,("Voice %x - kill", this)); - /** - * Immediately kill the voice. This method should not be used to kill - * a normal, active voice, because it doesn't take care of things like - * fading down the volume level to avoid clicks and regular processing - * until the kill event actually occured! - * - * If it's necessary to know when the voice's disk stream was actually - * deleted, then one can set the optional @a bRequestNotification - * parameter and this method will then return the handle of the disk - * stream (unique identifier) and one can use this handle to poll the - * disk thread if this stream has been deleted. In any case this method - * will return immediately and will not block until the stream actually - * was deleted. - * - * @param bRequestNotification - (optional) whether the disk thread shall - * provide a notification once it deleted - * the respective disk stream - * (default=false) - * @returns handle to the voice's disk stream or @c Stream::INVALID_HANDLE - * if the voice did not use a disk stream at all - * @see Kill() - */ - Stream::Handle Voice::KillImmediately(bool bRequestNotification) { - Stream::Handle hStream = Stream::INVALID_HANDLE; - if (DiskVoice && DiskStreamRef.State != Stream::state_unused) { - pDiskThread->OrderDeletionOfStream(&DiskStreamRef, bRequestNotification); - hStream = DiskStreamRef.hStream; + // kill the voice fast + pEG1->enterFadeOutStage(); } - Reset(); - return hStream; } - /** - * Kill the voice in regular sense. Let the voice render audio until - * the kill event actually occured and then fade down the volume level - * very quickly and let the voice die finally. Unlike a normal release - * of a voice, a kill process cannot be cancalled and is therefore - * usually used for voice stealing and key group conflicts. - * - * @param itKillEvent - event which caused the voice to be killed - */ - void Voice::Kill(Pool<Event>::Iterator& itKillEvent) { - #if CONFIG_DEVMODE - if (!itKillEvent) dmsg(1,("gig::Voice::Kill(): ERROR, !itKillEvent !!!\n")); - if (itKillEvent && !itKillEvent.isValid()) dmsg(1,("gig::Voice::Kill(): ERROR, itKillEvent invalid !!!\n")); - #endif // CONFIG_DEVMODE - - if (itTriggerEvent && itKillEvent->FragmentPos() <= itTriggerEvent->FragmentPos()) return; - this->itKillEvent = itKillEvent; + void Voice::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + EG1.CalculateFadeOutCoeff(FadeOutTime, SampleRate); } }} // namespace LinuxSampler::gig
View file
linuxsampler-1.0.0.tar.bz2/src/engines/gig/Voice.h -> linuxsampler-2342.tar.bz2/src/engines/gig/Voice.h
Changed
@@ -3,7 +3,8 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2007 Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * * * * 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 * @@ -31,177 +32,86 @@ #include "../../common/RTMath.h" #include "../../common/Pool.h" #include "../../drivers/audio/AudioOutputDevice.h" -#include "Engine.h" -#include "EngineChannel.h" #include "Stream.h" #include "DiskThread.h" #include "EGADSR.h" #include "EGDecay.h" #include "Filter.h" -#include "../common/LFOBase.h" +#include "../common/VoiceBase.h" #include "SynthesisParam.h" #include "SmoothVolume.h" -// include the appropriate (unsigned) triangle LFO implementation -#if CONFIG_UNSIGNED_TRIANG_ALGO == INT_MATH_SOLUTION -# include "../common/LFOTriangleIntMath.h" -#elif CONFIG_UNSIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION -# include "../common/LFOTriangleIntAbsMath.h" -#elif CONFIG_UNSIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION -# include "../common/LFOTriangleDiHarmonic.h" -#else -# error "Unknown or no (unsigned) triangle LFO implementation selected!" -#endif - -// include the appropriate (signed) triangle LFO implementation -#if CONFIG_SIGNED_TRIANG_ALGO == INT_MATH_SOLUTION -# include "../common/LFOTriangleIntMath.h" -#elif CONFIG_SIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION -# include "../common/LFOTriangleIntAbsMath.h" -#elif CONFIG_SIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION -# include "../common/LFOTriangleDiHarmonic.h" -#else -# error "Unknown or no (signed) triangle LFO implementation selected!" -#endif - namespace LinuxSampler { namespace gig { - class Engine; - - /// Reflects a MIDI controller - struct midi_ctrl { - uint8_t controller; ///< MIDI control change controller number - uint8_t value; ///< Current MIDI controller value - float fvalue; ///< Transformed / effective value (e.g. volume level or filter cutoff frequency) - }; - - #if CONFIG_UNSIGNED_TRIANG_ALGO == INT_MATH_SOLUTION - typedef LFOTriangleIntMath<range_unsigned> LFOUnsigned; - #elif CONFIG_UNSIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION - typedef LFOTriangleIntAbsMath<range_unsigned> LFOUnsigned; - #elif CONFIG_UNSIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION - typedef LFOTriangleDiHarmonic<range_unsigned> LFOUnsigned; - #endif - - #if CONFIG_SIGNED_TRIANG_ALGO == INT_MATH_SOLUTION - typedef LFOTriangleIntMath<range_signed> LFOSigned; - #elif CONFIG_SIGNED_TRIANG_ALGO == INT_ABS_MATH_SOLUTION - typedef LFOTriangleIntAbsMath<range_signed> LFOSigned; - #elif CONFIG_SIGNED_TRIANG_ALGO == DI_HARMONIC_SOLUTION - typedef LFOTriangleDiHarmonic<range_signed> LFOSigned; - #endif + class EngineChannel; /** Gig Voice * * Renders a voice for the Gigasampler format. */ - class Voice { + class Voice : public LinuxSampler::VoiceBase<EngineChannel, ::gig::DimensionRegion, ::gig::Sample, DiskThread> { public: - // Types - enum type_t { - type_normal, - type_release_trigger_required, ///< If the key of this voice will be released, it causes a release triggered voice to be spawned - type_release_trigger ///< Release triggered voice which cannot be killed by releasing its key - }; - - // Attributes - type_t Type; ///< Voice Type - int MIDIKey; ///< MIDI key number of the key that triggered the voice - uint KeyGroup; - DiskThread* pDiskThread; ///< Pointer to the disk thread, to be able to order a disk stream and later to delete the stream again - - // Methods Voice(); virtual ~Voice(); - void Kill(Pool<Event>::Iterator& itKillEvent); - void Render(uint Samples); - void Reset(); void SetOutput(AudioOutputDevice* pAudioOutputDevice); - void SetEngine(Engine* pEngine); - int Trigger(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int PitchBend, ::gig::DimensionRegion* pDimRgn, type_t VoiceType, int iKeyGroup); - inline bool IsActive() { return PlaybackState; } - inline bool IsStealable() { return !itKillEvent && PlaybackState >= playback_state_ram; } - void UpdatePortamentoPos(Pool<Event>::Iterator& itNoteOffEvent); - - //private: - // Types - enum playback_state_t { - playback_state_end = 0, - playback_state_init = 1, - playback_state_ram = 2, - playback_state_disk = 3 - }; - + void SetEngine(LinuxSampler::Engine* pEngine); + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + protected: + virtual SampleInfo GetSampleInfo(); + virtual RegionInfo GetRegionInfo(); + virtual InstrumentInfo GetInstrumentInfo(); + virtual double CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity); + virtual AbstractEngine* GetEngine() { return (AbstractEngine*)pEngine; } + virtual double GetEG1ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG1ControllerInfluence(double eg1ControllerValue); + virtual void TriggerEG1(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity); + virtual double GetEG2ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG2ControllerInfluence(double eg2ControllerValue); + virtual void TriggerEG2(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity); + virtual void InitLFO1(); + virtual void InitLFO2(); + virtual void InitLFO3(); + virtual float CalculateCutoffBase(uint8_t MIDIKeyVelocity); + virtual float CalculateFinalCutoff(float cutoffBase); + virtual uint8_t GetVCFCutoffCtrl(); + virtual uint8_t GetVCFResonanceCtrl(); + virtual void ProcessCCEvent(RTList<Event>::Iterator& itEvent); + virtual void ProcessCutoffEvent(RTList<Event>::Iterator& itEvent); + virtual double GetVelocityAttenuation(uint8_t MIDIKeyVelocity); + virtual double GetVelocityRelease(uint8_t MIDIKeyVelocity); + virtual double GetSampleAttenuation(); + virtual void ProcessGroupEvent(RTList<Event>::Iterator& itEvent); + + private: + EGADSR EG1; + EGADSR EG2; + + public: // FIXME: just made public for debugging (sanity check in Engine::RenderAudio()), should be changed to private before the final release // Attributes - EngineChannel* pEngineChannel; Engine* pEngine; ///< Pointer to the sampler engine, to be able to access the event lists. - float VolumeLeft; ///< Left channel volume. This factor is calculated when the voice is triggered and doesn't change after that. - float VolumeRight; ///< Right channel volume. This factor is calculated when the voice is triggered and doesn't change after that. - SmoothVolume CrossfadeSmoother; ///< Crossfade volume, updated by crossfade CC events - SmoothVolume VolumeSmoother; ///< Volume, updated by CC 7 (volume) events - SmoothVolume PanLeftSmoother; ///< Left channel volume, updated by CC 10 (pan) events - SmoothVolume PanRightSmoother; ///< Right channel volume, updated by CC 10 (pan) events - double Pos; ///< Current playback position in sample - float PitchBase; ///< Basic pitch depth, stays the same for the whole life time of the voice - float PitchBend; ///< Current pitch value of the pitchbend wheel - float PitchBendRange; ///< The pitch range of the pitchbend wheel, value is in cents / 8192 - float CutoffBase; ///< Cutoff frequency before control change, EG and LFO are applied - ::gig::Sample* pSample; ///< Pointer to the sample to be played back - ::gig::DimensionRegion* pDimRgn; ///< Pointer to the articulation information of current dimension region of this voice - bool Orphan; ///< true if this voice is playing a sample from an instrument that is unloaded. When the voice dies, the sample (and dimension region) will be handed back to the instrument resource manager. - playback_state_t PlaybackState; ///< When a sample will be triggered, it will be first played from RAM cache and after a couple of sample points it will switch to disk streaming and at the end of a disk stream we have to add null samples, so the interpolator can do it's work correctly - bool DiskVoice; ///< If the sample is very short it completely fits into the RAM cache and doesn't need to be streamed from disk, in that case this flag is set to false - Stream::reference_t DiskStreamRef; ///< Reference / link to the disk stream - int RealSampleWordsLeftToRead; ///< Number of samples left to read, not including the silence added for the interpolator - unsigned long MaxRAMPos; ///< The upper allowed limit (not actually the end) in the RAM sample cache, after that point it's not safe to chase the interpolator another time over over the current cache position, instead we switch to disk then. - bool RAMLoop; ///< If this voice has a loop defined which completely fits into the cached RAM part of the sample, in this case we handle the looping within the voice class, else if the loop is located in the disk stream part, we let the disk stream handle the looping //uint LoopCyclesLeft; ///< In case there is a RAMLoop and it's not an endless loop; reflects number of loop cycles left to be passed - uint Delay; ///< Number of sample points the rendering process of this voice should be delayed (jitter correction), will be set to 0 after the first audio fragment cycle - EGADSR EG1; ///< Envelope Generator 1 (Amplification) - EGADSR EG2; ///< Envelope Generator 2 (Filter cutoff frequency) - EGDecay EG3; ///< Envelope Generator 3 (Pitch) - midi_ctrl VCFCutoffCtrl; - midi_ctrl VCFResonanceCtrl; - LFOUnsigned* pLFO1; ///< Low Frequency Oscillator 1 (Amplification) - LFOUnsigned* pLFO2; ///< Low Frequency Oscillator 2 (Filter cutoff frequency) - LFOSigned* pLFO3; ///< Low Frequency Oscillator 3 (Pitch) - bool bLFO1Enabled; ///< Should we use the Amplitude LFO for this voice? - bool bLFO2Enabled; ///< Should we use the Filter Cutoff LFO for this voice? - bool bLFO3Enabled; ///< Should we use the Pitch LFO for this voice? - Pool<Event>::Iterator itTriggerEvent; ///< First event on the key's list the voice should process (only needed for the first audio fragment in which voice was triggered, after that it will be set to NULL). - //public: // FIXME: just made public for debugging (sanity check in Engine::RenderAudio()), should be changed to private before the final release - Pool<Event>::Iterator itKillEvent; ///< Event which caused this voice to be killed - //private: - int SynthesisMode; - float fFinalCutoff; - float fFinalResonance; - SynthesisParam finalSynthesisParameters; - Loop loop; // Static Methods static float CalculateFilterCutoffCoeff(); // Methods - Stream::Handle KillImmediately(bool bRequestNotification = false); void ProcessEvents(uint Samples); - void Synthesize(uint Samples, sample_t* pSrc, uint Skip); - void processTransitionEvents(RTList<Event>::Iterator& itEvent, uint End); - void processCCEvents(RTList<Event>::Iterator& itEvent, uint End); - void processPitchEvent(RTList<Event>::Iterator& itEvent); void processCrossFadeEvent(RTList<Event>::Iterator& itEvent); - void processCutoffEvent(RTList<Event>::Iterator& itEvent); - void processResonanceEvent(RTList<Event>::Iterator& itEvent); - - inline uint8_t CrossfadeAttenuation(uint8_t& CrossfadeControllerValue) { - uint8_t c = std::max(CrossfadeControllerValue, pDimRgn->AttenuationControllerThreshold); - c = (!pDimRgn->Crossfade.out_end) ? c /* 0,0,0,0 means no crossfade defined */ - : (c < pDimRgn->Crossfade.in_end) ? - ((c <= pDimRgn->Crossfade.in_start) ? 0 - : 127 * (c - pDimRgn->Crossfade.in_start) / (pDimRgn->Crossfade.in_end - pDimRgn->Crossfade.in_start)) - : (c <= pDimRgn->Crossfade.out_start) ? 127 - : (c < pDimRgn->Crossfade.out_end) ? 127 * (pDimRgn->Crossfade.out_end - c) / (pDimRgn->Crossfade.out_end - pDimRgn->Crossfade.out_start) + + EngineChannel* GetGigEngineChannel(); + + protected: + virtual uint8_t CrossfadeAttenuation(uint8_t& CrossfadeControllerValue) { + uint8_t c = std::max(CrossfadeControllerValue, pRegion->AttenuationControllerThreshold); + c = (!pRegion->Crossfade.out_end) ? c /* 0,0,0,0 means no crossfade defined */ + : (c < pRegion->Crossfade.in_end) ? + ((c <= pRegion->Crossfade.in_start) ? 0 + : 127 * (c - pRegion->Crossfade.in_start) / (pRegion->Crossfade.in_end - pRegion->Crossfade.in_start)) + : (c <= pRegion->Crossfade.out_start) ? 127 + : (c < pRegion->Crossfade.out_end) ? 127 * (pRegion->Crossfade.out_end - c) / (pRegion->Crossfade.out_end - pRegion->Crossfade.out_start) : 0; - return pDimRgn->InvertAttenuationController ? 127 - c : c; + return pRegion->InvertAttenuationController ? 127 - c : c; } inline float Constrain(float ValueToCheck, float Min, float Max) {
View file
linuxsampler-2342.tar.bz2/src/engines/sf2
Added
+(directory)
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/DiskThread.cpp
Added
@@ -0,0 +1,63 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "DiskThread.h" +#include "Stream.h" +#include "../../common/global_private.h" + +namespace LinuxSampler { + // just a placeholder to mark a cell in the pickup array as 'reserved' + template <> + LinuxSampler::Stream* LinuxSampler::DiskThreadBase< ::sf2::Region, sf2::InstrumentResourceManager>::SLOT_RESERVED = (LinuxSampler::Stream*) &SLOT_RESERVED; + +namespace sf2 { + + DiskThread::DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments) : + DiskThreadBase< ::sf2::Region, InstrumentResourceManager>(MaxStreams, BufferWrapElements, pInstruments) + { + CreateAllStreams(MaxStreams, BufferWrapElements); + } + + DiskThread::~DiskThread() { + + } + + LinuxSampler::Stream* DiskThread::CreateStream(long BufferSize, uint BufferWrapElements) { + return new Stream(BufferSize, BufferWrapElements); // 131072 sample words + } + + void DiskThread::LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::sf2::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + Stream* pSf2Stream = dynamic_cast<Stream*>(pStream); + if(!pSf2Stream) throw Exception("Invalid stream type"); + pSf2Stream->Launch(hStream, pExportReference, pRgn, SampleOffset, DoLoop); + } +}} // namespace LinuxSampler::sf2 +
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/DiskThread.h
Added
@@ -0,0 +1,56 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_DISKTHREAD_H__ +#define __LS_SF2_DISKTHREAD_H__ + +#include "../InstrumentManagerBase.h" +#include "../common/DiskThreadBase.h" +#include "InstrumentResourceManager.h" + +namespace LinuxSampler { namespace sf2 { + + class DiskThread: public LinuxSampler::DiskThreadBase< ::sf2::Region, InstrumentResourceManager> { + protected: + virtual LinuxSampler::Stream* CreateStream(long BufferSize, uint BufferWrapElements); + + virtual void LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::sf2::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); + + public: + DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments); + virtual ~DiskThread(); + }; + + +}} // namespace LinuxSampler::sf2 + +#endif /* __LS_SF2_STREAM_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Engine.cpp
Added
@@ -0,0 +1,164 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2010 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "Engine.h" +#include "EngineChannel.h" + +namespace LinuxSampler { namespace sf2 { + Engine::Format Engine::GetEngineFormat() { return SF2; } + + /** + * Reacts on supported control change commands (e.g. pitch bend wheel, + * modulation wheel, aftertouch). + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itControlChangeEvent - controller, value and time stamp of the event + */ + void Engine::ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ) { + dmsg(4,("Engine::ContinuousController cc=%d v=%d\n", itControlChangeEvent->Param.CC.Controller, itControlChangeEvent->Param.CC.Value)); + + EngineChannel* pChannel = dynamic_cast<EngineChannel*>(pEngineChannel); + // handle the "control triggered" MIDI rule: a control change + // event can trigger a new note on or note off event + if (pChannel->pInstrument) { + + // TODO: + } + + // update controller value in the engine channel's controller table + pChannel->ControllerTableitControlChangeEvent->Param.CC.Controller = itControlChangeEvent->Param.CC.Value; + + ProcessHardcodedControllers(pEngineChannel, itControlChangeEvent); + + // handle FX send controllers + ProcessFxSendControllers(pChannel, itControlChangeEvent); + } + + DiskThread* Engine::CreateDiskThread() { + return new DiskThread ( + iMaxDiskStreams, + ((pAudioOutputDevice->MaxSamplesPerCycle() << CONFIG_MAX_PITCH) << 1) + 6, //FIXME: assuming stereo + &instruments + ); + } + + void Engine::TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + + uint8_t chan = pChannel->MidiChannel(); + int key = itNoteOnEvent->Param.Note.Key; + uint8_t vel = itNoteOnEvent->Param.Note.Velocity; + int bend = pChannel->Pitch; + uint8_t chanaft = pChannel->ControllerTable128; + uint8_t* cc = pChannel->ControllerTable; + + int layer = 0; + ::sf2::Query query(*pChannel->pInstrument); + query.key = key; + query.vel = vel; + while (::sf2::Region* region = query.next()) { + // TODO: Generators in the PGEN sub-chunk are applied relative to generators in the IGEN sub-chunk in an additive manner. In + // other words, PGEN generators increase or decrease the value of an IGEN generator. + ::sf2::Query subQuery(*region->pInstrument); + subQuery.key = key; + subQuery.vel = vel; + while (::sf2::Region* r = subQuery.next()) { + //std::cout << r->GetSample()->GetName(); + //std::cout << " loKey: " << r->loKey << " hiKey: " << r->hiKey << " minVel: " << r->minVel << " maxVel: " << r->maxVel << " Vel: " << ((int)vel) << std::endl << std::endl; + if (!RegionSuspended(r)) { + itNoteOnEvent->Param.Note.pRegion = r; + LaunchVoice(pChannel, itNoteOnEvent, layer, false, true, HandleKeyGroupConflicts); + } + layer++; + } + } + } + + void Engine::TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ) { + + } + + Pool<Voice>::Iterator Engine::LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + int key = itNoteOnEvent->Param.Note.Key; + EngineChannel::MidiKey* pKey = &pChannel->pMIDIKeyInfokey; + + Voice::type_t VoiceType = Voice::type_normal; + + Pool<Voice>::Iterator itNewVoice; + ::sf2::Region* pRgn = static_cast< ::sf2::Region*>(itNoteOnEvent->Param.Note.pRegion); + + // no need to process if sample is silent + if (!pRgn->GetSample() || !pRgn->GetSample()->GetTotalFrameCount()) return Pool<Voice>::Iterator(); + + int iKeyGroup = pRgn->exclusiveClass; + if (HandleKeyGroupConflicts) pChannel->HandleKeyGroupConflicts(iKeyGroup, itNoteOnEvent); + + // allocate a new voice for the key + itNewVoice = pKey->pActiveVoices->allocAppend(); + int res = InitNewVoice ( + pChannel, pRgn, itNoteOnEvent, VoiceType, iLayer, + iKeyGroup, ReleaseTriggerVoice, VoiceStealing, itNewVoice + ); + if (!res) return itNewVoice; + + // return if this is a release triggered voice and there is no + // releasetrigger dimension (could happen if an instrument + // change has occured between note on and off) + //if (ReleaseTriggerVoice && VoiceType != Voice::type_release_trigger) return Pool<Voice>::Iterator(); + + return Pool<Voice>::Iterator(); // no free voice or error + } + + bool Engine::DiskStreamSupported() { + return true; + } + + String Engine::Description() { + return "SoundFont Format Engine"; + } + + String Engine::Version() { + String s = "$Revision: 1.4 $"; + return s.substr(11, s.size() - 13); // cut dollar signs, spaces and CVS macro keyword + } + +}} // namespace LinuxSampler::sf2
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Engine.h
Added
@@ -0,0 +1,80 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2010 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_ENGINE_H__ +#define __LS_SF2_ENGINE_H__ + +#include "DiskThread.h" +#include "../EngineBase.h" +#include "Voice.h" +#include <SF.h> + +namespace LinuxSampler { namespace sf2 { + + class Engine: public LinuxSampler::EngineBase<Voice, ::sf2::Region, ::sf2::Region, DiskThread, InstrumentResourceManager, ::sf2::Preset> { + public: + Engine() { } + virtual ~Engine() { } + // implementation of abstract methods derived from class 'LinuxSampler::Engine' + virtual bool DiskStreamSupported(); + virtual String Description(); + virtual String Version(); + + virtual Format GetEngineFormat(); + + virtual void ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ); + + friend class Voice; + + protected: + virtual DiskThread* CreateDiskThread(); + + virtual Pool<Voice>::Iterator LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ); + + virtual void TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ); + + void TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ); + }; + +}} // namespace LinuxSampler::sf2 + +#endif /* __LS_SF2_ENGINE_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/EngineChannel.cpp
Added
@@ -0,0 +1,155 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "EngineChannel.h" +#include "Engine.h" + +namespace LinuxSampler { namespace sf2 { + EngineChannel::EngineChannel() { + for(int i = 0; i < 128; i++) PressedKeysi = false; + LastKey = LastKeySwitch = -1; + } + + EngineChannel::~EngineChannel() { + DisconnectAudioOutputDevice(); + // In case the channel was removed before the instrument was + // fully loaded, try to give back instrument again (see bug #113) + InstrumentChangeCmd< ::sf2::Region, ::sf2::Preset>& cmd = ChangeInstrument(NULL); + if (cmd.pInstrument) { + Engine::instruments.HandBack(cmd.pInstrument, this); + } + /////// + } + + AbstractEngine::Format EngineChannel::GetEngineFormat() { return AbstractEngine::SF2; } + + /** This method is not thread safe! */ + void EngineChannel::ResetInternal() { + CurrentKeyDimension = 0; + EngineChannelBase<Voice, ::sf2::Region, ::sf2::Preset>::ResetInternal(); + for(int i = 0; i < 128; i++) PressedKeysi = false; + } + + /** + * Will be called by the MIDIIn Thread to signal that a program + * change should be performed. As a program change isn't + * real-time safe, the actual change is performed by the disk + * thread. + * + * @param Program - MIDI program change number + */ + void EngineChannel::SendProgramChange(uint8_t Program) { + SetMidiProgram(Program); + Engine* engine = dynamic_cast<Engine*>(pEngine); + if(engine == NULL) return; + + if(engine->GetDiskThread()) { + uint32_t merged = (GetMidiBankMsb() << 16) | (GetMidiBankLsb() << 8) | Program; + engine->GetDiskThread()->OrderProgramChange(merged, this); + } else { + // TODO: + } + } + + /** + * Load an instrument from a .sf2 file. PrepareLoadInstrument() has to + * be called first to provide the information which instrument to load. + * This method will then actually start to load the instrument and block + * the calling thread until loading was completed. + * + * @see PrepareLoadInstrument() + */ + void EngineChannel::LoadInstrument() { + InstrumentResourceManager* pInstrumentManager = dynamic_cast<InstrumentResourceManager*>(pEngine->GetInstrumentManager()); + + // make sure we don't trigger any new notes with an old + // instrument + InstrumentChangeCmd< ::sf2::Region, ::sf2::Preset>& cmd = ChangeInstrument(0); + if (cmd.pInstrument) { + // give old instrument back to instrument manager, but + // keep the dimension regions and samples that are in use + pInstrumentManager->HandBackInstrument(cmd.pInstrument, this, cmd.pRegionsInUse); + } + cmd.pRegionsInUse->clear(); + + // delete all key groups + DeleteGroupEventLists(); + + // request sf2 instrument from instrument manager + ::sf2::Preset* newInstrument; + try { + InstrumentManager::instrument_id_t instrid; + instrid.FileName = InstrumentFile; + instrid.Index = InstrumentIdx; + + newInstrument = pInstrumentManager->Borrow(instrid, this); + if (!newInstrument) { + throw InstrumentManagerException("resource was not created"); + } + } + catch (InstrumentManagerException e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sf2::Engine error: Failed to load instrument, cause: " + e.Message(); + throw Exception(msg); + } + catch (::sf2::Exception e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sf2::Engine error: Failed to load instrument, cause: " + e.Message; + throw Exception(msg); + } + catch (::std::runtime_error e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sf2::Engine error: Failed to load instrument, cause: "; + msg += e.what(); + throw Exception(msg); + } + catch (...) { + InstrumentStat = -4; + StatusChanged(true); + throw Exception("sf2::Engine error: Failed to load instrument, cause: Unknown exception while trying to parse sf2 file."); + } + + // rebuild ActiveKeyGroups map with key groups of current instrument + for (int i = 0 ; i < newInstrument->GetRegionCount() ; i++) { + ::sf2::Region* pRegion = newInstrument->GetRegion(i); + for (int j = 0 ; j < pRegion->pInstrument->GetRegionCount() ; j++) { + ::sf2::Region* pSubRegion = pRegion->pInstrument->GetRegion(j); + AddGroup(pSubRegion->exclusiveClass); + } + } + + InstrumentIdxName = newInstrument->GetName(); + InstrumentStat = 100; + + ChangeInstrument(newInstrument); + + StatusChanged(true); + } + + void EngineChannel::ProcessKeySwitchChange(int key) { } + +}} // namespace LinuxSampler::sf2
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/EngineChannel.h
Added
@@ -0,0 +1,61 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_ENGINECHANNEL_H__ +#define __LS_SF2_ENGINECHANNEL_H__ + +#include "../AbstractEngine.h" +#include "../EngineChannelBase.h" +#include "../EngineChannelFactory.h" +#include "Voice.h" +#include <SF.h> + +namespace LinuxSampler { namespace sf2 { + class EngineChannel: public LinuxSampler::EngineChannelBase<Voice, ::sf2::Region, ::sf2::Preset> { + public: + virtual void SendProgramChange(uint8_t Program); + virtual void LoadInstrument(); + virtual void ResetInternal(); + + virtual AbstractEngine::Format GetEngineFormat(); + + friend class Voice; + friend class Engine; + friend class LinuxSampler::EngineChannelFactory; + + protected: + EngineChannel(); + virtual ~EngineChannel(); + + virtual void ProcessKeySwitchChange(int key); + + private: + bool PressedKeys128; + int LastKeySwitch; + int LastKey; + }; + +}} // namespace LinuxSampler::sf2 + +#endif /* __LS_SF2_ENGINECHANNEL_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/InstrumentResourceManager.cpp
Added
@@ -0,0 +1,267 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <sstream> + +#include "InstrumentResourceManager.h" +#include "EngineChannel.h" +#include "Engine.h" + +#include "../../common/global_private.h" +#include "../../common/Path.h" +#include "../../plugins/InstrumentEditorFactory.h" + + +namespace LinuxSampler { namespace sf2 { + + String InstrumentResourceManager::GetInstrumentName(instrument_id_t ID) { + Lock(); + ::sf2::Preset* pInstrument = Resource(ID, false); + String res = (pInstrument) ? pInstrument->GetName() : ""; + Unlock(); + return res; + } + + std::vector<InstrumentResourceManager::instrument_id_t> InstrumentResourceManager::GetInstrumentFileContent(String File) throw (InstrumentManagerException) { + ::RIFF::File* riff = NULL; + ::sf2::File* sf2 = NULL; + try { + std::vector<instrument_id_t> result; + riff = new ::RIFF::File(File); + sf2 = new ::sf2::File(riff); + for (int i = 0; i < GetSfInstrumentCount(sf2); i++) { + instrument_id_t id; + id.FileName = File; + id.Index = i; + result.push_back(id); + } + if (sf2) delete sf2; + if (riff) delete riff; + return result; + } catch (::RIFF::Exception e) { + if (sf2) delete sf2; + if (riff) delete riff; + throw InstrumentManagerException(e.Message); + } catch (...) { + if (sf2) delete sf2; + if (riff) delete riff; + throw InstrumentManagerException("Unknown exception while trying to parse '" + File + "'"); + } + } + + InstrumentResourceManager::instrument_info_t InstrumentResourceManager::GetInstrumentInfo(instrument_id_t ID) throw (InstrumentManagerException) { + Lock(); + ::sf2::Preset* pInstrument = Resource(ID, false); + bool loaded = (pInstrument != NULL); + if (!loaded) Unlock(); + + ::RIFF::File* riff = NULL; + ::sf2::File* sf2 = NULL; + try { + if (!loaded) { + riff = new ::RIFF::File(ID.FileName); + sf2 = new ::sf2::File(riff); + pInstrument = GetSfInstrument(sf2, ID.Index); + } + + instrument_info_t info; + for (int i = 0; i < 128; i++) { info.KeyBindingsi = info.KeySwitchBindingsi = 0; } + + ::sf2::File* pFile = pInstrument->GetFile(); + + info.FormatVersion = ToString(pFile->pInfo->pVer->Major); + info.Product = pFile->pInfo->Product; + info.Artists = pFile->pInfo->Engineers; + + info.InstrumentName = pInstrument->Name; + + for (int i = 0; i < pInstrument->GetRegionCount(); i++) { + int low = pInstrument->GetRegion(i)->loKey; + int high = pInstrument->GetRegion(i)->hiKey; + if (low == ::sf2::NONE || high == ::sf2::NONE) { + ::sf2::Instrument* layer = pInstrument->GetRegion(i)->pInstrument; + for (int j = 0; j < layer->GetRegionCount(); j++) { + int lo = layer->GetRegion(j)->loKey; + int hi = layer->GetRegion(j)->hiKey; + SetKeyBindings(info.KeyBindings, lo, hi, ::sf2::NONE); + } + } else { + SetKeyBindings(info.KeyBindings, low, high, ::sf2::NONE); + } + } + + if (loaded) Unlock(); + + if (sf2) delete sf2; + if (riff) delete riff; + return info; + } catch (::sf2::Exception e) { + if (loaded) Unlock(); + if (sf2) delete sf2; + if (riff) delete riff; + throw InstrumentManagerException(e.Message); + } catch (...) { + if (loaded) Unlock(); + if (sf2) delete sf2; + if (riff) delete riff; + throw InstrumentManagerException("Unknown exception while trying to parse '" + ID.FileName + "'"); + } + } + + ::sf2::Preset* InstrumentResourceManager::Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg) { + // get sfz file from internal sfz file manager + ::sf2::File* pSf2 = Sf2s.Borrow(Key.FileName, reinterpret_cast<Sf2Consumer*>(Key.Index)); // conversion kinda hackish :/ + + dmsg(1,("Loading sf2 instrument ('%s',%d)...",Key.FileName.c_str(),Key.Index)); + ::sf2::Preset* pInstrument = GetSfInstrument(pSf2, Key.Index); + dmsg(1,("OK\n")); + + // cache initial samples points (for actually needed samples) + dmsg(1,("Caching initial samples...")); + float regTotal = 0, regCurrent = 0; + for (int i = 0 ; i < pInstrument->GetRegionCount() ; i++) { + ::sf2::Instrument* sf2Instr = pInstrument->GetRegion(i)->pInstrument; + if (sf2Instr) regTotal += sf2Instr->GetRegionCount(); + } + uint maxSamplesPerCycle = GetMaxSamplesPerCycle(pConsumer); + for (int i = 0 ; i < pInstrument->GetRegionCount() ; i++) { + ::sf2::Instrument* sf2Instr = pInstrument->GetRegion(i)->pInstrument; + if (sf2Instr) { + // pInstrument is ::sf2::Preset + for (int j = 0 ; j < sf2Instr->GetRegionCount() ; j++) { + float localProgress = regCurrent++ / regTotal; + DispatchResourceProgressEvent(Key, localProgress); + CacheInitialSamples(sf2Instr->GetRegion(j)->GetSample(), maxSamplesPerCycle); + } + } + } + dmsg(1,("OK\n")); + DispatchResourceProgressEvent(Key, 1.0f); // done; notify all consumers about progress 100% + + // we need the following for destruction later + instr_entry_t* pEntry = new instr_entry_t; + pEntry->ID.FileName = Key.FileName; + pEntry->ID.Index = Key.Index; + pEntry->pFile = pSf2; + + // and we save this to check if we need to reallocate for an engine with higher value of 'MaxSamplesPerSecond' + pEntry->MaxSamplesPerCycle = maxSamplesPerCycle; + + pArg = pEntry; + + return pInstrument; + } + + void InstrumentResourceManager::Destroy(::sf2::Preset* pResource, void* pArg) { + instr_entry_t* pEntry = (instr_entry_t*) pArg; + // we don't need the .sf2 file here anymore + Sf2s.HandBack(pEntry->pFile, reinterpret_cast<Sf2Consumer*>(pEntry->ID.Index)); // conversion kinda hackish :/ + delete pEntry; + } + + void InstrumentResourceManager::DeleteRegionIfNotUsed(::sf2::Region* pRegion, region_info_t* pRegInfo) { + // TODO: we could delete Region and Instrument here if they have become unused + } + + void InstrumentResourceManager::DeleteSampleIfNotUsed(::sf2::Sample* pSample, region_info_t* pRegInfo) { + ::sf2::File* sf2 = pRegInfo->file; + ::RIFF::File* riff = static_cast< ::RIFF::File*>(pRegInfo->pArg); + if (sf2) { + sf2->DeleteSample(pSample); + if (!sf2->HasSamples()) { + dmsg(2,("No more samples in use - freeing sf2\n")); + delete sf2; + delete riff; + } + } + } + + + + // internal sfz file manager + + ::sf2::File* InstrumentResourceManager::Sf2ResourceManager::Create(String Key, Sf2Consumer* pConsumer, void*& pArg) { + dmsg(1,("Loading sf2 file \'%s\'...", Key.c_str())); + ::RIFF::File* pRIFF = new ::RIFF::File(Key); + ::sf2::File* pSf2 = new ::sf2::File(pRIFF); + pArg = pRIFF; + dmsg(1,("OK\n")); + return pSf2; + } + + void InstrumentResourceManager::Sf2ResourceManager::Destroy(::sf2::File* pResource, void* pArg) { + dmsg(1,("Freeing sf2 file from memory...")); + + // Delete as much as possible of the sf2 file. Some of the + // regions and samples may still be in use - these + // will be deleted later by the HandBackRegion function. + bool deleteFile = true; + + for (int i = pResource->GetInstrumentCount() - 1; i >= 0; i--) { + ::sf2::Instrument* pInstr = pResource->GetInstrument(i); + bool deleteInstrument = true; + + for (int j = pInstr->GetRegionCount() - 1; j >= 0 ; j--) { + ::sf2::Region* pRegion = pInstr->GetRegion(j); + std::map< ::sf2::Region*, region_info_t>::iterator iter = parent->RegionInfo.find(pRegion); + if (iter != parent->RegionInfo.end()) { + region_info_t& regInfo = (*iter).second; + regInfo.file = pResource; + deleteFile = deleteInstrument = false; + } else { + pInstr->DeleteRegion(pRegion); + } + } + + if (deleteInstrument) pResource->DeleteInstrument(pInstr); + } + + if (deleteFile) { + delete pResource; + delete (::RIFF::File*) pArg; + } else { + dmsg(2,("keeping some samples that are in use...")); + for (int i = pResource->GetSampleCount() - 1; i >= 0; i--) { + ::sf2::Sample* sample = pResource->GetSample(i); + if (parent->SampleRefCount.find(sample) == parent->SampleRefCount.end()) { + pResource->DeleteSample(sample); + } + } + } + + dmsg(1,("OK\n")); + } + + int InstrumentResourceManager::GetSfInstrumentCount(::sf2::File* pFile) { + return pFile->GetPresetCount(); + } + + ::sf2::Preset* InstrumentResourceManager::GetSfInstrument(::sf2::File* pFile, int idx) { + if (idx >= pFile->GetPresetCount()) { + throw InstrumentManagerException("There is no instrument with index " + ToString(idx)); + } + return pFile->GetPreset(idx); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/InstrumentResourceManager.h
Added
@@ -0,0 +1,101 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_INSTRUMENTRESOURCEMANAGER_H__ +#define __LS_SF2_INSTRUMENTRESOURCEMANAGER_H__ + +#include "../../common/global.h" + +#include <SF.h> + +#include "../../common/global.h" +#include "../../common/Pool.h" +#include "../../common/ResourceManager.h" +#include "../../drivers/audio/AudioOutputDevice.h" +#include "../InstrumentManagerBase.h" +#include "../../common/ArrayList.h" + +namespace LinuxSampler { namespace sf2 { + + typedef ResourceConsumer< ::sf2::Preset> InstrumentConsumer; + +}} // namespace LinuxSampler::sf2 + +#include "../../plugins/InstrumentEditor.h" + +namespace LinuxSampler { namespace sf2 { + class Engine; + class EngineChannel; + + /** @brief sf2 instrument manager + * + * Manager to share sf2 instruments between multiple sf2 + * engine channels. The engine channels Borrow() instruments when they + * need them and HandBack() when they don't need them anymore. The + * InstrumentResourceManager loads the corresponding sf2 file and sf2 + * instrument if needed, if it's already in use by another engine + * channel, then it just returns the same resource, if a sf2 + * instrument / file is not needed anymore, then it will be freed from + * memory. + */ + class InstrumentResourceManager : public InstrumentManagerBase< ::sf2::File, ::sf2::Preset, ::sf2::Region, ::sf2::Sample> { + public: + InstrumentResourceManager() : Sf2s(this) {} + virtual ~InstrumentResourceManager() {} + + // implementation of derived abstract methods from 'InstrumentManager' + virtual String GetInstrumentName(instrument_id_t ID); + virtual std::vector<instrument_id_t> GetInstrumentFileContent(String File) throw (InstrumentManagerException); + virtual instrument_info_t GetInstrumentInfo(instrument_id_t ID) throw (InstrumentManagerException); + + protected: + // implementation of derived abstract methods from 'ResourceManager' + virtual ::sf2::Preset* Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg); + virtual void Destroy(::sf2::Preset* pResource, void* pArg); + virtual void DeleteRegionIfNotUsed(::sf2::Region* pRegion, region_info_t* pRegInfo); + virtual void DeleteSampleIfNotUsed(::sf2::Sample* pSample, region_info_t* pRegInfo); + private: + typedef ResourceConsumer< ::sf2::File> Sf2Consumer; + + class Sf2ResourceManager : public ResourceManager<String, ::sf2::File> { + protected: + // implementation of derived abstract methods from 'ResourceManager' + virtual ::sf2::File* Create(String Key, Sf2Consumer* pConsumer, void*& pArg); + virtual void Destroy(::sf2::File* pResource, void* pArg); + virtual void OnBorrow(::sf2::File* pResource, Sf2Consumer* pConsumer, void*& pArg) {} // ignore + public: + Sf2ResourceManager(InstrumentResourceManager* parent) : parent(parent) {} + virtual ~Sf2ResourceManager() {} + friend class InstrumentResourceManager; + private: + InstrumentResourceManager* parent; + } Sf2s; + + int GetSfInstrumentCount(::sf2::File* pFile); + ::sf2::Preset* GetSfInstrument(::sf2::File* pFile, int idx); + }; + +}} // namespace LinuxSampler::sf2 + +#endif // __LS_SF2_INSTRUMENTRESOURCEMANAGER_H__
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Makefile.am
Added
@@ -0,0 +1,18 @@ +if HAVE_SF2 +INCLUDES = $(all_includes) $(GIG_CFLAGS) +METASOURCES = AUTO + +AM_CXXFLAGS = -Wreturn-type -ffast-math + +noinst_LTLIBRARIES = liblinuxsamplersf2engine.la +liblinuxsamplersf2engine_la_SOURCES = \ + InstrumentResourceManager.cpp InstrumentResourceManager.h \ + DiskThread.cpp DiskThread.h \ + EngineChannel.cpp EngineChannel.h \ + Engine.cpp Engine.h \ + Voice.cpp Voice.h \ + SF2SignalUnitRack.cpp SF2SignalUnitRack.h \ + Stream.cpp Stream.h +liblinuxsamplersf2engine_la_LIBADD = $(GIG_LIBS) +liblinuxsamplersf2engine_la_LDFLAGS = $(GIG_CFLAGS) +endif
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/SF2SignalUnitRack.cpp
Added
@@ -0,0 +1,296 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 - 2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "SF2SignalUnitRack.h" +#include "Voice.h" + +namespace LinuxSampler { namespace sf2 { + + SFSignalUnit::SFSignalUnit(SF2SignalUnitRack* rack): SignalUnit(rack), pVoice(NULL) { + + } + + void EGUnit::EnterReleaseStage() { + update(EG::event_release, pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + + void EGUnit::CancelRelease() { + update(EG::event_cancel_release, pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + + + void VolEGUnit::Trigger() { + // set the delay trigger + double d = pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + uiDelayTrigger = pVoice->pRegion->GetEG1PreAttackDelay(pVoice->pPresetRegion) * d; + //////////// + + // GetEG1Sustain gets the decrease in level in centibels + uint sustain = ::sf2::ToRatio(-1 * pVoice->pRegion->GetEG1Sustain(pVoice->pPresetRegion)) * 1000; // in permille + + trigger ( + 0, // should be in permille + pVoice->pRegion->GetEG1Attack(pVoice->pPresetRegion), + pVoice->pRegion->GetEG1Hold(pVoice->pPresetRegion), + pVoice->pRegion->GetEG1Decay(pVoice->pPresetRegion), + sustain, + pVoice->pRegion->GetEG1Release(pVoice->pPresetRegion), + pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE, + false + ); + } + + void VolEGUnit::Increment() { + if (DelayStage()) return; + + EGUnit::Increment(); + if (!active()) return; + + switch (getSegmentType()) { + case EG::segment_lin: + processLin(); + break; + case EG::segment_exp: + processExp(); + break; + case EG::segment_end: + getLevel(); + break; // noop + case EG::segment_pow: + processPow(); + break; + } + + if (active()) { + + // if sample has a loop and loop start has been reached in this subfragment, send a special event to EG1 to let it finish the attack hold stage + /*if (pVoice->SmplInfo.HasLoops && pVoice->Pos <= pVoice->SmplInfo.LoopStart && pVoice->SmplInfo.LoopStart < newPos) { + update(EG::event_hold_end, pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + }*/ + // TODO: ^^^ + + increment(1); + if (!toStageEndLeft()) update(EG::event_stage_end, pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + } + + void ModEGUnit::Trigger() { + double d = pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + uiDelayTrigger = pVoice->pRegion->GetEG2PreAttackDelay(pVoice->pPresetRegion) * d; + + trigger ( + 0, // should be in permille + pVoice->pRegion->GetEG2Attack(pVoice->pPresetRegion), + pVoice->pRegion->GetEG2Hold(pVoice->pPresetRegion), + pVoice->pRegion->GetEG2Decay(pVoice->pPresetRegion), + uint(1000 - pVoice->pRegion->GetEG2Sustain(pVoice->pPresetRegion)), + pVoice->pRegion->GetEG2Release(pVoice->pPresetRegion), + pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE, + true + ); + } + + void ModEGUnit::Increment() { + if (DelayStage()) return; + + EGUnit::Increment(); + if (!active()) return; + + switch (getSegmentType()) { + case EG::segment_lin: + processLin(); + break; + case EG::segment_exp: + processExp(); + break; + case EG::segment_end: + getLevel(); + break; // noop + case EG::segment_pow: + processPow(); + break; + } + + if (active()) { + increment(1); + if (!toStageEndLeft()) update(EG::event_stage_end, pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE); + } + } + + + void ModLfoUnit::Trigger() { + //reset + Level = 0; + + // set the delay trigger + double samplerate = pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + uiDelayTrigger = pVoice->pRegion->GetDelayModLfo(pVoice->pPresetRegion) * samplerate; + //////////// + + trigger ( + pVoice->pRegion->GetFreqModLfo(pVoice->pPresetRegion), + start_level_min, + 1, 0, false, samplerate + ); + update(0); + } + + void ModLfoUnit::Increment() { + if (DelayStage()) return; + + SignalUnit::Increment(); + + Level = render(); + } + + + void VibLfoUnit::Trigger() { + //reset + Level = 0; + + // set the delay trigger + double samplerate = pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + uiDelayTrigger = pVoice->pRegion->GetDelayVibLfo(pVoice->pPresetRegion) * samplerate; + //////////// + + trigger ( + pVoice->pRegion->GetFreqVibLfo(pVoice->pPresetRegion), + start_level_min, + pVoice->pRegion->GetVibLfoToPitch(pVoice->pPresetRegion), + 0, false, samplerate + ); + update(0); + } + + void VibLfoUnit::Increment() { + if (DelayStage()) return; + + SignalUnit::Increment(); + + Level = render(); + } + + + EndpointUnit::EndpointUnit(SF2SignalUnitRack* rack): EndpointSignalUnit(rack) { + + } + + void EndpointUnit::Trigger() { + prmModEgPitch->Coeff = pVoice->pRegion->GetModEnvToPitch(pVoice->pPresetRegion); + if (prmModEgPitch->Coeff == ::sf2::NONE) prmModEgPitch->Coeff = 0; + + prmModEgCutoff->Coeff = pVoice->pRegion->GetModEnvToFilterFc(pVoice->pPresetRegion); // cents + if (prmModEgCutoff->Coeff == ::sf2::NONE) prmModEgCutoff->Coeff = 0; + + prmModLfoVol->Coeff = pVoice->pRegion->GetModLfoToVolume(pVoice->pPresetRegion); // centibels + if (prmModLfoVol->Coeff == ::sf2::NONE) prmModLfoVol->Coeff = 0; + + prmModLfoCutoff->Coeff = pVoice->pRegion->GetModLfoToFilterFc(pVoice->pPresetRegion); + if (prmModLfoCutoff->Coeff == ::sf2::NONE) prmModLfoCutoff->Coeff = 0; + + prmModLfoPitch->Coeff = pVoice->pRegion->GetModLfoToPitch(pVoice->pPresetRegion); + if (prmModLfoPitch->Coeff == ::sf2::NONE) prmModLfoPitch->Coeff = 0; + } + + bool EndpointUnit::Active() { + return prmVolEg->pUnit->Active(); // volEGUnit + } + + float EndpointUnit::GetVolume() { + if (!prmVolEg->pUnit->Active()) return 0; + return prmVolEg->GetValue() * + ::sf2::ToRatio(prmModLfoVol->GetValue() /*logarithmically modified */); + } + + float EndpointUnit::GetFilterCutoff() { + double modEg, modLfo; + modEg = prmModEgCutoff->pUnit->Active() ? prmModEgCutoff->GetValue() : 0; + modEg = RTMath::CentsToFreqRatioUnlimited(modEg); + + modLfo = prmModLfoCutoff->pUnit->Active() ? prmModLfoCutoff->GetValue() : 0; + modLfo = RTMath::CentsToFreqRatioUnlimited(modLfo); + + return modEg * modLfo; + } + + float EndpointUnit::GetPitch() { + double modEg, modLfo, vibLfo; + modEg = prmModEgPitch->pUnit->Active() ? RTMath::CentsToFreqRatioUnlimited(prmModEgPitch->GetValue()) : 1; + modLfo = prmModLfoPitch->pUnit->Active() ? RTMath::CentsToFreqRatioUnlimited(prmModLfoPitch->GetValue()) : 1; + vibLfo = prmVibLfo->pUnit->Active() ? RTMath::CentsToFreqRatioUnlimited(prmVibLfo->GetValue()) : 1; + + return modEg * modLfo * vibLfo; + } + + float EndpointUnit::GetResonance() { + return 1; + } + + SF2SignalUnitRack::SF2SignalUnitRack(Voice* voice) + : SignalUnitRack(MaxUnitCount), pVoice(voice), suVolEG(this), suModEG(this), suModLfo(this), suVibLfo(this), suEndpoint(this) { + + suVolEG.pVoice = suModEG.pVoice = suModLfo.pVoice = suVibLfo.pVoice = suEndpoint.pVoice = voice; + Units.add(&suVolEG); + Units.add(&suModEG); + Units.add(&suModLfo); + Units.add(&suVibLfo); + Units.add(&suEndpoint); + + // Volume envelope + suEndpoint.Params.add(SignalUnit::Parameter(&suVolEG)); // Volume + // Modulation envelope + suEndpoint.Params.add(SignalUnit::Parameter(&suModEG)); // Pitch + suEndpoint.Params.add(SignalUnit::Parameter(&suModEG)); // Filter cutoff + // Modulation LFO + suEndpoint.Params.add(SignalUnit::Parameter(&suModLfo)); // Volume + suEndpoint.Params.add(SignalUnit::Parameter(&suModLfo)); // Pitch + suEndpoint.Params.add(SignalUnit::Parameter(&suModLfo)); // Filter cutoff + // Vibrato LFO + suEndpoint.Params.add(SignalUnit::Parameter(&suVibLfo)); // Pitch + + /* This should be done at the end because when a parameter is added to + ArrayList a new copy is made for all parameters */ + suEndpoint.prmVolEg = &suEndpoint.Params0; + suEndpoint.prmModEgPitch = &suEndpoint.Params1; + suEndpoint.prmModEgCutoff = &suEndpoint.Params2; + suEndpoint.prmModLfoVol = &suEndpoint.Params3; + suEndpoint.prmModLfoPitch = &suEndpoint.Params4; + suEndpoint.prmModLfoCutoff = &suEndpoint.Params5; + suEndpoint.prmVibLfo = &suEndpoint.Params6; + } + + EndpointSignalUnit* SF2SignalUnitRack::GetEndpointUnit() { + return static_cast<EndpointSignalUnit*> (&suEndpoint); + } + + void SF2SignalUnitRack::EnterFadeOutStage() { + suVolEG.enterFadeOutStage(); + } + + void SF2SignalUnitRack::EnterFadeOutStage(int maxFadeOutSteps) { + suVolEG.enterFadeOutStage(maxFadeOutSteps); + } + + void SF2SignalUnitRack::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + suVolEG.CalculateFadeOutCoeff(FadeOutTime, SampleRate); + } +}} // namespace LinuxSampler::sf2
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/SF2SignalUnitRack.h
Added
@@ -0,0 +1,137 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 - 2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2SIGNALUNITRACK_H__ +#define __LS_SF2SIGNALUNITRACK_H__ + +#include "../common/SignalUnitRack.h" +#include "../sfz/EGADSR.h" +#include "../common/AbstractVoice.h" + +namespace LinuxSampler { namespace sf2 { + const int MaxUnitCount = 5; + + class Voice; + class SF2SignalUnitRack; + + class SFSignalUnit: public SignalUnit { + public: + Voice* pVoice; + + SFSignalUnit(SF2SignalUnitRack* rack); + }; + + class EGUnit : public SFSignalUnit, public ::LinuxSampler::sfz::EGADSR { + public: + EGUnit(SF2SignalUnitRack* rack): SFSignalUnit(rack) { } + + virtual bool Active() { return active(); } + virtual float GetLevel() { return getLevel(); } + virtual void EnterReleaseStage(); + virtual void CancelRelease(); + }; + + class VolEGUnit : public EGUnit { + public: + VolEGUnit(SF2SignalUnitRack* rack): EGUnit(rack) { } + + virtual void Trigger(); + virtual void Increment(); + }; + + class ModEGUnit : public EGUnit { + public: + ModEGUnit(SF2SignalUnitRack* rack): EGUnit(rack) { } + + virtual void Trigger(); + virtual void Increment(); + }; + + class ModLfoUnit : public SFSignalUnit, public LFOSigned { + public: + ModLfoUnit(SF2SignalUnitRack* rack): SFSignalUnit(rack), LFOSigned(1200.0f) { } + virtual bool Active() { return true; } + virtual void Trigger(); + virtual void Increment(); + virtual float GetLevel() { return Level; } + }; + + class VibLfoUnit : public SFSignalUnit, public LFOSigned { + public: + VibLfoUnit(SF2SignalUnitRack* rack): SFSignalUnit(rack), LFOSigned(1200.0f) { } + virtual bool Active() { return true; } + virtual void Trigger(); + virtual void Increment(); + virtual float GetLevel() { return Level; } + }; + + class EndpointUnit : public EndpointSignalUnit { + public: + Voice* pVoice; + + Parameter *prmVolEg, *prmModEgPitch, *prmModEgCutoff, *prmModLfoVol, + *prmModLfoPitch, *prmModLfoCutoff, *prmVibLfo; + + EndpointUnit(SF2SignalUnitRack* rack); + + virtual void Trigger(); + + /** The endpoint should be active until the volume EG is active. */ + virtual bool Active(); + + virtual float GetVolume(); + virtual float GetFilterCutoff(); + virtual float GetPitch(); + virtual float GetResonance(); + virtual float GetPan() { return 0; } + virtual uint8_t CaluclatePan(uint8_t pan) { return pan; } + }; + + class SF2SignalUnitRack : public SignalUnitRack { + private: + VolEGUnit suVolEG; + ModEGUnit suModEG; + ModLfoUnit suModLfo; + VibLfoUnit suVibLfo; + EndpointUnit suEndpoint; + + + public: + Voice* const pVoice; + + /** + * @param Voice The voice to which this rack belongs. + */ + SF2SignalUnitRack(Voice* Voice); + + virtual EndpointSignalUnit* GetEndpointUnit(); + virtual void EnterFadeOutStage(); + virtual void EnterFadeOutStage(int maxFadeOutSteps); + + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + virtual void UpdateEqSettings(EqSupport* pEqSupport) { } + }; + +}} // namespace LinuxSampler::sf2 + +#endif /* __LS_SF2SIGNALUNITRACK_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Stream.cpp
Added
@@ -0,0 +1,110 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <signal.h> + + +#include "Stream.h" +#include "../../common/global_private.h" + +namespace LinuxSampler { namespace sf2 { + + Stream::Stream ( + uint BufferSize, + uint BufferWrapElements + ) : LinuxSampler::StreamBase< ::sf2::Region>(BufferSize, BufferWrapElements) { + + } + + long Stream::Read(uint8_t* pBuf, long SamplesToRead) { + ::sf2::Sample* pSample = pRegion->pSample; + long total_readsamples = 0, readsamples = 0; + bool endofsamplereached; + + // refill the disk stream buffer + if (this->DoLoop) { // honor looping + ::sf2::Sample::PlaybackState pbs; + pbs.position = PlaybackState.position; + pbs.reverse = PlaybackState.reverse; + pbs.loop_cycles_left = PlaybackState.loop_cycles_left; + + total_readsamples = pSample->ReadAndLoop(pBuf, SamplesToRead, &pbs, pRegion); + PlaybackState.position = pbs.position; + PlaybackState.reverse = pbs.reverse; + PlaybackState.loop_cycles_left = pbs.loop_cycles_left; + endofsamplereached = (this->PlaybackState.position >= pSample->GetTotalFrameCount()); + dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->PlaybackState.position)); + } + else { // normal forward playback + + pSample->SetPos(this->SampleOffset); // recover old position + + do { + readsamples = pSample->Read(&pBuftotal_readsamples * pSample->GetFrameSize(), SamplesToRead); + SamplesToRead -= readsamples; + total_readsamples += readsamples; + } while (SamplesToRead && readsamples > 0); + + // we have to store the position within the sample, because other streams might use the same sample + this->SampleOffset = pSample->GetPos(); + + endofsamplereached = (SampleOffset >= pSample->GetTotalFrameCount()); + dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->SampleOffset)); + } + + // update stream state + if (endofsamplereached) SetState(state_end); + else SetState(state_active); + + return total_readsamples; + } + + void Stream::Kill() { + StreamBase< ::sf2::Region>::Kill(); + } + + void Stream::Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::sf2::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + SampleDescription info; + info.ChannelsPerFrame = pRgn->pSample->GetChannelCount(); + info.FrameSize = pRgn->pSample->GetFrameSize(); + info.BytesPerSample = pRgn->pSample->GetFrameSize() / pRgn->pSample->GetChannelCount(); + info.TotalSampleCount = pRgn->pSample->GetTotalFrameCount(); + + Sample::PlaybackState playbackState; + playbackState.position = SampleOffset; + playbackState.reverse = false; + playbackState.loop_cycles_left = 0; // TODO: pRgn->pSample->LoopPlayCount; + + LinuxSampler::StreamBase< ::sf2::Region>::Launch ( + hStream, pExportReference, pRgn, info, playbackState, SampleOffset, DoLoop + ); + } + +}} // namespace LinuxSampler::sf2
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Stream.h
Added
@@ -0,0 +1,52 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_STREAM_H__ +#define __LS_SF2_STREAM_H__ + +#include "../common/StreamBase.h" +#include <SF.h> + +namespace LinuxSampler { namespace sf2 { + + class Stream: public LinuxSampler::StreamBase< ::sf2::Region> { + public: + Stream(uint BufferSize, uint BufferWrapElements); + virtual long Read(uint8_t* pBuf, long SamplesToRead); + virtual void Kill(); + + void Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::sf2::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); + }; + + +}} // namespace LinuxSampler::sf2 + +#endif /* __LS_SF2_STREAM_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Voice.cpp
Added
@@ -0,0 +1,347 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "Voice.h" + +#include "Engine.h" +#include "EngineChannel.h" + +namespace LinuxSampler { namespace sf2 { + + typedef LinuxSampler::VoiceBase<EngineChannel, ::sf2::Region, ::sf2::Sample, DiskThread> SF2Voice; + Voice::Voice(): SignalRack(this), SF2Voice(&SignalRack) { + pEngine = NULL; + pEG1 = NULL; + pEG2 = NULL; + } + + Voice::~Voice() { + + } + + void Voice::AboutToTrigger() { + + } + + EngineChannel* Voice::GetSf2EngineChannel() { + return static_cast<EngineChannel*>(pEngineChannel); + } + + void Voice::SetEngine(LinuxSampler::Engine* pEngine) { + Engine* engine = static_cast<Engine*>(pEngine); + this->pEngine = engine; + this->pDiskThread = engine->pDiskThread; + dmsg(6,("Voice::SetEngine()\n")); + } + + Voice::SampleInfo Voice::GetSampleInfo() { + SampleInfo si; + si.SampleRate = pSample->SampleRate; + si.ChannelCount = pSample->GetChannelCount(); + si.FrameSize = pSample->GetFrameSize(); + si.BitDepth = (pSample->GetFrameSize() / pSample->GetChannelCount()) * 8; + si.TotalFrameCount = pSample->GetTotalFrameCount(); + + si.HasLoops = pRegion->HasLoop; + si.LoopStart = (si.HasLoops) ? pRegion->LoopStart : 0; + si.LoopLength = (si.HasLoops) ? ((pRegion->LoopEnd) - pRegion->LoopStart): 0; + si.LoopPlayCount = 0; // TODO: + si.Unpitched = pSample->IsUnpitched(); + + return si; + } + + Voice::RegionInfo Voice::GetRegionInfo() { + ::sf2::Region* reg = NULL; + ::sf2::Preset* preset = GetSf2EngineChannel()->pInstrument; + for (int i = 0; i < preset->GetRegionCount(); i++) { // TODO: some optimization? + if (preset->GetRegion(i)->pInstrument == pRegion->GetParentInstrument()) { + reg = preset->GetRegion(i); // TODO: Can the instrument belong to more than one preset region? + break; + } + } + pPresetRegion = reg; + + RegionInfo ri; + ri.UnityNote = pRegion->GetUnityNote(); + ri.FineTune = pRegion->GetFineTune(reg) + (pRegion->GetCoarseTune(reg) * 100); + ri.Pan = pRegion->GetPan(reg); + ri.SampleStartOffset = pRegion->startAddrsOffset + pRegion->startAddrsCoarseOffset; + + // sample pitch + ri.VCFEnabled = true; // TODO: + ri.VCFType = Filter::vcf_type_2p_lowpass; // TODO: + ri.VCFResonance = 0; // TODO: + + ri.ReleaseTriggerDecay = 0; // TODO: + + return ri; + } + + Voice::InstrumentInfo Voice::GetInstrumentInfo() { + InstrumentInfo ii; + ii.FineTune = 0; // TODO: + ii.PitchbendRange = 2; // TODO: + + return ii; + } + + double Voice::GetSampleAttenuation() { + return 1.0; // TODO: + } + + double Voice::GetVelocityAttenuation(uint8_t MIDIKeyVelocity) { + return double(MIDIKeyVelocity) / 127.0f; // TODO: + } + + double Voice::GetVelocityRelease(uint8_t MIDIKeyVelocity) { + return 0.9; // TODO: + } + + void Voice::ProcessCCEvent(RTList<Event>::Iterator& itEvent) { + /*if (itEvent->Type == Event::type_control_change && itEvent->Param.CC.Controller) { // if (valid) MIDI control change event + if (pRegion->AttenuationController.type == ::gig::attenuation_ctrl_t::type_controlchange && + itEvent->Param.CC.Controller == pRegion->AttenuationController.controller_number) { + CrossfadeSmoother.update(AbstractEngine::CrossfadeCurveCrossfadeAttenuation(itEvent->Param.CC.Value)); + } + }*/ // TODO: ^^^ + } + + void Voice::ProcessCutoffEvent(RTList<Event>::Iterator& itEvent) { + /*int ccvalue = itEvent->Param.CC.Value; + if (VCFCutoffCtrl.value == ccvalue) return; + VCFCutoffCtrl.value == ccvalue; + if (pRegion->VCFCutoffControllerInvert) ccvalue = 127 - ccvalue; + if (ccvalue < pRegion->VCFVelocityScale) ccvalue = pRegion->VCFVelocityScale; + float cutoff = CutoffBase * float(ccvalue); + if (cutoff > 127.0f) cutoff = 127.0f; + + VCFCutoffCtrl.fvalue = cutoff; // needed for initialization of fFinalCutoff next time + fFinalCutoff = cutoff;*/ // TODO: ^^^ + } + + double Voice::CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity) { + /*float crossfadeVolume; + switch (pRegion->AttenuationController.type) { + case ::gig::attenuation_ctrl_t::type_channelaftertouch: + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetSf2EngineChannel()->ControllerTable128); + break; + case ::gig::attenuation_ctrl_t::type_velocity: + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(MIDIKeyVelocity); + break; + case ::gig::attenuation_ctrl_t::type_controlchange: //FIXME: currently not sample accurate + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetSf2EngineChannel()->ControllerTablepRegion->AttenuationController.controller_number); + break; + case ::gig::attenuation_ctrl_t::type_none: // no crossfade defined + default: + crossfadeVolume = 1.0f; + } + + return crossfadeVolume;*/ // TODO: ^^^ + return 1.0f; + } + + double Voice::GetEG1ControllerValue(uint8_t MIDIKeyVelocity) { + /*double eg1controllervalue = 0; + switch (pRegion->EG1Controller.type) { + case ::gig::eg1_ctrl_t::type_none: // no controller defined + eg1controllervalue = 0; + break; + case ::gig::eg1_ctrl_t::type_channelaftertouch: + eg1controllervalue = GetSf2EngineChannel()->ControllerTable128; + break; + case ::gig::eg1_ctrl_t::type_velocity: + eg1controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg1_ctrl_t::type_controlchange: // MIDI control change controller + eg1controllervalue = GetSf2EngineChannel()->ControllerTablepRegion->EG1Controller.controller_number; + break; + } + if (pRegion->EG1ControllerInvert) eg1controllervalue = 127 - eg1controllervalue; + + return eg1controllervalue;*/ // TODO: ^^^ + return 0; + } + + Voice::EGInfo Voice::CalculateEG1ControllerInfluence(double eg1ControllerValue) { + /*EGInfo eg; + // (eg1attack is different from the others) + eg.Attack = (pRegion->EG1ControllerAttackInfluence) ? + 1 + 0.031 * (double) (pRegion->EG1ControllerAttackInfluence == 1 ? + 1 : 1 << pRegion->EG1ControllerAttackInfluence) * eg1ControllerValue : 1.0; + eg.Decay = (pRegion->EG1ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerDecayInfluence) * eg1ControllerValue : 1.0; + eg.Release = (pRegion->EG1ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerReleaseInfluence) * eg1ControllerValue : 1.0; + + return eg;*/ // TODO: ^^^ + EGInfo eg; + eg.Attack = 1.0; + eg.Decay = 1.0; + eg.Release = 1.0; + return eg; + } + + double Voice::GetEG2ControllerValue(uint8_t MIDIKeyVelocity) { + /*double eg2controllervalue = 0; + switch (pRegion->EG2Controller.type) { + case ::gig::eg2_ctrl_t::type_none: // no controller defined + eg2controllervalue = 0; + break; + case ::gig::eg2_ctrl_t::type_channelaftertouch: + eg2controllervalue = GetSf2EngineChannel()->ControllerTable128; + break; + case ::gig::eg2_ctrl_t::type_velocity: + eg2controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg2_ctrl_t::type_controlchange: // MIDI control change controller + eg2controllervalue = GetSf2EngineChannel()->ControllerTablepRegion->EG2Controller.controller_number; + break; + } + if (pRegion->EG2ControllerInvert) eg2controllervalue = 127 - eg2controllervalue; + + return eg2controllervalue;*/ // TODO: ^^^ + return 0; + } + + Voice::EGInfo Voice::CalculateEG2ControllerInfluence(double eg2ControllerValue) { + /*EGInfo eg; + eg.Attack = (pRegion->EG2ControllerAttackInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerAttackInfluence) * eg2ControllerValue : 1.0; + eg.Decay = (pRegion->EG2ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerDecayInfluence) * eg2ControllerValue : 1.0; + eg.Release = (pRegion->EG2ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerReleaseInfluence) * eg2ControllerValue : 1.0; + + return eg;*/ // TODO: ^^^ + EGInfo eg; + eg.Attack = 1.0; + eg.Decay = 1.0; + eg.Release = 1.0; + return eg; + } + + float Voice::CalculateCutoffBase(uint8_t MIDIKeyVelocity) { + float cutoff = pRegion->GetInitialFilterFc(pPresetRegion); + if (MIDIKeyVelocity == 0) return cutoff; + + cutoff *= RTMath::CentsToFreqRatioUnlimited ( + ((127 - MIDIKeyVelocity) / 127.0) * -2400 // 8.4.2 MIDI Note-On Velocity to Filter Cutoff + ); + + return cutoff; + } + + float Voice::CalculateFinalCutoff(float cutoffBase) { + /*int cvalue; + if (VCFCutoffCtrl.controller) { + cvalue = GetSf2EngineChannel()->ControllerTableVCFCutoffCtrl.controller; + if (pRegion->VCFCutoffControllerInvert) cvalue = 127 - cvalue; + // VCFVelocityScale in this case means Minimum cutoff + if (cvalue < pRegion->VCFVelocityScale) cvalue = pRegion->VCFVelocityScale; + } + else { + cvalue = pRegion->VCFCutoff; + } + float fco = cutoffBase * float(cvalue); + if (fco > 127.0f) fco = 127.0f; + + return fco;*/ // TODO: ^^^ + return cutoffBase; + } + + uint8_t Voice::GetVCFCutoffCtrl() { + /*uint8_t ctrl; + switch (pRegion->VCFCutoffController) { + case ::gig::vcf_cutoff_ctrl_modwheel: + ctrl = 1; + break; + case ::gig::vcf_cutoff_ctrl_effect1: + ctrl = 12; + break; + case ::gig::vcf_cutoff_ctrl_effect2: + ctrl = 13; + break; + case ::gig::vcf_cutoff_ctrl_breath: + ctrl = 2; + break; + case ::gig::vcf_cutoff_ctrl_foot: + ctrl = 4; + break; + case ::gig::vcf_cutoff_ctrl_sustainpedal: + ctrl = 64; + break; + case ::gig::vcf_cutoff_ctrl_softpedal: + ctrl = 67; + break; + case ::gig::vcf_cutoff_ctrl_genpurpose7: + ctrl = 82; + break; + case ::gig::vcf_cutoff_ctrl_genpurpose8: + ctrl = 83; + break; + case ::gig::vcf_cutoff_ctrl_aftertouch: + ctrl = 128; + break; + case ::gig::vcf_cutoff_ctrl_none: + default: + ctrl = 0; + break; + } + + return ctrl;*/ // TODO: ^^^ + return 0; + } + + uint8_t Voice::GetVCFResonanceCtrl() { + /*uint8_t ctrl; + switch (pRegion->VCFResonanceController) { + case ::gig::vcf_res_ctrl_genpurpose3: + ctrl = 18; + break; + case ::gig::vcf_res_ctrl_genpurpose4: + ctrl = 19; + break; + case ::gig::vcf_res_ctrl_genpurpose5: + ctrl = 80; + break; + case ::gig::vcf_res_ctrl_genpurpose6: + ctrl = 81; + break; + case ::gig::vcf_res_ctrl_none: + default: + ctrl = 0; + } + + return ctrl;*/ // TODO: ^^^ + return 0; + } + + void Voice::ProcessGroupEvent(RTList<Event>::Iterator& itEvent) { + if (itEvent->Param.Note.Key != MIDIKey) { + // kill the voice fast + SignalRack.EnterFadeOutStage(); + } + } + + void Voice::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + SignalRack.CalculateFadeOutCoeff(FadeOutTime, SampleRate); + } + +}} // namespace LinuxSampler::sf2
View file
linuxsampler-2342.tar.bz2/src/engines/sf2/Voice.h
Added
@@ -0,0 +1,128 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SF2_VOICE_H__ +#define __LS_SF2_VOICE_H__ + +#include "../../common/global_private.h" + +#include "../../common/RTMath.h" +#include "../../common/Pool.h" +#include "../../drivers/audio/AudioOutputDevice.h" +#include "Stream.h" +#include "DiskThread.h" +#include "../gig/EGADSR.h" +#include "../gig/Filter.h" +#include "../common/VoiceBase.h" +#include "../gig/SynthesisParam.h" +#include "../sfz/EGADSR.h" +#include "SF2SignalUnitRack.h" + +namespace LinuxSampler { namespace sf2 { + class Engine; + class EngineChannel; + + /** SoundFont Voice + * + * Renders a voice for the SoundFont format. + */ + class Voice : public LinuxSampler::VoiceBase<EngineChannel, ::sf2::Region, ::sf2::Sample, DiskThread> { + public: + Voice(); + virtual ~Voice(); + void SetOutput(AudioOutputDevice* pAudioOutputDevice); + void SetEngine(LinuxSampler::Engine* pEngine); + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + protected: + virtual SampleInfo GetSampleInfo(); + virtual RegionInfo GetRegionInfo(); + virtual InstrumentInfo GetInstrumentInfo(); + virtual double CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity); + virtual AbstractEngine* GetEngine() { return (AbstractEngine*)pEngine; } + virtual double GetEG1ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG1ControllerInfluence(double eg1ControllerValue); + virtual void TriggerEG1(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { } + virtual double GetEG2ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG2ControllerInfluence(double eg2ControllerValue); + virtual void TriggerEG2(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { } + virtual void InitLFO1() { } + virtual void InitLFO2() { } + virtual void InitLFO3() { } + virtual float CalculateCutoffBase(uint8_t MIDIKeyVelocity); + virtual float CalculateFinalCutoff(float cutoffBase); + virtual uint8_t GetVCFCutoffCtrl(); + virtual uint8_t GetVCFResonanceCtrl(); + virtual void ProcessCCEvent(RTList<Event>::Iterator& itEvent); + virtual void ProcessCutoffEvent(RTList<Event>::Iterator& itEvent); + virtual double GetVelocityAttenuation(uint8_t MIDIKeyVelocity); + virtual double GetVelocityRelease(uint8_t MIDIKeyVelocity); + virtual double GetSampleAttenuation(); + virtual void ProcessGroupEvent(RTList<Event>::Iterator& itEvent); + virtual void AboutToTrigger(); + + private: + ::sf2::Region* pPresetRegion; + SF2SignalUnitRack SignalRack; + + public: // FIXME: just made public for debugging (sanity check in Engine::RenderAudio()), should be changed to private before the final release + // Attributes + Engine* pEngine; ///< Pointer to the sampler engine, to be able to access the event lists. + //uint LoopCyclesLeft; ///< In case there is a RAMLoop and it's not an endless loop; reflects number of loop cycles left to be passed + + // Static Methods + static float CalculateFilterCutoffCoeff(); + + // Methods + void ProcessEvents(uint Samples); + void processCrossFadeEvent(RTList<Event>::Iterator& itEvent); + + EngineChannel* GetSf2EngineChannel(); + + friend class EGUnit; + friend class VolEGUnit; + friend class ModEGUnit; + friend class ModLfoUnit; + friend class VibLfoUnit; + friend class EndpointUnit; + friend class SF2SignalUnitRack; + + protected: + virtual uint8_t CrossfadeAttenuation(uint8_t& CrossfadeControllerValue) { + /*uint8_t c = std::max(CrossfadeControllerValue, pRegion->AttenuationControllerThreshold); + c = (!pRegion->Crossfade.out_end) ? c // 0,0,0,0 means no crossfade defined + : (c < pRegion->Crossfade.in_end) ? + ((c <= pRegion->Crossfade.in_start) ? 0 + : 127 * (c - pRegion->Crossfade.in_start) / (pRegion->Crossfade.in_end - pRegion->Crossfade.in_start)) + : (c <= pRegion->Crossfade.out_start) ? 127 + : (c < pRegion->Crossfade.out_end) ? 127 * (pRegion->Crossfade.out_end - c) / (pRegion->Crossfade.out_end - pRegion->Crossfade.out_start) + : 0; + return pRegion->InvertAttenuationController ? 127 - c : c;*/ // TODO: ^^^ + return 0; + } + }; + +}} // namespace LinuxSampler::sf2 + +#endif // __LS_SF2_VOICE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/sfz
Added
+(directory)
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/DiskThread.cpp
Added
@@ -0,0 +1,63 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "DiskThread.h" +#include "Stream.h" +#include "../../common/global_private.h" + +namespace LinuxSampler { + // just a placeholder to mark a cell in the pickup array as 'reserved' + template <> + LinuxSampler::Stream* LinuxSampler::DiskThreadBase< ::sfz::Region, sfz::InstrumentResourceManager>::SLOT_RESERVED = (LinuxSampler::Stream*) &SLOT_RESERVED; + +namespace sfz { + + DiskThread::DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments) : + DiskThreadBase< ::sfz::Region, InstrumentResourceManager>(MaxStreams, BufferWrapElements, pInstruments) + { + CreateAllStreams(MaxStreams, BufferWrapElements); + } + + DiskThread::~DiskThread() { + + } + + LinuxSampler::Stream* DiskThread::CreateStream(long BufferSize, uint BufferWrapElements) { + return new Stream(BufferSize, BufferWrapElements, pInstruments->GetSampleManager()); // 131072 sample words + } + + void DiskThread::LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::sfz::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + Stream* pSfzStream = dynamic_cast<Stream*>(pStream); + if(!pSfzStream) throw Exception("Invalid stream type"); + pSfzStream->Launch(hStream, pExportReference, pRgn, SampleOffset, DoLoop); + } +}} // namespace LinuxSampler::sfz +
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/DiskThread.h
Added
@@ -0,0 +1,56 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_DISKTHREAD_H__ +#define __LS_SFZ_DISKTHREAD_H__ + +#include "../InstrumentManagerBase.h" +#include "../common/DiskThreadBase.h" +#include "InstrumentResourceManager.h" + +namespace LinuxSampler { namespace sfz { + + class DiskThread: public LinuxSampler::DiskThreadBase< ::sfz::Region, InstrumentResourceManager> { + protected: + virtual LinuxSampler::Stream* CreateStream(long BufferSize, uint BufferWrapElements); + + virtual void LaunchStream ( + LinuxSampler::Stream* pStream, + Stream::Handle hStream, + Stream::reference_t* pExportReference, + ::sfz::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); + + public: + DiskThread(int MaxStreams, uint BufferWrapElements, InstrumentResourceManager* pInstruments); + virtual ~DiskThread(); + }; + + +}} // namespace LinuxSampler::sfz + +#endif /* __LS_SFZ_STREAM_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EG.cpp
Added
@@ -0,0 +1,106 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2010 Andreas Persson * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#include "EG.h" + +#include "../../common/global_private.h" + +namespace LinuxSampler { namespace sfz { + + // Modeled after output from Rapture Demo 1.0, which means the + // stages are using a pow function and the "curve" parameter of + // the stage is ignored. The "shape" parameter decides the slope + // of the stage, a value of 1.0 or 0.0 means linear shape. The + // length of the stages are dependent on the velocity. + + // TODO: add support for loops + // TODO: optimization: use segment_lin for linear stages + // TODO: support cancel_release events? + + void EG::update(event_t Event, uint SampleRate) { + if (atEnd(Event)) return; + + // ignore duplicated release events + if (Event == event_release) { + if (GotRelease) return; + GotRelease = true; + } + + if (Event == event_stage_end || Event == event_release) { + if (Stage == eg->node.size() - 1) { + enterFadeOutStage(); + } else if (Stage == eg->sustain && Stage != 0 && + Event != event_release) { + enterSustainStage(); + } else { + if (Event == event_release) { + Stage = eg->sustain; + } else { + Level = eg->nodeStage.level; + } + + Stage++; + + float shape = eg->nodeStage.shape; + if (shape < 0.000001) shape = 1; + + float xd = eg->nodeStage.time * SampleRate * TimeCoeff; + float yd = eg->nodeStage.level - Level; + + if (eg->nodeStage - 1.shape > 0.999999 || + eg->nodeStage - 1.shape < 0.000001) { + Exp = 1 / shape; + Offset = Level; + X = 0; + XDelta = 1 / xd; + Coeff = yd; + } else { + Exp = shape; + Offset = eg->nodeStage.level; + X = 1; + XDelta = -1 / xd; + Coeff = -yd; + } + Segment = segment_pow; + StepsLeft = int(xd); + } + } + } + + void EG::trigger(::sfz::EG& eg, uint SampleRate, uint8_t Velocity) { + Stage = 0; + this->eg = ⪚ + TimeCoeff = exp(0.0054578518 * Velocity); // pow(2, Velcocity / 127) + GotRelease = false; + + enterFirstStage(); + update(event_stage_end, SampleRate); + } + + void EG::enterSustainStage() { + Segment = segment_lin; + Coeff = 0.0f; // don't change the envelope level in this stage + const int intMax = (unsigned int) -1 >> 1; + StepsLeft = intMax; // we use the highest value possible (we refresh StepsLeft in update() in case) + Level = eg->nodeStage.level; + } +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EG.h
Added
@@ -0,0 +1,70 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2010 Andreas Persson * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#ifndef LS_SFZ_EG_H +#define LS_SFZ_EG_H + +#include "../common/EG.h" +#include "../../common/global.h" +#include "../../common/RTMath.h" +#include "sfz.h" + +namespace LinuxSampler { namespace sfz { + +/** + * Multi Stage Envelope Generator + * + * SFZ v2 envelope generator with multiple stages for modulating + * arbitrary synthesis parameters. + */ +class EG : public ::LinuxSampler::EG { + public: + /** + * Will be called by the voice when the key / voice was triggered. + * + * @param eg - EG from sfz::Definition + * @param SampleRate - sample rate of used audio output driver + * @param Velocity - MIDI velocity + */ + void trigger(::sfz::EG& eg, uint SampleRate, uint8_t Velocity); + + /** + * Should be called to inform the EG about an external event and + * also whenever an envelope stage is completed. This will handle + * the envelope's transition to the respective next stage. + * + * @param Event - what happened + * @param SampleRate - sample rate + */ + void update(event_t Event, uint SampleRate); + + private: + int Stage; + ::sfz::EG* eg; + float TimeCoeff; + bool GotRelease; + void enterSustainStage(); +}; + +}} // namespace LinuxSampler::sfz + +#endif
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EGADSR.cpp
Added
@@ -0,0 +1,179 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#include "EGADSR.h" + +#include "../../common/global_private.h" + +namespace LinuxSampler { namespace sfz { + + // Modeled after output from SFZ Player 1.97 / Rapture Demo 1.0. + + void EGADSR::update(event_t Event, uint SampleRate) { + if (atEnd(Event)) return; + + switch (Stage) { + case stage_attack: + switch (Event) { + case event_release: + enterReleaseStage(); + break; + case event_stage_end: + if (HoldSteps) + enterAttackHoldStage(); + else + enterDecayStage(SampleRate); + break; + } + break; + case stage_attack_hold: + switch (Event) { + case event_stage_end: + enterDecayStage(SampleRate); + break; + case event_release: + enterReleaseStage(); + break; + } + break; + case stage_decay: + switch (Event) { + case event_release: + enterReleaseStage(); + break; + case event_stage_end: + if (Level < CONFIG_EG_BOTTOM) + enterEndStage(); + else + enterSustainStage(); + break; + } + break; + case stage_sustain: + switch (Event) { + case event_stage_end: { // just refresh time + const int intMax = (unsigned int) -1 >> 1; + StepsLeft = intMax; // we use the highest possible value + break; + } + case event_release: + enterReleaseStage(); + break; + } + break; + case stage_release: + switch (Event) { + case event_stage_end: + enterFadeOutStage(); + break; + case event_cancel_release: + enterSustainStage(); + break; + } + break; + } + } + + void EGADSR::trigger(uint PreAttack, float AttackTime, float HoldTime, float DecayTime, uint SustainLevel, float ReleaseTime, uint SampleRate, bool LinearRelease) { + this->SustainLevel = SustainLevel / 1000.0; + this->HoldSteps = int(HoldTime * SampleRate); + this->DecayTime = DecayTime; + this->LinearRelease = LinearRelease; + + if (ReleaseTime < CONFIG_EG_MIN_RELEASE_TIME) ReleaseTime = CONFIG_EG_MIN_RELEASE_TIME; // to avoid click sounds at the end of the sample playback + this->ReleaseTime = ReleaseTime * SampleRate; + Offset = 0; + enterFirstStage(); + enterAttackStage(PreAttack, AttackTime, SampleRate); + } + + void EGADSR::enterAttackStage(const uint PreAttack, const float AttackTime, const uint SampleRate) { + Stage = stage_attack; + Segment = segment_lin; + + if (AttackTime >= 0.0005f) { + StepsLeft = int(AttackTime * SampleRate); + Level = (float) PreAttack / 1000.0; + Coeff = (1.0f - Level) / StepsLeft; + } else { // attack is zero - immediately jump to the next stage + Level = 1.0f; + if (HoldSteps) enterAttackHoldStage(); + else enterDecayStage(SampleRate); + } + } + + void EGADSR::enterAttackHoldStage() { + Stage = stage_attack_hold; + Segment = segment_lin; + Coeff = 0.0f; // don't rise anymore + StepsLeft = HoldSteps; + } + + void EGADSR::enterDecayStage(const uint SampleRate) { + if (LinearRelease) { + StepsLeft = int(DecayTime * SampleRate * (Level - SustainLevel)); + if (StepsLeft > 0) { + Stage = stage_decay; + Segment = segment_lin; + Coeff = -1 / (DecayTime * SampleRate); + return; + } + } else { + StepsLeft = int(DecayTime * SampleRate); + if (StepsLeft && Level > SustainLevel) { + Stage = stage_decay; + Segment = segment_exp; + const float slope = -9.226 / StepsLeft; + Coeff = exp(slope); + StepsLeft = int(log(std::max(SustainLevel, float(CONFIG_EG_BOTTOM)) / Level) / slope); + if (StepsLeft > 0) return; + } + } + Level = SustainLevel; + enterSustainStage(); + } + + void EGADSR::enterSustainStage() { + Stage = stage_sustain; + Segment = segment_lin; + Coeff = 0.0f; // don't change the envelope level in this stage + const int intMax = (unsigned int) -1 >> 1; + StepsLeft = intMax; // we use the highest value possible (we refresh StepsLeft in update() in case) + } + + void EGADSR::enterReleaseStage() { + Stage = stage_release; + if (LinearRelease) { + Segment = segment_lin; + StepsLeft = int(Level * ReleaseTime); + Coeff = -1 / ReleaseTime; + } else { + Segment = segment_exp; + const float slope = -9.226 / ReleaseTime; + StepsLeft = int(log(CONFIG_EG_BOTTOM / Level) / slope); + Coeff = exp(slope); + } + if (StepsLeft <= 0) enterFadeOutStage(); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EGADSR.h
Added
@@ -0,0 +1,94 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#ifndef LS_SFZ_EGADSR_H +#define LS_SFZ_EGADSR_H + +#include "../common/EG.h" + +namespace LinuxSampler { namespace sfz { + +/** + * ADSR Envelope Generator + * + * SFZ v1 envelope generator with 'Attack', 'Hold', 'Decay', 'Sustain' + * and 'Release' stages for modulating arbitrary synthesis parameters. + */ +class EGADSR : public ::LinuxSampler::EG { + public: + + /** + * Will be called by the voice when the key / voice was triggered. + * + * @param PreAttack - Preattack value for the envelope + * (0 - 1000 permille) + * @param AttackTime - Attack time for the envelope + * @param HoldTime - Hold time for the envelope + * @param DecayTime - Decay1 time of the sample amplitude EG + * @param SustainLevel - Sustain level of the sample amplitude EG + * (0 - 1000 permille) + * @param ReleaseTIme - Release time for the envelope + * @param SampleRate - sample rate of used audio output driver + * @param LinearRelease - true if decay and release is linear + */ + void trigger(uint PreAttack, float AttackTime, float HoldTime, float DecayTime, uint SustainLevel, float ReleaseTime, uint SampleRate, bool LinearRelease); //FIXME: we should better use 'float' for SampleRate + + /** + * Should be called to inform the EG about an external event and + * also whenever an envelope stage is completed. This will handle + * the envelope's transition to the respective next stage. + * + * @param Event - what happened + * @param SampleRate - sample rate of used audio output driver + */ + void update(event_t Event, uint SampleRate); + + private: + + enum stage_t { + stage_attack, + stage_attack_hold, + stage_decay, + stage_sustain, + stage_release, + stage_fadeout, + stage_end + }; + + stage_t Stage; + int HoldSteps; + float DecayTime; + float SustainLevel; + float ReleaseTime; + bool LinearRelease; + + void enterAttackStage(const uint PreAttack, const float AttackTime, const uint SampleRate); + void enterAttackHoldStage(); + void enterDecayStage(const uint SampleRate); + void enterSustainStage(); + void enterReleaseStage(); +}; + +}} // namespace LinuxSampler::sfz + +#endif // LS_SFZ_EGADSR_H
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Engine.cpp
Added
@@ -0,0 +1,262 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "Engine.h" +#include "EngineChannel.h" + +namespace LinuxSampler { namespace sfz { + Engine::Format Engine::GetEngineFormat() { return SFZ; } + + Engine::Engine() { + pCCPool = new Pool<CCSignalUnit::CC>(GLOBAL_MAX_VOICES * MaxCCPerVoice); + pSmootherPool = new Pool<Smoother>(GLOBAL_MAX_VOICES * MaxCCPerVoice); + for (VoiceIterator iterVoice = GetVoicePool()->allocAppend(); iterVoice == GetVoicePool()->last(); iterVoice = GetVoicePool()->allocAppend()) { + (static_cast<SfzSignalUnitRack*>(iterVoice->pSignalUnitRack))->InitRTLists(); + } + GetVoicePool()->clear(); + } + + Engine::~Engine() { + if (pCCPool) { + pCCPool->clear(); + delete pCCPool; + } + + if (pSmootherPool) { + pSmootherPool->clear(); + delete pSmootherPool; + } + } + + void Engine::PostSetMaxVoices(int iVoices) { + pCCPool->resizePool(iVoices * MaxCCPerVoice); + pSmootherPool->resizePool(iVoices * MaxCCPerVoice); + + for (VoiceIterator iterVoice = GetVoicePool()->allocAppend(); iterVoice == GetVoicePool()->last(); iterVoice = GetVoicePool()->allocAppend()) { + (static_cast<SfzSignalUnitRack*>(iterVoice->pSignalUnitRack))->InitRTLists(); + } + GetVoicePool()->clear(); + } + + /** + * Reacts on supported control change commands (e.g. pitch bend wheel, + * modulation wheel, aftertouch). + * + * @param pEngineChannel - engine channel on which this event occured on + * @param itControlChangeEvent - controller, value and time stamp of the event + */ + void Engine::ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ) { + uint8_t cc = itControlChangeEvent->Param.CC.Controller; + dmsg(4,("Engine::ContinuousController cc=%d v=%d\n", cc, itControlChangeEvent->Param.CC.Value)); + + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + + // update controller value in the engine channel's controller table + pChannel->ControllerTablecc = itControlChangeEvent->Param.CC.Value; + + ProcessHardcodedControllers(pEngineChannel, itControlChangeEvent); + + // handle FX send controllers + ProcessFxSendControllers(pChannel, itControlChangeEvent); + + // handle control triggered regions: a control change event + // can trigger a new voice + if (pChannel->pInstrument && cc < 128) { + + ::sfz::Query q; + q.chan = itControlChangeEvent->Param.CC.Channel + 1; + q.key = 60; + q.vel = 127; + q.bend = pChannel->Pitch; + q.bpm = 0; + q.chanaft = pChannel->ControllerTable128; + q.polyaft = 0; + q.prog = 0; + q.rand = Random(); + q.cc = pChannel->ControllerTable; + q.timer = 0; + q.sw = pChannel->PressedKeys; + q.last_sw_key = pChannel->LastKeySwitch; + q.prev_sw_key = pChannel->LastKey; + q.trig = TRIGGER_ATTACK | TRIGGER_FIRST; + + q.search(pChannel->pInstrument, cc); + + int i = 0; + while (::sfz::Region* region = q.next()) { + if (!RegionSuspended(region)) { + itControlChangeEvent->Param.Note.Key = 60; + itControlChangeEvent->Param.Note.Velocity = 127; + itControlChangeEvent->Param.Note.pRegion = region; + LaunchVoice(pChannel, itControlChangeEvent, i, false, false, true); + } + i++; + } + } + } + + DiskThread* Engine::CreateDiskThread() { + return new DiskThread ( + iMaxDiskStreams, + ((pAudioOutputDevice->MaxSamplesPerCycle() << CONFIG_MAX_PITCH) << 1) + 6, //FIXME: assuming stereo + &instruments + ); + } + + void Engine::TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + ::sfz::Query q; + q.chan = itNoteOnEvent->Param.Note.Channel + 1; + q.key = itNoteOnEvent->Param.Note.Key; + q.vel = itNoteOnEvent->Param.Note.Velocity; + q.bend = pChannel->Pitch; + q.bpm = 0; + q.chanaft = pChannel->ControllerTable128; + q.polyaft = 0; + q.prog = 0; + q.rand = Random(); + q.cc = pChannel->ControllerTable; + q.timer = 0; + q.sw = pChannel->PressedKeys; + q.last_sw_key = pChannel->LastKeySwitch; + q.prev_sw_key = pChannel->LastKey; + q.trig = TRIGGER_ATTACK | + ((pChannel->LastKey != -1 && + pChannel->PressedKeyspChannel->LastKey && + pChannel->LastKey != q.key) ? + TRIGGER_LEGATO : TRIGGER_FIRST); + + q.search(pChannel->pInstrument); + + int i = 0; + while (::sfz::Region* region = q.next()) { + if (!RegionSuspended(region)) { + itNoteOnEvent->Param.Note.pRegion = region; + LaunchVoice(pChannel, itNoteOnEvent, i, false, true, HandleKeyGroupConflicts); + } + i++; + } + } + + void Engine::TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + ::sfz::Query q; + q.chan = itNoteOffEvent->Param.Note.Channel + 1; + q.key = itNoteOffEvent->Param.Note.Key; + + // MIDI note-on velocity is used instead of note-off velocity + q.vel = pChannel->pMIDIKeyInfoq.key.Velocity; + itNoteOffEvent->Param.Note.Velocity = q.vel; + + q.bend = pChannel->Pitch; + q.bpm = 0; + q.chanaft = pChannel->ControllerTable128; + q.polyaft = 0; + q.prog = 0; + q.rand = Random(); + q.cc = pChannel->ControllerTable; + q.timer = 0; + q.sw = pChannel->PressedKeys; + q.last_sw_key = pChannel->LastKeySwitch; + q.prev_sw_key = pChannel->LastKey; + q.trig = TRIGGER_RELEASE; + + q.search(pChannel->pInstrument); + + // now launch the required amount of voices + int i = 0; + while (::sfz::Region* region = q.next()) { + itNoteOffEvent->Param.Note.pRegion = region; + LaunchVoice(pChannel, itNoteOffEvent, i, true, false, true); //FIXME: for the moment we don't perform voice stealing for release triggered samples + i++; + } + } + + Pool<Voice>::Iterator Engine::LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ) { + EngineChannel* pChannel = static_cast<EngineChannel*>(pEngineChannel); + int key = itNoteOnEvent->Param.Note.Key; + EngineChannel::MidiKey* pKey = &pChannel->pMIDIKeyInfokey; + ::sfz::Region* pRgn = static_cast< ::sfz::Region*>(itNoteOnEvent->Param.Note.pRegion); + + Voice::type_t VoiceType = + itNoteOnEvent->Type == Event::type_control_change ? Voice::type_controller_triggered : + ReleaseTriggerVoice ? Voice::type_release_trigger : + iLayer == 0 ? Voice::type_release_trigger_required : + Voice::type_normal; + if (pRgn->loop_mode == ::sfz::ONE_SHOT) VoiceType |= Voice::type_one_shot; + + Pool<Voice>::Iterator itNewVoice; + + if (HandleKeyGroupConflicts) pChannel->HandleKeyGroupConflicts(pRgn->group, itNoteOnEvent); + + // no need to process if sample is silent + if (!pRgn->GetSample(false) || !pRgn->GetSample()->GetTotalFrameCount()) return Pool<Voice>::Iterator(); + + // allocate a new voice for the key + itNewVoice = pKey->pActiveVoices->allocAppend(); + int res = InitNewVoice ( + pChannel, pRgn, itNoteOnEvent, VoiceType, iLayer, + pRgn->off_by, ReleaseTriggerVoice, VoiceStealing, itNewVoice + ); + if (!res) return itNewVoice; + + // return if this is a release triggered voice and there is no + // releasetrigger dimension (could happen if an instrument + // change has occured between note on and off) + //if (ReleaseTriggerVoice && VoiceType != Voice::type_release_trigger) return Pool<Voice>::Iterator(); + + return Pool<Voice>::Iterator(); // no free voice or error + } + + bool Engine::DiskStreamSupported() { + return true; + } + + String Engine::Description() { + return "SFZ Format Engine"; + } + + String Engine::Version() { + String s = "$Revision: 1.11 $"; + return s.substr(11, s.size() - 13); // cut dollar signs, spaces and CVS macro keyword + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Engine.h
Added
@@ -0,0 +1,87 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2010 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_ENGINE_H__ +#define __LS_SFZ_ENGINE_H__ + +#include "DiskThread.h" +#include "../EngineBase.h" +#include "Voice.h" +#include "sfz.h" + +namespace LinuxSampler { namespace sfz { + const int MaxCCPerVoice = 128; // FIXME: too much? + + class Engine: public LinuxSampler::EngineBase<Voice, ::sfz::Region, ::sfz::Region, DiskThread, InstrumentResourceManager, ::sfz::Instrument> { + public: + Engine(); + virtual ~Engine(); + // implementation of abstract methods derived from class 'LinuxSampler::Engine' + virtual bool DiskStreamSupported(); + virtual String Description(); + virtual String Version(); + + virtual Format GetEngineFormat(); + + virtual void ProcessControlChange ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itControlChangeEvent + ); + + virtual void PostSetMaxVoices(int iVoices); + + friend class Voice; + friend class SfzSignalUnitRack; + + protected: + Pool<CCSignalUnit::CC>* pCCPool; + Pool<Smoother>* pSmootherPool; + + virtual DiskThread* CreateDiskThread(); + + virtual Pool<Voice>::Iterator LaunchVoice ( + LinuxSampler::EngineChannel* pEngineChannel, + Pool<Event>::Iterator& itNoteOnEvent, + int iLayer, + bool ReleaseTriggerVoice, + bool VoiceStealing, + bool HandleKeyGroupConflicts + ); + + virtual void TriggerNewVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOnEvent, + bool HandleKeyGroupConflicts + ); + + void TriggerReleaseVoices ( + LinuxSampler::EngineChannel* pEngineChannel, + RTList<Event>::Iterator& itNoteOffEvent + ); + }; + +}} // namespace LinuxSampler::sfz + +#endif /* __LS_SFZ_ENGINE_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EngineChannel.cpp
Added
@@ -0,0 +1,168 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2011 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "EngineChannel.h" +#include "Engine.h" + +namespace LinuxSampler { namespace sfz { + EngineChannel::EngineChannel() { + for(int i = 0; i < 128; i++) PressedKeysi = false; + LastKey = LastKeySwitch = -1; + AddMidiKeyboardListener(this); + } + + EngineChannel::~EngineChannel() { + DisconnectAudioOutputDevice(); + RemoveMidiKeyboardListener(this); + // In case the channel was removed before the instrument was + // fully loaded, try to give back instrument again (see bug #113) + InstrumentChangeCmd< ::sfz::Region, ::sfz::Instrument>& cmd = ChangeInstrument(NULL); + if (cmd.pInstrument) { + Engine::instruments.HandBack(cmd.pInstrument, this); + } + /////// + } + + AbstractEngine::Format EngineChannel::GetEngineFormat() { return AbstractEngine::SFZ; } + + /** This method is not thread safe! */ + void EngineChannel::ResetInternal() { + CurrentKeyDimension = 0; + EngineChannelBase<Voice, ::sfz::Region, ::sfz::Instrument>::ResetInternal(); + for(int i = 0; i < 128; i++) PressedKeysi = false; + } + + /** + * Will be called by the MIDIIn Thread to signal that a program + * change should be performed. As a program change isn't + * real-time safe, the actual change is performed by the disk + * thread. + * + * @param Program - MIDI program change number + */ + void EngineChannel::SendProgramChange(uint8_t Program) { + SetMidiProgram(Program); + Engine* engine = dynamic_cast<Engine*>(pEngine); + if(engine == NULL) return; + + if(engine->GetDiskThread()) { + uint32_t merged = (GetMidiBankMsb() << 16) | (GetMidiBankLsb() << 8) | Program; + engine->GetDiskThread()->OrderProgramChange(merged, this); + } else { + // TODO: + } + } + + /** + * Load an instrument from a .sfz file. PrepareLoadInstrument() has to + * be called first to provide the information which instrument to load. + * This method will then actually start to load the instrument and block + * the calling thread until loading was completed. + * + * @see PrepareLoadInstrument() + */ + void EngineChannel::LoadInstrument() { + InstrumentResourceManager* pInstrumentManager = dynamic_cast<InstrumentResourceManager*>(pEngine->GetInstrumentManager()); + + // make sure we don't trigger any new notes with an old + // instrument + InstrumentChangeCmd< ::sfz::Region, ::sfz::Instrument>& cmd = ChangeInstrument(0); + if (cmd.pInstrument) { + // give old instrument back to instrument manager, but + // keep the dimension regions and samples that are in use + pInstrumentManager->HandBackInstrument(cmd.pInstrument, this, cmd.pRegionsInUse); + } + cmd.pRegionsInUse->clear(); + + // delete all key groups + DeleteGroupEventLists(); + + // request sfz instrument from instrument manager + ::sfz::Instrument* newInstrument; + try { + InstrumentManager::instrument_id_t instrid; + instrid.FileName = InstrumentFile; + instrid.Index = InstrumentIdx; + + newInstrument = pInstrumentManager->Borrow(instrid, this); + if (!newInstrument) { + throw InstrumentManagerException("resource was not created"); + } + } + catch (InstrumentManagerException e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sfz::Engine error: Failed to load instrument, cause: " + e.Message(); + throw Exception(msg); + } + catch (::sfz::Exception e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sfz::Engine error: Failed to load instrument, cause: " + e.Message(); + throw Exception(msg); + } + catch (::std::runtime_error e) { + InstrumentStat = -3; + StatusChanged(true); + String msg = "sfz::Engine error: Failed to load instrument, cause: "; + msg += e.what(); + throw Exception(msg); + } + catch (...) { + InstrumentStat = -4; + StatusChanged(true); + throw Exception("sfz::Engine error: Failed to load instrument, cause: Unknown exception while trying to parse sfz file."); + } + + // rebuild ActiveKeyGroups map with key groups of current instrument + for (std::vector< ::sfz::Region*>::iterator itRegion = newInstrument->regions.begin() ; + itRegion != newInstrument->regions.end() ; ++itRegion) { + AddGroup((*itRegion)->group); + AddGroup((*itRegion)->off_by); + } + + InstrumentIdxName = newInstrument->GetName(); + InstrumentStat = 100; + + ChangeInstrument(newInstrument); + + StatusChanged(true); + } + + void EngineChannel::ProcessKeySwitchChange(int key) { } + + void EngineChannel::PreProcessNoteOn(uint8_t key, uint8_t velocity) { + if(pInstrument != NULL && pInstrument->HasKeySwitchBinding(key)) LastKeySwitch = key; + PressedKeyskey = true; + } + + void EngineChannel::PostProcessNoteOn(uint8_t key, uint8_t velocity) { + LastKey = key; + } + + void EngineChannel::PreProcessNoteOff(uint8_t key, uint8_t velocity) { + PressedKeyskey = false; + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/EngineChannel.h
Added
@@ -0,0 +1,66 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_ENGINECHANNEL_H__ +#define __LS_SFZ_ENGINECHANNEL_H__ + +#include "../AbstractEngine.h" +#include "../EngineChannelBase.h" +#include "../EngineChannelFactory.h" +#include "Voice.h" +#include "sfz.h" + +namespace LinuxSampler { namespace sfz { + class EngineChannel: public LinuxSampler::EngineChannelBase<Voice, ::sfz::Region, ::sfz::Instrument>, public MidiKeyboardAdapter { + public: + virtual void SendProgramChange(uint8_t Program); + virtual void LoadInstrument(); + virtual void ResetInternal(); + + virtual AbstractEngine::Format GetEngineFormat(); + + // methods derived from MidiKeyboardListener + virtual void PreProcessNoteOn(uint8_t key, uint8_t velocity); + virtual void PostProcessNoteOn(uint8_t key, uint8_t velocity); + virtual void PreProcessNoteOff(uint8_t key, uint8_t velocity); + + friend class Voice; + friend class Engine; + friend class LinuxSampler::EngineChannelFactory; + + protected: + EngineChannel(); + virtual ~EngineChannel(); + + virtual void ProcessKeySwitchChange(int key); + + private: + bool PressedKeys128; + int LastKeySwitch; + int LastKey; + }; + +}} // namespace LinuxSampler::sfz + +#endif /* __LS_SFZ_ENGINECHANNEL_H__ */
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/InstrumentResourceManager.cpp
Added
@@ -0,0 +1,199 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <sstream> + +#include "InstrumentResourceManager.h" +#include "EngineChannel.h" +#include "Engine.h" + +#include "../../common/global_private.h" +#include "../../common/Path.h" +#include "../../plugins/InstrumentEditorFactory.h" + + +namespace LinuxSampler { namespace sfz { + + String InstrumentResourceManager::GetInstrumentName(instrument_id_t ID) { + Lock(); + ::sfz::Instrument* pInstrument = Resource(ID, false); + String res = (pInstrument) ? pInstrument->GetName() : ""; + Unlock(); + return res; + } + + std::vector<InstrumentResourceManager::instrument_id_t> InstrumentResourceManager::GetInstrumentFileContent(String File) throw (InstrumentManagerException) { + std::vector<instrument_id_t> result; + instrument_id_t id; + id.FileName = File; + id.Index = 0; + result.push_back(id); + return result; + } + + InstrumentResourceManager::instrument_info_t InstrumentResourceManager::GetInstrumentInfo(instrument_id_t ID) throw (InstrumentManagerException) { + if (ID.Index) throw InstrumentManagerException("There is no instrument " + ToString(ID.Index) + " in " + ID.FileName); + Lock(); + ::sfz::Instrument* pInstrument = Resource(ID, false); + bool loaded = (pInstrument != NULL); + if (!loaded) Unlock(); + + ::sfz::File* sfz = NULL; + try { + if (!loaded) { + sfz = new ::sfz::File(ID.FileName); + pInstrument = sfz->GetInstrument(); + } + + if (!pInstrument) throw InstrumentManagerException("There is no instrument " + ToString(ID.Index) + " in " + ID.FileName); + + instrument_info_t info; + info.InstrumentName = Path::getBaseName(ID.FileName); + + for (int i = 0; i < 128; i++) { + info.KeyBindingsi = pInstrument->HasKeyBinding(i); + info.KeySwitchBindingsi = pInstrument->HasKeySwitchBinding(i); + } + + if (loaded) Unlock(); + + if (sfz) delete sfz; + return info; + } catch (::sfz::Exception e) { + if (loaded) Unlock(); + if (sfz) delete sfz; + throw InstrumentManagerException(e.Message()); + } catch (...) { + if (loaded) Unlock(); + if (sfz) delete sfz; + throw InstrumentManagerException("Unknown exception while trying to parse '" + ID.FileName + "'"); + } + } + + ::sfz::Instrument* InstrumentResourceManager::Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg) { + // get sfz file from internal sfz file manager + ::sfz::File* pSfz = Sfzs.Borrow(Key.FileName, reinterpret_cast<SfzConsumer*>(Key.Index)); // conversion kinda hackish :/ + + dmsg(1,("Loading sfz instrument ('%s',%d)...",Key.FileName.c_str(),Key.Index)); + if (Key.Index) { + std::stringstream msg; + msg << "There's no instrument with index " << Key.Index << "."; + throw InstrumentManagerException(msg.str()); + } + ::sfz::Instrument* pInstrument = pSfz->GetInstrument(); + if (!pInstrument) { + std::stringstream msg; + msg << "There's no instrument with index " << Key.Index << "."; + throw InstrumentManagerException(msg.str()); + } + dmsg(1,("OK\n")); + + // cache initial samples points (for actually needed samples) + dmsg(1,("Caching initial samples...")); + int regionCount = pInstrument->regions.size(); + uint maxSamplesPerCycle = GetMaxSamplesPerCycle(pConsumer); + for (int i = 0 ; i < regionCount ; i++) { + float localProgress = (float) i / (float) regionCount; + DispatchResourceProgressEvent(Key, localProgress); + CacheInitialSamples(pInstrument->regionsi->GetSample(), maxSamplesPerCycle); + //pInstrument->regionsi->GetSample()->Close(); + } + dmsg(1,("OK\n")); + DispatchResourceProgressEvent(Key, 1.0f); // done; notify all consumers about progress 100% + + // we need the following for destruction later + instr_entry_t* pEntry = new instr_entry_t; + pEntry->ID.FileName = Key.FileName; + pEntry->ID.Index = Key.Index; + pEntry->pFile = pSfz; + + // and we save this to check if we need to reallocate for an engine with higher value of 'MaxSamplesPerSecond' + pEntry->MaxSamplesPerCycle = maxSamplesPerCycle; + + pArg = pEntry; + + return pInstrument; + } + + void InstrumentResourceManager::Destroy(::sfz::Instrument* pResource, void* pArg) { + instr_entry_t* pEntry = (instr_entry_t*) pArg; + // we don't need the .sfz file here anymore + Sfzs.HandBack(pEntry->pFile, reinterpret_cast<SfzConsumer*>(pEntry->ID.Index)); // conversion kinda hackish :/ + delete pEntry; + } + + void InstrumentResourceManager::DeleteRegionIfNotUsed(::sfz::Region* pRegion, region_info_t* pRegInfo) { + ::sfz::File* file = pRegInfo->file; + if (file == NULL) return; + + file->GetInstrument()->DestroyRegion(pRegion); + if (file->GetInstrument()->regions.empty()) { + dmsg(2,("No more regions in use - freeing sfz\n")); + delete file; + } + } + + void InstrumentResourceManager::DeleteSampleIfNotUsed(Sample* pSample, region_info_t* pRegInfo) { + + } + + + + // internal sfz file manager + + ::sfz::File* InstrumentResourceManager::SfzResourceManager::Create(String Key, SfzConsumer* pConsumer, void*& pArg) { + dmsg(1,("Loading sfz file \'%s\'...", Key.c_str())); + ::sfz::File* pSfz = new ::sfz::File(Key, &sampleManager); + dmsg(1,("OK\n")); + return pSfz; + } + + void InstrumentResourceManager::SfzResourceManager::Destroy(::sfz::File* pResource, void* pArg) { + dmsg(1,("Freeing sfz file from memory...")); + + // Delete as much as possible of the sfz file. Some of the + // regions and samples may still be in use - these + // will be deleted later by the HandBackRegion function. + bool deleteInstrument = true; + ::sfz::Instrument* pInstr = pResource->GetInstrument(); + + for (int i = pInstr->regions.size() - 1; i >= 0 ; i--) { + ::sfz::Region* pRegion = pInstr->regionsi; + std::map< ::sfz::Region*, region_info_t>::iterator iter = parent->RegionInfo.find(pRegion); + if (iter != parent->RegionInfo.end()) { + region_info_t& regInfo = (*iter).second; + regInfo.file = pResource; + deleteInstrument = false; + } else { + pInstr->DestroyRegion(pRegion); + } + } + + if (deleteInstrument) delete pResource; + else dmsg(2,("keeping some samples that are in use...")); + + dmsg(1,("OK\n")); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/InstrumentResourceManager.h
Added
@@ -0,0 +1,102 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_INSTRUMENTRESOURCEMANAGER_H__ +#define __LS_SFZ_INSTRUMENTRESOURCEMANAGER_H__ + +#include "../../common/global.h" + +#include "sfz.h" + +#include "../../common/global.h" +#include "../../common/Pool.h" +#include "../../common/ResourceManager.h" +#include "../../drivers/audio/AudioOutputDevice.h" +#include "../InstrumentManagerBase.h" +#include "../common/Sample.h" +#include "../../common/ArrayList.h" + +namespace LinuxSampler { namespace sfz { + + typedef ResourceConsumer< ::sfz::Instrument> InstrumentConsumer; + +}} // namespace LinuxSampler::sfz + +#include "../../plugins/InstrumentEditor.h" + +namespace LinuxSampler { namespace sfz { + class Engine; + class EngineChannel; + + /** @brief sfz instrument manager + * + * Manager to share sfz instruments between multiple sfz + * engine channels. The engine channels Borrow() instruments when they + * need them and HandBack() when they don't need them anymore. The + * InstrumentResourceManager loads the corresponding sfz file and sfz + * instrument if needed, if it's already in use by another engine + * channel, then it just returns the same resource, if a sfz + * instrument / file is not needed anymore, then it will be freed from + * memory. + */ + class InstrumentResourceManager : public InstrumentManagerBase< ::sfz::File, ::sfz::Instrument, ::sfz::Region, Sample> { + public: + InstrumentResourceManager() : Sfzs(this) {} + virtual ~InstrumentResourceManager() {} + + // implementation of derived abstract methods from 'InstrumentManager' + virtual String GetInstrumentName(instrument_id_t ID); + virtual std::vector<instrument_id_t> GetInstrumentFileContent(String File) throw (InstrumentManagerException); + virtual instrument_info_t GetInstrumentInfo(instrument_id_t ID) throw (InstrumentManagerException); + + ::sfz::SampleManager* GetSampleManager() { return &Sfzs.sampleManager; } + + protected: + // implementation of derived abstract methods from 'ResourceManager' + virtual ::sfz::Instrument* Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg); + virtual void Destroy(::sfz::Instrument* pResource, void* pArg); + virtual void DeleteRegionIfNotUsed(::sfz::Region* pRegion, region_info_t* pRegInfo); + virtual void DeleteSampleIfNotUsed(Sample* pSample, region_info_t* pRegInfo); + private: + typedef ResourceConsumer< ::sfz::File> SfzConsumer; + + class SfzResourceManager : public ResourceManager<String, ::sfz::File> { + protected: + // implementation of derived abstract methods from 'ResourceManager' + virtual ::sfz::File* Create(String Key, SfzConsumer* pConsumer, void*& pArg); + virtual void Destroy(::sfz::File* pResource, void* pArg); + virtual void OnBorrow(::sfz::File* pResource, SfzConsumer* pConsumer, void*& pArg) {} // ignore + public: + SfzResourceManager(InstrumentResourceManager* parent) : parent(parent) {} + virtual ~SfzResourceManager() {} + friend class InstrumentResourceManager; + private: + InstrumentResourceManager* parent; + ::sfz::SampleManager sampleManager; + } Sfzs; + }; + +}} // namespace LinuxSampler::sfz + +#endif // __LS_SFZ_INSTRUMENTRESOURCEMANAGER_H__
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/LookupTable.cpp
Added
@@ -0,0 +1,352 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2010 Andreas Persson * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#include "LookupTable.h" +#include <cstdio> +#include <set> +#include "../../common/global_private.h" + +namespace sfz { + + struct LookupTable::DimDef { + const int Definition::* lo; + const int Definition::* hi; + const uint8_t Query::* qarg; + int min; + int max; + const char* str; + }; + + // List of all dimensions handled by the lookup table, except + // control change. Only uint8_t types are currently supported. + const LookupTable::DimDef LookupTable::dimDefs = { + { &Region::lochan, &Region::hichan, + &Query::chan, 1, 16, "chan" }, + { &Region::lokey, &Region::hikey, + &Query::key, 0, 127, "key" }, + { &Region::lovel, &Region::hivel, + &Query::vel, 0, 127, "vel" }, + { &Region::lochanaft, &Region::hichanaft, + &Query::chanaft, 0, 127, "chanaft" }, + { &Region::lopolyaft, &Region::hipolyaft, + &Query::polyaft, 0, 127, "polyaft" }, + { &Region::loprog, &Region::hiprog, + &Query::prog, 0, 127, "prog" }, + { &Region::sw_previous, &Region::sw_previous, + &Query::prev_sw_key, -1, -1, "sw_previous" }, + { 0, 0, 0, 0 } + }; + + // fills a mapping array for a given dimension + int LookupTable::fillMapArr(const std::vector<Region*>& regions, + const int Definition::* lo, + const int Definition::* hi, + int min, int max, int* a) { + std::set<int> s; + s.insert(min); + s.insert(max + 1); + for (std::vector<Region*>::const_iterator i = regions.begin() ; + i != regions.end() ; ++i) { + s.insert((*i)->*lo); + s.insert((*i)->*hi + 1); + } + + int j = min; + int l = -1; + for (std::set<int>::const_iterator i = s.begin() ; + i != s.end() ; ++i) { + dmsg(2,(" %d", *i)); + for ( ; j < *i ; j++) { + aj = l; + } + l++; + } + dmsg(2,("\n")); + return l; + } + + // fills a mapping array for a given control change number + int LookupTable::fillMapArr(const std::vector<Region*>& regions, + int cc, int* a, int triggercc) { + std::set<int> s; + s.insert(0); + s.insert(128); + for (std::vector<Region*>::const_iterator i = regions.begin() ; + i != regions.end() ; ++i) { + int lo = (*i)->locccc; + int hi = (*i)->hicccc; + if (cc == triggercc) { + lo = std::max(lo, (*i)->on_locccc); + hi = std::min(hi, (*i)->on_hicccc); + } + + s.insert(lo); + s.insert(hi + 1); + } + + int j = 0; + int l = -1; + for (std::set<int>::const_iterator i = s.begin() ; + i != s.end() ; ++i) { + dmsg(2,(" %d", *i)); + for ( ; j < *i ; j++) { + aj = l; + } + l++; + } + dmsg(2,("\n")); + return l; + } + + LinuxSampler::ArrayList<Region*>& + LookupTable::query(const Query& q) const { + int offset = 0; + int dim; + for (dim = 0 ; qargsdim ; dim++) { + offset += mapArrdimint8_t(q.*qargsdim); + } + for (int cc = 0 ; ccargscc >= 0 ; cc++, dim++) { + offset += mapArrdimq.ccccargscc; + } + return regionArroffset; + } + + // recursively fills the region array with regions + void LookupTable::fillRegionArr(const int* len, Region* region, + std::vector<int>::size_type dim, int j, + int triggercc) { + if (dim == dims.size() + ccs.size()) { + regionArrj.add(region); + } else if (dim < dims.size()) { + int d = dimsdim; + int hi = region->*dimDefsd.hi; + // special case for sw_previous + if (hi == -1) hi = 127; + for (int l = mapArrdimregion->*dimDefsd.lo ; + l <= mapArrdimhi ; l++) { + fillRegionArr(len, region, dim + 1, j * lendim + l, + triggercc); + } + } else { + int cc = ccsdim - dims.size(); + int lo = region->locccc; + int hi = region->hicccc; + if (cc == triggercc) { + lo = std::max(lo, region->on_locccc); + hi = std::min(hi, region->on_hicccc); + } + for (int l = mapArrdimlo ; l <= mapArrdimhi ; l++) { + fillRegionArr(len, region, dim + 1, j * lendim + l, + triggercc); + } + } + } + + + LookupTable::LookupTable(const Instrument* instrument, int triggercc) { + std::vector<Region*> regions; + + // copy the interesting regions + for (std::vector<Region*>::const_iterator i = + instrument->regions.begin() ; + i != instrument->regions.end() ; ++i) { + + if (triggercc == -1) { + if ((*i)->lokey >= 0) { + regions.push_back(*i); + } + } else { + if ((*i)->hikey < 0 && + (*i)->on_locctriggercc >= 0 && + (*i)->on_hicctriggercc >= 0) { + regions.push_back(*i); + } + } + } + + dmsg(2,("\nregions before filter: %d, after: %d\n", + instrument->regions.size(), regions.size())); + + // find dimensions used by the instrument + for (int dim = 0 ; dimDefsdim.lo ; dim++) { + for (std::vector<Region*>::const_iterator i = regions.begin() ; + i != regions.end() ; ++i) { + + if ((triggercc == -1 || dimDefsdim.lo != &Region::lokey) && + ((*i)->*dimDefsdim.lo != dimDefsdim.min || + (*i)->*dimDefsdim.hi != dimDefsdim.max)) { + dims.push_back(dim); + break; + } + } + } + + // create and fill the qargs array with pointers to Query + // members + qargs = new const uint8_t Query::*dims.size() + 1; + for (std::vector<int>::size_type i = 0 ; i < dims.size() ; i++) { + dmsg(2,("qargs %d: %s\n", i, dimDefsdimsi.str)); + qargsi = dimDefsdimsi.qarg; + } + qargsdims.size() = 0; + + // find CC dimensions used by the instrument + for (int cc = 0 ; cc < 128 ; cc++) { + for (std::vector<Region*>::const_iterator i = regions.begin() ; + i != regions.end() ; ++i) { + int lo = (*i)->locccc; + int hi = (*i)->hicccc; // TODO == -1 ? 127 : (*i)->hicccc; + if (cc == triggercc) { + lo = std::max(lo, (*i)->on_locccc); + hi = std::min(hi, (*i)->on_hicccc); + } + if (lo > 0 || hi != 127) { + ccs.push_back(cc); + break; + } + } + } + + // copy ccs vector to ccargs array + ccargs = new intccs.size() + 1; + for (std::vector<int>::size_type i = 0 ; i < ccs.size() ; ++i) { + dmsg(2,("ccargs %d: %d\n", i, ccsi)); + ccargsi = ccsi; + } + ccargsccs.size() = -1; + + int nbDimensions = dims.size() + ccs.size(); + int* len = new intnbDimensions; + mapArr = new int*nbDimensions; + + int size = 1; + int dim = 0; + + // create and fill the dimension mapping arrays + + for (std::vector<int>::const_iterator dimi = dims.begin() ; + dimi != dims.end() ; ++dimi) { + int min = dimDefs*dimi.min; + int max = dimDefs*dimi.max == -1 ? 127 : dimDefs*dimi.max; + mapArrdim = new intmax - min + 1 - min; + lendim = fillMapArr(regions, dimDefs*dimi.lo, dimDefs*dimi.hi, + min, max, mapArrdim); + size *= lendim; + dim++; + } + + for (std::vector<int>::const_iterator cci = ccs.begin() ; + cci != ccs.end() ; ++cci) { + mapArrdim = new int128; + lendim = fillMapArr(regions, *cci, mapArrdim, triggercc); + size *= lendim; + dim++; + } + + + dmsg(2,("-------------------------------\n")); + dmsg(2,("nbDimensions=%d size=%d\n", nbDimensions, size)); + + // create and fill the region array + regionArr = new LinuxSampler::ArrayList<Region*>size; + + for (std::vector<Region*>::const_iterator i = regions.begin() ; + i != regions.end() ; ++i) { + fillRegionArr(len, *i, 0, 0, triggercc); + } + + // multiply the offsets in the mapping arrays so simple + // addition can be used in the query method + if (nbDimensions) { + int c = lennbDimensions - 1; + for (dim = nbDimensions - 2 ; dim >= 0 ; dim--) { + for (int i = 0 ; i < 128 ; i++) mapArrdimi *= c; + c *= lendim; + } + } + +#if CONFIG_DEBUG_LEVEL >= 2 + // print the dimension mapping arrays + + dmsg(2,("-------------------------------\n")); + dim = 0; + for (std::vector<int>::const_iterator dimi = dims.begin() ; + dimi != dims.end() ; ++dimi) { + dmsg(2,("%d: len=%d dim=%s\n", dim, lendim, dimDefs*dimi.str)); + + int max = dimDefs*dimi.max == -1 ? 127 : dimDefs*dimi.max; + for (int i = dimDefs*dimi.min ; i <= max ; i++) { + dmsg(2,(" %d", mapArrdimi)); + } + dmsg(2,("\n")); + + dim++; + } + for (std::vector<int>::const_iterator cci = ccs.begin() ; + cci != ccs.end() ; ++cci) { + dmsg(2,("%d: len=%d cc=%d\n", dim, lendim, *cci)); + + for (int i = 0 ; i < 128 ; i++) { + dmsg(2,(" %d", mapArrdimi)); + } + dmsg(2,("\n")); + + dim++; + } +#endif + delete len; + +#if CONFIG_DEBUG_LEVEL >= 3 + // print the region array + + int tot = 0; + for (int i = 0 ; i < size ; i++) { + dmsg(3,("%d:", i)); + for (int j = 0 ; j < regionArri.size() ; j++) { + dmsg(3,(" %s", regionArrij->sample.c_str())); + tot++; + } + dmsg(3,("\n")); + } + dmsg(3,("tot=%d\n", tot)); +#endif + } + + LookupTable::~LookupTable() { + delete qargs; + delete ccargs; + delete regionArr; + + int dim = 0; + for (std::vector<int>::const_iterator dimi = dims.begin() ; + dimi != dims.end() ; ++dimi) { + delete (mapArrdim + dimDefs*dimi.min); + dim++; + } + for (std::vector<int>::const_iterator cci = ccs.begin() ; + cci != ccs.end() ; ++cci) { + delete mapArrdim; + dim++; + } + delete mapArr; + } +}
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/LookupTable.h
Added
@@ -0,0 +1,107 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2010 Andreas Persson * + * * + * 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 St, Fifth Floor, Boston, * + * MA 02110-1301 USA * + ***************************************************************************/ + +#ifndef SFZ_LOOKUPTABLE_H +#define SFZ_LOOKUPTABLE_H + +#include <vector> + +#include "sfz.h" +#include "../../common/ArrayList.h" + +namespace sfz { + + /** + * Lookup table for fast access to regions in an sfz instrument. + * + * The table is organized in two levels. First, the values of the + * dimensions actually in use by the instrument (could be key, + * velocity, controller values, etc) are used as indexes in a set + * of integer arrays. The resulting integers are then added + * together and the sum is used as an index in an array of lists + * of regions. + * + * The first level is used to make the second array smaller. An + * instrument with three key zones and two velocity zones will + * have two integer arrays, each of size 128, one for key number, + * one for velocity. The region array only needs to be six items + * big, as there are only 2 * 3 possible zone variations. + */ + class LookupTable { + public: + /** + * Constructs a lookup table for the instrument. If triggercc + * is specified, the lookup table is made for regions + * triggered by the MIDI controller, otherwise the table is + * made for ordinary note-on triggered regions. + * + * @param instrument - instrument + * @param triggercc - controller number or -1 + */ + LookupTable(const Instrument* instrument, int triggercc = -1); + + ~LookupTable(); + + /** + * Performs a lookup in the table of regions. + * + * @param q - query with constraints on key, velocity, etc. + * @returns list of regions matching the query + */ + LinuxSampler::ArrayList<Region*>& query(const Query& q) const; + + private: + struct DimDef; + + static const DimDef dimDefs; // list of possible dimensions + std::vector<int> dims; // dimensions used by the instrument + + // control change dimensions used by the instrument + std::vector<int> ccs; + + // arrays mapping dimension values to regionArr offsets + int** mapArr; + + // second level array with lists of regions + LinuxSampler::ArrayList<Region*>* regionArr; + + // pointers to used dimension arguments in the Query object + const uint8_t Query::** qargs; + + // array with CCs used by the instrument + int* ccargs; + + + // helper functions for the constructor + static int fillMapArr(const std::vector<Region*>& regions, + const int Definition::* lo, + const int Definition::* hi, + int min, int max, int* a); + static int fillMapArr(const std::vector<Region*>& regions, + int cc, int* a, int triggercc); + void fillRegionArr(const int* len, Region* region, + std::vector<int>::size_type dim, int j, + int triggercc); + }; +} + +#endif
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Makefile.am
Added
@@ -0,0 +1,18 @@ +INCLUDES = $(all_includes) $(GIG_CFLAGS) +METASOURCES = AUTO + +AM_CXXFLAGS = -Wreturn-type -ffast-math + +noinst_LTLIBRARIES = liblinuxsamplersfzengine.la +liblinuxsamplersfzengine_la_SOURCES = \ + sfz.cpp sfz.h \ + InstrumentResourceManager.cpp InstrumentResourceManager.h \ + DiskThread.cpp DiskThread.h \ + EngineChannel.cpp EngineChannel.h \ + Engine.cpp Engine.h \ + Voice.cpp Voice.h \ + Stream.cpp Stream.h \ + EGADSR.cpp EGADSR.h \ + EG.cpp EG.h \ + SfzSignalUnitRack.cpp SfzSignalUnitRack.h \ + LookupTable.cpp LookupTable.h
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/SfzSignalUnitRack.cpp
Added
@@ -0,0 +1,1313 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 - 2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "SfzSignalUnitRack.h" +#include "Engine.h" + +#define _200TH_ROOT_OF_10 1.011579454259899 + +namespace LinuxSampler { namespace sfz { + + double ToRatio(int Centibels) { + if (Centibels == 0) return 1.0; + return pow(_200TH_ROOT_OF_10, Centibels); + } + + SfzSignalUnit::SfzSignalUnit(SfzSignalUnitRack* rack): SignalUnit(rack), pVoice(rack->pVoice) { + + } + + double SfzSignalUnit::GetSampleRate() { + return pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + } + + float SfzSignalUnit::GetInfluence(ArrayList< ::sfz::CC>& cc) { + float f = 0; + for (int i = 0; i < cc.size(); i++) { + int val = pVoice->GetControllerValue(cci.Controller); + f += (val / 127.0f) * cci.Influence; + } + return f; + } + + void XFInCCUnit::SetCrossFadeCCs(::sfz::Array<int>& loCCs, ::sfz::Array<int>& hiCCs) { + RemoveAllCCs(); + + for (int cc = 0; cc < 128; cc++) { + if (loCCscc == 0 && hiCCscc == 0) continue; + int i = loCCscc; + int j = hiCCscc; + if (j == 0) j = 127; + i += j << 8; // workaround to keep both values in the Influence parameter + AddCC(cc, i); + } + } + + void XFInCCUnit::Calculate() { + float l = 1; + + RTList<CC>::Iterator ctrl = pCtrls->first(); + RTList<CC>::Iterator end = pCtrls->end(); + for(; ctrl != end; ++ctrl) { + float c = 1; + int influence = (*ctrl).Influence; + int lo = influence & 0xff; + int hi = influence >> 8; + if ((*ctrl).Value <= lo) { + c = 0; + } else if ((*ctrl).Value >= hi) { + c = 1; + } else { + float xfVelSize = hi - lo; + float velPos = (*ctrl).Value - lo; + c = velPos / xfVelSize; + if (pVoice->pRegion->xf_cccurve == ::sfz::POWER) { + c = sin(c * M_PI / 2.0); + } + } + + l *= c; + } + + if (Level != l) { + Level = l; + if (pListener != NULL) pListener->ValueChanged(this); + } + } + + + void XFOutCCUnit::Calculate() { + float l = 1; + + RTList<CC>::Iterator ctrl = pCtrls->first(); + RTList<CC>::Iterator end = pCtrls->end(); + for(; ctrl != end; ++ctrl) { + float c = 1; + int influence = (*ctrl).Influence; + int lo = influence & 0xff; + int hi = influence >> 8; + if ((*ctrl).Value >= hi) { + c = 0; + } else if ((*ctrl).Value <= lo) { + c = 1; + } else { + float xfVelSize = hi - lo; + float velPos = (*ctrl).Value - lo; + c = 1.0f - velPos / xfVelSize; + if (pVoice->pRegion->xf_cccurve == ::sfz::POWER) { + c = sin(c * M_PI / 2.0); + } + } + + l *= c; + } + + if (Level != l) { + Level = l; + if (pListener != NULL) pListener->ValueChanged(this); + } + } + + + EGv2Unit::EGv2Unit(SfzSignalUnitRack* rack) + : EGUnit< ::LinuxSampler::sfz::EG>(rack), EqUnitSupport(rack), suAmpOnCC(rack), suVolOnCC(rack), + suPitchOnCC(rack), suCutoffOnCC(rack), suResOnCC(rack), suPanOnCC(rack) + { } + + void EGv2Unit::Trigger() { + egInfo = *pEGInfo; + for (int i = 0; i < egInfo.node.size(); i++) { + float f = GetInfluence(egInfo.nodei.level_oncc); + egInfo.nodei.level = std::min(egInfo.nodei.level + f, 1.0f); + + f = GetInfluence(egInfo.nodei.time_oncc); + egInfo.nodei.time = std::min(egInfo.nodei.time + f, 100.0f); + } + EG.trigger(egInfo, GetSampleRate(), pVoice->MIDIVelocity); + } + + + void PitchEGUnit::Trigger() { + ::sfz::Region* const pRegion = pVoice->pRegion; + depth = pRegion->pitcheg_depth + GetInfluence(pRegion->pitcheg_depth_oncc); + + // the length of the decay and release curves are dependent on the velocity + const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); + + // set the delay trigger + float delay = pRegion->pitcheg_delay + pRegion->pitcheg_vel2delay * velrelease; + delay += GetInfluence(pRegion->pitcheg_delay_oncc); + uiDelayTrigger = std::max(0.0f, delay) * GetSampleRate(); + + float start = (pRegion->pitcheg_start + GetInfluence(pRegion->pitcheg_start_oncc)) * 10; + + float attack = pRegion->pitcheg_attack + pRegion->pitcheg_vel2attack * velrelease; + attack = std::max(0.0f, attack + GetInfluence(pRegion->pitcheg_attack_oncc)); + + float hold = pRegion->pitcheg_hold + pRegion->pitcheg_vel2hold * velrelease; + hold = std::max(0.0f, hold + GetInfluence(pRegion->pitcheg_hold_oncc)); + + float decay = pRegion->pitcheg_decay + pRegion->pitcheg_vel2decay * velrelease; + decay = std::max(0.0f, decay + GetInfluence(pRegion->pitcheg_decay_oncc)); + + float sustain = pRegion->pitcheg_sustain + pRegion->pitcheg_vel2sustain * velrelease; + sustain = 10 * (sustain + GetInfluence(pRegion->pitcheg_sustain_oncc)); + + float release = pRegion->pitcheg_release + pRegion->pitcheg_vel2release * velrelease; + release = std::max(0.0f, release + GetInfluence(pRegion->pitcheg_release_oncc)); + + EG.trigger ( + uint(std::min(std::max(0.0f, start), 1000.0f)), attack, hold, decay, + uint(std::min(std::max(0.0f, sustain), 1000.0f)), release, GetSampleRate(), true + ); + } + + + void FilEGUnit::Trigger() { + ::sfz::Region* const pRegion = pVoice->pRegion; + depth = pRegion->fileg_depth + GetInfluence(pRegion->fileg_depth_oncc); + + // the length of the decay and release curves are dependent on the velocity + const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); + + // set the delay trigger + float delay = pRegion->fileg_delay + pRegion->fileg_vel2delay * velrelease; + delay += GetInfluence(pRegion->fileg_delay_oncc); + uiDelayTrigger = std::max(0.0f, delay) * GetSampleRate(); + + float start = (pRegion->fileg_start + GetInfluence(pRegion->fileg_start_oncc)) * 10; + + float attack = pRegion->fileg_attack + pRegion->fileg_vel2attack * velrelease; + attack = std::max(0.0f, attack + GetInfluence(pRegion->fileg_attack_oncc)); + + float hold = pRegion->fileg_hold + pRegion->fileg_vel2hold * velrelease; + hold = std::max(0.0f, hold + GetInfluence(pRegion->fileg_hold_oncc)); + + float decay = pRegion->fileg_decay + pRegion->fileg_vel2decay * velrelease; + decay = std::max(0.0f, decay + GetInfluence(pRegion->fileg_decay_oncc)); + + float sustain = pRegion->fileg_sustain + pRegion->fileg_vel2sustain * velrelease; + sustain = 10 * (sustain + GetInfluence(pRegion->fileg_sustain_oncc)); + + float release = pRegion->fileg_release + pRegion->fileg_vel2release * velrelease; + release = std::max(0.0f, release + GetInfluence(pRegion->fileg_release_oncc)); + + EG.trigger ( + uint(std::min(std::max(0.0f, start), 1000.0f)), attack, hold, decay, + uint(std::min(std::max(0.0f, sustain), 1000.0f)), release, GetSampleRate(), true + ); + } + + + void AmpEGUnit::Trigger() { + ::sfz::Region* const pRegion = pVoice->pRegion; + + // the length of the decay and release curves are dependent on the velocity + const double velrelease = 1 / pVoice->GetVelocityRelease(pVoice->MIDIVelocity); + + // set the delay trigger + float delay = pRegion->ampeg_delay + pRegion->ampeg_vel2delay * velrelease; + delay += GetInfluence(pRegion->ampeg_delaycc); + uiDelayTrigger = std::max(0.0f, delay) * GetSampleRate(); + + float start = (pRegion->ampeg_start + GetInfluence(pRegion->ampeg_startcc)) * 10; + + float attack = pRegion->ampeg_attack + pRegion->ampeg_vel2attack * velrelease; + attack = std::max(0.0f, attack + GetInfluence(pRegion->ampeg_attackcc)); + + float hold = pRegion->ampeg_hold + pRegion->ampeg_vel2hold * velrelease; + hold = std::max(0.0f, hold + GetInfluence(pRegion->ampeg_holdcc)); + + float decay = pRegion->ampeg_decay + pRegion->ampeg_vel2decay * velrelease; + decay = std::max(0.0f, decay + GetInfluence(pRegion->ampeg_decaycc)); + + float sustain = pRegion->ampeg_sustain + pRegion->ampeg_vel2sustain * velrelease; + sustain = 10 * (sustain + GetInfluence(pRegion->ampeg_sustaincc)); + + float release = pRegion->ampeg_release + pRegion->ampeg_vel2release * velrelease; + release = std::max(0.0f, release + GetInfluence(pRegion->ampeg_releasecc)); + + EG.trigger ( + uint(std::min(std::max(0.0f, start), 1000.0f)), attack, hold, decay, + uint(std::min(std::max(0.0f, sustain), 1000.0f)), release, GetSampleRate(), false + ); + } + + + LFOUnit::LFOUnit(SfzSignalUnitRack* rack) + : SfzSignalUnit(rack), pLfoInfo(NULL), pLFO(NULL), + suFadeEG(rack), suFreqOnCC(rack, this), suDepthOnCC(rack) + { } + + LFOUnit::LFOUnit(const LFOUnit& Unit) + : SfzSignalUnit(Unit), suFadeEG(static_cast<SfzSignalUnitRack*>(Unit.pRack)), + suFreqOnCC(static_cast<SfzSignalUnitRack*>(Unit.pRack), this), + suDepthOnCC(static_cast<SfzSignalUnitRack*>(Unit.pRack)) + { + Copy(Unit); + } + + void LFOUnit::Increment() { + if (DelayStage()) return; + + SignalUnit::Increment(); + + Level = pLFO->Render(); + if (suFadeEG.Active()) Level *= suFadeEG.GetLevel(); + } + + void LFOUnit::Trigger() { + //reset + Level = 0; + + // set the delay trigger + uiDelayTrigger = (pLfoInfo->delay + GetInfluence(pLfoInfo->delay_oncc)) * GetSampleRate(); + if(pLfoInfo->fade != 0 || !pLfoInfo->fade_oncc.empty()) { + float f = pLfoInfo->fade; + f += GetInfluence(pLfoInfo->fade_oncc); + + if (f != 0) { + suFadeEG.uiDelayTrigger = pLfoInfo->delay * GetSampleRate(); + suFadeEG.EG.trigger(0, f, 0, 0, 1000, 0, GetSampleRate(), false); + } + } + } + + void LFOUnit::ValueChanged(CCSignalUnit* pUnit) { + if (pLFO == NULL) return; + pLFO->SetFrequency(std::max(0.0f, suFreqOnCC.GetLevel() + pLfoInfo->freq), GetSampleRate()); + } + + + void LFOv1Unit::Trigger() { + LFOUnit::Trigger(); + + lfo.trigger ( + pLfoInfo->freq + suFreqOnCC.GetLevel(), + start_level_mid, + 1, 0, false, GetSampleRate() + ); + lfo.update(0); + } + + + LFOv2Unit::LFOv2Unit(SfzSignalUnitRack* rack) + : LFOUnit(rack), EqUnitSupport(rack), lfos(8), lfo0(1200.0f), lfo1(1200.0f), lfo2(1200.0f), + lfo3(1200.0f), lfo4(1200.0f), lfo5(1200.0f), lfo6(1200.0f), lfo7(1200.0f), + suVolOnCC(rack), suPitchOnCC(rack), suPanOnCC(rack), suCutoffOnCC(rack), suResOnCC(rack) + { + lfos.add(&lfo0); + lfos.add(&lfo1); + lfos.add(&lfo2); + lfos.add(&lfo3); + lfos.add(&lfo4); + lfos.add(&lfo5); + lfos.add(&lfo6); + lfos.add(&lfo7); + } + + void LFOv2Unit::Trigger() { + LFOUnit::Trigger(); + + if (pLfoInfo->wave < 0 || pLfoInfo->wave >= lfos.size()) pLFO = &lfo0; + else pLFO = lfospLfoInfo->wave; + + pLFO->Trigger ( + pLfoInfo->freq + suFreqOnCC.GetLevel(), + start_level_mid, + 1, 0, false, GetSampleRate() + ); + pLFO->Update(0); + + float phase = pLfoInfo->phase + GetInfluence(pLfoInfo->phase_oncc); + if (phase != 0) pLFO->SetPhase(phase); + } + + void AmpLFOUnit::Trigger() { + bActive = true; + ::sfz::Region* const pRegion = pVoice->pRegion; + pLfoInfo->delay = pRegion->amplfo_delay + GetInfluence(pRegion->amplfo_delay_oncc); + pLfoInfo->freq = pRegion->amplfo_freq; + pLfoInfo->fade = pRegion->amplfo_fade + GetInfluence(pRegion->amplfo_fade_oncc); + pLfoInfo->volume = pRegion->amplfo_depth; + + if (pLfoInfo->freq <= 0) { + if (!pRegion->amplfo_freqcc.empty()) pLfoInfo->freq = 0; + else bActive = false; + } + + LFOv1Unit::Trigger(); + } + + void PitchLFOUnit::Trigger() { + bActive = true; + ::sfz::Region* const pRegion = pVoice->pRegion; + pLfoInfo->delay = pRegion->pitchlfo_delay + GetInfluence(pRegion->pitchlfo_delay_oncc); + pLfoInfo->freq = pRegion->pitchlfo_freq; + pLfoInfo->fade = pRegion->pitchlfo_fade + GetInfluence(pRegion->pitchlfo_fade_oncc); + pLfoInfo->pitch = pRegion->pitchlfo_depth; + + if (pLfoInfo->freq <= 0) { + if (!pRegion->pitchlfo_freqcc.empty()) pLfoInfo->freq = 0; + else bActive = false; + } + + LFOv1Unit::Trigger(); + } + + void FilLFOUnit::Trigger() { + bActive = true; + ::sfz::Region* const pRegion = pVoice->pRegion; + pLfoInfo->delay = pRegion->fillfo_delay + GetInfluence(pRegion->fillfo_delay_oncc); + pLfoInfo->freq = pRegion->fillfo_freq; + pLfoInfo->fade = pRegion->fillfo_fade + GetInfluence(pRegion->fillfo_fade_oncc); + pLfoInfo->cutoff = pRegion->fillfo_depth; + + if (pLfoInfo->freq <= 0) { + if (!pRegion->fillfo_freqcc.empty()) pLfoInfo->freq = 0; + else bActive = false; + } + + LFOv1Unit::Trigger(); + } + + CCUnit::CCUnit(SfzSignalUnitRack* rack, Listener* l): CCSignalUnit(rack, l) { + pVoice = NULL; + } + + void CCUnit::Trigger() { + RTList<CC>::Iterator ctrl = pCtrls->first(); + RTList<CC>::Iterator end = pCtrls->end(); + for(; ctrl != end; ++ctrl) { + (*ctrl).Value = pVoice->GetControllerValue((*ctrl).Controller); + if ((*ctrl).pSmoother != NULL) { + if ((*ctrl).Step > 0) { + float val = Normalize((*ctrl).Value, (*ctrl).Curve) * (*ctrl).Influence; + (*ctrl).pSmoother->setValue( ((int) (val / (*ctrl).Step)) * (*ctrl).Step ); + } else { + (*ctrl).pSmoother->setValue((*ctrl).Value); + } + } + } + CCSignalUnit::Trigger(); + } + + void CCUnit::SetCCs(::sfz::Array<int>& cc) { + RemoveAllCCs(); + for (int i = 0; i < 128; i++) { + if (cci != 0) AddCC(i, cci); + } + } + + void CCUnit::SetCCs(::sfz::Array<float>& cc) { + RemoveAllCCs(); + for (int i = 0; i < 128; i++) { + if (cci != 0) AddCC(i, cci); + } + } + + void CCUnit::SetCCs(ArrayList< ::sfz::CC>& cc) { + RemoveAllCCs(); + for (int i = 0; i < cc.size(); i++) { + if (cci.Influence != 0) { + short int curve = cci.Curve; + if (curve >= GetCurveCount()) curve = -1; + AddSmoothCC(cci.Controller, cci.Influence, curve, cci.Smooth, cci.Step); + } + } + } + + void CCUnit::AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth, float Step) { + AddCC(Controller, Influence, Curve, NULL, Step); + } + + int CCUnit::GetCurveCount() { + return pVoice->pRegion->GetInstrument()->curves.size(); + } + + ::sfz::Curve* CCUnit::GetCurve(int idx) { + return &pVoice->pRegion->GetInstrument()->curvesidx; + } + + double CCUnit::GetSampleRate() { + return pVoice->GetSampleRate() / CONFIG_DEFAULT_SUBFRAGMENT_SIZE; + } + + + SmoothCCUnit::~SmoothCCUnit() { + if (pSmoothers != NULL) delete pSmoothers; + } + + void SmoothCCUnit::AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth, float Step) { + if (Smooth > 0) { + if (pSmoothers->poolIsEmpty()) { + std::cerr << "Maximum number of smoothers reached" << std::endl; + return; + } + Smoother* smoother = &(*(pSmoothers->allocAppend())); + smoother->trigger(Smooth / 1000.0f, GetSampleRate()); + AddCC(Controller, Influence, Curve, smoother, Step); + } else { + AddCC(Controller, Influence, Curve, NULL, Step); + } + } + + void SmoothCCUnit::InitSmoothers(Pool<Smoother>* pSmootherPool) { + if (pSmoothers != NULL) delete pSmoothers; + pSmoothers = new RTList<Smoother>(pSmootherPool); + } + + void SmoothCCUnit::InitCCList(Pool<CC>* pCCPool, Pool<Smoother>* pSmootherPool) { + CurveCCUnit::InitCCList(pCCPool, pSmootherPool); + InitSmoothers(pSmootherPool); + } + + + EndpointUnit::EndpointUnit(SfzSignalUnitRack* rack) + : EndpointSignalUnit(rack), suXFInCC(rack), suXFOutCC(rack), suPanOnCC(rack), pitchVeltrackRatio(0) + { + + } + + float EndpointUnit::GetInfluence(::sfz::Array< ::sfz::optional<float> >& cc) { + float f = 0; + for (int i = 0; i < 128; i++) { + if (cci) { + f += (pVoice->GetControllerValue(i) / 127.0f) * (*cci); + } + } + return f; + } + + float EndpointUnit::GetInfluence(::sfz::Array< ::sfz::optional<int> >& cc) { + float f = 0; + for (int i = 0; i < 128; i++) { + if (cci) { + f += (pVoice->GetControllerValue(i) / 127.0f) * (*cci); + } + } + return f; + } + + SfzSignalUnitRack* const EndpointUnit::GetRack() { + return static_cast<SfzSignalUnitRack* const>(pRack); + } + + void EndpointUnit::Trigger() { + uiDelayTrigger = (uint)GetInfluence(pVoice->pRegion->delay_samples_oncc); + if (pVoice->pRegion->delay_samples) uiDelayTrigger += *pVoice->pRegion->delay_samples; + + if (pVoice->pRegion->delay) { + /* here we use the device sample rate */ + uiDelayTrigger += (uint)( (*pVoice->pRegion->delay) * pVoice->GetSampleRate() ); + } + + if (pVoice->pRegion->delay_random) { + float r = pVoice->GetEngine()->Random(); + uiDelayTrigger += (uint)( r * (*pVoice->pRegion->delay_random) * pVoice->GetSampleRate() ); + } + + uiDelayTrigger += (uint)(GetInfluence(pVoice->pRegion->delay_oncc) * pVoice->GetSampleRate()); + + float xfInVelCoeff = 1; + + if (pVoice->MIDIVelocity <= pVoice->pRegion->xfin_lovel) { + xfInVelCoeff = 0; + } else if (pVoice->MIDIVelocity >= pVoice->pRegion->xfin_hivel) { + xfInVelCoeff = 1; + } else { + float xfVelSize = pVoice->pRegion->xfin_hivel - pVoice->pRegion->xfin_lovel; + float velPos = pVoice->MIDIVelocity - pVoice->pRegion->xfin_lovel; + xfInVelCoeff = velPos / xfVelSize; + if (pVoice->pRegion->xf_velcurve == ::sfz::POWER) { + xfInVelCoeff = sin(xfInVelCoeff * M_PI / 2.0); + } + } + + float xfOutVelCoeff = 1; + + if (pVoice->MIDIVelocity >= pVoice->pRegion->xfout_hivel) { + if (pVoice->pRegion->xfout_lovel < 127 /* is set */) xfOutVelCoeff = 0; + } else if (pVoice->MIDIVelocity <= pVoice->pRegion->xfout_lovel) { + xfOutVelCoeff = 1; + } else { + float xfVelSize = pVoice->pRegion->xfout_hivel - pVoice->pRegion->xfout_lovel; + float velPos = pVoice->MIDIVelocity - pVoice->pRegion->xfout_lovel; + xfOutVelCoeff = 1.0f - velPos / xfVelSize; + if (pVoice->pRegion->xf_velcurve == ::sfz::POWER) { + xfOutVelCoeff = sin(xfOutVelCoeff * M_PI / 2.0); + } + } + + float xfInKeyCoeff = 1; + + if (pVoice->MIDIKey <= pVoice->pRegion->xfin_lokey) { + if (pVoice->pRegion->xfin_hikey > 0 /* is set */) xfInKeyCoeff = 0; + } else if (pVoice->MIDIKey >= pVoice->pRegion->xfin_hikey) { + xfInKeyCoeff = 1; + } else { + float xfKeySize = pVoice->pRegion->xfin_hikey - pVoice->pRegion->xfin_lokey; + float keyPos = pVoice->MIDIKey - pVoice->pRegion->xfin_lokey; + xfInKeyCoeff = keyPos / xfKeySize; + if (pVoice->pRegion->xf_keycurve == ::sfz::POWER) { + xfInKeyCoeff = sin(xfInKeyCoeff * M_PI / 2.0); + } + } + + float xfOutKeyCoeff = 1; + + if (pVoice->MIDIKey >= pVoice->pRegion->xfout_hikey) { + if (pVoice->pRegion->xfout_lokey < 127 /* is set */) xfOutKeyCoeff = 0; + } else if (pVoice->MIDIKey <= pVoice->pRegion->xfout_lokey) { + xfOutKeyCoeff = 1; + } else { + float xfKeySize = pVoice->pRegion->xfout_hikey - pVoice->pRegion->xfout_lokey; + float keyPos = pVoice->MIDIKey - pVoice->pRegion->xfout_lokey; + xfOutKeyCoeff = 1.0f - keyPos / xfKeySize; + if (pVoice->pRegion->xf_keycurve == ::sfz::POWER) { + xfOutKeyCoeff = sin(xfOutKeyCoeff * M_PI / 2.0); + } + } + + xfCoeff = xfInVelCoeff * xfOutVelCoeff * xfInKeyCoeff * xfOutKeyCoeff; + + suXFInCC.SetCrossFadeCCs(pVoice->pRegion->xfin_locc, pVoice->pRegion->xfin_hicc); + suXFOutCC.SetCrossFadeCCs(pVoice->pRegion->xfout_locc, pVoice->pRegion->xfout_hicc); + + suPanOnCC.SetCCs(pVoice->pRegion->pan_oncc); + + pitchVeltrackRatio = RTMath::CentsToFreqRatioUnlimited((pVoice->MIDIVelocity / 127.0f) * pVoice->pRegion->pitch_veltrack); + } + + bool EndpointUnit::Active() { + if (pRack->isReleaseStageEntered() && uiDelayTrigger) { + return false; // The key was released before the delay end, so the voice won't play at all. + } + + if (GetRack()->suVolEG.Active()) return true; + + bool b = false; + for (int i = 0; i < GetRack()->volEGs.size(); i++) { + if (GetRack()->volEGsi->Active()) { b = true; break; } + } + + return b; + } + + float EndpointUnit::GetVolume() { + float vol = GetRack()->suVolEG.Active() ? GetRack()->suVolEG.GetLevel() : 0; + + for (int i = 0; i < GetRack()->volEGs.size(); i++) { + EGv2Unit* eg = GetRack()->volEGsi; + if (!eg->Active()) continue; + + float dB = eg->suVolOnCC.Active() ? eg->suVolOnCC.GetLevel() : -200; + if (dB < -144) dB = eg->pEGInfo->volume; + else if (eg->pEGInfo->volume >= -144) dB += eg->pEGInfo->volume; + + float amp = eg->suAmpOnCC.Active() ? eg->suAmpOnCC.GetLevel() : 0; + amp = (amp + eg->pEGInfo->amplitude) / 100.0f; + + if (dB >= -144) { + if (amp == 0 && eg->suAmpOnCC.GetCCCount() == 0) amp = 1.0f; + amp *= ToRatio(dB * 10.0); + } + + vol += amp * eg->GetLevel(); + } + + AmpLFOUnit* u = &(GetRack()->suAmpLFO); + CCSignalUnit* u2 = &(GetRack()->suAmpLFO.suDepthOnCC); + float f = u2->Active() ? u2->GetLevel() : 0; + vol *= u->Active() ? ToRatio((u->GetLevel() * (u->pLfoInfo->volume + f) * 10.0)) : 1; + + vol *= ToRatio(GetRack()->suVolOnCC.GetLevel() * 10.0); + + for (int i = 0; i < GetRack()->volLFOs.size(); i++) { + LFOv2Unit* lfo = GetRack()->volLFOsi; + if (!lfo->Active()) continue; + + float f = lfo->suVolOnCC.Active() ? lfo->suVolOnCC.GetLevel() : 0; + vol *= ToRatio(lfo->GetLevel() * (lfo->pLfoInfo->volume + f) * 10.0); + } + + if (suXFInCC.Active()) vol *= suXFInCC.GetLevel(); + if (suXFOutCC.Active()) vol *= suXFOutCC.GetLevel(); + return vol * xfCoeff; + } + + float EndpointUnit::GetFilterCutoff() { + float val = GetRack()->suCutoffOnCC.Active() ? RTMath::CentsToFreqRatioUnlimited(GetRack()->suCutoffOnCC.GetLevel()) : 1; + + FilLFOUnit* u = &(GetRack()->suFilLFO); + CCSignalUnit* u1 = &(GetRack()->suFilLFO.suDepthOnCC); + float f = u1->Active() ? u1->GetLevel() : 0; + val *= u->Active() ? RTMath::CentsToFreqRatioUnlimited(u->GetLevel() * (u->pLfoInfo->cutoff + f)) : 1; + + FilEGUnit* u2 = &(GetRack()->suFilEG); + val *= u2->Active() ? RTMath::CentsToFreqRatioUnlimited(u2->GetLevel() * u2->depth) : 1; + + for (int i = 0; i < GetRack()->filEGs.size(); i++) { + EGv2Unit* eg = GetRack()->filEGsi; + if (!eg->Active()) continue; + + float f = eg->suCutoffOnCC.Active() ? eg->suCutoffOnCC.GetLevel() : 0; + f = eg->GetLevel() * (eg->pEGInfo->cutoff + f); + val *= RTMath::CentsToFreqRatioUnlimited(f); + } + + for (int i = 0; i < GetRack()->filLFOs.size(); i++) { + LFOv2Unit* lfo = GetRack()->filLFOsi; + if (!lfo->Active()) continue; + + float f = lfo->suCutoffOnCC.Active() ? lfo->suCutoffOnCC.GetLevel() : 0; + f = lfo->GetLevel() * (lfo->pLfoInfo->cutoff + f); + val *= RTMath::CentsToFreqRatioUnlimited(f); + } + + return val; + } + + float EndpointUnit::CalculateFilterCutoff(float cutoff) { + cutoff *= GetFilterCutoff(); + float maxCutoff = 0.49 * pVoice->GetSampleRate(); + return cutoff > maxCutoff ? maxCutoff : cutoff; + } + + float EndpointUnit::GetPitch() { + double p = GetRack()->suPitchOnCC.Active() ? RTMath::CentsToFreqRatioUnlimited(GetRack()->suPitchOnCC.GetLevel()) : 1; + + EGv1Unit* u = &(GetRack()->suPitchEG); + p *= u->Active() ? RTMath::CentsToFreqRatioUnlimited(u->GetLevel() * u->depth) : 1; + + for (int i = 0; i < GetRack()->pitchEGs.size(); i++) { + EGv2Unit* eg = GetRack()->pitchEGsi; + if (!eg->Active()) continue; + + float f = eg->suPitchOnCC.Active() ? eg->suPitchOnCC.GetLevel() : 0; + p *= RTMath::CentsToFreqRatioUnlimited(eg->GetLevel() * (eg->pEGInfo->pitch + f)); + } + + PitchLFOUnit* u2 = &(GetRack()->suPitchLFO); + CCSignalUnit* u3 = &(GetRack()->suPitchLFO.suDepthOnCC); + float f = u3->Active() ? u3->GetLevel() : 0; + p *= u2->Active() ? RTMath::CentsToFreqRatioUnlimited(u2->GetLevel() * (u2->pLfoInfo->pitch + f)) : 1; + + for (int i = 0; i < GetRack()->pitchLFOs.size(); i++) { + LFOv2Unit* lfo = GetRack()->pitchLFOsi; + if (!lfo->Active()) continue; + + float f = lfo->suPitchOnCC.Active() ? lfo->suPitchOnCC.GetLevel() : 0; + p *= RTMath::CentsToFreqRatioUnlimited(lfo->GetLevel() * (lfo->pLfoInfo->pitch + f)); + } + + return p * pitchVeltrackRatio; + } + + float EndpointUnit::GetResonance() { + float val = GetRack()->suResOnCC.Active() ? GetRack()->suResOnCC.GetLevel() : 0; + + for (int i = 0; i < GetRack()->resEGs.size(); i++) { + EGv2Unit* eg = GetRack()->resEGsi; + if (!eg->Active()) continue; + + float f = eg->suResOnCC.Active() ? eg->suResOnCC.GetLevel() : 0; + val += eg->GetLevel() * (eg->pEGInfo->resonance + f); + } + + for (int i = 0; i < GetRack()->resLFOs.size(); i++) { + LFOv2Unit* lfo = GetRack()->resLFOsi; + if (!lfo->Active()) continue; + + float f = lfo->suResOnCC.Active() ? lfo->suResOnCC.GetLevel() : 0; + val += lfo->GetLevel() * (lfo->pLfoInfo->resonance + f); + } + + return val; + } + + float EndpointUnit::GetPan() { + float pan = suPanOnCC.Active() ? suPanOnCC.GetLevel() : 0; + + for (int i = 0; i < GetRack()->panEGs.size(); i++) { + EGv2Unit* eg = GetRack()->panEGsi; + if (!eg->Active()) continue; + + float f = eg->suPanOnCC.Active() ? eg->suPanOnCC.GetLevel() : 0; + + if (eg->pEGInfo->pan_curve >= 0 && eg->pEGInfo->pan_curve < suPanOnCC.GetCurveCount()) { + uint8_t val = eg->GetLevel() * 127; + if (val > 127) val = 127; + pan += eg->pEGInfo->pan * suPanOnCC.GetCurve(eg->pEGInfo->pan_curve)->vval + eg->GetLevel() * f; + } else { + pan += eg->GetLevel() * (eg->pEGInfo->pan + f); + } + } + + for (int i = 0; i < GetRack()->panLFOs.size(); i++) { + LFOv2Unit* lfo = GetRack()->panLFOsi; + if (!lfo->Active()) continue; + + float f = lfo->suPanOnCC.Active() ? lfo->suPanOnCC.GetLevel() : 0; + pan += lfo->GetLevel() * (lfo->pLfoInfo->pan + f); + } + + if(pan < -100) return -100; + if(pan > 100) return 100; + + return pan; + } + + + SfzSignalUnitRack::SfzSignalUnitRack(Voice* voice) + : SignalUnitRack(MaxUnitCount), EqUnitSupport(this, voice), pVoice(voice), + suEndpoint(this), suVolEG(this), suFilEG(this), suPitchEG(this), + EGs(maxEgCount), volEGs(maxEgCount), pitchEGs(maxEgCount), filEGs(maxEgCount), + resEGs(maxEgCount), panEGs(maxEgCount), eqEGs(maxEgCount), + suVolOnCC(this), suPitchOnCC(this), suCutoffOnCC(this), suResOnCC(this), + suAmpLFO(this), suPitchLFO(this), suFilLFO(this), + LFOs(maxLfoCount), volLFOs(maxLfoCount), pitchLFOs(maxLfoCount), + filLFOs(maxLfoCount), resLFOs(maxLfoCount), panLFOs(maxLfoCount), eqLFOs(maxLfoCount) + { + suEndpoint.pVoice = suEndpoint.suXFInCC.pVoice = suEndpoint.suXFOutCC.pVoice = suEndpoint.suPanOnCC.pVoice = voice; + suVolEG.pVoice = suFilEG.pVoice = suPitchEG.pVoice = voice; + suAmpLFO.pVoice = suPitchLFO.pVoice = suFilLFO.pVoice = voice; + + suVolOnCC.pVoice = suPitchOnCC.pVoice = suCutoffOnCC.pVoice = suResOnCC.pVoice = voice; + suPitchLFO.suDepthOnCC.pVoice = suPitchLFO.suFadeEG.pVoice = suPitchLFO.suFreqOnCC.pVoice = voice; + suFilLFO.suFadeEG.pVoice = suFilLFO.suDepthOnCC.pVoice = suFilLFO.suFreqOnCC.pVoice = voice; + suAmpLFO.suFadeEG.pVoice = suAmpLFO.suDepthOnCC.pVoice = suAmpLFO.suFreqOnCC.pVoice = voice; + + for (int i = 0; i < EGs.capacity(); i++) { + EGsi = new EGv2Unit(this); + EGsi->pVoice = voice; + EGsi->suAmpOnCC.pVoice = voice; + EGsi->suVolOnCC.pVoice = voice; + EGsi->suPitchOnCC.pVoice = voice; + EGsi->suCutoffOnCC.pVoice = voice; + EGsi->suResOnCC.pVoice = voice; + EGsi->suPanOnCC.pVoice = voice; + EGsi->SetVoice(voice); // class EqUnitSupport + } + + for (int i = 0; i < LFOs.capacity(); i++) { + LFOsi = new LFOv2Unit(this); + LFOsi->pVoice = voice; + LFOsi->suDepthOnCC.pVoice = voice; + LFOsi->suFreqOnCC.pVoice = voice; + LFOsi->suFadeEG.pVoice = voice; + LFOsi->suVolOnCC.pVoice = voice; + LFOsi->suPitchOnCC.pVoice = voice; + LFOsi->suFreqOnCC.pVoice = voice; + LFOsi->suPanOnCC.pVoice = voice; + LFOsi->suCutoffOnCC.pVoice = voice; + LFOsi->suResOnCC.pVoice = voice; + LFOsi->SetVoice(voice); // class EqUnitSupport + } + } + + SfzSignalUnitRack::~SfzSignalUnitRack() { + for (int i = 0; i < EGs.capacity(); i++) { + delete EGsi; EGsi = NULL; + } + + for (int i = 0; i < LFOs.capacity(); i++) { + delete LFOsi; LFOsi = NULL; + } + } + + void SfzSignalUnitRack::InitRTLists() { + Pool<CCSignalUnit::CC>* pCCPool = pVoice->pEngine->pCCPool; + Pool<Smoother>* pSmootherPool = pVoice->pEngine->pSmootherPool; + + EqUnitSupport::InitCCLists(pCCPool, pSmootherPool); + + suVolOnCC.InitCCList(pCCPool, pSmootherPool); + suPitchOnCC.InitCCList(pCCPool, pSmootherPool); + suCutoffOnCC.InitCCList(pCCPool, pSmootherPool); + suResOnCC.InitCCList(pCCPool, pSmootherPool); + suEndpoint.suXFInCC.InitCCList(pCCPool, pSmootherPool); + suEndpoint.suXFOutCC.InitCCList(pCCPool, pSmootherPool); + suEndpoint.suPanOnCC.InitCCList(pCCPool, pSmootherPool); + suPitchLFO.suDepthOnCC.InitCCList(pCCPool, pSmootherPool); + suPitchLFO.suFreqOnCC.InitCCList(pCCPool, pSmootherPool); + suFilLFO.suDepthOnCC.InitCCList(pCCPool, pSmootherPool); + suFilLFO.suFreqOnCC.InitCCList(pCCPool, pSmootherPool); + suAmpLFO.suDepthOnCC.InitCCList(pCCPool, pSmootherPool); + suAmpLFO.suFreqOnCC.InitCCList(pCCPool, pSmootherPool); + + for (int i = 0; i < EGs.capacity(); i++) { + EGsi->suAmpOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->suVolOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->suPitchOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->suCutoffOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->suResOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->suPanOnCC.InitCCList(pCCPool, pSmootherPool); + EGsi->InitCCLists(pCCPool, pSmootherPool); // class EqUnitSupport + } + + for (int i = 0; i < LFOs.capacity(); i++) { + LFOsi->suDepthOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suFreqOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suVolOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suPitchOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suFreqOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suPanOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suCutoffOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->suResOnCC.InitCCList(pCCPool, pSmootherPool); + LFOsi->InitCCLists(pCCPool, pSmootherPool); // class EqUnitSupport + } + } + + void SfzSignalUnitRack::Trigger() { + EGs.clear(); + volEGs.clear(); + pitchEGs.clear(); + filEGs.clear(); + resEGs.clear(); + panEGs.clear(); + eqEGs.clear(); + + LFOs.clear(); + volLFOs.clear(); + pitchLFOs.clear(); + filLFOs.clear(); + resLFOs.clear(); + panLFOs.clear(); + eqLFOs.clear(); + + ::sfz::Region* const pRegion = pVoice->pRegion; + + suVolOnCC.SetCCs(pRegion->volume_oncc); + suPitchOnCC.SetCCs(pRegion->pitch_oncc); + suCutoffOnCC.SetCCs(pRegion->cutoff_oncc); + suResOnCC.SetCCs(pRegion->resonance_oncc); + + for (int i = 0; i < pRegion->eg.size(); i++) { + if (pRegion->egi.node.size() == 0) continue; + + if(EGs.size() < EGs.capacity()) { + EGv2Unit eg(this); + eg.pEGInfo = &(pRegion->egi); + EGs.increment()->Copy(eg); + EGsEGs.size() - 1->suAmpOnCC.SetCCs(pRegion->egi.amplitude_oncc); + EGsEGs.size() - 1->suVolOnCC.SetCCs(pRegion->egi.volume_oncc); + EGsEGs.size() - 1->suPitchOnCC.SetCCs(pRegion->egi.pitch_oncc); + EGsEGs.size() - 1->suCutoffOnCC.SetCCs(pRegion->egi.cutoff_oncc); + EGsEGs.size() - 1->suResOnCC.SetCCs(pRegion->egi.resonance_oncc); + EGsEGs.size() - 1->suPanOnCC.SetCCs(pRegion->egi.pan_oncc); + if (pVoice->bEqSupport) { + EGsEGs.size() - 1->suEq1FreqOnCC.SetCCs(pRegion->egi.eq1freq_oncc); + EGsEGs.size() - 1->suEq2FreqOnCC.SetCCs(pRegion->egi.eq2freq_oncc); + EGsEGs.size() - 1->suEq3FreqOnCC.SetCCs(pRegion->egi.eq3freq_oncc); + EGsEGs.size() - 1->suEq1GainOnCC.SetCCs(pRegion->egi.eq1gain_oncc); + EGsEGs.size() - 1->suEq2GainOnCC.SetCCs(pRegion->egi.eq2gain_oncc); + EGsEGs.size() - 1->suEq3GainOnCC.SetCCs(pRegion->egi.eq3gain_oncc); + EGsEGs.size() - 1->suEq1BwOnCC.SetCCs(pRegion->egi.eq1bw_oncc); + EGsEGs.size() - 1->suEq2BwOnCC.SetCCs(pRegion->egi.eq2bw_oncc); + EGsEGs.size() - 1->suEq3BwOnCC.SetCCs(pRegion->egi.eq3bw_oncc); + } + } else { std::cerr << "Maximum number of EGs reached!" << std::endl; break; } + + if ( pRegion->egi.amplitude > 0 || !pRegion->egi.amplitude_oncc.empty() || + pRegion->egi.volume > -145 || !pRegion->egi.volume_oncc.empty() + ) { + if(volEGs.size() < volEGs.capacity()) volEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + + if (pRegion->egi.cutoff != 0 || !pRegion->egi.cutoff_oncc.empty()) { + if(filEGs.size() < filEGs.capacity()) filEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + + if (pRegion->egi.resonance != 0 || !pRegion->egi.resonance_oncc.empty()) { + if(resEGs.size() < resEGs.capacity()) resEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + + if (pRegion->egi.pitch != 0 || !pRegion->egi.pitch_oncc.empty()) { + if(pitchEGs.size() < pitchEGs.capacity()) pitchEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + + if (pRegion->egi.pan != 0 || !pRegion->egi.pan_oncc.empty()) { + if(panEGs.size() < panEGs.capacity()) panEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + + if (pRegion->egi.HasEq()) { + if(eqEGs.size() < eqEGs.capacity()) eqEGs.add(EGsEGs.size() - 1); + else std::cerr << "Maximum number of EGs reached!" << std::endl; + } + } + + if (pRegion->ampeg_sustain == -1) { + if (volEGs.size() > 0) pRegion->ampeg_sustain = 0; + else pRegion->ampeg_sustain = 100; + } + + // LFO + for (int i = 0; i < pRegion->lfos.size(); i++) { + if (pRegion->lfosi.freq <= 0) { + if (pRegion->lfosi.freq_oncc.empty()) continue; // Not initialized + else pRegion->lfosi.freq = 0; + } + + if(LFOs.size() < LFOs.capacity()) { + LFOv2Unit lfo(this); + lfo.pLfoInfo = &(pRegion->lfosi); + LFOs.increment()->Copy(lfo); + LFOsLFOs.size() - 1->suVolOnCC.SetCCs(pRegion->lfosi.volume_oncc); + LFOsLFOs.size() - 1->suPitchOnCC.SetCCs(pRegion->lfosi.pitch_oncc); + LFOsLFOs.size() - 1->suFreqOnCC.SetCCs(pRegion->lfosi.freq_oncc); + LFOsLFOs.size() - 1->suPanOnCC.SetCCs(pRegion->lfosi.pan_oncc); + LFOsLFOs.size() - 1->suCutoffOnCC.SetCCs(pRegion->lfosi.cutoff_oncc); + LFOsLFOs.size() - 1->suResOnCC.SetCCs(pRegion->lfosi.resonance_oncc); + if (pVoice->bEqSupport) { + LFOsLFOs.size() - 1->suEq1FreqOnCC.SetCCs(pRegion->lfosi.eq1freq_oncc); + LFOsLFOs.size() - 1->suEq2FreqOnCC.SetCCs(pRegion->lfosi.eq2freq_oncc); + LFOsLFOs.size() - 1->suEq3FreqOnCC.SetCCs(pRegion->lfosi.eq3freq_oncc); + LFOsLFOs.size() - 1->suEq1GainOnCC.SetCCs(pRegion->lfosi.eq1gain_oncc); + LFOsLFOs.size() - 1->suEq2GainOnCC.SetCCs(pRegion->lfosi.eq2gain_oncc); + LFOsLFOs.size() - 1->suEq3GainOnCC.SetCCs(pRegion->lfosi.eq3gain_oncc); + LFOsLFOs.size() - 1->suEq1BwOnCC.SetCCs(pRegion->lfosi.eq1bw_oncc); + LFOsLFOs.size() - 1->suEq2BwOnCC.SetCCs(pRegion->lfosi.eq2bw_oncc); + LFOsLFOs.size() - 1->suEq3BwOnCC.SetCCs(pRegion->lfosi.eq3bw_oncc); + } + } else { std::cerr << "Maximum number of LFOs reached!" << std::endl; break; } + + if (pRegion->lfosi.volume != 0 || !pRegion->lfosi.volume_oncc.empty()) { + if(volLFOs.size() < volLFOs.capacity()) volLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + + if (pRegion->lfosi.pitch != 0 || !pRegion->lfosi.pitch_oncc.empty()) { + if(pitchLFOs.size() < pitchLFOs.capacity()) pitchLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + + if (pRegion->lfosi.cutoff != 0 || !pRegion->lfosi.cutoff_oncc.empty()) { + if(filLFOs.size() < filLFOs.capacity()) filLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + + if (pRegion->lfosi.resonance != 0 || !pRegion->lfosi.resonance_oncc.empty()) { + if(resLFOs.size() < resLFOs.capacity()) resLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + + if (pRegion->lfosi.pan != 0 || !pRegion->lfosi.pan_oncc.empty()) { + if(panLFOs.size() < panLFOs.capacity()) panLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + + if (pRegion->lfosi.HasEq()) { + if(eqLFOs.size() < eqLFOs.capacity()) eqLFOs.add(LFOsLFOs.size() - 1); + else std::cerr << "Maximum number of LFOs reached!" << std::endl; + } + } + + if (!pVoice->bEqSupport) { + bHasEq = false; + } else { + suEq1GainOnCC.SetCCs(pRegion->eq1_gain_oncc); + suEq2GainOnCC.SetCCs(pRegion->eq2_gain_oncc); + suEq3GainOnCC.SetCCs(pRegion->eq3_gain_oncc); + suEq1FreqOnCC.SetCCs(pRegion->eq1_freq_oncc); + suEq2FreqOnCC.SetCCs(pRegion->eq2_freq_oncc); + suEq3FreqOnCC.SetCCs(pRegion->eq3_freq_oncc); + suEq1BwOnCC.SetCCs(pRegion->eq1_bw_oncc); + suEq2BwOnCC.SetCCs(pRegion->eq2_bw_oncc); + suEq3BwOnCC.SetCCs(pRegion->eq3_bw_oncc); + + bHasEq = pRegion->eq1_gain || pRegion->eq2_gain || pRegion->eq3_gain || + pRegion->eq1_vel2gain || pRegion->eq2_vel2gain || pRegion->eq3_vel2gain || + suEq1GainOnCC.HasCCs() || suEq2GainOnCC.HasCCs() || suEq3GainOnCC.HasCCs() || + eqEGs.size() > 0 || eqLFOs.size() > 0; + } + + suPitchLFO.suDepthOnCC.SetCCs(pRegion->pitchlfo_depthcc); + suPitchLFO.suFreqOnCC.SetCCs(pRegion->pitchlfo_freqcc); + + suFilLFO.suDepthOnCC.SetCCs(pRegion->fillfo_depthcc); + suFilLFO.suFreqOnCC.SetCCs(pRegion->fillfo_freqcc); + + suAmpLFO.suDepthOnCC.SetCCs(pRegion->amplfo_depthcc); + suAmpLFO.suFreqOnCC.SetCCs(pRegion->amplfo_freqcc); + + Units.clear(); + + EqUnitSupport::ImportUnits(this); + + Units.add(&suVolOnCC); + Units.add(&suPitchOnCC); + Units.add(&suCutoffOnCC); + Units.add(&suResOnCC); + + Units.add(&suVolEG); + Units.add(&suFilEG); + Units.add(&suPitchEG); + + Units.add(&suPitchLFO.suFreqOnCC); // Don't change order! (should be triggered before the LFO) + Units.add(&suPitchLFO); + Units.add(&suPitchLFO.suDepthOnCC); + Units.add(&suPitchLFO.suFadeEG); + + Units.add(&suAmpLFO.suFreqOnCC); // Don't change order! (should be triggered before the LFO) + Units.add(&suAmpLFO.suDepthOnCC); + Units.add(&suAmpLFO); + Units.add(&suAmpLFO.suFadeEG); + + Units.add(&suFilLFO.suFreqOnCC); // Don't change order! (should be triggered before the LFO) + Units.add(&suFilLFO.suDepthOnCC); + Units.add(&suFilLFO); + Units.add(&suFilLFO.suFadeEG); + + for (int i = 0; i < EGs.size(); i++) { + Units.add(EGsi); + Units.add(&(EGsi->suAmpOnCC)); + Units.add(&(EGsi->suVolOnCC)); + Units.add(&(EGsi->suPitchOnCC)); + Units.add(&(EGsi->suCutoffOnCC)); + Units.add(&(EGsi->suResOnCC)); + Units.add(&(EGsi->suPanOnCC)); + EGsi->ImportUnits(this); // class EqUnitSupport + } + + for (int i = 0; i < LFOs.size(); i++) { + Units.add(&(LFOsi->suFreqOnCC)); // Don't change order! (should be triggered before the LFO) + Units.add(LFOsi); + Units.add(&(LFOsi->suFadeEG)); + Units.add(&(LFOsi->suVolOnCC)); + Units.add(&(LFOsi->suPitchOnCC)); + Units.add(&(LFOsi->suPanOnCC)); + Units.add(&(LFOsi->suCutoffOnCC)); + Units.add(&(LFOsi->suResOnCC)); + LFOsi->ImportUnits(this); // class EqUnitSupport + } + + Units.add(&suEndpoint); + Units.add(&suEndpoint.suXFInCC); + Units.add(&suEndpoint.suXFOutCC); + Units.add(&suEndpoint.suPanOnCC); + + SignalUnitRack::Trigger(); + } + + EndpointSignalUnit* SfzSignalUnitRack::GetEndpointUnit() { + return &suEndpoint; + } + + void SfzSignalUnitRack::EnterFadeOutStage() { + suVolEG.EG.enterFadeOutStage(); + + for (int i = 0; i < volEGs.size(); i++) { + volEGsi->EG.enterFadeOutStage(); + } + } + + void SfzSignalUnitRack::EnterFadeOutStage(int maxFadeOutSteps) { + suVolEG.EG.enterFadeOutStage(maxFadeOutSteps); + for (int i = 0; i < volEGs.size(); i++) { + volEGsi->EG.enterFadeOutStage(maxFadeOutSteps); + } + } + + void SfzSignalUnitRack::Reset() { + EqUnitSupport::ResetUnits(); + + suVolOnCC.RemoveAllCCs(); + suPitchOnCC.RemoveAllCCs(); + suCutoffOnCC.RemoveAllCCs(); + suResOnCC.RemoveAllCCs(); + suEndpoint.suXFInCC.RemoveAllCCs(); + suEndpoint.suXFOutCC.RemoveAllCCs(); + suEndpoint.suPanOnCC.RemoveAllCCs(); + suPitchLFO.suDepthOnCC.RemoveAllCCs(); + suPitchLFO.suFreqOnCC.RemoveAllCCs(); + suFilLFO.suDepthOnCC.RemoveAllCCs(); + suFilLFO.suFreqOnCC.RemoveAllCCs(); + suAmpLFO.suDepthOnCC.RemoveAllCCs(); + suAmpLFO.suFreqOnCC.RemoveAllCCs(); + + for (int i = 0; i < EGs.capacity(); i++) { + EGsi->suAmpOnCC.RemoveAllCCs(); + EGsi->suVolOnCC.RemoveAllCCs(); + EGsi->suPitchOnCC.RemoveAllCCs(); + EGsi->suCutoffOnCC.RemoveAllCCs(); + EGsi->suResOnCC.RemoveAllCCs(); + EGsi->suPanOnCC.RemoveAllCCs(); + EGsi->ResetUnits(); // class EqUnitSupport + } + + for (int i = 0; i < LFOs.capacity(); i++) { + LFOsi->suDepthOnCC.RemoveAllCCs(); + LFOsi->suFreqOnCC.RemoveAllCCs(); + LFOsi->suVolOnCC.RemoveAllCCs(); + LFOsi->suPitchOnCC.RemoveAllCCs(); + LFOsi->suFreqOnCC.RemoveAllCCs(); + LFOsi->suPanOnCC.RemoveAllCCs(); + LFOsi->suCutoffOnCC.RemoveAllCCs(); + LFOsi->suResOnCC.RemoveAllCCs(); + LFOsi->ResetUnits(); // class EqUnitSupport + } + } + + void SfzSignalUnitRack::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + suVolEG.EG.CalculateFadeOutCoeff(FadeOutTime, SampleRate); + for (int i = 0; i < EGs.capacity(); i++) { + EGsi->EG.CalculateFadeOutCoeff(FadeOutTime, SampleRate); + } + } + + void SfzSignalUnitRack::UpdateEqSettings(EqSupport* pEqSupport) { + if (!pEqSupport->HasSupport()) return; + if (pEqSupport->GetBandCount() < 3) { + std::cerr << "SfzSignalUnitRack::UpdateEqSettings: EQ should have at least 3 bands\n"; + return; + } + + ::sfz::Region* const pRegion = pVoice->pRegion; + + float dB1 = (suEq1GainOnCC.Active() ? suEq1GainOnCC.GetLevel() : 0) + pRegion->eq1_gain; + float dB2 = (suEq2GainOnCC.Active() ? suEq2GainOnCC.GetLevel() : 0) + pRegion->eq2_gain; + float dB3 = (suEq3GainOnCC.Active() ? suEq3GainOnCC.GetLevel() : 0) + pRegion->eq3_gain; + + float freq1 = (suEq1FreqOnCC.Active() ? suEq1FreqOnCC.GetLevel() : 0) + pRegion->eq1_freq; + float freq2 = (suEq2FreqOnCC.Active() ? suEq2FreqOnCC.GetLevel() : 0) + pRegion->eq2_freq; + float freq3 = (suEq3FreqOnCC.Active() ? suEq3FreqOnCC.GetLevel() : 0) + pRegion->eq3_freq; + + float bw1 = (suEq1BwOnCC.Active() ? suEq1BwOnCC.GetLevel() : 0) + pRegion->eq1_bw; + float bw2 = (suEq2BwOnCC.Active() ? suEq2BwOnCC.GetLevel() : 0) + pRegion->eq2_bw; + float bw3 = (suEq3BwOnCC.Active() ? suEq3BwOnCC.GetLevel() : 0) + pRegion->eq3_bw; + + const float vel = pVoice->MIDIVelocity / 127.0f; + + dB1 += pRegion->eq1_vel2gain * vel; + dB2 += pRegion->eq2_vel2gain * vel; + dB3 += pRegion->eq3_vel2gain * vel; + + freq1 += pRegion->eq1_vel2freq * vel; + freq2 += pRegion->eq2_vel2freq * vel; + freq3 += pRegion->eq3_vel2freq * vel; + + for (int i = 0; i < eqEGs.size(); i++) { + EGv2Unit* eg = eqEGsi; + if (!eg->Active()) continue; + + float l = eg->GetLevel(); + dB1 += ((eg->suEq1GainOnCC.Active() ? eg->suEq1GainOnCC.GetLevel() : 0) + eg->pEGInfo->eq1gain) * l; + dB2 += ((eg->suEq2GainOnCC.Active() ? eg->suEq2GainOnCC.GetLevel() : 0) + eg->pEGInfo->eq2gain) * l; + dB3 += ((eg->suEq3GainOnCC.Active() ? eg->suEq3GainOnCC.GetLevel() : 0) + eg->pEGInfo->eq3gain) * l; + + freq1 += ((eg->suEq1FreqOnCC.Active() ? eg->suEq1FreqOnCC.GetLevel() : 0) + eg->pEGInfo->eq1freq) * l; + freq2 += ((eg->suEq2FreqOnCC.Active() ? eg->suEq2FreqOnCC.GetLevel() : 0) + eg->pEGInfo->eq2freq) * l; + freq3 += ((eg->suEq3FreqOnCC.Active() ? eg->suEq3FreqOnCC.GetLevel() : 0) + eg->pEGInfo->eq3freq) * l; + + bw1 += ((eg->suEq1BwOnCC.Active() ? eg->suEq1BwOnCC.GetLevel() : 0) + eg->pEGInfo->eq1bw) * l; + bw2 += ((eg->suEq2BwOnCC.Active() ? eg->suEq2BwOnCC.GetLevel() : 0) + eg->pEGInfo->eq2bw) * l; + bw3 += ((eg->suEq3BwOnCC.Active() ? eg->suEq3BwOnCC.GetLevel() : 0) + eg->pEGInfo->eq3bw) * l; + } + + for (int i = 0; i < eqLFOs.size(); i++) { + LFOv2Unit* lfo = eqLFOsi; + if (!lfo->Active()) continue; + + float l = lfo->GetLevel(); + dB1 += ((lfo->suEq1GainOnCC.Active() ? lfo->suEq1GainOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq1gain) * l; + dB2 += ((lfo->suEq2GainOnCC.Active() ? lfo->suEq2GainOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq2gain) * l; + dB3 += ((lfo->suEq3GainOnCC.Active() ? lfo->suEq3GainOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq3gain) * l; + + freq1 += ((lfo->suEq1FreqOnCC.Active() ? lfo->suEq1FreqOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq1freq) * l; + freq2 += ((lfo->suEq2FreqOnCC.Active() ? lfo->suEq2FreqOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq2freq) * l; + freq3 += ((lfo->suEq3FreqOnCC.Active() ? lfo->suEq3FreqOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq3freq) * l; + + bw1 += ((lfo->suEq1BwOnCC.Active() ? lfo->suEq1BwOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq1bw) * l; + bw2 += ((lfo->suEq2BwOnCC.Active() ? lfo->suEq2BwOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq2bw) * l; + bw3 += ((lfo->suEq3BwOnCC.Active() ? lfo->suEq3BwOnCC.GetLevel() : 0) + lfo->pLfoInfo->eq3bw) * l; + } + + pEqSupport->SetGain(0, dB1); + pEqSupport->SetGain(1, dB2); + pEqSupport->SetGain(2, dB3); + + pEqSupport->SetFreq(0, freq1); + pEqSupport->SetFreq(1, freq2); + pEqSupport->SetFreq(2, freq3); + + pEqSupport->SetBandwidth(0, bw1); + pEqSupport->SetBandwidth(1, bw2); + pEqSupport->SetBandwidth(2, bw3); + } + + EqUnitSupport::EqUnitSupport(SfzSignalUnitRack* pRack, Voice* pVoice) + : suEq1GainOnCC(pRack), suEq2GainOnCC(pRack), suEq3GainOnCC(pRack), + suEq1FreqOnCC(pRack), suEq2FreqOnCC(pRack), suEq3FreqOnCC(pRack), + suEq1BwOnCC(pRack), suEq2BwOnCC(pRack), suEq3BwOnCC(pRack) + { + SetVoice(pVoice); + } + + void EqUnitSupport::SetVoice(Voice* pVoice) { + suEq1GainOnCC.pVoice = suEq2GainOnCC.pVoice = suEq3GainOnCC.pVoice = pVoice; + suEq1FreqOnCC.pVoice = suEq2FreqOnCC.pVoice = suEq3FreqOnCC.pVoice = pVoice; + suEq1BwOnCC.pVoice = suEq2BwOnCC.pVoice = suEq3BwOnCC.pVoice = pVoice; + } + + void EqUnitSupport::ImportUnits(SfzSignalUnitRack* pRack) { + if (suEq1GainOnCC.HasCCs()) pRack->Units.add(&suEq1GainOnCC); + if (suEq2GainOnCC.HasCCs()) pRack->Units.add(&suEq2GainOnCC); + if (suEq3GainOnCC.HasCCs()) pRack->Units.add(&suEq3GainOnCC); + if (suEq1FreqOnCC.HasCCs()) pRack->Units.add(&suEq1FreqOnCC); + if (suEq2FreqOnCC.HasCCs()) pRack->Units.add(&suEq2FreqOnCC); + if (suEq3FreqOnCC.HasCCs()) pRack->Units.add(&suEq3FreqOnCC); + if (suEq1BwOnCC.HasCCs()) pRack->Units.add(&suEq1BwOnCC); + if (suEq2BwOnCC.HasCCs()) pRack->Units.add(&suEq2BwOnCC); + if (suEq3BwOnCC.HasCCs()) pRack->Units.add(&suEq3BwOnCC); + } + + void EqUnitSupport::ResetUnits() { + suEq1GainOnCC.RemoveAllCCs(); + suEq2GainOnCC.RemoveAllCCs(); + suEq3GainOnCC.RemoveAllCCs(); + suEq1FreqOnCC.RemoveAllCCs(); + suEq2FreqOnCC.RemoveAllCCs(); + suEq3FreqOnCC.RemoveAllCCs(); + suEq1BwOnCC.RemoveAllCCs(); + suEq2BwOnCC.RemoveAllCCs(); + suEq3BwOnCC.RemoveAllCCs(); + } + + void EqUnitSupport::InitCCLists(Pool<CCSignalUnit::CC>* pCCPool, Pool<Smoother>* pSmootherPool) { + suEq1GainOnCC.InitCCList(pCCPool, pSmootherPool); + suEq2GainOnCC.InitCCList(pCCPool, pSmootherPool); + suEq3GainOnCC.InitCCList(pCCPool, pSmootherPool); + suEq1FreqOnCC.InitCCList(pCCPool, pSmootherPool); + suEq2FreqOnCC.InitCCList(pCCPool, pSmootherPool); + suEq3FreqOnCC.InitCCList(pCCPool, pSmootherPool); + suEq1BwOnCC.InitCCList(pCCPool, pSmootherPool); + suEq2BwOnCC.InitCCList(pCCPool, pSmootherPool); + suEq3BwOnCC.InitCCList(pCCPool, pSmootherPool); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/SfzSignalUnitRack.h
Added
@@ -0,0 +1,497 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2011 - 2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZSIGNALUNITRACK_H__ +#define __LS_SFZSIGNALUNITRACK_H__ + +#include "../common/SignalUnitRack.h" +#include "EG.h" +#include "EGADSR.h" +#include "../common/AbstractVoice.h" +#include "../common/PulseLFO.h" +#include "../common/SawLFO.h" +#include "../common/SineLFO.h" + +namespace LinuxSampler { namespace sfz { + const int MaxUnitCount = 200; + const int maxEgCount = 30; // Maximum number of v2 envelope generators + const int maxLfoCount = 30; // Maximum number of v2 LFOs + + class Voice; + class SfzSignalUnitRack; + + class SfzSignalUnit: public SignalUnit { + public: + Voice* pVoice; + + SfzSignalUnit(SfzSignalUnitRack* rack); + SfzSignalUnit(const SfzSignalUnit& Unit): SignalUnit(Unit.pRack) { Copy(Unit); } + + void Copy(const SfzSignalUnit& Unit) { + pVoice = Unit.pVoice; + + SignalUnit::Copy(Unit); + } + + double GetSampleRate(); + float GetInfluence(ArrayList< ::sfz::CC>& cc); + }; + + + class CCUnit: public CCSignalUnit { + public: + Voice* pVoice; + + CCUnit(SfzSignalUnitRack* rack, Listener* l = NULL); + + virtual void Trigger(); + + void SetCCs(::sfz::Array<int>& pCC); + void SetCCs(::sfz::Array<float>& pCC); + void SetCCs(ArrayList< ::sfz::CC>& cc); + + virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth, float Step); + + int GetCurveCount(); + ::sfz::Curve* GetCurve(int idx); + + double GetSampleRate(); + }; + + class CurveCCUnit: public CCUnit { + public: + CurveCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { } + + virtual float Normalize(uint8_t val, short int curve = -1) { + if (curve == -1) return val / 127.0f; + return GetCurve(curve)->vval; + } + }; + + + + class SmoothCCUnit: public CurveCCUnit { + protected: + RTList<Smoother>* pSmoothers; + public: + SmoothCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CurveCCUnit(rack, l), pSmoothers(NULL) { } + virtual ~SmoothCCUnit(); + + virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth, float Step); + virtual void RemoveAllCCs() { CurveCCUnit::RemoveAllCCs(); pSmoothers->clear(); } + virtual void InitCCList(Pool<CC>* pCCPool, Pool<Smoother>* pSmootherPool); + + void InitSmoothers(Pool<Smoother>* pSmootherPool); + }; + + + class EqUnitSupport { + public: + EqUnitSupport(SfzSignalUnitRack* pRack, Voice* pVoice = NULL); + + SmoothCCUnit suEq1GainOnCC; + SmoothCCUnit suEq2GainOnCC; + SmoothCCUnit suEq3GainOnCC; + + SmoothCCUnit suEq1FreqOnCC; + SmoothCCUnit suEq2FreqOnCC; + SmoothCCUnit suEq3FreqOnCC; + + SmoothCCUnit suEq1BwOnCC; + SmoothCCUnit suEq2BwOnCC; + SmoothCCUnit suEq3BwOnCC; + + void SetVoice(Voice* pVoice); + void ImportUnits(SfzSignalUnitRack* pRack); + void ResetUnits(); + void InitCCLists(Pool<CCSignalUnit::CC>* pCCPool, Pool<Smoother>* pSmootherPool); + }; + + + class XFInCCUnit: public CCUnit { + public: + XFInCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { } + + virtual bool Active() { return !pCtrls->isEmpty(); } + virtual void Calculate(); + virtual void SetCrossFadeCCs(::sfz::Array<int>& loCCs, ::sfz::Array<int>& hiCCs); + }; + + + class XFOutCCUnit: public XFInCCUnit { + public: + XFOutCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): XFInCCUnit(rack, l) { } + + virtual void Calculate(); + }; + + + template <class T> + class EGUnit: public SfzSignalUnit { + public: + ::sfz::EG* pEGInfo; + T EG; + + EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { } + EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); } + void operator=(const EGUnit& Unit) { Copy(Unit); } + + void Copy(const EGUnit& Unit) { + pEGInfo = Unit.pEGInfo; + + SfzSignalUnit::Copy(Unit); + } + + virtual bool Active() { return EG.active(); } + virtual float GetLevel() { return DelayStage() ? 0 : EG.getLevel(); } + + virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); } + virtual void CancelRelease() { EG.update(EG::event_cancel_release, GetSampleRate()); } + + virtual void Increment() { + if (DelayStage()) return; + + SfzSignalUnit::Increment(); + if (!EG.active()) return; + + switch (EG.getSegmentType()) { + case EG::segment_lin: + EG.processLin(); + break; + case EG::segment_exp: + EG.processExp(); + break; + case EG::segment_end: + EG.getLevel(); + break; // noop + case EG::segment_pow: + EG.processPow(); + break; + } + + if (EG.active()) { + EG.increment(1); + if (!EG.toStageEndLeft()) EG.update(EG::event_stage_end, GetSampleRate()); + } + } + }; + + class EGv1Unit: public EGUnit<EGADSR> { + public: + int depth; + EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { } + }; + + class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG>, public EqUnitSupport { + protected: + ::sfz::EG egInfo; + public: + CCUnit suAmpOnCC; + CCUnit suVolOnCC; + CCUnit suPitchOnCC; + CCUnit suCutoffOnCC; + CCUnit suResOnCC; + CurveCCUnit suPanOnCC; + + EGv2Unit(SfzSignalUnitRack* rack); + virtual void Trigger(); + }; + + class PitchEGUnit: public EGv1Unit { + public: + PitchEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { } + virtual void Trigger(); + }; + + class FilEGUnit: public EGv1Unit { + public: + FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { } + virtual void Trigger(); + }; + + class AmpEGUnit: public EGv1Unit { + public: + AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { } + virtual void Trigger(); + }; + + class AbstractLfo { + public: + virtual float Render() = 0; + virtual void Update(const uint16_t& ExtControlValue) = 0; + virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0; + virtual void SetPhase(float phase) = 0; + virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0; + }; + + template <class T> + class LfoBase: public AbstractLfo, public T { + public: + LfoBase(float Max): T(Max) { } + virtual float Render() { return T::render(); } + + virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); } + + virtual void Trigger ( + float Frequency, start_level_t StartLevel, uint16_t InternalDepth, + uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate + ) { + T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate); + } + + virtual void SetPhase(float phase) { T::setPhase(phase); } + + virtual void SetFrequency(float Frequency, unsigned int SampleRate) { + T::setFrequency(Frequency, SampleRate); + } + }; + + class LFOUnit; + + class FadeEGUnit: public EGUnit<EGADSR> { + public: + FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { } + virtual void Trigger() { } + virtual void EnterReleaseStage() { } + virtual void CancelRelease() { } + + friend class LFOUnit; + }; + + class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener { + public: + ::sfz::LFO* pLfoInfo; + AbstractLfo* pLFO; + FadeEGUnit suFadeEG; + SmoothCCUnit suDepthOnCC; + SmoothCCUnit suFreqOnCC; + + LFOUnit(SfzSignalUnitRack* rack); + LFOUnit(const LFOUnit& Unit); + void operator=(const LFOUnit& Unit) { Copy(Unit); } + + void Copy(const LFOUnit& Unit) { + pLfoInfo = Unit.pLfoInfo; + suFadeEG = Unit.suFadeEG; + + SfzSignalUnit::Copy(Unit); + } + + virtual void Trigger(); + virtual void Increment(); + virtual float GetLevel() { return Level; } + + // CCSignalUnit::Listener interface implementation + virtual void ValueChanged(CCSignalUnit* pUnit); + }; + + class LFOv1Unit: public LFOUnit { + public: + ::sfz::LFO lfoInfo; + LfoBase<LFOSigned> lfo; + + LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) { + pLfoInfo = &lfoInfo; pLFO = &lfo; + } + + virtual void Trigger(); + }; + + class LFOv2Unit: public LFOUnit, public EqUnitSupport { + protected: + FixedArray<AbstractLfo*> lfos; + LfoBase<LFOSigned> lfo0; // triangle + LfoBase<SineLFO<range_signed> > lfo1; // sine + LfoBase<PulseLFO<range_unsigned, 750> > lfo2; // pulse 75% + LfoBase<SquareLFO<range_signed> > lfo3; // square + LfoBase<PulseLFO<range_unsigned, 250> > lfo4; // pulse 25% + LfoBase<PulseLFO<range_unsigned, 125> > lfo5; // pulse 12,5% + LfoBase<SawLFO<range_unsigned, true> > lfo6; // saw up + LfoBase<SawLFO<range_unsigned, false> > lfo7; // saw down + + + public: + SmoothCCUnit suVolOnCC; + SmoothCCUnit suPitchOnCC; + SmoothCCUnit suPanOnCC; + SmoothCCUnit suCutoffOnCC; + SmoothCCUnit suResOnCC; + + LFOv2Unit(SfzSignalUnitRack* rack); + + virtual void Trigger(); + virtual bool Active() { return true; } + }; + + class AmpLFOUnit: public LFOv1Unit { + public: + AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { } + + virtual void Trigger(); + }; + + class PitchLFOUnit: public LFOv1Unit { + public: + PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { } + + virtual void Trigger(); + }; + + class FilLFOUnit: public LFOv1Unit { + public: + FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { } + + virtual void Trigger(); + }; + + + class EndpointUnit: public EndpointSignalUnit { + private: + float xfCoeff; // crossfade coefficient + float pitchVeltrackRatio; + + public: + Voice* pVoice; + XFInCCUnit suXFInCC; + XFOutCCUnit suXFOutCC; + SmoothCCUnit suPanOnCC; + + EndpointUnit(SfzSignalUnitRack* rack); + + virtual void Trigger(); + + /** + * The endpoint should be active until the volume EG is active. + * This method determines the end of the voice playback. + */ + virtual bool Active(); + + virtual float GetVolume(); + virtual float GetFilterCutoff(); + virtual float GetPitch(); + virtual float GetResonance(); + virtual float GetPan(); + + SfzSignalUnitRack* const GetRack(); + + virtual float CalculateResonance(float res) { + return GetResonance() + res; + } + + virtual float CalculateFilterCutoff(float cutoff); + + float GetInfluence(::sfz::Array< ::sfz::optional<float> >& cc); + float GetInfluence(::sfz::Array< ::sfz::optional<int> >& cc); + }; + + + class SfzSignalUnitRack : public SignalUnitRack, public EqUnitSupport { + private: + EndpointUnit suEndpoint; + AmpEGUnit suVolEG; + FilEGUnit suFilEG; + PitchEGUnit suPitchEG; + + AmpLFOUnit suAmpLFO; + PitchLFOUnit suPitchLFO; + FilLFOUnit suFilLFO; + + // SFZ v2 + + SmoothCCUnit suVolOnCC; + SmoothCCUnit suPitchOnCC; + SmoothCCUnit suCutoffOnCC; + SmoothCCUnit suResOnCC; + + FixedArray<EGv2Unit*> EGs; + + // used for optimization - contains only the ones that are modulating volume + FixedArray<EGv2Unit*> volEGs; + + // used for optimization - contains only the ones that are modulating pitch + FixedArray<EGv2Unit*> pitchEGs; + + // used for optimization - contains only the ones that are modulating filter cutoff + FixedArray<EGv2Unit*> filEGs; + + // used for optimization - contains only the ones that are modulating resonance + FixedArray<EGv2Unit*> resEGs; + + // used for optimization - contains only the ones that are modulating pan + FixedArray<EGv2Unit*> panEGs; + + // used for optimization - contains only the ones that are modulating EQ + FixedArray<EGv2Unit*> eqEGs; + + + FixedArray<LFOv2Unit*> LFOs; + + // used for optimization - contains only the ones that are modulating volume + FixedArray<LFOv2Unit*> volLFOs; + + // used for optimization - contains only the ones that are modulating pitch + FixedArray<LFOv2Unit*> pitchLFOs; + + // used for optimization - contains only the ones that are modulating filter cutoff + FixedArray<LFOv2Unit*> filLFOs; + + // used for optimization - contains only the ones that are modulating resonance + FixedArray<LFOv2Unit*> resLFOs; + + // used for optimization - contains only the ones that are modulating pan + FixedArray<LFOv2Unit*> panLFOs; + + // used for optimization - contains only the ones that are modulating EQ + FixedArray<LFOv2Unit*> eqLFOs; + + + public: + Voice* const pVoice; + + /** + * @param Voice The voice to which this rack belongs. + */ + SfzSignalUnitRack(Voice* voice); + ~SfzSignalUnitRack(); + + virtual EndpointSignalUnit* GetEndpointUnit(); + + virtual void Trigger(); + virtual void EnterFadeOutStage(); + virtual void EnterFadeOutStage(int maxFadeOutSteps); + + /** Called when the engine is set and the engine's pools are ready to use. */ + void InitRTLists(); + + /** Invoked when the voice gone inactive. */ + void Reset(); + + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + virtual void UpdateEqSettings(EqSupport* pEqSupport); + + friend class EndpointUnit; + }; +}} // namespace LinuxSampler::sfz + +#endif /* __LS_SFZSIGNALUNITRACK_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Stream.cpp
Added
@@ -0,0 +1,106 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009-2012 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <signal.h> + + +#include "Stream.h" +#include "../../common/global_private.h" + +namespace LinuxSampler { namespace sfz { + + Stream::Stream ( + uint BufferSize, + uint BufferWrapElements, + ::sfz::SampleManager* pSampleManager + ) : LinuxSampler::StreamBase< ::sfz::Region>(BufferSize, BufferWrapElements) { + this->pSampleManager = pSampleManager; + } + + long Stream::Read(uint8_t* pBuf, long SamplesToRead) { + ::sfz::Sample* pSample = pRegion->pSample; + long total_readsamples = 0, readsamples = 0; + bool endofsamplereached; + + // refill the disk stream buffer + if (this->DoLoop) { // honor looping + total_readsamples = pSample->ReadAndLoop(pBuf, SamplesToRead, &PlaybackState, pRegion); + endofsamplereached = (this->PlaybackState.position >= pSample->GetTotalFrameCount()); + dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->PlaybackState.position)); + } + else { // normal forward playback + + pSample->SetPos(this->SampleOffset); // recover old position + + do { + readsamples = pSample->Read(&pBuftotal_readsamples * pSample->GetFrameSize(), SamplesToRead); + SamplesToRead -= readsamples; + total_readsamples += readsamples; + } while (SamplesToRead && readsamples > 0); + + // we have to store the position within the sample, because other streams might use the same sample + this->SampleOffset = pSample->GetPos(); + + endofsamplereached = (SampleOffset >= pSample->GetTotalFrameCount()); + dmsg(5,("Refilled stream %d with %d (SamplePos: %d)", this->hThis, total_readsamples, this->SampleOffset)); + } + + // update stream state + if (endofsamplereached) SetState(state_end); + else SetState(state_active); + + return total_readsamples; + } + + void Stream::Kill() { + if(pRegion) pSampleManager->SetSampleNotInUse(pRegion->pSample, pRegion); + StreamBase< ::sfz::Region>::Kill(); + } + + void Stream::Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::sfz::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ) { + SampleDescription info; + info.ChannelsPerFrame = pRgn->pSample->GetChannelCount(); + info.FrameSize = pRgn->pSample->GetFrameSize(); + info.BytesPerSample = pRgn->pSample->GetFrameSize() / pRgn->pSample->GetChannelCount(); + info.TotalSampleCount = pRgn->pSample->GetTotalFrameCount(); + + Sample::PlaybackState playbackState; + playbackState.position = SampleOffset; + playbackState.reverse = false; + playbackState.loop_cycles_left = 0; // TODO: pRgn->pSample->LoopPlayCount; + + pSampleManager->SetSampleInUse(pRgn->pSample, pRgn); + + LinuxSampler::StreamBase< ::sfz::Region>::Launch ( + hStream, pExportReference, pRgn, info, playbackState, SampleOffset, DoLoop + ); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Stream.h
Added
@@ -0,0 +1,55 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_STREAM_H__ +#define __LS_SFZ_STREAM_H__ + +#include "../common/StreamBase.h" +#include "sfz.h" + +namespace LinuxSampler { namespace sfz { + + class Stream: public LinuxSampler::StreamBase< ::sfz::Region> { + public: + Stream(uint BufferSize, uint BufferWrapElements, ::sfz::SampleManager* pSampleManager); + virtual long Read(uint8_t* pBuf, long SamplesToRead); + virtual void Kill(); + + void Launch ( + Stream::Handle hStream, + reference_t* pExportReference, + ::sfz::Region* pRgn, + unsigned long SampleOffset, + bool DoLoop + ); + + private: + ::sfz::SampleManager* pSampleManager; + }; + + +}} // namespace LinuxSampler::sfz + +#endif /* __LS_SFZ_STREAM_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Voice.cpp
Added
@@ -0,0 +1,305 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "Voice.h" + +#include "Engine.h" +#include "EngineChannel.h" + +#define LN_10_DIV_20 0.115129254649702 + +namespace LinuxSampler { namespace sfz { + + typedef LinuxSampler::VoiceBase<EngineChannel, ::sfz::Region, Sample, DiskThread> SfzVoice; + Voice::Voice(): SignalRack(this), SfzVoice(&SignalRack) { + pEngine = NULL; + bEqSupport = true; + } + + Voice::~Voice() { + + } + + EngineChannel* Voice::GetSfzEngineChannel() { + return static_cast<EngineChannel*>(pEngineChannel); + } + + void Voice::SetEngine(LinuxSampler::Engine* pEngine) { + Engine* engine = static_cast<Engine*>(pEngine); + this->pEngine = engine; + this->pDiskThread = engine->pDiskThread; + dmsg(6,("Voice::SetEngine()\n")); + } + + Voice::SampleInfo Voice::GetSampleInfo() { + SampleInfo si; + si.SampleRate = pSample->GetSampleRate(); + si.ChannelCount = pSample->GetChannelCount(); + si.FrameSize = pSample->GetFrameSize(); + si.BitDepth = (pSample->GetFrameSize() / pSample->GetChannelCount()) * 8; + si.TotalFrameCount = pSample->GetTotalFrameCount(); + + si.HasLoops = pRegion->HasLoop(); + si.LoopStart = pRegion->GetLoopStart(); + si.LoopLength = pRegion->GetLoopEnd() - pRegion->GetLoopStart(); + si.LoopPlayCount = pRegion->GetLoopCount(); + si.Unpitched = pRegion->pitch_keytrack == 0; + return si; + } + + Voice::RegionInfo Voice::GetRegionInfo() { + RegionInfo ri; + ri.UnityNote = pRegion->pitch_keycenter; + ri.FineTune = pRegion->tune + pRegion->transpose * 100; + ri.Pan = int(pRegion->pan * 0.63); // convert from -100..100 to -64..63 + ri.SampleStartOffset = pRegion->offset ? *(pRegion->offset) : 0; + + ri.VCFEnabled = pRegion->cutoff; + switch (pRegion->fil_type) { + case ::sfz::LPF_1P: + ri.VCFType = Filter::vcf_type_1p_lowpass; + break; + case ::sfz::LPF_2P: + ri.VCFType = Filter::vcf_type_2p_lowpass; + break; + case ::sfz::LPF_4P: + ri.VCFType = Filter::vcf_type_4p_lowpass; + break; + case ::sfz::LPF_6P: + ri.VCFType = Filter::vcf_type_6p_lowpass; + break; + case ::sfz::HPF_1P: + ri.VCFType = Filter::vcf_type_1p_highpass; + break; + case ::sfz::HPF_2P: + ri.VCFType = Filter::vcf_type_2p_highpass; + break; + case ::sfz::HPF_4P: + ri.VCFType = Filter::vcf_type_4p_highpass; + break; + case ::sfz::HPF_6P: + ri.VCFType = Filter::vcf_type_6p_highpass; + break; + case ::sfz::BPF_1P: + case ::sfz::BPF_2P: + ri.VCFType = Filter::vcf_type_2p_bandpass; + break; + case ::sfz::BRF_1P: + case ::sfz::BRF_2P: + ri.VCFType = Filter::vcf_type_2p_bandreject; + break; + case ::sfz::APF_1P: + case ::sfz::PKF_2P: + default: + ri.VCFEnabled = false; + break; + } + + ri.VCFResonance = pRegion->resonance; + + // rt_decay is in dB. Precalculate a suitable value for exp in + // GetReleaseTriggerAttenuation: -ln(10) / 20 * rt_decay + ri.ReleaseTriggerDecay = -LN_10_DIV_20 * pRegion->rt_decay; + + return ri; + } + + Voice::InstrumentInfo Voice::GetInstrumentInfo() { + InstrumentInfo ii; + ii.FineTune = 0; // TODO: + ii.PitchbendRange = 2; // TODO: + + return ii; + } + + double Voice::GetSampleAttenuation() { + return exp(LN_10_DIV_20 * pRegion->volume); + } + + double Voice::GetVelocityAttenuation(uint8_t MIDIKeyVelocity) { + float offset = -pRegion->amp_veltrack; + if (offset <= 0) offset += 100; + return (offset + pRegion->amp_veltrack * pRegion->amp_velcurveMIDIKeyVelocity) / 100; + } + + double Voice::GetVelocityRelease(uint8_t MIDIKeyVelocity) { + return 127.0 / MIDIKeyVelocity; + } + + void Voice::ProcessCCEvent(RTList<Event>::Iterator& itEvent) { + /*if (itEvent->Type == Event::type_control_change && itEvent->Param.CC.Controller) { // if (valid) MIDI control change event + if (pRegion->AttenuationController.type == ::gig::attenuation_ctrl_t::type_controlchange && + itEvent->Param.CC.Controller == pRegion->AttenuationController.controller_number) { + CrossfadeSmoother.update(AbstractEngine::CrossfadeCurveCrossfadeAttenuation(itEvent->Param.CC.Value)); + } + }*/ // TODO: ^^^ + } + + double Voice::CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity) { + /*float crossfadeVolume; + switch (pRegion->AttenuationController.type) { + case ::gig::attenuation_ctrl_t::type_channelaftertouch: + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetSfzEngineChannel()->ControllerTable128); + break; + case ::gig::attenuation_ctrl_t::type_velocity: + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(MIDIKeyVelocity); + break; + case ::gig::attenuation_ctrl_t::type_controlchange: //FIXME: currently not sample accurate + crossfadeVolume = Engine::CrossfadeCurveCrossfadeAttenuation(GetSfzEngineChannel()->ControllerTablepRegion->AttenuationController.controller_number); + break; + case ::gig::attenuation_ctrl_t::type_none: // no crossfade defined + default: + crossfadeVolume = 1.0f; + } + + return crossfadeVolume;*/ // TODO: ^^^ + return 1.0f; + } + + double Voice::GetEG1ControllerValue(uint8_t MIDIKeyVelocity) { + /*double eg1controllervalue = 0; + switch (pRegion->EG1Controller.type) { + case ::gig::eg1_ctrl_t::type_none: // no controller defined + eg1controllervalue = 0; + break; + case ::gig::eg1_ctrl_t::type_channelaftertouch: + eg1controllervalue = GetSfzEngineChannel()->ControllerTable128; + break; + case ::gig::eg1_ctrl_t::type_velocity: + eg1controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg1_ctrl_t::type_controlchange: // MIDI control change controller + eg1controllervalue = GetSfzEngineChannel()->ControllerTablepRegion->EG1Controller.controller_number; + break; + } + if (pRegion->EG1ControllerInvert) eg1controllervalue = 127 - eg1controllervalue; + + return eg1controllervalue;*/ // TODO: ^^^ + return 0; + } + + Voice::EGInfo Voice::CalculateEG1ControllerInfluence(double eg1ControllerValue) { + /*EGInfo eg; + // (eg1attack is different from the others) + eg.Attack = (pRegion->EG1ControllerAttackInfluence) ? + 1 + 0.031 * (double) (pRegion->EG1ControllerAttackInfluence == 1 ? + 1 : 1 << pRegion->EG1ControllerAttackInfluence) * eg1ControllerValue : 1.0; + eg.Decay = (pRegion->EG1ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerDecayInfluence) * eg1ControllerValue : 1.0; + eg.Release = (pRegion->EG1ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG1ControllerReleaseInfluence) * eg1ControllerValue : 1.0; + + return eg;*/ // TODO: ^^^ + EGInfo eg; + eg.Attack = 1.0; + eg.Decay = 1.0; + eg.Release = 1.0; + return eg; + } + + double Voice::GetEG2ControllerValue(uint8_t MIDIKeyVelocity) { + /*double eg2controllervalue = 0; + switch (pRegion->EG2Controller.type) { + case ::gig::eg2_ctrl_t::type_none: // no controller defined + eg2controllervalue = 0; + break; + case ::gig::eg2_ctrl_t::type_channelaftertouch: + eg2controllervalue = GetSfzEngineChannel()->ControllerTable128; + break; + case ::gig::eg2_ctrl_t::type_velocity: + eg2controllervalue = MIDIKeyVelocity; + break; + case ::gig::eg2_ctrl_t::type_controlchange: // MIDI control change controller + eg2controllervalue = GetSfzEngineChannel()->ControllerTablepRegion->EG2Controller.controller_number; + break; + } + if (pRegion->EG2ControllerInvert) eg2controllervalue = 127 - eg2controllervalue; + + return eg2controllervalue;*/ // TODO: ^^^ + return 0; + } + + Voice::EGInfo Voice::CalculateEG2ControllerInfluence(double eg2ControllerValue) { + /*EGInfo eg; + eg.Attack = (pRegion->EG2ControllerAttackInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerAttackInfluence) * eg2ControllerValue : 1.0; + eg.Decay = (pRegion->EG2ControllerDecayInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerDecayInfluence) * eg2ControllerValue : 1.0; + eg.Release = (pRegion->EG2ControllerReleaseInfluence) ? 1 + 0.00775 * (double) (1 << pRegion->EG2ControllerReleaseInfluence) * eg2ControllerValue : 1.0; + + return eg;*/ // TODO: ^^^ + EGInfo eg; + eg.Attack = 1.0; + eg.Decay = 1.0; + eg.Release = 1.0; + return eg; + } + + float Voice::CalculateCutoffBase(uint8_t MIDIKeyVelocity) { + float cutoff = *pRegion->cutoff; + cutoff *= RTMath::CentsToFreqRatioUnlimited( + MIDIKeyVelocity / 127.0f * pRegion->fil_veltrack + + (MIDIKey - pRegion->fil_keycenter) * pRegion->fil_keytrack); + return cutoff; + } + + float Voice::CalculateFinalCutoff(float cutoffBase) { + float cutoff = cutoffBase; + if (cutoff > 0.49 * pEngine->SampleRate) cutoff = 0.49 * pEngine->SampleRate; + return cutoff; + } + + float Voice::GetReleaseTriggerAttenuation(float noteLength) { + // pow(10, -rt_decay * noteLength / 20): + return expf(RgnInfo.ReleaseTriggerDecay * noteLength); + } + + void Voice::ProcessGroupEvent(RTList<Event>::Iterator& itEvent) { + dmsg(4,("Voice %x processGroupEvents event type=%d", this, itEvent->Type)); + if (itEvent->Type == Event::type_control_change || + (Type & Voice::type_controller_triggered) || + itEvent->Param.Note.Key != MIDIKey) { + dmsg(4,("Voice %x - kill", this)); + if (pRegion->off_mode == ::sfz::OFF_NORMAL) { + // turn off the voice by entering release envelope stage + EnterReleaseStage(); + } else { + // kill the voice fast + SignalRack.EnterFadeOutStage(); + } + } + } + + void Voice::SetSampleStartOffset() { + if (DiskVoice && RgnInfo.SampleStartOffset > pSample->MaxOffset) { + // The offset is applied to the RAM buffer + finalSynthesisParameters.dPos = 0; + Pos = 0; + } else { + finalSynthesisParameters.dPos = RgnInfo.SampleStartOffset; // offset where we should start playback of sample + Pos = RgnInfo.SampleStartOffset; + } + } + + void Voice::CalculateFadeOutCoeff(float FadeOutTime, float SampleRate) { + SignalRack.CalculateFadeOutCoeff(FadeOutTime, SampleRate); + } + +}} // namespace LinuxSampler::sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/Voice.h
Added
@@ -0,0 +1,134 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2009 - 2012 Christian Schoenebeck and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __LS_SFZ_VOICE_H__ +#define __LS_SFZ_VOICE_H__ + +#include "../../common/global_private.h" + +#include "../../common/RTMath.h" +#include "../../common/Pool.h" +#include "../../drivers/audio/AudioOutputDevice.h" +#include "DiskThread.h" +#include "../gig/Filter.h" +#include "../common/VoiceBase.h" +#include "../gig/SynthesisParam.h" +#include "EG.h" +#include "EGADSR.h" +#include "SfzSignalUnitRack.h" + +namespace LinuxSampler { namespace sfz { + class Engine; + class EngineChannel; + + /** SoundFont Voice + * + * Renders a voice for the SoundFont format. + */ + class Voice : public LinuxSampler::VoiceBase<EngineChannel, ::sfz::Region, Sample, DiskThread> { + public: + Voice(); + virtual ~Voice(); + void SetOutput(AudioOutputDevice* pAudioOutputDevice); + void SetEngine(LinuxSampler::Engine* pEngine); + void CalculateFadeOutCoeff(float FadeOutTime, float SampleRate); + + virtual void VoiceFreed() { SignalRack.Reset(); } + + protected: + virtual SampleInfo GetSampleInfo(); + virtual RegionInfo GetRegionInfo(); + virtual InstrumentInfo GetInstrumentInfo(); + virtual double CalculateCrossfadeVolume(uint8_t MIDIKeyVelocity); + virtual AbstractEngine* GetEngine() { return (AbstractEngine*)pEngine; } + virtual float GetReleaseTriggerAttenuation(float noteLength); + virtual double GetEG1ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG1ControllerInfluence(double eg1ControllerValue); + virtual void TriggerEG1(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { } + virtual double GetEG2ControllerValue(uint8_t MIDIKeyVelocity); + virtual EGInfo CalculateEG2ControllerInfluence(double eg2ControllerValue); + virtual void TriggerEG2(const EGInfo& egInfo, double velrelease, double velocityAttenuation, uint sampleRate, uint8_t velocity) { } + virtual void InitLFO1() { } + virtual void InitLFO2() { } + virtual void InitLFO3() { } + virtual float CalculateCutoffBase(uint8_t MIDIKeyVelocity); + virtual float CalculateFinalCutoff(float cutoffBase); + virtual uint8_t GetVCFCutoffCtrl() { return 0; } + virtual uint8_t GetVCFResonanceCtrl() { return 0; } + virtual void ProcessCCEvent(RTList<Event>::Iterator& itEvent); + virtual void ProcessCutoffEvent(RTList<Event>::Iterator& itEvent) { } + virtual double GetVelocityAttenuation(uint8_t MIDIKeyVelocity); + virtual double GetVelocityRelease(uint8_t MIDIKeyVelocity); + virtual double GetSampleAttenuation(); + virtual void ProcessGroupEvent(RTList<Event>::Iterator& itEvent); + virtual void SetSampleStartOffset(); + virtual int GetRAMCacheOffset() { return pRegion->pSample->RAMCacheOffset; } + + private: + SfzSignalUnitRack SignalRack; + + public: // FIXME: just made public for debugging (sanity check in Engine::RenderAudio()), should be changed to private before the final release + // Attributes + Engine* pEngine; ///< Pointer to the sampler engine, to be able to access the event lists. + //uint LoopCyclesLeft; ///< In case there is a RAMLoop and it's not an endless loop; reflects number of loop cycles left to be passed + + // Static Methods + static float CalculateFilterCutoffCoeff(); + + // Methods + void ProcessEvents(uint Samples); + void processCrossFadeEvent(RTList<Event>::Iterator& itEvent); + + EngineChannel* GetSfzEngineChannel(); + + friend class CCUnit; + friend class XFInCCUnit; + friend class XFOutCCUnit; + friend class AmpEGUnit; + friend class FilEGUnit; + friend class PitchEGUnit; + friend class PitchLFOUnit; + friend class AmpLFOUnit; + friend class FilLFOUnit; + friend class EndpointUnit; + friend class SfzSignalUnitRack; + + protected: + virtual uint8_t CrossfadeAttenuation(uint8_t& CrossfadeControllerValue) { + /*uint8_t c = std::max(CrossfadeControllerValue, pRegion->AttenuationControllerThreshold); + c = (!pRegion->Crossfade.out_end) ? c // 0,0,0,0 means no crossfade defined + : (c < pRegion->Crossfade.in_end) ? + ((c <= pRegion->Crossfade.in_start) ? 0 + : 127 * (c - pRegion->Crossfade.in_start) / (pRegion->Crossfade.in_end - pRegion->Crossfade.in_start)) + : (c <= pRegion->Crossfade.out_start) ? 127 + : (c < pRegion->Crossfade.out_end) ? 127 * (pRegion->Crossfade.out_end - c) / (pRegion->Crossfade.out_end - pRegion->Crossfade.out_start) + : 0; + return pRegion->InvertAttenuationController ? 127 - c : c;*/ // TODO: ^^^ + return 0; + } + }; + +}} // namespace LinuxSampler::sfz + +#endif // __LS_SFZ_VOICE_H__
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/sfz.cpp
Added
@@ -0,0 +1,2088 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2008 Anders Dahnielson <anders@dahnielson.com> * + * Copyright (C) 2009 - 2012 Anders Dahnielson and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include "sfz.h" + +#include <iostream> +#include <sstream> +#include <cctype> +#include <cstdio> +#include <cstring> + +#include "../../common/File.h" +#include "../../common/Path.h" +#include "LookupTable.h" + +namespace sfz +{ + template <typename T> T check(std::string name, T min, T max, T val) { + if (val < min) { + std::cerr << "sfz: The value of opcode '" << name; + std::cerr << "' is below the minimum allowed value (min=" << min << "): " << val << std::endl; + val = min; + } + if (val > max) { + std::cerr << "sfz: The value of opcode '" << name; + std::cerr << "' is above the maximum allowed value (max=" << max << "): " << val << std::endl; + val = max; + } + + return val; + } + + Sample* SampleManager::FindSample(std::string samplePath, uint offset, int end) { + std::map<Sample*, std::set<Region*> >::iterator it = sampleMap.begin(); + for (; it != sampleMap.end(); it++) { + if (it->first->GetFile() == samplePath) { + /* Because the start of the sample is cached in RAM we treat + * same sample with different offset as different samples + * // TODO: Ignore offset when the whole sample is cached in RAM? + */ + if (it->first->Offset == offset && it->first->End == end) return it->first; + } + } + + return NULL; + } + + ///////////////////////////////////////////////////////////// + // class optional + + const optional_base::nothing_t optional_base::nothing; + + ///////////////////////////////////////////////////////////// + // class Articulation + + Articulation::Articulation() + { + } + + Articulation::~Articulation() + { + } + + ///////////////////////////////////////////////////////////// + // class Definition + + Definition::Definition() + { + } + + Definition::~Definition() + { + } + + ///////////////////////////////////////////////////////////// + // class Region + + Region::Region() + { + pSample = NULL; + seq_counter = 1; + } + + Region::~Region() + { + DestroySampleIfNotUsed(); + } + + Sample* Region::GetSample(bool create) + { + if (pSample == NULL && create) { + uint i = offset ? *offset : 0; + Sample* sf = GetInstrument()->GetSampleManager()->FindSample(sample, i, end); + if (sf != NULL) pSample = sf; // Reuse already created sample + else pSample = new Sample(sample, false, i, end); + GetInstrument()->GetSampleManager()->AddSampleConsumer(pSample, this); + } + return pSample; + } + + void Region::DestroySampleIfNotUsed() { + if (pSample == NULL) return; + GetInstrument()->GetSampleManager()->RemoveSampleConsumer(pSample, this); + if (!GetInstrument()->GetSampleManager()->HasSampleConsumers(pSample)) { + GetInstrument()->GetSampleManager()->RemoveSample(pSample); + delete pSample; + pSample = NULL; + } + } + + bool Region::OnKey(const Query& q) { + // As the region comes from a LookupTable search on the query, + // the following parameters are not checked here: chan, key, + // vel, chanaft, polyaft, prog, sw_previous, cc. They are all + // handled by the lookup table. + bool is_triggered( + q.bend >= lobend && q.bend <= hibend && + q.bpm >= lobpm && q.bpm < hibpm && + q.rand >= lorand && q.rand < hirand && + q.timer >= lotimer && q.timer <= hitimer && + + ( sw_last == -1 || + ((sw_last >= sw_lokey && sw_last <= sw_hikey) ? (q.last_sw_key == sw_last) : false) ) && + + ( sw_down == -1 || + ((sw_down >= sw_lokey && (sw_hikey == -1 || sw_down <= sw_hikey)) ? (q.swsw_down) : false) ) && + + ( sw_up == -1 || + ((sw_up >= sw_lokey && (sw_hikey == -1 || sw_up <= sw_hikey)) ? (!q.swsw_up) : true) ) && + + ((trigger & q.trig) != 0) + ); + + if (!is_triggered) + return false; + + // seq_position has to be checked last, so we know that we + // increment the right counter + is_triggered = (seq_counter == seq_position); + seq_counter = (seq_counter % seq_length) + 1; + + return is_triggered; + } + + Articulation* + Region::GetArticulation(int bend, uint8_t bpm, uint8_t chanaft, uint8_t polyaft, uint8_t* cc) + { + return new Articulation(); //todo: implement GetArticulation() + } + + bool Region::HasLoop() { + bool b = loop_mode == LOOP_UNSET ? pSample->GetLoops() : + (loop_mode == LOOP_CONTINUOUS || loop_mode == LOOP_SUSTAIN); + return b && GetLoopEnd() > GetLoopStart(); + } + + uint Region::GetLoopStart() { + return (!loop_start) ? pSample->GetLoopStart() : *loop_start; + } + + uint Region::GetLoopEnd() { + return (!loop_end) ? pSample->GetLoopEnd() : *loop_end; + } + + uint Region::GetLoopCount() { + return (!count) ? 0 : *count; + } + + ///////////////////////////////////////////////////////////// + // class Instrument + + Instrument::Instrument(std::string name, SampleManager* pSampleManager) : KeyBindings(128, false), KeySwitchBindings(128, false) + { + this->name = name; + this->pSampleManager = pSampleManager ? pSampleManager : this; + pLookupTable = 0; + + // The first 6 curves are defined internally (actually 7 with the one at index 0) + Curve c; + for (int i = 0; i < 128; i++) c.vi = i / 127.0f; + curves.add(c); curves.add(c); curves.add(c); curves.add(c); + curves.add(c); curves.add(c); curves.add(c); + /////// + } + + Instrument::~Instrument() + { + for (int i = 0; i < regions.size(); i++) { + delete regionsi; + } + delete pLookupTable; + for (int i = 0 ; i < 128 ; i++) { + delete pLookupTableCCi; + } + } + + void Query::search(const Instrument* pInstrument) { + pRegionList = &pInstrument->pLookupTable->query(*this); + regionIndex = 0; + } + + void Query::search(const Instrument* pInstrument, int triggercc) { + pRegionList = &pInstrument->pLookupTableCCtriggercc->query(*this); + regionIndex = 0; + } + + Region* Query::next() { + for ( ; regionIndex < pRegionList->size() ; regionIndex++) { + if ((*pRegionList)regionIndex->OnKey(*this)) { + return (*pRegionList)regionIndex++; + } + } + return 0; + } + + bool Instrument::DestroyRegion(Region* pRegion) { + for (std::vector<Region*>::iterator it = regions.begin(); it != regions.end(); it++) { + if(*it == pRegion) { + regions.erase(it); + delete pRegion; + return true; + } + } + + return false; + } + + bool Instrument::HasKeyBinding(uint8_t key) { + if (key > 127) return false; + return KeyBindingskey; + } + + bool Instrument::HasKeySwitchBinding(uint8_t key) { + if (key > 127) return false; + return KeySwitchBindingskey; + } + + ///////////////////////////////////////////////////////////// + // class Group + + Group::Group() : + id(0) + { + Reset(); + } + + Group::~Group() + { + } + + void + Group::Reset() + { + // This is where all the default values are set. + + // sample definition default + sample = ""; + + // input control + lochan = 1; hichan = 16; + lokey = 0; hikey = 127; + lovel = 0; hivel = 127; + lobend = -8192; hibend = 8192; + lobpm = 0; hibpm = 500; + lochanaft = 0; hichanaft = 127; + lopolyaft = 0; hipolyaft = 127; + loprog = 0; hiprog = 127; + lorand = 0.0; hirand = 1.0; + lotimer = 0.0; hitimer = 0.0; + + seq_length = 1; + seq_position = 1; + + sw_lokey = -1; sw_hikey = -1; + sw_last = -1; + sw_down = -1; + sw_up = -1; + sw_previous = -1; + sw_vel = VEL_CURRENT; + + trigger = TRIGGER_ATTACK; + + group = 0; + off_by = 0; + off_mode = OFF_FAST; + + // sample player + count.unset(); + delay.unset(); delay_random.unset(); + delay_beats.unset(); stop_beats.unset(); + delay_samples.unset(); + end = 0; + loop_crossfade.unset(); + offset.unset(); offset_random.unset(); + loop_mode = LOOP_UNSET; + loop_start.unset(); loop_end.unset(); + sync_beats.unset(); sync_offset.unset(); + + // amplifier + volume = 0; + volume_oncc.clear(); + volume_curvecc.clear(); + volume_smoothcc.clear(); + volume_stepcc.clear(); + pan = 0; + pan_oncc.clear(); + pan_curvecc.clear(); + pan_smoothcc.clear(); + pan_stepcc.clear(); + width = 100; + position = 0; + amp_keytrack = 0; + amp_keycenter = 60; + amp_veltrack = 100; + amp_random = 0; + rt_decay = 0; + xfin_lokey = 0; xfin_hikey = 0; + xfout_lokey = 127; xfout_hikey = 127; + xf_keycurve = POWER; + xfin_lovel = 0; xfin_hivel = 0; + xfout_lovel = 127; xfout_hivel = 127; + xf_velcurve = POWER; + xf_cccurve = POWER; + + // pitch + transpose = 0; + tune = 0; + pitch_keycenter = 60; + pitch_keytrack = 100; + pitch_veltrack = 0; + pitch_random = 0; + bend_up = 200; + bend_down = -200; + bend_step = 1; + + pitch_oncc.clear(); + pitch_smoothcc.clear(); + pitch_curvecc.clear(); + pitch_stepcc.clear(); + + // filter + fil_type = LPF_2P; + cutoff.unset(); + cutoff_chanaft = 0; + cutoff_polyaft = 0; + resonance = 0; + fil_keytrack = 0; + fil_keycenter = 60; + fil_veltrack = 0; + fil_random = 0; + + fil2_type = LPF_2P; + cutoff2.unset(); + cutoff2_chanaft = 0; + cutoff2_polyaft = 0; + resonance2 = 0; + fil2_keytrack = 0; + fil2_keycenter = 60; + fil2_veltrack = 0; + fil2_random = 0; + + cutoff_oncc.clear(); + cutoff_smoothcc.clear(); + cutoff_curvecc.clear(); + cutoff_stepcc.clear(); + cutoff2_oncc.clear(); + cutoff2_smoothcc.clear(); + cutoff2_curvecc.clear(); + cutoff2_stepcc.clear(); + + resonance_oncc.clear(); + resonance_smoothcc.clear(); + resonance_curvecc.clear(); + resonance_stepcc.clear(); + resonance2_oncc.clear(); + resonance2_smoothcc.clear(); + resonance2_curvecc.clear(); + resonance2_stepcc.clear(); + + // per voice equalizer + eq1_freq = 50; + eq2_freq = 500; + eq3_freq = 5000; + eq1_vel2freq = 0; + eq2_vel2freq = 0; + eq3_vel2freq = 0; + eq1_bw = 1; + eq2_bw = 1; + eq3_bw = 1; + eq1_gain = 0; + eq2_gain = 0; + eq3_gain = 0; + eq1_vel2gain = 0; + eq2_vel2gain = 0; + eq3_vel2gain = 0; + + // CCs + for (int i = 0; i < 128; ++i) + { + // input control + locc.set(i, 0); + hicc.set(i, 127); + start_locc.set(i, -1); + start_hicc.set(i, -1); + stop_locc.set(i, -1); + stop_hicc.set(i, -1); + on_locc.set(i, -1); + on_hicc.set(i, -1); + + // sample player + delay_oncc.set(i, optional<float>::nothing); + delay_samples_oncc.set(i, optional<int>::nothing); + offset_oncc.set(i, optional<int>::nothing); + + // amplifier + amp_velcurve.set(i, -1); + gain_oncc.set(i, 0); + xfin_locc.set(i, 0); + xfin_hicc.set(i, 0); + xfout_locc.set(i, 0); + xfout_hicc.set(i, 0); + + // per voice equalizer + eq1_freq_oncc.set(i, 0); + eq2_freq_oncc.set(i, 0); + eq3_freq_oncc.set(i, 0); + eq1_bw_oncc.set(i, 0); + eq2_bw_oncc.set(i, 0); + eq3_bw_oncc.set(i, 0); + eq1_gain_oncc.set(i, 0); + eq2_gain_oncc.set(i, 0); + eq3_gain_oncc.set(i, 0); + } + + eg.clear(); + lfos.clear(); + + // deprecated + ampeg_delay = 0; + ampeg_start = 0; //in percentage + ampeg_attack = 0; + ampeg_hold = 0; + ampeg_decay = 0; + ampeg_sustain = -1; // in percentage + ampeg_release = 0; + + ampeg_vel2delay = 0; + ampeg_vel2attack = 0; + ampeg_vel2hold = 0; + ampeg_vel2decay = 0; + ampeg_vel2sustain = 0; + ampeg_vel2release = 0; + + ampeg_delaycc.clear(); + ampeg_startcc.clear(); + ampeg_attackcc.clear(); + ampeg_holdcc.clear(); + ampeg_decaycc.clear(); + ampeg_sustaincc.clear(); + ampeg_releasecc.clear(); + + fileg_delay = 0; + fileg_start = 0; //in percentage + fileg_attack = 0; + fileg_hold = 0; + fileg_decay = 0; + fileg_sustain = 100; // in percentage + fileg_release = 0; + + fileg_vel2delay = 0; + fileg_vel2attack = 0; + fileg_vel2hold = 0; + fileg_vel2decay = 0; + fileg_vel2sustain = 0; + fileg_vel2release = 0; + fileg_depth = 0; + + fileg_delay_oncc.clear(); + fileg_start_oncc.clear(); + fileg_attack_oncc.clear(); + fileg_hold_oncc.clear(); + fileg_decay_oncc.clear(); + fileg_sustain_oncc.clear(); + fileg_release_oncc.clear(); + fileg_depth_oncc.clear(); + + pitcheg_delay = 0; + pitcheg_start = 0; //in percentage + pitcheg_attack = 0; + pitcheg_hold = 0; + pitcheg_decay = 0; + pitcheg_sustain = 100; // in percentage + pitcheg_release = 0; + pitcheg_depth = 0; + + pitcheg_vel2delay = 0; + pitcheg_vel2attack = 0; + pitcheg_vel2hold = 0; + pitcheg_vel2decay = 0; + pitcheg_vel2sustain = 0; + pitcheg_vel2release = 0; + + pitcheg_delay_oncc.clear(); + pitcheg_start_oncc.clear(); + pitcheg_attack_oncc.clear(); + pitcheg_hold_oncc.clear(); + pitcheg_decay_oncc.clear(); + pitcheg_sustain_oncc.clear(); + pitcheg_release_oncc.clear(); + pitcheg_depth_oncc.clear(); + + amplfo_delay = 0; + amplfo_fade = 0; + amplfo_freq = -1; /* -1 is used to determine whether the LFO was initialized */ + amplfo_depth = 0; + amplfo_delay_oncc.clear(); + amplfo_fade_oncc.clear(); + amplfo_depthcc.clear(); + amplfo_freqcc.clear(); + + fillfo_delay = 0; + fillfo_fade = 0; + fillfo_freq = -1; /* -1 is used to determine whether the LFO was initialized */ + fillfo_depth = 0; + fillfo_delay_oncc.clear(); + fillfo_fade_oncc.clear(); + fillfo_depthcc.clear(); + fillfo_freqcc.clear(); + + pitchlfo_delay = 0; + pitchlfo_fade = 0; + pitchlfo_freq = -1; /* -1 is used to determine whether the LFO was initialized */ + pitchlfo_depth = 0; + pitchlfo_delay_oncc.clear(); + pitchlfo_fade_oncc.clear(); + pitchlfo_depthcc.clear(); + pitchlfo_freqcc.clear(); + } + + Region* + Group::RegionFactory() + { + // This is where the current group setting are copied to the new region. + + Region* region = new Region(); + + region->id = id++; + + // sample definition + region->sample = sample; + + // input control + region->lochan = lochan; + region->hichan = hichan; + region->lokey = lokey; + region->hikey = hikey; + region->lovel = lovel; + region->hivel = hivel; + region->locc = locc; + region->hicc = hicc; + region->lobend = lobend; + region->hibend = hibend; + region->lobpm = lobpm; + region->hibpm = hibpm; + region->lochanaft = lochanaft; + region->hichanaft = hichanaft; + region->lopolyaft = lopolyaft; + region->hipolyaft = hipolyaft; + region->loprog = loprog; + region->hiprog = hiprog; + region->lorand = lorand; + region->hirand = hirand; + region->lotimer = lotimer; + region->hitimer = hitimer; + region->seq_length = seq_length; + region->seq_position = seq_position; + region->start_locc = start_locc; + region->start_hicc = start_hicc; + region->stop_locc = stop_locc; + region->stop_hicc = stop_hicc; + region->sw_lokey = sw_lokey; + region->sw_hikey = sw_hikey; + region->sw_last = sw_last; + region->sw_down = sw_down; + region->sw_up = sw_up; + region->sw_previous = sw_previous; + region->sw_vel = sw_vel; + region->trigger = trigger; + region->group = group; + region->off_by = off_by; + region->off_mode = off_mode; + region->on_locc = on_locc; + region->on_hicc = on_hicc; + + // sample player + region->count = count; + region->delay = delay; + region->delay_random = delay_random; + region->delay_oncc = delay_oncc; + region->delay_beats = delay_beats; + region->stop_beats = stop_beats; + region->delay_samples = delay_samples; + region->delay_samples_oncc = delay_samples_oncc; + region->end = end; + region->loop_crossfade = loop_crossfade; + region->offset = offset; + region->offset_random = offset_random; + region->offset_oncc = offset_oncc; + region->loop_mode = loop_mode; + region->loop_start = loop_start; + region->loop_end = loop_end; + region->sync_beats = sync_beats; + region->sync_offset = sync_offset; + + // amplifier + region->volume = volume; + region->volume_oncc = volume_oncc; + region->volume_curvecc = volume_curvecc; + region->volume_smoothcc = volume_smoothcc; + region->volume_stepcc = volume_stepcc; + region->pan = pan; + region->pan_oncc = pan_oncc; + region->pan_curvecc = pan_curvecc; + region->pan_smoothcc = pan_smoothcc; + region->pan_stepcc = pan_stepcc; + region->width = width; + region->position = position; + region->amp_keytrack = amp_keytrack; + region->amp_keycenter = amp_keycenter; + region->amp_veltrack = amp_veltrack; + region->amp_velcurve = amp_velcurve; + region->amp_random = amp_random; + region->rt_decay = rt_decay; + region->gain_oncc = gain_oncc; + region->xfin_lokey = xfin_lokey; + region->xfin_hikey = xfin_hikey; + region->xfout_lokey = xfout_lokey; + region->xfout_hikey = xfout_hikey; + region->xf_keycurve = xf_keycurve; + region->xfin_lovel = xfin_lovel; + region->xfin_hivel = xfin_lovel; + region->xfout_lovel = xfout_lovel; + region->xfout_hivel = xfout_hivel; + region->xf_velcurve = xf_velcurve; + region->xfin_locc = xfin_locc; + region->xfin_hicc = xfin_hicc; + region->xfout_locc = xfout_locc; + region->xfout_hicc = xfout_hicc; + region->xf_cccurve = xf_cccurve; + + // pitch + region->transpose = transpose; + region->tune = tune; + region->pitch_keycenter = pitch_keycenter; + region->pitch_keytrack = pitch_keytrack; + region->pitch_veltrack = pitch_veltrack; + region->pitch_random = pitch_random; + region->bend_up = bend_up; + region->bend_down = bend_down; + region->bend_step = bend_step; + + region->pitch_oncc = pitch_oncc; + region->pitch_smoothcc = pitch_smoothcc; + region->pitch_curvecc = pitch_curvecc; + region->pitch_stepcc = pitch_stepcc; + + // filter + region->fil_type = fil_type; + region->cutoff = cutoff; + region->cutoff_oncc = cutoff_oncc; + region->cutoff_smoothcc = cutoff_smoothcc; + region->cutoff_stepcc = cutoff_stepcc; + region->cutoff_curvecc = cutoff_curvecc; + region->cutoff_chanaft = cutoff_chanaft; + region->cutoff_polyaft = cutoff_polyaft; + region->resonance = resonance; + region->resonance_oncc = resonance_oncc; + region->resonance_smoothcc = resonance_smoothcc; + region->resonance_stepcc = resonance_stepcc; + region->resonance_curvecc = resonance_curvecc; + region->fil_keytrack = fil_keytrack; + region->fil_keycenter = fil_keycenter; + region->fil_veltrack = fil_veltrack; + region->fil_random = fil_random; + + region->fil2_type = fil2_type; + region->cutoff2 = cutoff2; + region->cutoff2_oncc = cutoff2_oncc; + region->cutoff2_smoothcc = cutoff2_smoothcc; + region->cutoff2_stepcc = cutoff2_stepcc; + region->cutoff2_curvecc = cutoff2_curvecc; + region->cutoff2_chanaft = cutoff2_chanaft; + region->cutoff2_polyaft = cutoff2_polyaft; + region->resonance2 = resonance2; + region->resonance2_oncc = resonance2_oncc; + region->resonance2_smoothcc = resonance2_smoothcc; + region->resonance2_stepcc = resonance2_stepcc; + region->resonance2_curvecc = resonance2_curvecc; + region->fil2_keytrack = fil2_keytrack; + region->fil2_keycenter = fil2_keycenter; + region->fil2_veltrack = fil2_veltrack; + region->fil2_random = fil2_random; + + // per voice equalizer + region->eq1_freq = eq1_freq; + region->eq2_freq = eq2_freq; + region->eq3_freq = eq3_freq; + region->eq1_freq_oncc = eq1_freq_oncc; + region->eq2_freq_oncc = eq2_freq_oncc; + region->eq3_freq_oncc = eq3_freq_oncc; + region->eq1_vel2freq = eq1_vel2freq; + region->eq2_vel2freq = eq2_vel2freq; + region->eq3_vel2freq = eq3_vel2freq; + region->eq1_bw = eq1_bw; + region->eq2_bw = eq2_bw; + region->eq3_bw = eq3_bw; + region->eq1_bw_oncc = eq1_bw_oncc; + region->eq2_bw_oncc = eq2_bw_oncc; + region->eq3_bw_oncc = eq3_bw_oncc; + region->eq1_gain = eq1_gain; + region->eq2_gain = eq2_gain; + region->eq3_gain = eq3_gain; + region->eq1_gain_oncc = eq1_gain_oncc; + region->eq2_gain_oncc = eq2_gain_oncc; + region->eq3_gain_oncc = eq3_gain_oncc; + region->eq1_vel2gain = eq1_vel2gain; + region->eq2_vel2gain = eq2_vel2gain; + region->eq3_vel2gain = eq3_vel2gain; + + // envelope generator + region->eg = eg; + + // deprecated + region->ampeg_delay = ampeg_delay; + region->ampeg_start = ampeg_start; + region->ampeg_attack = ampeg_attack; + region->ampeg_hold = ampeg_hold; + region->ampeg_decay = ampeg_decay; + region->ampeg_sustain = ampeg_sustain; + region->ampeg_release = ampeg_release; + + region->ampeg_vel2delay = ampeg_vel2delay; + region->ampeg_vel2attack = ampeg_vel2attack; + region->ampeg_vel2hold = ampeg_vel2hold; + region->ampeg_vel2decay = ampeg_vel2decay; + region->ampeg_vel2sustain = ampeg_vel2sustain; + region->ampeg_vel2release = ampeg_vel2release; + + region->ampeg_delaycc = ampeg_delaycc; + region->ampeg_startcc = ampeg_startcc; + region->ampeg_attackcc = ampeg_attackcc; + region->ampeg_holdcc = ampeg_holdcc; + region->ampeg_decaycc = ampeg_decaycc; + region->ampeg_sustaincc = ampeg_sustaincc; + region->ampeg_releasecc = ampeg_releasecc; + + region->fileg_delay = fileg_delay; + region->fileg_start = fileg_start; + region->fileg_attack = fileg_attack; + region->fileg_hold = fileg_hold; + region->fileg_decay = fileg_decay; + region->fileg_sustain = fileg_sustain; + region->fileg_release = fileg_release; + region->fileg_depth = fileg_depth; + + region->fileg_vel2delay = fileg_vel2delay; + region->fileg_vel2attack = fileg_vel2attack; + region->fileg_vel2hold = fileg_vel2hold; + region->fileg_vel2decay = fileg_vel2decay; + region->fileg_vel2sustain = fileg_vel2sustain; + region->fileg_vel2release = fileg_vel2release; + + region->fileg_delay_oncc = fileg_delay_oncc; + region->fileg_start_oncc = fileg_start_oncc; + region->fileg_attack_oncc = fileg_attack_oncc; + region->fileg_hold_oncc = fileg_hold_oncc; + region->fileg_decay_oncc = fileg_decay_oncc; + region->fileg_sustain_oncc = fileg_sustain_oncc; + region->fileg_release_oncc = fileg_release_oncc; + region->fileg_depth_oncc = fileg_depth_oncc; + + region->pitcheg_delay = pitcheg_delay; + region->pitcheg_start = pitcheg_start; + region->pitcheg_attack = pitcheg_attack; + region->pitcheg_hold = pitcheg_hold; + region->pitcheg_decay = pitcheg_decay; + region->pitcheg_sustain = pitcheg_sustain; + region->pitcheg_release = pitcheg_release; + region->pitcheg_depth = pitcheg_depth; + + region->pitcheg_vel2delay = pitcheg_vel2delay; + region->pitcheg_vel2attack = pitcheg_vel2attack; + region->pitcheg_vel2hold = pitcheg_vel2hold; + region->pitcheg_vel2decay = pitcheg_vel2decay; + region->pitcheg_vel2sustain = pitcheg_vel2sustain; + region->pitcheg_vel2release = pitcheg_vel2release; + + region->pitcheg_delay_oncc = pitcheg_delay_oncc; + region->pitcheg_start_oncc = pitcheg_start_oncc; + region->pitcheg_attack_oncc = pitcheg_attack_oncc; + region->pitcheg_hold_oncc = pitcheg_hold_oncc; + region->pitcheg_decay_oncc = pitcheg_decay_oncc; + region->pitcheg_sustain_oncc = pitcheg_sustain_oncc; + region->pitcheg_release_oncc = pitcheg_release_oncc; + region->pitcheg_depth_oncc = pitcheg_depth_oncc; + + region->amplfo_delay = amplfo_delay; + region->amplfo_fade = amplfo_fade; + region->amplfo_freq = amplfo_freq; + region->amplfo_depth = amplfo_depth; + + region->amplfo_delay_oncc = amplfo_delay_oncc; + region->amplfo_fade_oncc = amplfo_fade_oncc; + region->amplfo_depthcc = amplfo_depthcc; + region->amplfo_freqcc = amplfo_freqcc; + + region->fillfo_delay = fillfo_delay; + region->fillfo_fade = fillfo_fade; + region->fillfo_freq = fillfo_freq; + region->fillfo_depth = fillfo_depth; + + region->fillfo_delay_oncc = fillfo_delay_oncc; + region->fillfo_fade_oncc = fillfo_fade_oncc; + region->fillfo_depthcc = fillfo_depthcc; + region->fillfo_freqcc = fillfo_freqcc; + + region->pitchlfo_delay = pitchlfo_delay; + region->pitchlfo_fade = pitchlfo_fade; + region->pitchlfo_freq = pitchlfo_freq; + region->pitchlfo_depth = pitchlfo_depth; + + region->pitchlfo_delay_oncc = pitchlfo_delay_oncc; + region->pitchlfo_fade_oncc = pitchlfo_fade_oncc; + region->pitchlfo_depthcc = pitchlfo_depthcc; + region->pitchlfo_freqcc = pitchlfo_freqcc; + + region->eg = eg; + region->lfos = lfos; + + return region; + } + + ///////////////////////////////////////////////////////////// + // class File + + File::File(std::string file, SampleManager* pSampleManager) : + _current_section(GROUP), + default_path(""), + octave_offset(0), + note_offset(0) + { + _instrument = new Instrument(LinuxSampler::Path::getBaseName(file), pSampleManager); + _current_group = new Group(); + pCurDef = _current_group; + enum token_type_t { HEADER, OPCODE }; + token_type_t token_type; + std::string token_string; + + std::ifstream fs(file.c_str()); + currentDir = LinuxSampler::Path::stripLastName(file); + std::string token; + std::string line; + currentLine = 0; + + while (std::getline(fs, line)) + { + currentLine++; + // COMMENT + std::string::size_type slash_index = line.find("//"); + if (slash_index != std::string::npos) + line.resize(slash_index); + + // DEFINITION + std::stringstream linestream(line); + linestream >> std::noskipws; + int spaces = 0; + while (linestream >> token) + { + if (token0 == '<' && tokentoken.size()-1 == '>') + { + // HEAD + if (!token_string.empty()) + { + switch (token_type) + { + case HEADER: + push_header(token_string); + break; + case OPCODE: + push_opcode(token_string); + break; + } + token_string.erase(); + } + token_string.append(token); + token_type = HEADER; + } + else if (token.find('=') != std::string::npos) + { + // HEAD + if (!token_string.empty()) + { + switch (token_type) + { + case HEADER: + push_header(token_string); + break; + case OPCODE: + push_opcode(token_string); + break; + } + token_string.erase(); + } + token_string.append(token); + token_type = OPCODE; + } + else + { + // TAIL + token_string.append(spaces, ' '); + token_string.append(token); + } + spaces = 0; + while (isspace(linestream.peek())) { + linestream.ignore(); + spaces++; + } + } + + // EOL + if (!token_string.empty()) + { + switch (token_type) + { + case HEADER: + push_header(token_string); + break; + case OPCODE: + push_opcode(token_string); + break; + } + token_string.erase(); + } + } + + std::set<float*> velcurves; + for (int i = 0; i < _instrument->regions.size(); i++) { + ::sfz::Region* pRegion = _instrument->regionsi; + int low = pRegion->lokey; + int high = pRegion->hikey; + if (low != -1) { // lokey -1 means region doesn't play on note-on + // hikey -1 is the same as no limit, except that it + // also enables on_locc/on_hicc + if (high == -1) high = 127; + if (low < 0 || low > 127 || high < 0 || high > 127 || low > high) { + std::cerr << "Invalid key range: " << low << " - " << high << std::endl; + } else { + for (int j = low; j <= high; j++) _instrument->KeyBindingsj = true; + } + } + + // get keyswitches + low = pRegion->sw_lokey; + if (low < 0) low = 0; + high = pRegion->sw_hikey; + if (high == -1) { + // Key switches not defined, so nothing to do + } else if (low >= 0 && low <= 127 && high >= 0 && high <= 127 && high >= low) { + for (int j = low; j <= high; j++) _instrument->KeySwitchBindingsj = true; + } else { + std::cerr << "Invalid key switch range: " << low << " - " << high << std::endl; + } + + // create velocity response curve + + // don't use copy-on-write here, instead change the actual + // unique buffers in memory + float* velcurve = const_cast<float*>(&pRegion->amp_velcurve0); + if (velcurves.insert(velcurve).second) { + int prev = 0; + float prevvalue = 0; + for (int v = 0 ; v < 128 ; v++) { + if (velcurvev >= 0) { + float step = (velcurvev - prevvalue) / (v - prev); + for ( ; prev < v ; prev++) { + velcurveprev = prevvalue; + prevvalue += step; + } + } + } + if (prev) { + float step = (1 - prevvalue) / (127 - prev); + for ( ; prev < 128 ; prev++) { + velcurveprev = prevvalue; + prevvalue += step; + } + } else { + // default curve + for (int v = 0 ; v < 128 ; v++) { + velcurvev = v * v / (127.0 * 127.0); + } + } + } + } + + _instrument->pLookupTable = new LookupTable(_instrument); + + // create separate lookup tables for controller triggered + // regions, one for each CC + for (int i = 0 ; i < 128 ; i++) { + _instrument->pLookupTableCCi = new LookupTable(_instrument, i); + } + + for (int i = 0; i < _instrument->regions.size(); i++) { + Region* r = _instrument->regionsi; + + copyCurves(r->volume_curvecc, r->volume_oncc); + r->volume_curvecc.clear(); + + copySmoothValues(r->volume_smoothcc, r->volume_oncc); + r->volume_smoothcc.clear(); + + copyStepValues(r->volume_stepcc, r->volume_oncc); + r->volume_stepcc.clear(); + + copyCurves(r->pitch_curvecc, r->pitch_oncc); + r->pitch_curvecc.clear(); + + copySmoothValues(r->pitch_smoothcc, r->pitch_oncc); + r->pitch_smoothcc.clear(); + + copyStepValues(r->pitch_stepcc, r->pitch_oncc); + r->pitch_stepcc.clear(); + + copyCurves(r->pan_curvecc, r->pan_oncc); + r->pan_curvecc.clear(); + + copySmoothValues(r->pan_smoothcc, r->pan_oncc); + r->pan_smoothcc.clear(); + + copyStepValues(r->pan_stepcc, r->pan_oncc); + r->pan_stepcc.clear(); + + copyCurves(r->cutoff_curvecc, r->cutoff_oncc); + r->cutoff_curvecc.clear(); + + copySmoothValues(r->cutoff_smoothcc, r->cutoff_oncc); + r->cutoff_smoothcc.clear(); + + copyStepValues(r->cutoff_stepcc, r->cutoff_oncc); + r->cutoff_stepcc.clear(); + + copyCurves(r->cutoff2_curvecc, r->cutoff2_oncc); + r->cutoff2_curvecc.clear(); + + copySmoothValues(r->cutoff2_smoothcc, r->cutoff2_oncc); + r->cutoff2_smoothcc.clear(); + + copyStepValues(r->cutoff2_stepcc, r->cutoff2_oncc); + r->cutoff2_stepcc.clear(); + + copyCurves(r->resonance_curvecc, r->resonance_oncc); + r->resonance_curvecc.clear(); + + copySmoothValues(r->resonance_smoothcc, r->resonance_oncc); + r->resonance_smoothcc.clear(); + + copyStepValues(r->resonance_stepcc, r->resonance_oncc); + r->resonance_stepcc.clear(); + + copyCurves(r->resonance2_curvecc, r->resonance2_oncc); + r->resonance2_curvecc.clear(); + + copySmoothValues(r->resonance2_smoothcc, r->resonance2_oncc); + r->resonance2_smoothcc.clear(); + + copyStepValues(r->resonance2_stepcc, r->resonance2_oncc); + r->resonance2_stepcc.clear(); + + for (int j = 0; j < r->eg.size(); j++) { + copyCurves(r->egj.pan_curvecc, r->egj.pan_oncc); + r->egj.pan_curvecc.clear(); + } + + for (int j = 0; j < r->lfos.size(); j++) { + r->lfosj.copySmoothValues(); + r->lfosj.copyStepValues(); + + copySmoothValues(r->lfosj.volume_smoothcc, r->lfosj.volume_oncc); + r->lfosj.volume_smoothcc.clear(); + + copyStepValues(r->lfosj.volume_stepcc, r->lfosj.volume_oncc); + r->lfosj.volume_stepcc.clear(); + + copySmoothValues(r->lfosj.freq_smoothcc, r->lfosj.freq_oncc); + r->lfosj.freq_smoothcc.clear(); + + copyStepValues(r->lfosj.freq_stepcc, r->lfosj.freq_oncc); + r->lfosj.freq_stepcc.clear(); + + copySmoothValues(r->lfosj.pitch_smoothcc, r->lfosj.pitch_oncc); + r->lfosj.pitch_smoothcc.clear(); + + copyStepValues(r->lfosj.pitch_stepcc, r->lfosj.pitch_oncc); + r->lfosj.pitch_stepcc.clear(); + + copySmoothValues(r->lfosj.pan_smoothcc, r->lfosj.pan_oncc); + r->lfosj.pan_smoothcc.clear(); + + copyStepValues(r->lfosj.pan_stepcc, r->lfosj.pan_oncc); + r->lfosj.pan_stepcc.clear(); + + copySmoothValues(r->lfosj.cutoff_smoothcc, r->lfosj.cutoff_oncc); + r->lfosj.cutoff_smoothcc.clear(); + + copyStepValues(r->lfosj.cutoff_stepcc, r->lfosj.cutoff_oncc); + r->lfosj.cutoff_stepcc.clear(); + + copySmoothValues(r->lfosj.resonance_smoothcc, r->lfosj.resonance_oncc); + r->lfosj.resonance_smoothcc.clear(); + + copyStepValues(r->lfosj.resonance_stepcc, r->lfosj.resonance_oncc); + r->lfosj.resonance_stepcc.clear(); + } + } + } + + File::~File() + { + delete _current_group; + delete _instrument; + } + + Instrument* + File::GetInstrument() + { + return _instrument; + } + + void File::copyCurves(LinuxSampler::ArrayList<CC>& curves, LinuxSampler::ArrayList<CC>& dest) { + for (int i = 0; i < curves.size(); i++) { + for (int j = 0; j < dest.size(); j++) { + if (curvesi.Controller == destj.Controller) { + destj.Curve = curvesi.Curve; + } + } + } + } + + void File::copySmoothValues(LinuxSampler::ArrayList<CC>& smooths, LinuxSampler::ArrayList<CC>& dest) { + for (int i = 0; i < smooths.size(); i++) { + for (int j = 0; j < dest.size(); j++) { + if (smoothsi.Controller == destj.Controller) { + destj.Smooth = smoothsi.Smooth; + } + } + } + } + + void File::copyStepValues(LinuxSampler::ArrayList<CC>& steps, LinuxSampler::ArrayList<CC>& dest) { + for (int i = 0; i < steps.size(); i++) { + for (int j = 0; j < dest.size(); j++) { + if (stepsi.Controller == destj.Controller) { + destj.Step = stepsi.Step; + } + } + } + } + + int File::ToInt(const std::string& s) throw(LinuxSampler::Exception) { + int i; + std::istringstream iss(s); + if(!(iss >> i)) { + std::ostringstream oss; + oss << "Line " << currentLine << ": Expected an integer"; + throw LinuxSampler::Exception(oss.str()); + } + return i; + } + + float File::ToFloat(const std::string& s) throw(LinuxSampler::Exception) { + float i; + std::istringstream iss(s); + if(!(iss >> i)) { + std::ostringstream oss; + oss << "Line " << currentLine << ": Expected a floating-point number"; + throw LinuxSampler::Exception(oss.str()); + } + return i; + } + + void + File::push_header(std::string token) + { + if (token == "<group>") + { + _current_section = GROUP; + _current_group->Reset(); + pCurDef = _current_group; + } + else if (token == "<region>") + { + _current_section = REGION; + _current_region = _current_group->RegionFactory(); + pCurDef = _current_region; + _instrument->regions.push_back(_current_region); + _current_region->SetInstrument(_instrument); + } + else if (token == "<control>") + { + _current_section = CONTROL; + default_path = ""; + octave_offset = 0; + note_offset = 0; + } + else if (token == "<curve>") + { + _current_section = CURVE; + _instrument->curves.add(Curve()); + _current_curve = &_instrument->curves_instrument->curves.size() - 1; + } + else + { + _current_section = UNKNOWN; + std::cerr << "The header '" << token << "' is unsupported by libsfz!" << std::endl; + } + } + + void + File::push_opcode(std::string token) + { + if (_current_section == UNKNOWN) + return; + + std::string::size_type delimiter_index = token.find('='); + std::string key = token.substr(0, delimiter_index); + std::string value = token.substr(delimiter_index + 1); + int x, y, z; + + if (_current_section == CURVE) { + if (sscanf(key.c_str(), "v%d", &x)) { + if (x < 0 || x > 127) { + std::cerr << "Invalid curve index: " << x << std::endl; + } + _current_curve->vx = check(key, 0.0f, 1.0f, ToFloat(value)); + } else { + std::cerr << "The opcode '" << key << "' in section <curve> is unsupported by libsfz!" << std::endl; + } + + return; + } + + // sample definition + if ("sample" == key) + { + std::string path = default_path + value; + #ifndef WIN32 + for (int i = 0; i < path.length(); i++) if (pathi == '\\') pathi = '/'; + bool absolute = path0 == '/'; + #else + bool absolute = path0 == '/' || path0 == '\\' || + (path.length() >= 2 && isalpha(path0) && path1 == ':'); + #endif + if (!absolute) path = currentDir + LinuxSampler::File::DirSeparator + path; + if(pCurDef) pCurDef->sample = path; + return; + } + + // control header directives + else if ("default_path" == key) + { + switch (_current_section) + { + case CONTROL: + default_path = value; + } + return; + } + else if ("octave_offset" == key) + { + switch (_current_section) + { + case CONTROL: + octave_offset = ToInt(value); + } + return; + } + else if ("note_offset" == key) + { + switch (_current_section) + { + case CONTROL: + note_offset = ToInt(value); + } + return; + } + + // input controls + else if ("lochan" == key) pCurDef->lochan = ToInt(value); + else if ("hichan" == key) pCurDef->hichan = ToInt(value); + else if ("lokey" == key) pCurDef->lokey = parseKey(value); + else if ("hikey" == key) pCurDef->hikey = parseKey(value); + else if ("key" == key) + { + pCurDef->lokey = pCurDef->hikey = pCurDef->pitch_keycenter = parseKey(value); + } + else if ("lovel" == key) pCurDef->lovel = ToInt(value); + else if ("hivel" == key) pCurDef->hivel = ToInt(value); + else if ("lobend" == key) pCurDef->lobend = ToInt(value); + else if ("hibend" == key) pCurDef->hibend = ToInt(value); + else if ("lobpm" == key) pCurDef->lobpm = ToFloat(value); + else if ("hibpm" == key) pCurDef->hibpm = ToFloat(value); + else if ("lochanaft" == key) pCurDef->lochanaft = ToInt(value); + else if ("hichanaft" == key) pCurDef->hichanaft = ToInt(value); + else if ("lopolyaft" == key) pCurDef->lopolyaft = ToInt(value); + else if ("hipolyaft" == key) pCurDef->hipolyaft = ToInt(value); + else if ("loprog" == key) pCurDef->loprog = ToInt(value); + else if ("hiprog" == key) pCurDef->hiprog = ToInt(value); + else if ("lorand" == key) pCurDef->lorand = ToFloat(value); + else if ("hirand" == key) pCurDef->hirand = ToFloat(value); + else if ("lotimer" == key) pCurDef->lotimer = ToFloat(value); + else if ("hitimer" == key) pCurDef->hitimer = ToFloat(value); + else if ("seq_length" == key) pCurDef->seq_length = ToInt(value); + else if ("seq_position" == key) pCurDef->seq_position = ToInt(value); + else if ("sw_lokey" == key) pCurDef->sw_lokey = parseKey(value); + else if ("sw_hikey" == key) pCurDef->sw_hikey = parseKey(value); + else if ("sw_last" == key) pCurDef->sw_last = parseKey(value); + else if ("sw_down" == key) pCurDef->sw_down = parseKey(value); + else if ("sw_up" == key) pCurDef->sw_up = parseKey(value); + else if ("sw_previous" == key) pCurDef->sw_previous = parseKey(value); + else if ("sw_vel" == key) + { + if (value == "current") pCurDef->sw_vel = VEL_CURRENT; + else if (value == "previous") pCurDef->sw_vel = VEL_PREVIOUS; + } + else if ("trigger" == key) + { + if (value == "attack") pCurDef->trigger = TRIGGER_ATTACK; + else if (value == "release") pCurDef->trigger = TRIGGER_RELEASE; + else if (value == "first") pCurDef->trigger = TRIGGER_FIRST; + else if (value == "legato") pCurDef->trigger = TRIGGER_LEGATO; + } + else if ("group" == key) pCurDef->group = ToInt(value); + else if ("off_by" == key || "offby" == key) pCurDef->off_by = ToInt(value); + else if ("off_mode" == key || "offmode" == key) + { + if (value == "fast") pCurDef->off_mode = OFF_FAST; + else if (value == "normal") pCurDef->off_mode = OFF_NORMAL; + } + + // sample player + else if ("count" == key) { pCurDef->count = ToInt(value); pCurDef->loop_mode = ONE_SHOT; } + else if ("delay" == key) pCurDef->delay = ToFloat(value); + else if ("delay_random" == key) pCurDef->delay_random = ToFloat(value); + else if ("delay_beats" == key) pCurDef->delay_beats = ToInt(value); + else if ("stop_beats" == key) pCurDef->stop_beats = ToInt(value); + else if ("delay_samples" == key) pCurDef->delay_samples = ToInt(value); + else if ("end" == key) pCurDef->end = ToInt(value); + else if ("loop_crossfade" == key) pCurDef->loop_crossfade = ToFloat(value); + else if ("offset_random" == key) pCurDef->offset_random = ToInt(value); + else if ("loop_mode" == key || "loopmode" == key) + { + if (value == "no_loop") pCurDef->loop_mode = NO_LOOP; + else if (value == "one_shot") pCurDef->loop_mode = ONE_SHOT; + else if (value == "loop_continuous") pCurDef->loop_mode = LOOP_CONTINUOUS; + else if (value == "loop_sustain") pCurDef->loop_mode = LOOP_SUSTAIN; + } + else if ("loop_start" == key) pCurDef->loop_start = ToInt(value); + else if ("loopstart" == key) pCurDef->loop_start = ToInt(value); // nonstandard + else if ("loop_end" == key) pCurDef->loop_end = ToInt(value); + else if ("loopend" == key) pCurDef->loop_end = ToInt(value); // nonstandard + else if ("offset" == key) pCurDef->offset = ToInt(value); + else if ("sync_beats" == key) pCurDef->sync_beats = ToInt(value); + else if ("sync_offset" == key) pCurDef->sync_offset = ToInt(value); + + // amplifier + else if ("volume" == key) pCurDef->volume = ToFloat(value); + else if ("pan" == key) pCurDef->pan = ToFloat(value); + else if ("width" == key) pCurDef->width = ToFloat(value); + else if ("position" == key) pCurDef->position = ToFloat(value); + else if ("amp_keytrack" == key) pCurDef->amp_keytrack = ToFloat(value); + else if ("amp_keycenter" == key) pCurDef->amp_keycenter = parseKey(value); + else if ("amp_veltrack" == key) pCurDef->amp_veltrack = ToFloat(value); + else if ("amp_random" == key) pCurDef->amp_random = ToFloat(value); + else if ("rt_decay" == key || "rtdecay" == key) pCurDef->rt_decay = ToFloat(value); + else if ("xfin_lokey" == key) pCurDef->xfin_lokey = parseKey(value); + else if ("xfin_hikey" == key) pCurDef->xfin_hikey = parseKey(value); + else if ("xfout_lokey" == key) pCurDef->xfout_lokey = parseKey(value); + else if ("xfout_hikey" == key) pCurDef->xfout_hikey = parseKey(value); + else if ("xf_keycurve" == key) + { + if (value == "gain") pCurDef->xf_keycurve = GAIN; + else if (value == "power") pCurDef->xf_keycurve = POWER; + } + else if ("xfin_lovel" == key) pCurDef->xfin_lovel = ToInt(value); + else if ("xfin_hivel" == key) pCurDef->xfin_hivel = ToInt(value); + else if ("xfout_lovel" == key) pCurDef->xfout_lovel = ToInt(value); + else if ("xfout_hivel" == key) pCurDef->xfout_hivel = ToInt(value); + else if ("xf_velcurve" == key) + { + if (value == "gain") pCurDef->xf_velcurve = GAIN; + else if (value == "power") pCurDef->xf_velcurve = POWER; + } + else if ("xf_cccurve" == key) + { + if (value == "gain") pCurDef->xf_cccurve = GAIN; + else if (value == "power") pCurDef->xf_cccurve = POWER; + } + + // pitch + else if ("transpose" == key) pCurDef->transpose = ToInt(value); + else if ("tune" == key) pCurDef->tune = ToInt(value); + else if ("pitch_keycenter" == key) pCurDef->pitch_keycenter = parseKey(value); + else if ("pitch_keytrack" == key) pCurDef->pitch_keytrack = ToInt(value); + else if ("pitch_veltrack" == key) pCurDef->pitch_veltrack = ToInt(value); + else if ("pitch_random" == key) pCurDef->pitch_random = ToInt(value); + else if ("bend_up" == key || "bendup" == key) pCurDef->bend_up = ToInt(value); + else if ("bend_down" == key || "benddown" == key) pCurDef->bend_down = ToInt(value); + else if ("bend_step" == key || "bendstep" == key) pCurDef->bend_step = ToInt(value); + + // filter + else if ("fil_type" == key || "filtype" == key) + { + if (value == "lpf_1p") pCurDef->fil_type = LPF_1P; + else if (value == "hpf_1p") pCurDef->fil_type = HPF_1P; + else if (value == "bpf_1p") pCurDef->fil_type = BPF_1P; + else if (value == "brf_1p") pCurDef->fil_type = BRF_1P; + else if (value == "apf_1p") pCurDef->fil_type = APF_1P; + else if (value == "lpf_2p") pCurDef->fil_type = LPF_2P; + else if (value == "hpf_2p") pCurDef->fil_type = HPF_2P; + else if (value == "bpf_2p") pCurDef->fil_type = BPF_2P; + else if (value == "brf_2p") pCurDef->fil_type = BRF_2P; + else if (value == "pkf_2p") pCurDef->fil_type = PKF_2P; + else if (value == "lpf_4p") pCurDef->fil_type = LPF_4P; + else if (value == "hpf_4p") pCurDef->fil_type = HPF_4P; + else if (value == "lpf_6p") pCurDef->fil_type = LPF_6P; + else if (value == "hpf_6p") pCurDef->fil_type = HPF_6P; + } + else if ("fil2_type" == key) + { + if (value == "lpf_1p") pCurDef->fil2_type = LPF_1P; + else if (value == "hpf_1p") pCurDef->fil2_type = HPF_1P; + else if (value == "bpf_1p") pCurDef->fil2_type = BPF_1P; + else if (value == "brf_1p") pCurDef->fil2_type = BRF_1P; + else if (value == "apf_1p") pCurDef->fil2_type = APF_1P; + else if (value == "lpf_2p") pCurDef->fil2_type = LPF_2P; + else if (value == "hpf_2p") pCurDef->fil2_type = HPF_2P; + else if (value == "bpf_2p") pCurDef->fil2_type = BPF_2P; + else if (value == "brf_2p") pCurDef->fil2_type = BRF_2P; + else if (value == "pkf_2p") pCurDef->fil2_type = PKF_2P; + else if (value == "lpf_4p") pCurDef->fil2_type = LPF_4P; + else if (value == "hpf_4p") pCurDef->fil2_type = HPF_4P; + else if (value == "lpf_6p") pCurDef->fil2_type = LPF_6P; + else if (value == "hpf_6p") pCurDef->fil2_type = HPF_6P; + } + else if ("cutoff" == key) pCurDef->cutoff = ToFloat(value); + else if ("cutoff2" == key) pCurDef->cutoff2 = ToFloat(value); + else if ("cutoff_chanaft" == key) { + pCurDef->cutoff_chanaft = check(key, -9600, 9600, ToInt(value)); + pCurDef->cutoff_oncc.add( CC(128, check(key, -9600, 9600, ToInt(value))) ); + } else if ("cutoff2_chanaft" == key) pCurDef->cutoff2_chanaft = ToInt(value); + else if ("cutoff_polyaft" == key) pCurDef->cutoff_polyaft = ToInt(value); + else if ("cutoff2_polyaft" == key) pCurDef->cutoff2_polyaft = ToInt(value); + else if ("resonance" == key) pCurDef->resonance = ToFloat(value); + else if ("resonance2" == key) pCurDef->resonance2 = ToFloat(value); + else if ("fil_keytrack" == key) pCurDef->fil_keytrack = ToInt(value); + else if ("fil2_keytrack" == key) pCurDef->fil2_keytrack = ToInt(value); + else if ("fil_keycenter" == key) pCurDef->fil_keycenter = parseKey(value); + else if ("fil2_keycenter" == key) pCurDef->fil2_keycenter = parseKey(value); + else if ("fil_veltrack" == key) pCurDef->fil_veltrack = ToInt(value); + else if ("fil2_veltrack" == key) pCurDef->fil2_veltrack = ToInt(value); + else if ("fil_random" == key) pCurDef->fil_random = ToInt(value); + else if ("fil2_random" == key) pCurDef->fil2_random = ToInt(value); + + // per voice equalizer + else if ("eq1_freq" == key) pCurDef->eq1_freq = ToFloat(value); + else if ("eq2_freq" == key) pCurDef->eq2_freq = ToFloat(value); + else if ("eq3_freq" == key) pCurDef->eq3_freq = ToFloat(value); + else if ("eq1_vel2freq" == key) pCurDef->eq1_vel2freq = ToFloat(value); + else if ("eq2_vel2freq" == key) pCurDef->eq2_vel2freq = ToFloat(value); + else if ("eq3_vel2freq" == key) pCurDef->eq3_vel2freq = ToFloat(value); + else if ("eq1_bw" == key) pCurDef->eq1_bw = ToFloat(value); + else if ("eq2_bw" == key) pCurDef->eq2_bw = ToFloat(value); + else if ("eq3_bw" == key) pCurDef->eq3_bw = ToFloat(value); + else if ("eq1_gain" == key) pCurDef->eq1_gain = ToFloat(value); + else if ("eq2_gain" == key) pCurDef->eq2_gain = ToFloat(value); + else if ("eq3_gain" == key) pCurDef->eq3_gain = ToFloat(value); + else if ("eq1_vel2gain" == key) pCurDef->eq1_vel2gain = ToFloat(value); + else if ("eq2_vel2gain" == key) pCurDef->eq2_vel2gain = ToFloat(value); + else if ("eq3_vel2gain" == key) pCurDef->eq3_vel2gain = ToFloat(value); + + else if (sscanf(key.c_str(), "amp_velcurve_%d", &x)) { + pCurDef->amp_velcurve.set(x, ToFloat(value)); + } + + // v2 envelope generators + else if (sscanf(key.c_str(), "eg%d%n", &x, &y)) { + const char* s = key.c_str() + y; + if (sscanf(s, "_time%d%n", &y, &z)) { + const char* s2 = s + z; + if (strcmp(s2, "") == 0) egnode(x, y).time = check(key, 0.0f, 100.0f, ToFloat(value)); + else if (sscanf(s2, "_oncc%d", &z)) egnode(x, y).time_oncc.add( CC(z, check(key, 0.0f, 100.0f, ToFloat(value))) ); + } else if (sscanf(s, "_level%d%n", &y, &z)) { + const char* s2 = s + z; + if (strcmp(s2, "") == 0) egnode(x, y).level = check(key, 0.0f, 1.0f, ToFloat(value)); + else if (sscanf(s2, "_oncc%d", &z)) egnode(x, y).level_oncc.add( CC(z, check(key, 0.0f, 1.0f, ToFloat(value))) ); + } + else if (sscanf(s, "_shape%d", &y)) egnode(x, y).shape = ToFloat(value); + else if (sscanf(s, "_curve%d", &y)) egnode(x, y).curve = ToFloat(value); + else if (strcmp(s, "_sustain") == 0) eg(x).sustain = ToInt(value); + else if (strcmp(s, "_loop") == 0) eg(x).loop = ToInt(value); + else if (strcmp(s, "_loop_count") == 0) eg(x).loop_count = ToInt(value); + else if (strcmp(s, "_amplitude") == 0) eg(x).amplitude = ToFloat(value); + else if (sscanf(s, "_amplitude_oncc%d", &y)) eg(x).amplitude_oncc.add( CC(y, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if (strcmp(s, "_volume") == 0) eg(x).volume = check(key, -144.0f, 6.0f, ToFloat(value)); + else if (sscanf(s, "_volume_oncc%d", &y)) eg(x).volume_oncc.add( CC(y, check(key, -144.0f, 6.0f, ToFloat(value))) ); + else if (strcmp(s, "_cutoff") == 0) eg(x).cutoff = ToFloat(value); + else if (sscanf(s, "_cutoff_oncc%d", &y)) eg(x).cutoff_oncc.add( CC(y, check(key, -9600, 9600, ToInt(value))) ); + else if (strcmp(s, "_pitch") == 0) eg(x).pitch = check(key, -9600, 9600, ToInt(value)); + else if (sscanf(s, "_pitch_oncc%d", &y)) eg(x).pitch_oncc.add( CC(y, check(key, -9600, 9600, ToInt(value))) ); + else if (strcmp(s, "_resonance") == 0) eg(x).resonance = check(key, 0.0f, 40.0f, ToFloat(value)); + else if (sscanf(s, "_resonance_oncc%d", &y)) eg(x).resonance_oncc.add( CC(y, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if (strcmp(s, "_pan") == 0) eg(x).pan = check(key, -100.0f, 100.0f, ToFloat(value)); + else if (strcmp(s, "_pan_curve") == 0) eg(x).pan_curve = check(key, 0, 30000, ToInt(value)); + else if (sscanf(s, "_pan_oncc%d", &y)) eg(x).pan_oncc.add( CC(y, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if (sscanf(s, "_pan_curvecc%d", &y)) eg(x).pan_curvecc.add( CC(y, 0.0f, check(key, 0, 30000, ToInt(value))) ); + else if (strcmp(s, "_eq1freq") == 0) eg(x).eq1freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq2freq") == 0) eg(x).eq2freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq3freq") == 0) eg(x).eq3freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq1bw") == 0) eg(x).eq1bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq2bw") == 0) eg(x).eq2bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq3bw") == 0) eg(x).eq3bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq1gain") == 0) eg(x).eq1gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (strcmp(s, "_eq2gain") == 0) eg(x).eq2gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (strcmp(s, "_eq3gain") == 0) eg(x).eq3gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (sscanf(s, "_eq1freq_oncc%d", &y)) eg(x).eq1freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2freq_oncc%d", &y)) eg(x).eq2freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3freq_oncc%d", &y)) eg(x).eq3freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1bw_oncc%d", &y)) eg(x).eq1bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2bw_oncc%d", &y)) eg(x).eq2bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3bw_oncc%d", &y)) eg(x).eq3bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1gain_oncc%d", &y)) eg(x).eq1gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2gain_oncc%d", &y)) eg(x).eq2gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3gain_oncc%d", &y)) eg(x).eq3gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else std::cerr << "The opcode '" << key << "' is unsupported by libsfz!" << std::endl; + } + + // v1 envelope generators + else if ("ampeg_delay" == key) pCurDef->ampeg_delay = ToFloat(value); + else if ("ampeg_start" == key) pCurDef->ampeg_start = ToFloat(value); + else if ("ampeg_attack" == key) pCurDef->ampeg_attack = ToFloat(value); + else if ("ampeg_hold" == key) pCurDef->ampeg_hold = ToFloat(value); + else if ("ampeg_decay" == key) pCurDef->ampeg_decay = ToFloat(value); + else if ("ampeg_sustain" == key) pCurDef->ampeg_sustain = ToFloat(value); + else if ("ampeg_release" == key) pCurDef->ampeg_release = ToFloat(value); + else if ("ampeg_vel2delay" == key) pCurDef->ampeg_vel2delay = ToFloat(value); + else if ("ampeg_vel2attack" == key) pCurDef->ampeg_vel2attack = ToFloat(value); + else if ("ampeg_vel2hold" == key) pCurDef->ampeg_vel2hold = ToFloat(value); + else if ("ampeg_vel2decay" == key) pCurDef->ampeg_vel2decay = ToFloat(value); + else if ("ampeg_vel2sustain" == key) pCurDef->ampeg_vel2sustain = ToFloat(value); + else if ("ampeg_vel2release" == key) pCurDef->ampeg_vel2release = ToFloat(value); + else if ("fileg_delay" == key) pCurDef->fileg_delay = ToFloat(value); + else if ("fileg_start" == key) pCurDef->fileg_start = ToFloat(value); + else if ("fileg_attack" == key) pCurDef->fileg_attack = ToFloat(value); + else if ("fileg_hold" == key) pCurDef->fileg_hold = ToFloat(value); + else if ("fileg_decay" == key) pCurDef->fileg_decay = ToFloat(value); + else if ("fileg_sustain" == key) pCurDef->fileg_sustain = ToFloat(value); + else if ("fileg_release" == key) pCurDef->fileg_release = ToFloat(value); + else if ("fileg_depth" == key) pCurDef->fileg_depth = check(key, -12000, 12000, ToInt(value)); + else if ("fileg_vel2delay" == key) pCurDef->fileg_vel2delay = check(key, -100.0f, 100.0f, ToFloat(value)); + else if ("fileg_vel2attack" == key) pCurDef->fileg_vel2attack = ToFloat(value); + else if ("fileg_vel2hold" == key) pCurDef->fileg_vel2hold = ToFloat(value); + else if ("fileg_vel2decay" == key) pCurDef->fileg_vel2decay = ToFloat(value); + else if ("fileg_vel2sustain" == key) pCurDef->fileg_vel2sustain = ToFloat(value); + else if ("fileg_vel2release" == key) pCurDef->fileg_vel2release = ToFloat(value); + else if ("pitcheg_delay" == key) pCurDef->pitcheg_delay = ToFloat(value); + else if ("pitcheg_start" == key) pCurDef->pitcheg_start = ToFloat(value); + else if ("pitcheg_attack" == key) pCurDef->pitcheg_attack = ToFloat(value); + else if ("pitcheg_hold" == key) pCurDef->pitcheg_hold = ToFloat(value); + else if ("pitcheg_decay" == key) pCurDef->pitcheg_decay = ToFloat(value); + else if ("pitcheg_sustain" == key) pCurDef->pitcheg_sustain = ToFloat(value); + else if ("pitcheg_release" == key) pCurDef->pitcheg_release = ToFloat(value); + else if ("pitcheg_depth" == key) pCurDef->pitcheg_depth = check(key, -12000, 12000, ToInt(value)); + else if ("pitcheg_vel2delay" == key) pCurDef->pitcheg_vel2delay = check(key, -100.0f, 100.0f, ToFloat(value)); + else if ("pitcheg_vel2attack" == key) pCurDef->pitcheg_vel2attack = ToFloat(value); + else if ("pitcheg_vel2hold" == key) pCurDef->pitcheg_vel2hold = ToFloat(value); + else if ("pitcheg_vel2decay" == key) pCurDef->pitcheg_vel2decay = ToFloat(value); + else if ("pitcheg_vel2sustain" == key) pCurDef->pitcheg_vel2sustain = ToFloat(value); + else if ("pitcheg_vel2release" == key) pCurDef->pitcheg_vel2release = ToFloat(value); + + + // v1 LFO + else if ("amplfo_delay" == key) pCurDef->amplfo_delay = ToFloat(value); + else if ("amplfo_fade" == key) pCurDef->amplfo_fade = ToFloat(value); + else if ("amplfo_freq" == key) pCurDef->amplfo_freq = ToFloat(value); + else if ("amplfo_freqchanaft" == key) pCurDef->amplfo_freqcc.add( CC(128, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("amplfo_depth" == key) pCurDef->amplfo_depth = ToFloat(value); + else if ("amplfo_depthchanaft" == key) pCurDef->amplfo_depthcc.add( CC(128, check(key, -10.0f, 10.0f, ToFloat(value))) ); + else if ("fillfo_delay" == key) pCurDef->fillfo_delay = ToFloat(value); + else if ("fillfo_fade" == key) pCurDef->fillfo_fade = ToFloat(value); + else if ("fillfo_freq" == key) pCurDef->fillfo_freq = ToFloat(value); + else if ("fillfo_freqchanaft" == key) pCurDef->fillfo_freqcc.add( CC(128, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("fillfo_depth" == key) pCurDef->fillfo_depth = ToFloat(value); + else if ("fillfo_depthchanaft" == key) pCurDef->fillfo_depthcc.add( CC(128, check(key, -1200, 1200, ToInt(value))) ); + else if ("pitchlfo_delay" == key) pCurDef->pitchlfo_delay = ToFloat(value); + else if ("pitchlfo_fade" == key) pCurDef->pitchlfo_fade = ToFloat(value); + else if ("pitchlfo_freq" == key) pCurDef->pitchlfo_freq = ToFloat(value); + else if ("pitchlfo_freqchanaft" == key) pCurDef->pitchlfo_freqcc.add( CC(128, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("pitchlfo_depth" == key) pCurDef->pitchlfo_depth = ToInt(value); + else if ("pitchlfo_depthchanaft" == key) pCurDef->pitchlfo_depthcc.add( CC(128, check(key, -1200, 1200, ToInt(value))) ); + + + // v2 LFO + else if (sscanf(key.c_str(), "lfo%d%n", &x, &y)) { + const char* s = key.c_str() + y; + if (strcmp(s, "_freq") == 0) lfo(x).freq = check(key, 0.0f, 20.0f, ToFloat(value)); + else if (sscanf(s, "_freq_oncc%d", &y)) lfo(x).freq_oncc.add( CC(y, check(key, 0.0f, 20.0f, ToFloat(value))) ); + else if (sscanf(s, "_freq_smoothcc%d", &y)) lfo(x).freq_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_freq_stepcc%d", &y)) lfo(x).freq_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 20.0f, ToFloat(value))) ); + else if (strcmp(s, "_wave") == 0) lfo(x).wave = ToInt(value); + else if (strcmp(s, "_delay") == 0) lfo(x).delay = check(key, 0.0f, 100.0f, ToFloat(value)); + else if (sscanf(s, "_delay_oncc%d", &y)) lfo(x).delay_oncc.add( CC(y, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if (strcmp(s, "_fade") == 0) lfo(x).fade = check(key, 0.0f, 100.0f, ToFloat(value)); + else if (sscanf(s, "_fade_oncc%d", &y)) lfo(x).fade_oncc.add( CC(y, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if (strcmp(s, "_phase") == 0) lfo(x).phase = check(key, 0.0f, 360.0f, ToFloat(value)); + else if (sscanf(s, "_phase_oncc%d", &y)) lfo(x).phase_oncc.add( CC(y, check(key, 0.0f, 360.0f, ToFloat(value))) ); + else if (strcmp(s, "_volume") == 0) lfo(x).volume = check(key, -144.0f, 6.0f, ToFloat(value)); + else if (sscanf(s, "_volume_oncc%d", &y)) lfo(x).volume_oncc.add( CC(y, check(key, -144.0f, 6.0f, ToFloat(value))) ); + else if (sscanf(s, "_volume_smoothcc%d", &y)) lfo(x).volume_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_volume_stepcc%d", &y)) lfo(x).volume_stepcc.add( CC(y, 0, -1, 0, check(key, -20.0f, 20.0f, ToFloat(value))) ); + else if (strcmp(s, "_pitch") == 0) lfo(x).pitch = check(key, -9600, 9600, ToInt(value)); + else if (sscanf(s, "_pitch_oncc%d", &y)) lfo(x).pitch_oncc.add( CC(y, check(key, -9600, 9600, ToInt(value))) ); + else if (sscanf(s, "_pitch_smoothcc%d", &y)) lfo(x).pitch_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_pitch_stepcc%d", &y)) lfo(x).pitch_stepcc.add( CC(y, 0, -1, 0, check(key, -9600, 9600, ToInt(value))) ); + else if (strcmp(s, "_cutoff") == 0) lfo(x).cutoff = check(key, -9600, 9600, ToInt(value)); + else if (sscanf(s, "_cutoff_oncc%d", &y)) lfo(x).cutoff_oncc.add( CC(y, check(key, -9600, 9600, ToInt(value))) ); + else if (sscanf(s, "_cutoff_smoothcc%d", &y)) lfo(x).cutoff_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_cutoff_stepcc%d", &y)) lfo(x).cutoff_stepcc.add( CC(y, 0, -1, 0, check(key, -9600, 9600, ToInt(value))) ); + else if (strcmp(s, "_resonance") == 0) lfo(x).resonance = check(key, 0.0f, 40.0f, ToFloat(value)); + else if (sscanf(s, "_resonance_oncc%d", &y)) lfo(x).resonance_oncc.add( CC(y, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if (sscanf(s, "_resonance_smoothcc%d", &y)) lfo(x).resonance_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_resonance_stepcc%d", &y)) lfo(x).resonance_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if (strcmp(s, "_pan") == 0) lfo(x).pan = check(key, -100.0f, 100.0f, ToFloat(value)); + else if (sscanf(s, "_pan_oncc%d", &y)) lfo(x).pan_oncc.add( CC(y, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if (sscanf(s, "_pan_smoothcc%d", &y)) lfo(x).pan_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_pan_stepcc%d", &y)) lfo(x).pan_stepcc.add( CC(y, 0, -1, 0, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if (strcmp(s, "_eq1freq") == 0) lfo(x).eq1freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq2freq") == 0) lfo(x).eq2freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq3freq") == 0) lfo(x).eq3freq = check(key, 0.0f, 30000.0f, ToFloat(value)); + else if (strcmp(s, "_eq1bw") == 0) lfo(x).eq1bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq2bw") == 0) lfo(x).eq2bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq3bw") == 0) lfo(x).eq3bw = check(key, 0.001f, 4.0f, ToFloat(value)); + else if (strcmp(s, "_eq1gain") == 0) lfo(x).eq1gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (strcmp(s, "_eq2gain") == 0) lfo(x).eq2gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (strcmp(s, "_eq3gain") == 0) lfo(x).eq3gain = check(key, -96.0f, 24.0f, ToFloat(value)); + else if (sscanf(s, "_eq1freq_oncc%d", &y)) lfo(x).eq1freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1freq_smoothcc%d", &y)) lfo(x).eq1freq_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq1freq_stepcc%d", &y)) lfo(x).eq1freq_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2freq_oncc%d", &y)) lfo(x).eq2freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2freq_smoothcc%d", &y)) lfo(x).eq2freq_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq2freq_stepcc%d", &y)) lfo(x).eq2freq_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3freq_oncc%d", &y)) lfo(x).eq3freq_oncc.add( CC(y, check(key, 0.0f, 30000.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3freq_smoothcc%d", &y)) lfo(x).eq3freq_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq3freq_stepcc%d", &y)) lfo(x).eq3freq_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1bw_oncc%d", &y)) lfo(x).eq1bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1bw_smoothcc%d", &y)) lfo(x).eq1bw_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq1bw_stepcc%d", &y)) lfo(x).eq1bw_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2bw_oncc%d", &y)) lfo(x).eq2bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2bw_smoothcc%d", &y)) lfo(x).eq2bw_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq2bw_stepcc%d", &y)) lfo(x).eq2bw_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3bw_oncc%d", &y)) lfo(x).eq3bw_oncc.add( CC(y, check(key, 0.001f, 4.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3bw_smoothcc%d", &y)) lfo(x).eq3bw_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq3bw_stepcc%d", &y)) lfo(x).eq3bw_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1gain_oncc%d", &y)) lfo(x).eq1gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq1gain_smoothcc%d", &y)) lfo(x).eq1gain_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq1gain_stepcc%d", &y)) lfo(x).eq1gain_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2gain_oncc%d", &y)) lfo(x).eq2gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq2gain_smoothcc%d", &y)) lfo(x).eq2gain_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq2gain_stepcc%d", &y)) lfo(x).eq2gain_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3gain_oncc%d", &y)) lfo(x).eq3gain_oncc.add( CC(y, check(key, -96.0f, 24.0f, ToFloat(value))) ); + else if (sscanf(s, "_eq3gain_smoothcc%d", &y)) lfo(x).eq3gain_smoothcc.add( CC(y, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if (sscanf(s, "_eq3gain_stepcc%d", &y)) lfo(x).eq3gain_stepcc.add( CC(y, 0, -1, 0, check(key, 0.0f, 4294967296.0f, ToFloat(value))) ); + else std::cerr << "The opcode '" << key << "' is unsupported by libsfz!" << std::endl; + } + + // CCs + else if (key.find("cc") != std::string::npos) + { + std::string::size_type delimiter_index = key.find("cc"); + std::string key_cc = key.substr(0, delimiter_index); + if (key_cc.size() > 3 && !strcmp(key_cc.c_str() + (key_cc.size() - 3), "_on")) { + key_cc = key_cc.substr(0, key_cc.size() - 3); + } + int num_cc = ToInt(key.substr(delimiter_index + 2)); + + // input controls + if ("lo" == key_cc) pCurDef->locc.set(num_cc, ToInt(value)); + else if ("hi" == key_cc) pCurDef->hicc.set(num_cc, ToInt(value)); + else if ("start_lo" == key_cc) pCurDef->start_locc.set(num_cc, ToInt(value)); + else if ("start_hi" == key_cc) pCurDef->start_hicc.set(num_cc, ToInt(value)); + else if ("stop_lo" == key_cc) pCurDef->stop_locc.set(num_cc, ToInt(value)); + else if ("stop_hi" == key_cc) pCurDef->stop_hicc.set(num_cc, ToInt(value)); + else if ("on_lo" == key_cc) pCurDef->on_locc.set(num_cc, ToInt(value)); + else if ("on_hi" == key_cc) pCurDef->on_hicc.set(num_cc, ToInt(value)); + + // sample player + else if ("delay" == key_cc) pCurDef->delay_oncc.set(num_cc, ToFloat(value)); + else if ("delay_samples" == key_cc) pCurDef->delay_samples_oncc.set(num_cc, ToInt(value)); + else if ("offset" == key_cc) pCurDef->offset_oncc.set(num_cc, ToInt(value)); + + // amplifier + else if ("gain" == key_cc || "gain_" == key_cc) pCurDef->gain_oncc.set(num_cc, ToFloat(value)); + else if ("xfin_lo" == key_cc) pCurDef->xfin_locc.set(num_cc, ToInt(value)); + else if ("xfin_hi" == key_cc) pCurDef->xfin_hicc.set(num_cc, ToInt(value)); + else if ("xfout_lo" == key_cc) pCurDef->xfout_locc.set(num_cc, ToInt(value)); + else if ("xfout_hi" == key_cc) pCurDef->xfout_hicc.set(num_cc, ToInt(value)); + + // pitch + else if ("pitch" == key_cc) pCurDef->pitch_oncc.add( CC(num_cc, check(key, -9600, 9600, ToInt(value))) ); + else if ("pitch_smooth" == key_cc) pCurDef->pitch_smoothcc.add( CC(num_cc, 0, -1, check(key, 0.0f, 100000.0f /* max? */, ToFloat(value))) ); + else if ("pitch_curve" == key_cc) pCurDef->pitch_curvecc.add( CC(num_cc, 0, check(key, 0, 30000, ToInt(value))) ); + else if ("pitch_step" == key_cc) pCurDef->pitch_stepcc.add( CC(num_cc, 0, -1, 0, check(key, 0, 1200, ToInt(value))) ); + + // filter + else if ("cutoff" == key_cc || "cutoff_" == key_cc) { + pCurDef->cutoff_oncc.add( CC(num_cc, check(key, -9600, 9600, ToInt(value))) ); + } else if ("cutoff2" == key_cc) pCurDef->cutoff2_oncc.add( CC(num_cc, check(key, -9600, 9600, ToInt(value))) ); + else if ("cutoff_smooth" == key_cc) pCurDef->cutoff_smoothcc.add( CC(num_cc, 0, -1, check(key, 0.0f, 100000.0f /* max? */, ToFloat(value))) ); + else if ("cutoff2_smooth" == key_cc) pCurDef->cutoff2_smoothcc.add( CC(num_cc, 0, -1, check(key, 0.0f, 100000.0f /* max? */, ToFloat(value))) ); + else if ("cutoff_step" == key_cc) pCurDef->cutoff_stepcc.add( CC(num_cc, 0, -1, 0, check(key, -1200, 1200, ToInt(value))) ); + else if ("cutoff2_step" == key_cc) pCurDef->cutoff2_stepcc.add( CC(num_cc, 0, -1, 0, check(key, -1200, 1200, ToInt(value))) ); + else if ("cutoff_curve" == key_cc) pCurDef->cutoff_curvecc.add( CC(num_cc, 0, check(key, 0, 30000, ToInt(value))) ); + else if ("cutoff2_curve" == key_cc) pCurDef->cutoff2_curvecc.add( CC(num_cc, 0, check(key, 0, 30000, ToInt(value))) ); + else if ("resonance" == key_cc) pCurDef->resonance_oncc.add( CC(num_cc, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if ("resonance2" == key_cc) pCurDef->resonance2_oncc.add( CC(num_cc, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if ("resonance_smooth" == key_cc) pCurDef->resonance_smoothcc.add( CC(num_cc, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if ("resonance2_smooth" == key_cc) pCurDef->resonance2_smoothcc.add( CC(num_cc, 0, -1, check(key, 0, 100000 /* max? */, ToInt(value))) ); + else if ("resonance_step" == key_cc) pCurDef->resonance_stepcc.add( CC(num_cc, 0, -1, 0, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if ("resonance2_step" == key_cc) pCurDef->resonance2_stepcc.add( CC(num_cc, 0, -1, 0, check(key, 0.0f, 40.0f, ToFloat(value))) ); + else if ("resonance_curve" == key_cc) pCurDef->resonance_curvecc.add( CC(num_cc, 0.0f, check(key, 0, 30000, ToInt(value))) ); + else if ("resonance2_curve" == key_cc) pCurDef->resonance2_curvecc.add( CC(num_cc, 0.0f, check(key, 0, 30000, ToInt(value))) ); + + // per voice equalizer + else if ("eq1_freq" == key_cc) pCurDef->eq1_freq_oncc.set(num_cc, ToInt(value)); + else if ("eq2_freq" == key_cc) pCurDef->eq2_freq_oncc.set(num_cc, ToInt(value)); + else if ("eq3_freq" == key_cc) pCurDef->eq3_freq_oncc.set(num_cc, ToInt(value)); + else if ("eq1_bw" == key_cc) pCurDef->eq1_bw_oncc.set(num_cc, ToInt(value)); + else if ("eq2_bw" == key_cc) pCurDef->eq2_bw_oncc.set(num_cc, ToInt(value)); + else if ("eq3_bw" == key_cc) pCurDef->eq3_bw_oncc.set(num_cc, ToInt(value)); + else if ("eq1_gain" == key_cc) pCurDef->eq1_gain_oncc.set(num_cc, ToInt(value)); + else if ("eq2_gain" == key_cc) pCurDef->eq2_gain_oncc.set(num_cc, ToInt(value)); + else if ("eq3_gain" == key_cc) pCurDef->eq3_gain_oncc.set(num_cc, ToInt(value)); + + else if ("ampeg_delay" == key_cc) pCurDef->ampeg_delaycc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_start" == key_cc) pCurDef->ampeg_startcc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_attack" == key_cc) pCurDef->ampeg_attackcc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_hold" == key_cc) pCurDef->ampeg_holdcc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_decay" == key_cc) pCurDef->ampeg_decaycc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_sustain" == key_cc) pCurDef->ampeg_sustaincc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("ampeg_release" == key_cc) pCurDef->ampeg_releasecc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + + else if ("fileg_delay" == key_cc) pCurDef->fileg_delay_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_start" == key_cc) pCurDef->fileg_start_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_attack" == key_cc) pCurDef->fileg_attack_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_hold" == key_cc) pCurDef->fileg_hold_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_decay" == key_cc) pCurDef->fileg_decay_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_sustain" == key_cc) pCurDef->fileg_sustain_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_release" == key_cc) pCurDef->fileg_release_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("fileg_depth" == key_cc) pCurDef->fileg_depth_oncc.add( CC(num_cc, check(key, -12000, 12000, ToInt(value))) ); + + else if ("pitcheg_delay" == key_cc) pCurDef->pitcheg_delay_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_start" == key_cc) pCurDef->pitcheg_start_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_attack" == key_cc) pCurDef->pitcheg_attack_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_hold" == key_cc) pCurDef->pitcheg_hold_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_decay" == key_cc) pCurDef->pitcheg_decay_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_sustain" == key_cc) pCurDef->pitcheg_sustain_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_release" == key_cc) pCurDef->pitcheg_release_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pitcheg_depth" == key_cc) pCurDef->pitcheg_depth_oncc.add( CC(num_cc, check(key, -12000, 12000, ToInt(value))) ); + + else if ("pitchlfo_delay" == key_cc) pCurDef->pitchlfo_delay_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("pitchlfo_fade" == key_cc) pCurDef->pitchlfo_fade_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("pitchlfo_depth" == key_cc) pCurDef->pitchlfo_depthcc.add( CC(num_cc, check(key, -1200, 1200, ToInt(value))) ); + else if ("pitchlfo_freq" == key_cc) pCurDef->pitchlfo_freqcc.add( CC(num_cc, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("fillfo_delay" == key_cc) pCurDef->fillfo_delay_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("fillfo_fade" == key_cc) pCurDef->fillfo_fade_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("fillfo_depth" == key_cc) pCurDef->fillfo_depthcc.add( CC(num_cc, check(key, -1200, 1200, ToInt(value))) ); + else if ("fillfo_freq" == key_cc) pCurDef->fillfo_freqcc.add( CC(num_cc, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("amplfo_delay" == key_cc) pCurDef->amplfo_delay_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("amplfo_fade" == key_cc) pCurDef->amplfo_fade_oncc.add( CC(num_cc, check(key, 0.0f, 100.0f, ToFloat(value))) ); + else if ("amplfo_depth" == key_cc) pCurDef->amplfo_depthcc.add( CC(num_cc, check(key, -10.0f, 10.0f, ToFloat(value))) ); + else if ("amplfo_freq" == key_cc) pCurDef->amplfo_freqcc.add( CC(num_cc, check(key, -200.0f, 200.0f, ToFloat(value))) ); + else if ("volume" == key_cc) pCurDef->volume_oncc.add( CC(num_cc, check(key, -144.0f, 100.0f, ToFloat(value))) ); + else if ("volume_curve" == key_cc) pCurDef->volume_curvecc.add( CC(num_cc, 0, check(key, 0, 30000, ToInt(value))) ); + else if ("volume_smooth" == key_cc) pCurDef->volume_smoothcc.add( CC(num_cc, 0, -1, check(key, 0.0f, 100000.0f /* max? */, ToFloat(value))) ); + else if ("volume_step" == key_cc) pCurDef->volume_stepcc.add( CC(num_cc, 0, -1, 0, check(key, -20.0f, 20.0f, ToFloat(value))) ); + else if ("pan" == key_cc) pCurDef->pan_oncc.add( CC(num_cc, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else if ("pan_curve" == key_cc) pCurDef->pan_curvecc.add( CC(num_cc, 0, check(key, 0, 30000, ToInt(value))) ); + else if ("pan_smooth" == key_cc) pCurDef->pan_smoothcc.add( CC(num_cc, 0, -1, check(key, 0.0f, 100000.0f /* max? */, ToFloat(value))) ); + else if ("pan_step" == key_cc) pCurDef->pan_stepcc.add( CC(num_cc, 0, -1, 0, check(key, -100.0f, 100.0f, ToFloat(value))) ); + else std::cerr << "The opcode '" << key << "' is unsupported by libsfz!" << std::endl; + } + + else { + std::cerr << "The opcode '" << key << "' is unsupported by libsfz!" << std::endl; + } + } + + int File::parseKey(const std::string& s) { + int i; + std::istringstream iss(s); + if (isdigit(iss.peek())) { + iss >> i; + } else { + switch (tolower(iss.get())) { + case 'c': i = 0; break; + case 'd': i = 2; break; + case 'e': i = 4; break; + case 'f': i = 5; break; + case 'g': i = 7; break; + case 'a': i = 9; break; + case 'b': i = 11; break; + case '-': if (s == "-1") return -1; + default: + std::cerr << "Not a note: " << s << std::endl; + return 0; + } + if (iss.peek() == '#') { + i++; + iss.get(); + } else if (tolower(iss.peek()) == 'b') { + i--; + iss.get(); + } + int octave; + if (!(iss >> octave)) { + std::cerr << "Not a note: " << s << std::endl; + return 0; + } + i += (octave + 1) * 12; + } + return i + note_offset + 12 * octave_offset; + } + + EGNode::EGNode() : time(0), level(0), shape(0), curve(0) { + } + + void EGNode::Copy(const EGNode& egNode) { + time = egNode.time; + level = egNode.level; + shape = egNode.shape; + curve = egNode.curve; + + time_oncc = egNode.time_oncc; + level_oncc = egNode.level_oncc; + } + + EG::EG() : + sustain(0), loop(0), loop_count(0), amplitude(0), pan(0), pan_curve(-1), + cutoff(0), pitch(0), resonance(0), volume(-200) /* less than -144 dB is considered unset */ + { } + + void EG::Copy(const EG& eg) { + EqImpl::Copy(static_cast<const EqImpl>(eg)); + + sustain = eg.sustain; + loop = eg.loop; + loop_count = eg.loop_count; + amplitude = eg.amplitude; + volume = eg.volume; + cutoff = eg.cutoff; + pitch = eg.pitch; + resonance = eg.resonance; + pan = eg.pan; + pan_curve = eg.pan_curve; + node = eg.node; + + amplitude_oncc = eg.amplitude_oncc; + volume_oncc = eg.volume_oncc; + cutoff_oncc = eg.cutoff_oncc; + pitch_oncc = eg.pitch_oncc; + resonance_oncc = eg.resonance_oncc; + pan_oncc = eg.pan_oncc; + pan_curvecc = eg.pan_curvecc; + } + + LFO::LFO(): freq (-1),/* -1 is used to determine whether the LFO was initialized */ + fade(0), phase(0), wave(0), delay(0), pitch(0), cutoff(0), resonance(0), pan(0), volume(0) { + + } + + void LFO::Copy(const LFO& lfo) { + EqSmoothStepImpl::Copy(static_cast<const EqSmoothStepImpl>(lfo)); + + delay = lfo.delay; + freq = lfo.freq; + fade = lfo.fade; + phase = lfo.phase; + wave = lfo.wave; + volume = lfo.volume; + pitch = lfo.pitch; + cutoff = lfo.cutoff; + resonance = lfo.resonance; + pan = lfo.pan; + + delay_oncc = lfo.delay_oncc; + freq_oncc = lfo.freq_oncc; + freq_smoothcc = lfo.freq_smoothcc; + freq_stepcc = lfo.freq_stepcc; + fade_oncc = lfo.fade_oncc; + phase_oncc = lfo.phase_oncc; + pitch_oncc = lfo.pitch_oncc; + pitch_smoothcc = lfo.pitch_smoothcc; + pitch_stepcc = lfo.pitch_stepcc; + volume_oncc = lfo.volume_oncc; + volume_smoothcc = lfo.volume_smoothcc; + volume_stepcc = lfo.volume_stepcc; + pan_oncc = lfo.pan_oncc; + pan_smoothcc = lfo.pan_smoothcc; + pan_stepcc = lfo.pan_stepcc; + cutoff_oncc = lfo.cutoff_oncc; + cutoff_smoothcc = lfo.cutoff_smoothcc; + cutoff_stepcc = lfo.cutoff_stepcc; + resonance_oncc = lfo.resonance_oncc; + resonance_smoothcc = lfo.resonance_smoothcc; + resonance_stepcc = lfo.resonance_stepcc; + } + + EqImpl::EqImpl() { + eq1freq = eq2freq = eq3freq = 0; + eq1bw = eq2bw = eq3bw = 0; + eq1gain = eq2gain = eq3gain = 0; + } + + void EqImpl::Copy(const EqImpl& eq) { + eq1freq = eq.eq1freq; + eq2freq = eq.eq2freq; + eq3freq = eq.eq3freq; + eq1bw = eq.eq1bw; + eq2bw = eq.eq2bw; + eq3bw = eq.eq3bw; + eq1gain = eq.eq1gain; + eq2gain = eq.eq2gain; + eq3gain = eq.eq3gain; + + eq1freq_oncc = eq.eq1freq_oncc; + eq2freq_oncc = eq.eq2freq_oncc; + eq3freq_oncc = eq.eq3freq_oncc; + eq1bw_oncc = eq.eq1bw_oncc; + eq2bw_oncc = eq.eq2bw_oncc; + eq3bw_oncc = eq.eq3bw_oncc; + eq1gain_oncc = eq.eq1gain_oncc; + eq2gain_oncc = eq.eq2gain_oncc; + eq3gain_oncc = eq.eq3gain_oncc; + } + + bool EqImpl::HasEq() { + return eq1freq || eq2freq || eq3freq || eq1bw || eq2bw || eq3bw || + eq1gain || eq2gain || eq3gain || !eq1gain_oncc.empty() || + !eq2gain_oncc.empty() || !eq3gain_oncc.empty() || + !eq1freq_oncc.empty() || !eq2freq_oncc.empty() || !eq3freq_oncc.empty() || + !eq1bw_oncc.empty() || !eq2bw_oncc.empty() || !eq3bw_oncc.empty(); + } + + void EqSmoothStepImpl::Copy(const EqSmoothStepImpl& eq) { + EqImpl::Copy(eq); + + eq1freq_smoothcc = eq.eq1freq_smoothcc; + eq2freq_smoothcc = eq.eq2freq_smoothcc; + eq3freq_smoothcc = eq.eq3freq_smoothcc; + eq1bw_smoothcc = eq.eq1bw_smoothcc; + eq2bw_smoothcc = eq.eq2bw_smoothcc; + eq3bw_smoothcc = eq.eq3bw_smoothcc; + eq1gain_smoothcc = eq.eq1gain_smoothcc; + eq2gain_smoothcc = eq.eq2gain_smoothcc; + eq3gain_smoothcc = eq.eq3gain_smoothcc; + + eq1freq_stepcc = eq.eq1freq_stepcc; + eq2freq_stepcc = eq.eq2freq_stepcc; + eq3freq_stepcc = eq.eq3freq_stepcc; + eq1bw_stepcc = eq.eq1bw_stepcc; + eq2bw_stepcc = eq.eq2bw_stepcc; + eq3bw_stepcc = eq.eq3bw_stepcc; + eq1gain_stepcc = eq.eq1gain_stepcc; + eq2gain_stepcc = eq.eq2gain_stepcc; + eq3gain_stepcc = eq.eq3gain_stepcc; + } + + void EqSmoothStepImpl::copySmoothValues() { + File::copySmoothValues(eq1freq_smoothcc, eq1freq_oncc); + eq1freq_smoothcc.clear(); + + File::copySmoothValues(eq2freq_smoothcc, eq2freq_oncc); + eq2freq_smoothcc.clear(); + + File::copySmoothValues(eq3freq_smoothcc, eq3freq_oncc); + eq3freq_smoothcc.clear(); + + File::copySmoothValues(eq1bw_smoothcc, eq1bw_oncc); + eq1bw_smoothcc.clear(); + + File::copySmoothValues(eq2bw_smoothcc, eq2bw_oncc); + eq2bw_smoothcc.clear(); + + File::copySmoothValues(eq3bw_smoothcc, eq3bw_oncc); + eq3bw_smoothcc.clear(); + + File::copySmoothValues(eq1gain_smoothcc, eq1gain_oncc); + eq1gain_smoothcc.clear(); + + File::copySmoothValues(eq2gain_smoothcc, eq2gain_oncc); + eq2gain_smoothcc.clear(); + + File::copySmoothValues(eq3gain_smoothcc, eq3gain_oncc); + eq3gain_smoothcc.clear(); + } + + void EqSmoothStepImpl::copyStepValues() { + File::copyStepValues(eq1freq_stepcc, eq1freq_oncc); + eq1freq_stepcc.clear(); + + File::copyStepValues(eq2freq_stepcc, eq2freq_oncc); + eq2freq_stepcc.clear(); + + File::copyStepValues(eq3freq_stepcc, eq3freq_oncc); + eq3freq_stepcc.clear(); + + File::copyStepValues(eq1bw_stepcc, eq1bw_oncc); + eq1bw_stepcc.clear(); + + File::copyStepValues(eq2bw_stepcc, eq2bw_oncc); + eq2bw_stepcc.clear(); + + File::copyStepValues(eq3bw_stepcc, eq3bw_oncc); + eq3bw_stepcc.clear(); + + File::copyStepValues(eq1gain_stepcc, eq1gain_oncc); + eq1gain_stepcc.clear(); + + File::copyStepValues(eq2gain_stepcc, eq2gain_oncc); + eq2gain_stepcc.clear(); + + File::copyStepValues(eq3gain_stepcc, eq3gain_oncc); + eq3gain_stepcc.clear(); + } + + EG& File::eg(int x) { + while (pCurDef->eg.size() <= x) { + pCurDef->eg.add(EG()); + } + return pCurDef->egx; + } + + EGNode& File::egnode(int x, int y) { + EG& e = eg(x); + while (e.node.size() <= y) { + e.node.add(EGNode()); + } + return e.nodey; + } + + LFO& File::lfo(int x) { + while (pCurDef->lfos.size() <= x) { + pCurDef->lfos.add(LFO()); + } + return pCurDef->lfosx; + } + +} // !namespace sfz
View file
linuxsampler-2342.tar.bz2/src/engines/sfz/sfz.h
Added
@@ -0,0 +1,800 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2008 Anders Dahnielson <anders@dahnielson.com> * + * Copyright (C) 2009 - 2012 Anders Dahnielson and Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef LIBSFZ_SFZ_H +#define LIBSFZ_SFZ_H + +#include <fstream> +#include <iostream> +#include <vector> +#include <string> +#include <stdexcept> + +#include "../common/SampleFile.h" +#include "../common/SampleManager.h" +#include "../../common/ArrayList.h" + +#define TRIGGER_ATTACK ((unsigned char) (1 << 0)) // 0x01 +#define TRIGGER_RELEASE ((unsigned char) (1 << 1)) // 0x02 +#define TRIGGER_FIRST ((unsigned char) (1 << 2)) // 0x04 +#define TRIGGER_LEGATO ((unsigned char) (1 << 3)) // 0x08 + +namespace sfz +{ + // Forward declarations + class Articulation; + class Region; + class Group; + class Instrument; + class File; + class LookupTable; + class SampleManager; + + class Sample : public LinuxSampler::SampleFileBase<Region> { + private: + int End; + long TotalFrames; + + public: + Sample(String File, bool DontClose = false, uint offset = 0, int end = 0 /* 0 means unspecified */) + : LinuxSampler::SampleFileBase<Region>(File, DontClose) + { + Offset = offset; + End = end; + + long tfc = LinuxSampler::SampleFileBase<Region>::GetTotalFrameCount(); + if (Offset >= tfc) { + std::cerr << "Offset for file '" << this->GetFile() << "' too long (" << Offset << ")" << std::endl; + Offset = 0; + } + + if (End == 0 || End > tfc) TotalFrames = tfc; + else if (End == -1 || End < Offset) TotalFrames = 0; + else TotalFrames = End; + } + virtual ~Sample() { } + + virtual long GetTotalFrameCount() { return TotalFrames; } + + friend class SampleManager; + }; + + // Enumerations + enum sw_vel_t { VEL_CURRENT, VEL_PREVIOUS }; + enum off_mode_t { OFF_FAST, OFF_NORMAL }; + enum loop_mode_t { NO_LOOP, ONE_SHOT, LOOP_CONTINUOUS, LOOP_SUSTAIN, LOOP_UNSET }; + enum curve_t { GAIN, POWER }; + enum filter_t { LPF_1P, HPF_1P, BPF_1P, BRF_1P, APF_1P, + LPF_2P, HPF_2P, BPF_2P, BRF_2P, PKF_2P, + LPF_4P, HPF_4P, + LPF_6P, HPF_6P }; + + typedef unsigned char trigger_t; + typedef unsigned char uint8_t; + + class SampleManager : public LinuxSampler::SampleManager<Sample, Region> { + public: + Sample* FindSample(std::string samplePath, uint offset, int end); + + protected: + virtual void OnSampleInUse(Sample* pSample) { + pSample->Open(); + } + + virtual void OnSampleInNotUse(Sample* pSample) { + pSample->Close(); + } + }; + + class CC { + public: + uint8_t Controller; ///< MIDI controller number. + short int Curve; + float Influence; ///< Controller Value. + float Smooth; ///< The speed of parameter change in milliseconds + float Step; + + CC ( + uint8_t Controller = 0, + float Influence = 0, + short int Curve = -1, + float Smooth = 0, + float Step = 0 + ) { + this->Controller = Controller; + this->Influence = Influence; + this->Curve = Curve; + this->Smooth = Smooth; + this->Step = Step; + } + + CC(const CC& cc) { Copy(cc); } + void operator=(const CC& cc) { Copy(cc); } + + void Copy(const CC& cc) { + Controller = cc.Controller; + Influence = cc.Influence; + Curve = cc.Curve; + Smooth = cc.Smooth; + Step = cc.Step; + } + }; + + ///////////////////////////////////////////////////////////// + // class Exception + + class Exception : + public std::runtime_error + { + public: + Exception(const std::string& msg) : + runtime_error(msg) + { + } + + std::string Message() + { + return what(); + } + + void PrintMessage() + { + std::cerr << what() << std::endl << std::flush; + } + }; + + ///////////////////////////////////////////////////////////// + // class optional + + // Handy class nicked from LinuxSampler... + // Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck + // Copyright (C) 2005, 2006 Christian Schoenebeck + + class optional_base + { + public: + class nothing_t { public: nothing_t() {} }; + static const nothing_t nothing; + }; + + template<class T> + class optional : + public optional_base + { + public: + optional() + { + initialized = false; + } + + optional(T data) + { + this->data = data; + initialized = true; + } + + optional(nothing_t) + { + initialized = false; + } + + template <class T_inner> + optional(T_inner data) + { + this->data = T(data); + initialized = true; + } + + const T& get() const throw (Exception) + { + if (!initialized) throw Exception("optional variable not initialized"); + return data; + } + + T& get() throw (Exception) + { + if (!initialized) throw Exception("optional variable not initialized"); + return data; + } + + void unset() + { + initialized = false; + } + + optional& operator =(const optional& arg) throw (Exception) + { + if (!arg.initialized) { + initialized = false; + } else { + this->data = arg.data; + initialized = true; + } + return *this; + } + + optional& operator =(const T& arg) + { + this->data = arg; + initialized = true; + return *this; + } + + const T& operator *() const throw (Exception) { return get(); } + T& operator *() throw (Exception) { return get(); } + + const T* operator ->() const throw (Exception) + { + if (!initialized) throw Exception("optional variable not initialized"); + return &data; + } + + T* operator ->() throw (Exception) + { + if (!initialized) throw Exception("optional variable not initialized"); + return &data; + } + + operator bool() const { return initialized; } + bool operator !() const { return !initialized; } + + protected: + T data; + bool initialized; + }; + + ///////////////////////////////////////////////////////////// + // class Articulation + + // Articulation containing all performance parameters for synthesis + class Articulation + { + public: + Articulation(); + virtual ~Articulation(); + }; + + class EGNode + { + public: + float time; + float level; + float shape; + float curve; + LinuxSampler::ArrayList<CC> time_oncc; + LinuxSampler::ArrayList<CC> level_oncc; + + EGNode(); + EGNode(const EGNode& egNode) { Copy(egNode); } + void operator=(const EGNode& egNode) { Copy(egNode); } + void Copy(const EGNode& egNode); + }; + + class EqImpl { + public: + float eq1freq, eq2freq, eq3freq; + float eq1bw, eq2bw, eq3bw; + float eq1gain, eq2gain, eq3gain; + LinuxSampler::ArrayList<CC> eq1freq_oncc; + LinuxSampler::ArrayList<CC> eq2freq_oncc; + LinuxSampler::ArrayList<CC> eq3freq_oncc; + LinuxSampler::ArrayList<CC> eq1bw_oncc; + LinuxSampler::ArrayList<CC> eq2bw_oncc; + LinuxSampler::ArrayList<CC> eq3bw_oncc; + LinuxSampler::ArrayList<CC> eq1gain_oncc; + LinuxSampler::ArrayList<CC> eq2gain_oncc; + LinuxSampler::ArrayList<CC> eq3gain_oncc; + + EqImpl(); + + EqImpl(const EqImpl& eq) { Copy(eq); } + void Copy(const EqImpl& eq); + bool HasEq(); + }; + + class EqSmoothStepImpl: public EqImpl { + public: + LinuxSampler::ArrayList<CC> eq1freq_smoothcc; + LinuxSampler::ArrayList<CC> eq2freq_smoothcc; + LinuxSampler::ArrayList<CC> eq3freq_smoothcc; + LinuxSampler::ArrayList<CC> eq1bw_smoothcc; + LinuxSampler::ArrayList<CC> eq2bw_smoothcc; + LinuxSampler::ArrayList<CC> eq3bw_smoothcc; + LinuxSampler::ArrayList<CC> eq1gain_smoothcc; + LinuxSampler::ArrayList<CC> eq2gain_smoothcc; + LinuxSampler::ArrayList<CC> eq3gain_smoothcc; + + LinuxSampler::ArrayList<CC> eq1freq_stepcc; + LinuxSampler::ArrayList<CC> eq2freq_stepcc; + LinuxSampler::ArrayList<CC> eq3freq_stepcc; + LinuxSampler::ArrayList<CC> eq1bw_stepcc; + LinuxSampler::ArrayList<CC> eq2bw_stepcc; + LinuxSampler::ArrayList<CC> eq3bw_stepcc; + LinuxSampler::ArrayList<CC> eq1gain_stepcc; + LinuxSampler::ArrayList<CC> eq2gain_stepcc; + LinuxSampler::ArrayList<CC> eq3gain_stepcc; + + EqSmoothStepImpl() { } + EqSmoothStepImpl(const EqSmoothStepImpl& eq) { Copy(eq); } + + void Copy(const EqSmoothStepImpl& eq); + void copySmoothValues(); + void copyStepValues(); + }; + + class EG: public EqImpl + { + public: + LinuxSampler::ArrayList<EGNode> node; + int sustain; + int loop; + int loop_count; + float amplitude; + float volume; + float cutoff; + int pitch; // -9600 to 9600 cents + float resonance; // 0 to 40 dB + float pan; // -100 to 100 % + int pan_curve; + + LinuxSampler::ArrayList<CC> amplitude_oncc; + LinuxSampler::ArrayList<CC> volume_oncc; + LinuxSampler::ArrayList<CC> cutoff_oncc; // -9600 to 9600 cents + LinuxSampler::ArrayList<CC> pitch_oncc; + LinuxSampler::ArrayList<CC> resonance_oncc; // 0 to 40 dB + LinuxSampler::ArrayList<CC> pan_oncc; // -100 to 100 % + LinuxSampler::ArrayList<CC> pan_curvecc; // used only as temporary buffer during the parsing - values are then moved to pan_oncc + + EG(); + EG(const EG& eg) { Copy(eg); } + void operator=(const EG& eg) { Copy(eg); } + void Copy(const EG& eg); + }; + + class LFO: public EqSmoothStepImpl + { + public: + float delay; // 0 to 100 seconds + float freq; // 0 to 20 Hz + float fade; // 0 to 100 seconds + float phase; // 0 to 360 degrees + uint wave; // 0 to 4294967296 + float volume; // -144 to 6 dB + int pitch; // -9600 to 9600 cents + int cutoff; // -9600 to 9600 cents + float resonance; // 0 to 40 dB + float pan; // -100 to 100 % + + LinuxSampler::ArrayList<CC> delay_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> freq_oncc; // 0 to 20 Hz + LinuxSampler::ArrayList<CC> freq_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> freq_stepcc; + LinuxSampler::ArrayList<CC> fade_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> phase_oncc; // 0 to 360 degrees + LinuxSampler::ArrayList<CC> volume_oncc; // -144 to 6 dB + LinuxSampler::ArrayList<CC> volume_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> volume_stepcc; + LinuxSampler::ArrayList<CC> pitch_oncc; + LinuxSampler::ArrayList<CC> pitch_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> pitch_stepcc; + LinuxSampler::ArrayList<CC> pan_oncc; // -100 to 100 % + LinuxSampler::ArrayList<CC> pan_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> pan_stepcc; + LinuxSampler::ArrayList<CC> cutoff_oncc; // -9600 to 9600 cents + LinuxSampler::ArrayList<CC> cutoff_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> cutoff_stepcc; + LinuxSampler::ArrayList<CC> resonance_oncc; // 0 to 40 dB + LinuxSampler::ArrayList<CC> resonance_smoothcc; // 0 to ? milliseconds + LinuxSampler::ArrayList<CC> resonance_stepcc; // 0 to 40 dB + + LFO(); + LFO(const LFO& lfo) { Copy(lfo); } + void operator=(const LFO& lfo) { Copy(lfo); } + void Copy(const LFO& lfo); + }; + + // Fixed size array with copy-on-write semantics + template<class T> + class Array + { + private: + struct Rep { + int refcount; + T a128; + + Rep() : refcount(1) { } + static void release(Rep* rep) { + if (!--rep->refcount) delete rep; + } + } *ptr; + public: + Array() : ptr(0) { } + ~Array() { Rep::release(ptr); } + + Array& operator=(const Array& array) { + if (this != &array) { + ptr = array.ptr; + if (ptr) ptr->refcount++; + } + return *this; + } + + const T& operator(int i) const { return ptr->ai; } + + void set(int i, const T& v) { + if (!ptr) { + ptr = new Rep; + } else if (ptr->refcount > 1 && ptr->ai != v) { + Rep* newptr = new Rep(*ptr); + newptr->refcount = 1; + Rep::release(ptr); + ptr = newptr; + } + ptr->ai = v; + } + }; + + ///////////////////////////////////////////////////////////// + // class Definition + + // Base definition used by groups and regions + class Definition + { + public: + Definition(); + virtual ~Definition(); + + // sample definition + std::string sample; + + // input controls + int lochan; int hichan; + int lokey; int hikey; + int lovel; int hivel; + Array<int> locc; Array<int> hicc; + int lobend; int hibend; + float lobpm; float hibpm; + int lochanaft; int hichanaft; + int lopolyaft; int hipolyaft; + int loprog; int hiprog; + float lorand; float hirand; + float lotimer; float hitimer; + + int seq_length; + int seq_position; + + Array<int> start_locc; Array<int> start_hicc; + Array<int> stop_locc; Array<int> stop_hicc; + + int sw_lokey; int sw_hikey; + int sw_last; + int sw_down; + int sw_up; + int sw_previous; + sw_vel_t sw_vel; + + trigger_t trigger; + + uint group; + uint off_by; + off_mode_t off_mode; + + Array<int> on_locc; Array<int> on_hicc; + + // sample player + optional<int> count; + optional<float> delay; optional<float> delay_random; Array<optional<float> > delay_oncc; + optional<int> delay_beats; optional<int> stop_beats; + optional<int> delay_samples; Array<optional<int> > delay_samples_oncc; + int end; + optional<float> loop_crossfade; + optional<uint> offset; optional<int> offset_random; Array<optional<int> > offset_oncc; + loop_mode_t loop_mode; + optional<int> loop_start; optional<int> loop_end; + optional<int> sync_beats; + optional<int> sync_offset; + + // amplifier + float volume; + float pan; + float width; + float position; + float amp_keytrack; int amp_keycenter; float amp_veltrack; Array<float> amp_velcurve; float amp_random; + float rt_decay; + Array<float> gain_oncc; + int xfin_lokey; int xfin_hikey; + int xfout_lokey; int xfout_hikey; + curve_t xf_keycurve; + int xfin_lovel; int xfin_hivel; + int xfout_lovel; int xfout_hivel; + curve_t xf_velcurve; + Array<int> xfin_locc; Array<int> xfin_hicc; + Array<int> xfout_locc; Array<int> xfout_hicc; + curve_t xf_cccurve; + + // pitch + int transpose; + int tune; + int pitch_keycenter; int pitch_keytrack; int pitch_veltrack; int pitch_random; + int bend_up; int bend_down; int bend_step; + + // filter + filter_t fil_type; filter_t fil2_type; + optional<float> cutoff; optional<float> cutoff2; + LinuxSampler::ArrayList<CC> cutoff_oncc, cutoff2_oncc; + LinuxSampler::ArrayList<CC> cutoff_smoothcc, cutoff2_smoothcc; + LinuxSampler::ArrayList<CC> cutoff_stepcc, cutoff2_stepcc; + LinuxSampler::ArrayList<CC> cutoff_curvecc, cutoff2_curvecc; + int cutoff_chanaft; int cutoff2_chanaft; + int cutoff_polyaft; int cutoff2_polyaft; + float resonance; float resonance2; + LinuxSampler::ArrayList<CC> resonance_oncc, resonance2_oncc; + LinuxSampler::ArrayList<CC> resonance_smoothcc, resonance2_smoothcc; + LinuxSampler::ArrayList<CC> resonance_stepcc, resonance2_stepcc; + LinuxSampler::ArrayList<CC> resonance_curvecc, resonance2_curvecc; + LinuxSampler::ArrayList<CC> pitch_oncc, pitch_stepcc; + LinuxSampler::ArrayList<CC> pitch_smoothcc, pitch_curvecc; + int fil_keytrack; int fil2_keytrack; + int fil_keycenter; int fil2_keycenter; + int fil_veltrack; int fil2_veltrack; + int fil_random; int fil2_random; + + // per voice equalizer + float eq1_freq; float eq2_freq; float eq3_freq; + Array<float> eq1_freq_oncc; Array<float> eq2_freq_oncc; Array<float> eq3_freq_oncc; + float eq1_vel2freq; float eq2_vel2freq; float eq3_vel2freq; + float eq1_bw; float eq2_bw; float eq3_bw; + Array<float> eq1_bw_oncc; Array<float> eq2_bw_oncc; Array<float> eq3_bw_oncc; + float eq1_gain; float eq2_gain; float eq3_gain; + Array<float> eq1_gain_oncc; Array<float> eq2_gain_oncc; Array<float> eq3_gain_oncc; + float eq1_vel2gain; float eq2_vel2gain; float eq3_vel2gain; + + //Deprecated (from version 1) + float ampeg_delay, ampeg_start, ampeg_attack, ampeg_hold, ampeg_decay, ampeg_sustain, ampeg_release; + float ampeg_vel2delay, ampeg_vel2attack, ampeg_vel2hold, ampeg_vel2decay, ampeg_vel2sustain, ampeg_vel2release; + LinuxSampler::ArrayList<CC> ampeg_delaycc, ampeg_startcc, ampeg_attackcc, ampeg_holdcc; + LinuxSampler::ArrayList<CC> ampeg_decaycc, ampeg_sustaincc, ampeg_releasecc; + float fileg_delay, fileg_start, fileg_attack, fileg_hold, fileg_decay, fileg_sustain, fileg_release; + float fileg_vel2delay, fileg_vel2attack, fileg_vel2hold, fileg_vel2decay, fileg_vel2sustain, fileg_vel2release; + LinuxSampler::ArrayList<CC> fileg_delay_oncc, fileg_start_oncc, fileg_attack_oncc, fileg_hold_oncc; + LinuxSampler::ArrayList<CC> fileg_decay_oncc, fileg_sustain_oncc, fileg_release_oncc, fileg_depth_oncc; + float pitcheg_delay, pitcheg_start, pitcheg_attack, pitcheg_hold, pitcheg_decay, pitcheg_sustain, pitcheg_release; + float pitcheg_vel2delay, pitcheg_vel2attack, pitcheg_vel2hold, pitcheg_vel2decay, pitcheg_vel2sustain, pitcheg_vel2release; + int fileg_depth, pitcheg_depth; + LinuxSampler::ArrayList<CC> pitcheg_delay_oncc, pitcheg_start_oncc, pitcheg_attack_oncc, pitcheg_hold_oncc; + LinuxSampler::ArrayList<CC> pitcheg_decay_oncc, pitcheg_sustain_oncc, pitcheg_release_oncc, pitcheg_depth_oncc; + float amplfo_delay, amplfo_fade, amplfo_freq, amplfo_depth; + float fillfo_delay, fillfo_fade, fillfo_freq, fillfo_depth; + float pitchlfo_delay, pitchlfo_fade, pitchlfo_freq; + int pitchlfo_depth; + + LinuxSampler::ArrayList<CC> pitchlfo_delay_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> pitchlfo_fade_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> pitchlfo_depthcc; // -1200 to 1200 cents + LinuxSampler::ArrayList<CC> pitchlfo_freqcc; // 0 to 20 Hz + LinuxSampler::ArrayList<CC> fillfo_delay_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> fillfo_fade_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> fillfo_depthcc; // -1200 to 1200 cents + LinuxSampler::ArrayList<CC> fillfo_freqcc; // 0 to 20 Hz + LinuxSampler::ArrayList<CC> amplfo_delay_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> amplfo_fade_oncc; // 0 to 100 seconds + LinuxSampler::ArrayList<CC> amplfo_depthcc; // -10 to 10 dB + LinuxSampler::ArrayList<CC> amplfo_freqcc; // 0 to 20 Hz + + // envelope generators + LinuxSampler::ArrayList<EG> eg; + + // low frequency oscillators + LinuxSampler::ArrayList<LFO> lfos; + + LinuxSampler::ArrayList<CC> volume_oncc; + LinuxSampler::ArrayList<CC> volume_curvecc; // used only as temporary buffer during the parsing - values are then moved to volume_oncc + LinuxSampler::ArrayList<CC> volume_smoothcc; // used only as temporary buffer during the parsing - values are then moved to volume_oncc + LinuxSampler::ArrayList<CC> volume_stepcc; // used only as temporary buffer during the parsing - values are then moved to volume_oncc + + LinuxSampler::ArrayList<CC> pan_oncc; // -100 to 100 % + LinuxSampler::ArrayList<CC> pan_curvecc; // used only as temporary buffer during the parsing - values are then moved to pan_oncc + LinuxSampler::ArrayList<CC> pan_smoothcc; // used only as temporary buffer during the parsing - values are then moved to pan_oncc + LinuxSampler::ArrayList<CC> pan_stepcc; // used only as temporary buffer during the parsing - values are then moved to pan_oncc + }; + + class Query { + public: + uint8_t chan; // MIDI channel + uint8_t key; // MIDI note + uint8_t vel; // MIDI velocity + int bend; // MIDI pitch bend + uint8_t bpm; // host BPM + uint8_t chanaft; // MIDI channel pressure + uint8_t polyaft; // MIDI polyphonic aftertouch + uint8_t prog; // MIDI program change + float rand; // generated random number + trigger_t trig; // how it was triggered + uint8_t* cc; // all 128 CC values + float timer; // time since previous region in the group was triggered + bool* sw; // state of region key switches, 128 possible values + uint8_t last_sw_key; // last key pressed in the key switch range + uint8_t prev_sw_key; // previous note value + + void search(const Instrument* pInstrument); + void search(const Instrument* pInstrument, int triggercc); + Region* next(); + private: + LinuxSampler::ArrayList<Region*>* pRegionList; + int regionIndex; + }; + + ///////////////////////////////////////////////////////////// + // class Region + + /// Defines Region information of an Instrument + class Region : + public Definition + { + public: + Region(); + virtual ~Region(); + + Sample* pSample; + Sample* GetSample(bool create = true); + void DestroySampleIfNotUsed(); + + Region* GetParent() { return this; }; // needed by EngineBase + Instrument* GetInstrument() { return pInstrument; } + void SetInstrument(Instrument* pInstrument) { this->pInstrument = pInstrument; } + + bool HasLoop(); + uint GetLoopStart(); + uint GetLoopEnd(); + uint GetLoopCount(); + + /// Return true if region is triggered by key. Region is + /// assumed to come from a search in the lookup table. + bool OnKey(const Query& q); + + /// Return an articulation for the current state + Articulation* GetArticulation(int bend, uint8_t bpm, uint8_t chanaft, uint8_t polyaft, uint8_t* cc); + + // unique region id + int id; + + private: + Instrument* pInstrument; + int seq_counter; + }; + + class Curve { + public: + float v128; + Curve() { for (int i = 0; i < 128; i++) vi = 0; } + Curve(const Curve& curve) { Copy(curve); } + void operator=(const Curve& curve) { Copy(curve); } + void Copy(const Curve& curve) { for (int i = 0; i < 128; i++) vi = curve.vi; } + }; + + ///////////////////////////////////////////////////////////// + // class Instrument + + /// Provides all necessary information for the synthesis of an Instrument + class Instrument : public SampleManager + { + public: + Instrument(std::string name = "Unknown", SampleManager* pSampleManager = NULL); + virtual ~Instrument(); + + std::string GetName() { return name; } + SampleManager* GetSampleManager() { return pSampleManager; } + + bool DestroyRegion(Region* pRegion); + bool HasKeyBinding(uint8_t key); + bool HasKeySwitchBinding(uint8_t key); + + /// List of Regions belonging to this Instrument + std::vector<Region*> regions; + ::LinuxSampler::ArrayList<Curve> curves; + + friend class File; + friend class Query; + + private: + std::string name; + std::vector<bool> KeyBindings; + std::vector<bool> KeySwitchBindings; + SampleManager* pSampleManager; + LookupTable* pLookupTable; + LookupTable* pLookupTableCC128; + }; + + ///////////////////////////////////////////////////////////// + // class Group + + /// A Group act just as a template containing Region default values + class Group : + public Definition + { + public: + Group(); + virtual ~Group(); + + /// Reset Group to default values + void Reset(); + + /// Create a new Region + Region* RegionFactory(); + + // id counter + int id; + + }; + + ///////////////////////////////////////////////////////////// + // class File + + /// Parses SFZ files and provides abstract access to the data + class File + { + public: + static void copyCurves(LinuxSampler::ArrayList<CC>& curves, LinuxSampler::ArrayList<CC>& dest); + static void copySmoothValues(LinuxSampler::ArrayList<CC>& smooths, LinuxSampler::ArrayList<CC>& dest); + static void copyStepValues(LinuxSampler::ArrayList<CC>& steps, LinuxSampler::ArrayList<CC>& dest); + + /// Load an existing SFZ file + File(std::string file, SampleManager* pSampleManager = NULL); + virtual ~File(); + + /// Returns a pointer to the instrument object + Instrument* GetInstrument(); + + private: + void push_header(std::string token); + void push_opcode(std::string token); + int parseKey(const std::string& value); + EG& eg(int x); + EGNode& egnode(int x, int y); + LFO& lfo(int x); + + int ToInt(const std::string& s) throw(LinuxSampler::Exception); + float ToFloat(const std::string& s) throw(LinuxSampler::Exception); + + int currentLine; + std::string currentDir; + /// Pointer to the Instrument belonging to this file + Instrument* _instrument; + + // state variables + enum section_t { UNKNOWN, GROUP, REGION, CONTROL, CURVE }; + section_t _current_section; + Region* _current_region; + Group* _current_group; + Curve* _current_curve; + Definition* pCurDef; + + // control header directives + std::string default_path; + int octave_offset; + int note_offset; + }; + +} // !namespace sfz + +#endif // !LIBSFZ_SFZ_H
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/Info.plist
Added
@@ -0,0 +1,26 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> +<plist version="1.0"> +<dict> + <key>CFBundleDevelopmentRegion</key> + <string>English</string> + <key>CFBundleExecutable</key> + <string>LinuxSamplerAU</string> + <key>CFBundleIdentifier</key> + <string>org.linuxsampler.LinuxSamplerAU</string> + <key>CFBundleInfoDictionaryVersion</key> + <string>6.0</string> + <key>CFBundleName</key> + <string>LinuxSamplerAU</string> + <key>CFBundlePackageType</key> + <string>BNDL</string> + <key>CFBundleShortVersionString</key> + <string>1.0</string> + <key>CFBundleSignature</key> + <string>LSam</string> + <key>CFBundleVersion</key> + <string>1.0</string> + <key>CSResourcesFileMapped</key> + <true/> +</dict> +</plist>
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/au/Makefile.am -> linuxsampler-2342.tar.bz2/src/hostplugins/au/Makefile.am
Changed
@@ -1,20 +1,18 @@ if HAVE_AU plugindir = $(libdir)/au -examples_dir = /Developer/Examples +examples_dir = $(DEVELOPER_EXTRAS_DIR) au_public_dir = $(examples_dir)/CoreAudio/AudioUnits/AUPublic ca_public_dir = $(examples_dir)/CoreAudio/PublicUtility INCLUDES = -I$(au_public_dir)/AUBase -I$(au_public_dir)/OtherBases \ - -I$(au_public_dir)/Utility -I$(ca_public_dir) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) + -I$(au_public_dir)/Utility -I$(ca_public_dir) $(GIG_CFLAGS) $(SQLITE3_CFLAGS) $(SNDFILE_CFLAGS) -noinst_LIBRARIES = libpluginau.a +noinst_PROGRAMS = LinuxSamplerAU # Uncomment for debug messages. #debug_messages = -DAU_DEBUG_DISPATCHER=1 -libpluginau_a_CXXFLAGS = $(debug_messages) - -nodist_libpluginau_a_SOURCES = $(ca_public_dir)/CAHostTimeBase.cpp \ +nodist_LinuxSamplerAU_SOURCES = $(ca_public_dir)/CAHostTimeBase.cpp \ $(ca_public_dir)/CAHostTimeBase.h \ $(ca_public_dir)/CAAUMIDIMap.cpp \ $(ca_public_dir)/CAAUMIDIMap.h \ @@ -55,37 +53,40 @@ $(au_public_dir)/OtherBases/MusicDeviceBase.cpp \ $(au_public_dir)/OtherBases/MusicDeviceBase.h -bin_PROGRAMS = LinuxSamplerAU -LinuxSamplerAU_SOURCES = PluginAU.cpp +LinuxSamplerAU_SOURCES = PluginAU.cpp PluginAU.h PluginAUVersion.h -LinuxSamplerAU_LDADD = $(top_builddir)/src/.libs/liblinuxsampler.a libpluginau.a +LinuxSamplerAU_LDADD = $(top_builddir)/src/liblinuxsampler.la if HAVE_AUFLAGS else -AUFLAGS = $(GIG_LIBS) $(JACK_LIBS) $(SQLITE3_LIBS) +AUFLAGS = $(GIG_LIBS) $(JACK_LIBS) $(SQLITE3_LIBS) $(SNDFILE_LIBS) endif -LinuxSamplerAU_CXXFLAGS = -bundle $(debug_messages) -LinuxSamplerAU_LDFLAGS = -static $(AUFLAGS) \ - -exported_symbols_list PluginAU.exp \ +LinuxSamplerAU_CPPFLAGS = $(debug_messages) +LinuxSamplerAU_LDFLAGS = -bundle $(AUFLAGS) \ + -exported_symbols_list $(srcdir)/PluginAU.exp \ -framework CoreServices -framework CoreMIDI -framework CoreAudio \ -framework CoreFoundation -framework AudioToolbox -framework AudioUnit COMPONENT_DIR = LinuxSamplerAU.component -all-local: - Rez PluginAU.r -d SystemSevenOrLater=1 -useDF -script Roman -d ppc_YES -d i386_YES -d x86_64_YES \ +all-local: $(COMPONENT_DIR) + +LinuxSamplerAU.rsrc: $(srcdir)/PluginAU.r $(srcdir)/PluginAUVersion.h + Rez $(srcdir)/PluginAU.r -d SystemSevenOrLater=1 -useDF -script Roman -d ppc_YES -d i386_YES -d x86_64_YES \ -I /System/Library/Frameworks/CoreServices.framework/Frameworks/CarbonCore.framework/Versions/Current/Headers \ -I $(au_public_dir)/AUBase/ -arch i386 -arch x86_64 -arch ppc -o LinuxSamplerAU.rsrc - if test ! -d "$(COMPONENT_DIR)/Contents/Frameworks"; then mkdir -p "$(COMPONENT_DIR)/Contents/Frameworks"; fi - if test ! -d "$(COMPONENT_DIR)/Contents/MacOS"; then mkdir -p "$(COMPONENT_DIR)/Contents/MacOS"; fi - if test ! -d "$(COMPONENT_DIR)/Contents/Resources"; then mkdir -p "$(COMPONENT_DIR)/Contents/Resources"; fi +$(COMPONENT_DIR): $(srcdir)/PkgInfo $(srcdir)/Info.plist LinuxSamplerAU LinuxSamplerAU.rsrc + mkdir -p "$(COMPONENT_DIR)/Contents/Frameworks" + mkdir -p "$(COMPONENT_DIR)/Contents/MacOS" + mkdir -p "$(COMPONENT_DIR)/Contents/Resources" - cp PkgInfo "$(COMPONENT_DIR)/Contents" - cp Info.plist "$(COMPONENT_DIR)/Contents" - cp LinuxSamplerAU "$(COMPONENT_DIR)/Contents/MacOS" + cp $(srcdir)/PkgInfo "$(COMPONENT_DIR)/Contents" + cp $(srcdir)/Info.plist "$(COMPONENT_DIR)/Contents" + $(LIBTOOL) --mode=install cp LinuxSamplerAU "$(PWD)/$(COMPONENT_DIR)/Contents/MacOS" cp LinuxSamplerAU.rsrc "$(COMPONENT_DIR)/Contents/Resources" + @touch $@ # cp "`pkg-config --variable=libdir gig`/libgig.6.dylib" "$(COMPONENT_DIR)/Contents/Frameworks/"; \ # install_name_tool -id @executable_path/../Frameworks/libgig.6.dylib \ @@ -117,7 +118,13 @@ rm -rf $(COMPONENT_DIR) install-exec-hook: - cp -r $(COMPONENT_DIR) /Library/Audio/Plug-Ins/Components/ + if mkdir -p $(MAC_PLUGIN_INSTALL_DIR)/Components && \ + test -w $(MAC_PLUGIN_INSTALL_DIR)/Components ; then \ + cp -r $(COMPONENT_DIR) $(MAC_PLUGIN_INSTALL_DIR)/Components/ ; \ + if test -n "$(INSTALL_STRIP_FLAG)" ; then $(STRIP) -x $(MAC_PLUGIN_INSTALL_DIR)/Components/$(COMPONENT_DIR)/Contents/MacOS/LinuxSamplerAU ; fi ; fi + uninstall-hook: - rm -rf /Library/Audio/Plug-Ins/Components/$(COMPONENT_DIR) + rm -rf $(MAC_PLUGIN_INSTALL_DIR)/Components/$(COMPONENT_DIR) endif + +EXTRA_DIST = PluginAU.exp PluginAU.r PkgInfo Info.plist
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/PkgInfo
Added
@@ -0,0 +1,1 @@ +BNDLLSam \ No newline at end of file
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/au/PluginAU.cpp -> linuxsampler-2342.tar.bz2/src/hostplugins/au/PluginAU.cpp
Changed
@@ -2,7 +2,7 @@ * * * LinuxSampler - modular, streaming capable sampler * * * - * Copyright (C) 2009 Grigor Iliev * + * Copyright (C) 2009 - 2011 Grigor Iliev * * * * 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 * @@ -45,8 +45,7 @@ }; PluginAU::PluginAU(ComponentInstance inComponentInstance) - : MusicDeviceBase(inComponentInstance, 0, 1), Plugin(false) { - + : MusicDeviceBase(inComponentInstance, 0, 16), Plugin(false) { #if AU_DEBUG_DISPATCHER mDebugDispatcher = new AUDebugDispatcher(this); #endif @@ -170,30 +169,42 @@ } UInt32 PluginAU::SupportedNumChannels(const AUChannelInfo** outInfo) { - static AUChannelInfo plugChannelInfo = { 0, -1 }; + static AUChannelInfo plugChannelInfo = { 0, 2 }; if (outInfo != NULL) *outInfo = &plugChannelInfo; return 1; } ComponentResult PluginAU::Initialize() { + // format validation: current LS engines only support stereo + // buses + int busCount = Outputs().GetNumberOfElements(); + for (int i = 0 ; i < busCount ; i++) { + if (GetOutput(i)->GetStreamFormat().mChannelsPerFrame != 2) { + return kAudioUnitErr_FormatNotSupported; + } + } + MusicDeviceBase::Initialize(); - // The timeconsuming tasks delayed until the pluging is to be used + // The timeconsuming tasks delayed until the plugin is to be used PreInit(); if(pAudioDevice) { RemoveChannels(); - global->pSampler->DestroyAudioOutputDevice(pAudioDevice); + DestroyDevice(pAudioDevice); pAudioDevice = NULL; } if(pMidiDevice) { - global->pSampler->DestroyMidiInputDevice(pMidiDevice); + DestroyDevice(pMidiDevice); pMidiDevice = NULL; } int srate = (int)GetStreamFormat(kAudioUnitScope_Output, 0).mSampleRate; - int chnNum = GetStreamFormat(kAudioUnitScope_Output, 0).NumberChannels(); + int chnNum = 0; + for (int i = 0 ; i < busCount ; i++) { + chnNum += GetOutput(i)->GetStreamFormat().mChannelsPerFrame; + } Init(srate, GetMaxFramesPerSlice(), chnNum); @@ -294,11 +305,16 @@ const AudioTimeStamp& inTimeStamp, UInt32 inNumberFrames ) { - float* buf; - int chnCount = GetOutput(0)->GetBufferList().mNumberBuffers; - for(int i = 0; i < chnCount; i++) { - buf = (float*)GetOutput(0)->GetBufferList().mBuffersi.mData; - pAudioDevice->Channel(i)->SetBuffer(buf); + int i = 0; + int busCount = Outputs().GetNumberOfElements(); + for (int bus = 0 ; bus < busCount ; bus++) { + AudioBufferList& list = GetOutput(bus)->PrepareBuffer(inNumberFrames); + int chnCount = list.mNumberBuffers; + for (int chn = 0; chn < chnCount; chn++) { + float* buf = static_cast<float*>(list.mBufferschn.mData); + pAudioDevice->Channel(i)->SetBuffer(buf); + i++; + } } pAudioDevice->Render(inNumberFrames);
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/PluginAU.exp
Added
@@ -0,0 +1,1 @@ +_PluginAUEntry
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/PluginAU.h
Added
@@ -0,0 +1,143 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __PLUGIN_AU_H__ +#define __PLUGIN_AU_H__ + +#include "PluginAUVersion.h" + +#include <AudioUnit/AudioUnit.h> +#include <CoreAudio/CoreAudio.h> +#include <MusicDeviceBase.h> + +#include "../../drivers/Plugin.h" + +using namespace LinuxSampler; + +//namespace LinuxSampler { + + class PluginAU : public MusicDeviceBase, public LinuxSampler::Plugin { + public: + PluginAU(ComponentInstance inComponentInstance); + virtual ~PluginAU(); + virtual OSStatus Version() { return kPluginAUVersion; } + virtual UInt32 SupportedNumChannels(const AUChannelInfo** outInfo); + virtual bool StreamFormatWritable(AudioUnitScope scope, AudioUnitElement element); + virtual ComponentResult Initialize(); + + virtual ComponentResult GetPropertyInfo ( + AudioUnitPropertyID inID, + AudioUnitScope inScope, + AudioUnitElement inElement, + UInt32& outDataSize, + Boolean& outWritable + ); + + virtual ComponentResult GetProperty ( + AudioUnitPropertyID inID, + AudioUnitScope inScope, + AudioUnitElement inElement, + void* outData + ); + + virtual ComponentResult SetProperty ( + AudioUnitPropertyID inID, + AudioUnitScope inScope, + AudioUnitElement inElement, + const void* inData, + UInt32 inDataSize + ); + + virtual ComponentResult Render ( + AudioUnitRenderActionFlags& ioActionFlags, + const AudioTimeStamp& inTimeStamp, + UInt32 inNumberFrames + ); + + virtual ComponentResult StartNote ( + MusicDeviceInstrumentID inInstrument, + MusicDeviceGroupID inGroupID, + NoteInstanceID* outNoteInstanceID, + UInt32 inOffsetSampleFrame, + const MusicDeviceNoteParams &inParams + ) { return noErr; } + + virtual ComponentResult StopNote ( + MusicDeviceGroupID inGroupID, + NoteInstanceID inNoteInstanceID, + UInt32 inOffsetSampleFrame + ) { return noErr; } + + virtual OSStatus HandleMidiEvent ( + UInt8 inStatus, UInt8 inChannel, + UInt8 inData1, UInt8 inData2, + UInt32 inStartFrame + ); + + virtual void PropertyChanged ( + AudioUnitPropertyID inID, + AudioUnitScope inScope, + AudioUnitElement inElement + ); + + virtual OSStatus NewFactoryPresetSet (const AUPreset& inNewFactoryPreset); + virtual OSStatus GetInstrumentCount(UInt32 &outInstCount) const; + virtual ComponentResult GetPresets(CFArrayRef* outData) const; + virtual ComponentResult SaveState(CFPropertyListRef* outData); + virtual ComponentResult RestoreState(CFPropertyListRef inData); + + private: + enum { + kOneSamplerChannel = 0, + k16SamplerChannels = 1 + }; + + static const midi_chan_t midiChns16; + static const UInt32 kDefaultPreset = kOneSamplerChannel; + static const UInt32 kFactoryPresetCount = 2; + static AUPreset factoryPresetskFactoryPresetCount; + + static void PropertyListenerCallback ( + void* inRefCon, + AudioUnit ci, + AudioUnitPropertyID inID, + AudioUnitScope inScope, + AudioUnitElement inElement + ); + + std::string hostName; + char* charBuf; + UInt32 charBufSize; + + std::string GetStr(CFStringRef s); + void InstallListeners(); + void UninstallListeners(); + std::string GetHostNameByID(std::string Identifier); + std::string GetHostBundleID(); + void Set16SamplerChannelsPreset(); + void AddSamplerChannel(const char* engine, midi_chan_t midiChn); + }; + +//} // namespace LinuxSampler + +#endif /* __AU_PLUGIN_H__ */ +
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/PluginAU.r
Added
@@ -0,0 +1,38 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#include <AudioUnit/AudioUnit.r> +#include <PluginAUVersion.h> + +#define kAudioUnitResID_LinuxSamplerUnit 1000 + +#define RES_ID kAudioUnitResID_LinuxSamplerUnit +#define COMP_TYPE LINUXSAMPLER_COMP_TYPE +#define COMP_SUBTYPE LINUXSAMPLER_COMP_SUBTYPE +#define COMP_MANUF LINUXSAMPLER_COMP_MANUF + +#define VERSION kPluginAUVersion +#define NAME "LinuxSampler: LinuxSampler Unit" +#define DESCRIPTION "LinuxSampler AU plugin" +#define ENTRY_POINT "PluginAUEntry" + +#include "AUResources.r"
View file
linuxsampler-2342.tar.bz2/src/hostplugins/au/PluginAUVersion.h
Added
@@ -0,0 +1,33 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2009 Grigor Iliev * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/ + +#ifndef __PLUGINAUVERSION_H__ +#define __PLUGINAUVERSION_H__ + +#define kPluginAUVersion 0x002a + +#define LINUXSAMPLER_COMP_TYPE kAudioUnitType_MusicDevice +#define LINUXSAMPLER_COMP_SUBTYPE 'LSau' +#define LINUXSAMPLER_COMP_MANUF 'LSam' + +#endif /* __AUPLUGINVERSION_H__ */ +
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/dssi/PluginDssi.cpp -> linuxsampler-2342.tar.bz2/src/hostplugins/dssi/PluginDssi.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 - 2009 Andreas Persson * + * Copyright (C) 2008 - 2011 Andreas Persson * * * * 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 * @@ -26,7 +26,7 @@ #include "PluginDssi.h" -#include "../../engines/gig/EngineChannel.h" +#include "../../engines/AbstractEngineChannel.h" namespace { @@ -57,12 +57,11 @@ pChannel = plugin->global->pSampler->AddSamplerChannel(); pChannel->SetEngineType("gig"); pChannel->SetAudioOutputDevice(plugin->pAudioDevice); - LinuxSampler::MidiInputPort* port = plugin->pMidiDevice->CreateMidiPort(); - port->Connect(pChannel->GetEngineChannel(), LinuxSampler::midi_chan_all); + pPort = plugin->pMidiDevice->CreateMidiPort(); + pPort->Connect(pChannel->GetEngineChannel(), LinuxSampler::midi_chan_all); - // TODO: remove dependency on gig engine - LinuxSampler::gig::EngineChannel* engineChannel = - (LinuxSampler::gig::EngineChannel*)pChannel->GetEngineChannel(); + LinuxSampler::AbstractEngineChannel* engineChannel = + static_cast<LinuxSampler::AbstractEngineChannel*>(pChannel->GetEngineChannel()); // TODO: pChannelLeft and pChannelRight are meant to be // protected engineChannel->pChannelLeft = new LinuxSampler::AudioChannel(0, 0, 0); @@ -70,11 +69,10 @@ } PluginInstance::~PluginInstance() { - LinuxSampler::gig::EngineChannel* engineChannel = - (LinuxSampler::gig::EngineChannel*)pChannel->GetEngineChannel(); + LinuxSampler::AbstractEngineChannel* engineChannel = + static_cast<LinuxSampler::AbstractEngineChannel*>(pChannel->GetEngineChannel()); delete engineChannel->pChannelLeft; delete engineChannel->pChannelRight; - LinuxSampler::MidiInputPort* port = engineChannel->pMidiInputPort; if (--plugin->RefCount == 0) { delete plugin; @@ -83,7 +81,7 @@ plugin->global->pSampler->RemoveSamplerChannel(pChannel); } - LinuxSampler::MidiInputDevicePlugin::DeleteMidiPort(port); + LinuxSampler::MidiInputDevicePlugin::DeleteMidiPort(pPort); } void PluginInstance::ConnectPort(unsigned long Port, LADSPA_Data* DataLocation) { @@ -183,13 +181,13 @@ } } - LinuxSampler::gig::EngineChannel* gigEngineChannel = - (LinuxSampler::gig::EngineChannel*)engineChannel; - gigEngineChannel->pChannelLeft->SetBuffer(instance->Out0 + samplePos); - gigEngineChannel->pChannelRight->SetBuffer(instance->Out1 + samplePos); + LinuxSampler::AbstractEngineChannel* abstractEngineChannel = + static_cast<LinuxSampler::AbstractEngineChannel*>(engineChannel); + abstractEngineChannel->pChannelLeft->SetBuffer(instance->Out0 + samplePos); + abstractEngineChannel->pChannelRight->SetBuffer(instance->Out1 + samplePos); if (i) { - gigEngineChannel->pChannelLeft->Clear(samples); - gigEngineChannel->pChannelRight->Clear(samples); + abstractEngineChannel->pChannelLeft->Clear(samples); + abstractEngineChannel->pChannelRight->Clear(samples); } else { // the buffer set in the audio device is cleared // by Render @@ -268,7 +266,7 @@ Ladspa.Name = "LinuxSampler"; Ladspa.Maker = "linuxsampler.org"; Ladspa.Copyright = "(C) 2003,2004 Benno Senoner and Christian Schoenebeck, " - "2005-2009 Christian Schoenebeck"; + "2005-2012 Christian Schoenebeck"; Ladspa.PortCount = 2; Ladspa.ImplementationData = 0; Ladspa.PortDescriptors = PortDescriptors;
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/dssi/PluginDssi.h -> linuxsampler-2342.tar.bz2/src/hostplugins/dssi/PluginDssi.h
Changed
@@ -51,6 +51,7 @@ private: static PluginDssi* plugin; LinuxSampler::SamplerChannel* pChannel; + LinuxSampler::MidiInputPort* pPort; LADSPA_Data* Out2; };
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/Makefile.am -> linuxsampler-2342.tar.bz2/src/hostplugins/lv2/Makefile.am
Changed
@@ -3,10 +3,11 @@ plugindir = $(libdir)/lv2/linuxsampler.lv2 plugin_LTLIBRARIES = linuxsampler.la plugin_DATA = manifest.ttl linuxsampler.ttl -EXTRA_DIST = $(plugin_DATA) linuxsampler_la_SOURCES = PluginLv2.cpp PluginLv2.h \ - lv2_event.h lv2-saverestore.h + lv2_event.h lv2_state.h lv2_uri_map.h lv2_files.h linuxsampler_la_LDFLAGS = -module -avoid-version linuxsampler_la_LIBADD = $(top_builddir)/src/liblinuxsampler.la endif + +EXTRA_DIST = $(plugin_DATA)
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/PluginLv2.cpp -> linuxsampler-2342.tar.bz2/src/hostplugins/lv2/PluginLv2.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 Andreas Persson * + * Copyright (C) 2008 - 2012 Andreas Persson * * * * 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 * @@ -19,6 +19,7 @@ ***************************************************************************/ #include <algorithm> +#include <cassert> #include <cstdio> #include <cstdlib> #include <cstring> @@ -27,6 +28,9 @@ #include "PluginLv2.h" +#define NS_ATOM "http://lv2plug.in/ns/ext/atom#" +#define NS_LS "http://linuxsampler.org/schema#" + namespace { PluginLv2::PluginLv2(const LV2_Descriptor* Descriptor, @@ -34,13 +38,25 @@ const LV2_Feature* const* Features) { Out0 = 0; Out1 = 0; + UriMap = 0; + MapPath = 0; + MakePath = 0; for (int i = 0 ; Featuresi ; i++) { - dmsg(2, ("linuxsampler: host feature: %s\n", Featuresi->URI)); + dmsg(2, ("linuxsampler: init feature: %s\n", Featuresi->URI)); + if (!strcmp(Featuresi->URI, LV2_URI_MAP_URI)) { + UriMap = (LV2_URI_Map_Feature*)Featuresi->data; + } else if (!strcmp(Featuresi->URI, LV2_STATE__mapPath)) { + MapPath = (LV2_State_Map_Path*)Featuresi->data; + } else if (!strcmp(Featuresi->URI, LV2_STATE__makePath)) { + MakePath = (LV2_State_Make_Path*)Featuresi->data; + } } Init(SampleRate, 128); InitState(); + + DefaultState = GetState(); } void PluginLv2::ConnectPort(uint32_t Port, void* DataLocation) { @@ -86,44 +102,128 @@ dmsg(2, ("linuxsampler: Deactivate\n")); } - char* PluginLv2::Save(const char* Directory, LV2SR_File*** Files) { - dmsg(2, ("linuxsampler: Save Directory=%s\n", Directory)); - - String filename(Directory); - filename += "/linuxsampler"; - dmsg(2, ("saving to %s\n", filename.c_str())); - std::ofstream out(filename.c_str()); - out << GetState(); - out.close(); + String PluginLv2::PathToState(const String& path) { + if (MapPath) { + char* cstr = MapPath->abstract_path(MapPath->handle, path.c_str()); + const String abstract_path(cstr); + free(cstr); + return abstract_path; + } + return path; + } - LV2SR_File** filearr = static_cast<LV2SR_File**>(malloc(sizeof(LV2SR_File*) * 2)); + String PluginLv2::PathFromState(const String& path) { + if (MapPath) { + char* cstr = MapPath->absolute_path(MapPath->handle, path.c_str()); + const String abstract_path(cstr); + free(cstr); + return abstract_path; + } + return path; + } - LV2SR_File* file = static_cast<LV2SR_File*>(malloc(sizeof(LV2SR_File))); - file->name = strdup("linuxsampler"); - file->path = strdup(filename.c_str()); - file->must_copy = 0; + void PluginLv2::SetStateFeatures(const LV2_Feature* const* Features) + { + for (int i = 0 ; Featuresi ; i++) { + dmsg(2, ("linuxsampler: state feature: %s\n", Featuresi->URI)); + if (!strcmp(Featuresi->URI, LV2_STATE__mapPath)) { + MapPath = (LV2_State_Map_Path*)Featuresi->data; + } else if (!strcmp(Featuresi->URI, LV2_STATE__makePath)) { + MakePath = (LV2_State_Make_Path*)Featuresi->data; + } + } + } - filearr0 = file; - filearr1 = 0; + LV2_State_Status PluginLv2::Save( + LV2_State_Store_Function store, LV2_State_Handle handle, + uint32_t flags, const LV2_Feature* const* features) + { + LV2_State_Map_Path* OldMapPath = MapPath; + LV2_State_Make_Path* OldMakePath = MakePath; + SetStateFeatures(features); + + if (MakePath && MapPath) { + char* abs_path = MakePath->path(MakePath->handle, "linuxsampler"); + dmsg(2, ("saving to file %s\n", abs_path)); + + std::ofstream out(abs_path); + out << GetState(); + + char* path = MapPath->abstract_path(MapPath->handle, abs_path); + + store(handle, + uri_to_id(NULL, NS_LS "state-file"), + path, + strlen(path) + 1, + uri_to_id(NULL, NS_ATOM "Path"), + LV2_STATE_IS_PORTABLE); + + free(path); + free(abs_path); + } else { + dmsg(2, ("saving to string\n")); + + std::ostringstream out; + out << GetState(); + + store(handle, + uri_to_id(NULL, NS_LS "state-string"), + out.str().c_str(), + out.str().length() + 1, + uri_to_id(NULL, NS_ATOM "String"), + LV2_STATE_IS_POD | LV2_STATE_IS_PORTABLE); + } + dmsg(2, ("saving done\n")); - *Files = filearr; + MapPath = OldMapPath; + MakePath = OldMakePath; - dmsg(2, ("saving done\n")); - return 0; + return LV2_STATE_SUCCESS; } - char* PluginLv2::Restore(const LV2SR_File** Files) { - dmsg(2, ("linuxsampler: restore\n")); - for (int i = 0 ; Filesi ; i++) { - dmsg(2, (" name=%s path=%s\n", Filesi->name, Filesi->path)); - if (strcmp(Filesi->name, "linuxsampler") == 0) { - std::ifstream in(Files0->path); - String state; - std::getline(in, state, '\0'); - SetState(state); - } + LV2_State_Status PluginLv2::Restore( + LV2_State_Retrieve_Function retrieve, LV2_State_Handle handle, + uint32_t rflags, const LV2_Feature* const* features) + { + LV2_State_Map_Path* OldMapPath = MapPath; + LV2_State_Make_Path* OldMakePath = MakePath; + SetStateFeatures(features); + + size_t size; + uint32_t type; + uint32_t flags; + + const void* value = retrieve( + handle, + uri_to_id(NULL, NS_LS "state-file"), + &size, &type, &flags); + if (value) { + // Restore from state-file + assert(type == uri_to_id(NULL, NS_ATOM "Path")); + const String path((const char*)value); + dmsg(2, ("linuxsampler: restoring from file %s\n", path.c_str())); + std::ifstream in(path.c_str()); + String state; + std::getline(in, state, '\0'); + SetState(state); + } else if ((value = retrieve(handle, + uri_to_id(NULL, NS_LS "state-string"), + &size, &type, &flags))) { + // Restore from state-string + dmsg(2, ("linuxsampler: restoring from string\n")); + assert(type == uri_to_id(NULL, NS_ATOM "String")); + String state((const char*)value); + SetState(state); + } else { + // No valid state found, reset to default state + dmsg(2, ("linuxsampler: restoring default state\n")); + SetState(DefaultState); } - return 0; + + MapPath = OldMapPath; + MakePath = OldMakePath; + + return LV2_STATE_SUCCESS; } LV2_Handle instantiate(const LV2_Descriptor* descriptor, @@ -152,12 +252,18 @@ delete static_cast<PluginLv2*>(instance); } - char* save(LV2_Handle handle, const char* directory, LV2SR_File*** files) { - return static_cast<PluginLv2*>(handle)->Save(directory, files); + LV2_State_Status save(LV2_Handle handle, LV2_State_Store_Function store, + LV2_State_Handle state, + uint32_t flags, const LV2_Feature* const* features) { + return static_cast<PluginLv2*>(handle)->Save( + store, state, flags, features); } - char* restore(LV2_Handle handle, const LV2SR_File** files) { - return static_cast<PluginLv2*>(handle)->Restore(files); + LV2_State_Status restore(LV2_Handle handle, LV2_State_Retrieve_Function retrieve, + LV2_State_Handle state, + uint32_t flags, const LV2_Feature* const* features) { + return static_cast<PluginLv2*>(handle)->Restore( + retrieve, state, flags, features); } PluginInfo PluginInfo::Instance; @@ -171,15 +277,15 @@ Lv2.instantiate = instantiate; Lv2.run = run; Lv2.extension_data = extension_data; - Lv2sr.save = save; - Lv2sr.restore = restore; + StateInterface.save = save; + StateInterface.restore = restore; } const void* extension_data(const char* uri) { dmsg(2, ("linuxsampler: extension_data %s\n", uri)); - if (strcmp(uri, LV2_SAVERESTORE_URI) == 0) { - return PluginInfo::Lv2srDescriptor(); + if (strcmp(uri, LV2_STATE__interface) == 0) { + return PluginInfo::Lv2StateInterface(); } return 0; }
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/PluginLv2.h -> linuxsampler-2342.tar.bz2/src/hostplugins/lv2/PluginLv2.h
Changed
@@ -23,7 +23,8 @@ #include <lv2.h> #include "lv2_event.h" -#include "lv2-saverestore.h" +#include "lv2_state.h" +#include "lv2_uri_map.h" #include "../../drivers/Plugin.h" namespace { @@ -37,12 +38,29 @@ void Activate(); void Run(uint32_t SampleCount); void Deactivate(); - char* Save(const char* Directory, LV2SR_File*** Files); - char* Restore(const LV2SR_File** Files); + LV2_State_Status Save(LV2_State_Store_Function store, void* data, + uint32_t flags, const LV2_Feature* const* features); + LV2_State_Status Restore(LV2_State_Retrieve_Function retrieve, void* data, + uint32_t flags, const LV2_Feature* const* features); + + protected: + virtual String PathToState(const String& string); + virtual String PathFromState(const String& string); private: + uint32_t uri_to_id(const char* map, const char* uri) { + return UriMap->uri_to_id(UriMap->callback_data, map, uri); + } + + void SetStateFeatures(const LV2_Feature* const* Features); + float* Out2; LV2_Event_Buffer* MidiBuf; + LV2_URI_Map_Feature* UriMap; + LV2_State_Map_Path* MapPath; + LV2_State_Make_Path* MakePath; + + String DefaultState; }; class PluginInfo { @@ -50,12 +68,12 @@ static const LV2_Descriptor* Lv2Descriptor() { return &Instance.Lv2; } - static const LV2SR_Descriptor* Lv2srDescriptor() { - return &Instance.Lv2sr; + static const LV2_State_Interface* Lv2StateInterface() { + return &Instance.StateInterface; } private: LV2_Descriptor Lv2; - LV2SR_Descriptor Lv2sr; + LV2_State_Interface StateInterface; PluginInfo(); static PluginInfo Instance; @@ -73,9 +91,13 @@ static void cleanup(LV2_Handle instance); static const void* extension_data(const char* uri); - static char* save(LV2_Handle handle, const char* directory, - LV2SR_File*** files); - static char* restore(LV2_Handle handle, const LV2SR_File** files); + static LV2_State_Status save(LV2_Handle handle, + LV2_State_Store_Function store, + void* data); + + static LV2_State_Status restore(LV2_Handle handle, + LV2_State_Retrieve_Function retrieve, + void* data); } }
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/lv2/linuxsampler.ttl -> linuxsampler-2342.tar.bz2/src/hostplugins/lv2/linuxsampler.ttl
Changed
@@ -1,14 +1,16 @@ @prefix lv2: <http://lv2plug.in/ns/lv2core#> . @prefix doap: <http://usefulinc.com/ns/doap#> . @prefix ev: <http://lv2plug.in/ns/ext/event#> . -@prefix guiext: <http://lv2plug.in/ns/extensions/ui#> . <http://linuxsampler.org/plugins/linuxsampler> a lv2:InstrumentPlugin ; doap:name "LinuxSampler" ; doap:license <http://linuxsampler.org/downloads.html#exception> ; - lv2:optionalFeature lv2:hardRtCapable ; - lv2:optionalFeature <http://ll-plugins.nongnu.org/lv2/ext/saverestore> ; + lv2:optionalFeature lv2:hardRTCapable ; + lv2:extensionData <http://lv2plug.in/ns/ext/state#interface> ; + lv2:optionalFeature <http://lv2plug.in/ns/ext/state#mapPath> ; + lv2:optionalFeature <http://lv2plug.in/ns/ext/state#makePath> ; + lv2:optionalFeature <http://lv2plug.in/ns/ext/uri-map> ; lv2:port a lv2:AudioPort , lv2:OutputPort ; lv2:index 0 ;
View file
linuxsampler-2342.tar.bz2/src/hostplugins/lv2/lv2_state.h
Added
@@ -0,0 +1,359 @@ +/* + Copyright 2010-2012 David Robillard <http://drobilla.net> + Copyright 2010 Leonard Ritter <paniq@paniq.org> + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THIS SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +/** + @file state.h + C API for the LV2 State extension <http://lv2plug.in/ns/ext/state>. +*/ + +#ifndef LV2_STATE_H +#define LV2_STATE_H + +#include <stddef.h> +#include <stdint.h> + +#include "lv2/lv2plug.in/ns/lv2core/lv2.h" + +#define LV2_STATE_URI "http://lv2plug.in/ns/ext/state" +#define LV2_STATE_PREFIX LV2_STATE_URI "#" + +#define LV2_STATE__State LV2_STATE_PREFIX "State" +#define LV2_STATE__interface LV2_STATE_PREFIX "interface" +#define LV2_STATE__makePath LV2_STATE_PREFIX "makePath" +#define LV2_STATE__mapPath LV2_STATE_PREFIX "mapPath" +#define LV2_STATE__state LV2_STATE_PREFIX "state" + +#ifdef __cplusplus +extern "C" { +#else +# include <stdbool.h> +#endif + +typedef void* LV2_State_Handle; +typedef void* LV2_State_Map_Path_Handle; +typedef void* LV2_State_Make_Path_Handle; + +/** + Flags describing value characteristics. + + These flags are used along with the value's type URI to determine how to + (de-)serialise the value data, or whether it is even possible to do so. +*/ +typedef enum { + + /** + Plain Old Data. + + Values with this flag contain no pointers or references to other areas + of memory. It is safe to copy POD values with a simple memcpy and store + them for the duration of the process. A POD value is not necessarily + safe to trasmit between processes or machines (e.g. filenames are POD), + see LV2_STATE_IS_PORTABLE for details. + + Implementations MUST NOT attempt to copy or serialise a non-POD value if + they do not understand its type (and thus know how to correctly do so). + */ + LV2_STATE_IS_POD = 1, + + /** + Portable (architecture independent) data. + + Values with this flag are in a format that is usable on any + architecture. A portable value saved on one machine can be restored on + another machine regardless of architecture. The format of portable + values MUST NOT depend on architecture-specific properties like + endianness or alignment. Portable values MUST NOT contain filenames. + */ + LV2_STATE_IS_PORTABLE = 1 << 1, + + /** + Native data. + + This flag is used by the host to indicate that the saved data is only + going to be used locally in the currently running process (e.g. for + instance duplication or snapshots), so the plugin should use the most + efficient representation possible and not worry about serialisation + and portability. + */ + LV2_STATE_IS_NATIVE = 1 << 2 + +} LV2_State_Flags; + +/** A status code for state functions. */ +typedef enum { + LV2_STATE_SUCCESS = 0, /**< Completed successfully. */ + LV2_STATE_ERR_UNKNOWN = 1, /**< Unknown error. */ + LV2_STATE_ERR_BAD_TYPE = 2, /**< Failed due to unsupported type. */ + LV2_STATE_ERR_BAD_FLAGS = 3, /**< Failed due to unsupported flags. */ + LV2_STATE_ERR_NO_FEATURE = 4, /**< Failed due to missing features. */ + LV2_STATE_ERR_NO_PROPERTY = 5 /**< Failed due to missing property. */ +} LV2_State_Status; + +/** + A host-provided function to store a property. + @param handle Must be the handle passed to LV2_State_Interface.save(). + @param key The key to store @p value under (URID). + @param value Pointer to the value to be stored. + @param size The size of @p value in bytes. + @param type The type of @p value (URID). + @param flags LV2_State_Flags for @p value. + @return 0 on success, otherwise a non-zero error code. + + The host passes a callback of this type to LV2_State_Interface.save(). This + callback is called repeatedly by the plugin to store all the properties that + describe its current state. + + DO NOT INVENT NONSENSE URI SCHEMES FOR THE KEY. Best is to use keys from + existing vocabularies. If nothing appropriate is available, use http URIs + that point to somewhere you can host documents so documentation can be made + resolvable (e.g. a child of the plugin or project URI). If this is not + possible, invent a URN scheme, e.g. urn:myproj:whatever. The plugin MUST + NOT pass an invalid URI key. + + The host MAY fail to store a property for whatever reason, but SHOULD + store any property that is LV2_STATE_IS_POD and LV2_STATE_IS_PORTABLE. + Implementations SHOULD use the types from the LV2 Atom extension + (http://lv2plug.in/ns/ext/atom) wherever possible. The plugin SHOULD + attempt to fall-back and avoid the error if possible. + + Note that @p size MUST be > 0, and @p value MUST point to a valid region of + memory @p size bytes long (this is required to make restore unambiguous). + + The plugin MUST NOT attempt to use this function outside of the + LV2_State_Interface.restore() context. +*/ +typedef LV2_State_Status (*LV2_State_Store_Function)( + LV2_State_Handle handle, + uint32_t key, + const void* value, + size_t size, + uint32_t type, + uint32_t flags); + +/** + A host-provided function to retrieve a property. + @param handle Must be the handle passed to LV2_State_Interface.restore(). + @param key The key of the property to retrieve (URID). + @param size (Output) If non-NULL, set to the size of the restored value. + @param type (Output) If non-NULL, set to the type of the restored value. + @param flags (Output) If non-NULL, set to the flags for the restored value. + @return A pointer to the restored value (object), or NULL if no value + has been stored under @p key. + + A callback of this type is passed by the host to + LV2_State_Interface.restore(). This callback is called repeatedly by the + plugin to retrieve any properties it requires to restore its state. + + The returned value MUST remain valid until LV2_State_Interface.restore() + returns. The plugin MUST NOT attempt to use this function, or any value + returned from it, outside of the LV2_State_Interface.restore() context. +*/ +typedef const void* (*LV2_State_Retrieve_Function)( + LV2_State_Handle handle, + uint32_t key, + size_t* size, + uint32_t* type, + uint32_t* flags); + +/** + LV2 Plugin State Interface. + + When the plugin's extension_data is called with argument + LV2_STATE__interface, the plugin MUST return an LV2_State_Interface + structure, which remains valid for the lifetime of the plugin. + + The host can use the contained function pointers to save and restore the + state of a plugin instance at any time, provided the threading restrictions + of the functions are met. + + Stored data is only guaranteed to be compatible between instances of plugins + with the same URI (i.e. if a change to a plugin would cause a fatal error + when restoring state saved by a previous version of that plugin, the plugin + URI MUST change just as it must when ports change incompatibly). Plugin + authors should consider this possibility, and always store sensible data + with meaningful types to avoid such problems in the future. +*/ +typedef struct _LV2_State_Interface { + + /** + Save plugin state using a host-provided @p store callback. + + @param instance The instance handle of the plugin. + @param store The host-provided store callback. + @param handle An opaque pointer to host data which MUST be passed as the + handle parameter to @p store if it is called. + @param flags Flags describing desired properties of this save. These + flags may be used to determine the most appropriate values to store. + @param features Extensible parameter for passing any additional + features to be used for this save. + + The plugin is expected to store everything necessary to completely + restore its state later. Plugins SHOULD store simple POD data whenever + possible, and consider the possibility of state being restored much + later on a different machine. + + The @p handle pointer and @p store function MUST NOT be used + beyond the scope of save(). + + This function has its own special threading class: it may not be called + concurrently with any "Instantiation" function, but it may be called + concurrently with functions in any other class, unless the definition of + that class prohibits it (e.g. it may not be called concurrently with a + "Discovery" function, but it may be called concurrently with an "Audio" + function. The plugin is responsible for any locking or lock-free + techniques necessary to make this possible. + + Note that in the simple case where state is only modified by restore(), + there are no synchronization issues since save() is never called + concurrently with restore() (though run() may read it during a save). + + Plugins that dynamically modify state while running, however, must take + care to do so in such a way that a concurrent call to save() will save a + consistent representation of plugin state for a single instant in time. + */ + LV2_State_Status (*save)(LV2_Handle instance, + LV2_State_Store_Function store, + LV2_State_Handle handle, + uint32_t flags, + const LV2_Feature *const * features); + + /** + Restore plugin state using a host-provided @p retrieve callback. + + @param instance The instance handle of the plugin. + @param retrieve The host-provided retrieve callback. + @param handle An opaque pointer to host data which MUST be passed as the + handle parameter to @p retrieve if it is called. + @param flags Currently unused. + @param features Extensible parameter for passing any additional + features to be used for this restore. + + The plugin MAY assume a restored value was set by a previous call to + LV2_State_Interface.save() by a plugin with the same URI. + + The plugin MUST gracefully fall back to a default value when a value can + not be retrieved. This allows the host to reset the plugin state with + an empty map. + + The @p handle pointer and @p store function MUST NOT be used + beyond the scope of restore(). + + This function is in the "Instantiation" threading class as defined by + LV2. This means it MUST NOT be called concurrently with any other + function on the same plugin instance. + */ + LV2_State_Status (*restore)(LV2_Handle instance, + LV2_State_Retrieve_Function retrieve, + LV2_State_Handle handle, + uint32_t flags, + const LV2_Feature *const * features); + +} LV2_State_Interface; + +/** + Feature data for state:mapPath (LV2_STATE__mapPath). +*/ +typedef struct { + + /** + Opaque host data. + */ + LV2_State_Map_Path_Handle handle; + + /** + Map an absolute path to an abstract path for use in plugin state. + @param handle MUST be the @p handle member of this struct. + @param absolute_path The absolute path of a file. + @return An abstract path suitable for use in plugin state. + + The plugin MUST use this function to map any paths that will be stored + in plugin state. The returned value is an abstract path which MAY not + be an actual file system path; @ref absolute_path() MUST be used to map + it to an actual path in order to use the file. + + Plugins MUST NOT make any assumptions about abstract paths except that + they can be mapped back to the absolute path of the "same" file (though + not necessarily the same original path) using @ref absolute_path(). + + This function may only be called within the context of + LV2_State_Interface methods. The caller is responsible for freeing the + returned value with free(). + */ + char* (*abstract_path)(LV2_State_Map_Path_Handle handle, + const char* absolute_path); + + /** + Map an abstract path from plugin state to an absolute path. + @param handle MUST be the @p handle member of this struct. + @param abstract_path An abstract path (e.g. a path from plugin state). + @return An absolute file system path. + + The plugin MUST use this function in order to actually open or otherwise + use any paths loaded from plugin state. + + This function may only be called within the context of + LV2_State_Interface methods. The caller is responsible for freeing the + returned value with free(). + */ + char* (*absolute_path)(LV2_State_Map_Path_Handle handle, + const char* abstract_path); + +} LV2_State_Map_Path; + +/** + Feature data for state:makePath (@ref LV2_STATE__makePath). +*/ +typedef struct { + + /** + Opaque host data. + */ + LV2_State_Make_Path_Handle handle; + + /** + Return a path the plugin may use to create a new file. + @param handle MUST be the @p handle member of this struct. + @param path The path of the new file within a namespace unique to this + plugin instance. + @return The absolute path to use for the new file. + + This function can be used by plugins to create files and directories, + either at state saving time (if this feature is passed to + LV2_State_Interface.save()) or any time (if this feature is passed to + LV2_Descriptor.instantiate()). + + The host MUST do whatever is necessary for the plugin to be able to + create a file at the returned path (e.g. using fopen), including + creating any leading directories. + + If this function is passed to LV2_Descriptor.instantiate(), it may be + called from any non-realtime context. If it is passed to + LV2_State_Interface.save(), it may only be called within the dynamic + scope of that function call. + + The caller is responsible for freeing the returned value with free(). + */ + char* (*path)(LV2_State_Make_Path_Handle handle, + const char* path); + +} LV2_State_Make_Path; + +#ifdef __cplusplus +} /* extern "C" */ +#endif + +#endif /* LV2_STATE_H */
View file
linuxsampler-2342.tar.bz2/src/hostplugins/lv2/lv2_uri_map.h
Added
@@ -0,0 +1,87 @@ +/* lv2_uri_map.h - C header file for the LV2 URI Map extension. + * + * Copyright (C) 2008-2009 David Robillard <http://drobilla.net> + * + * This header is free software; you can redistribute it and/or modify it + * under the terms of the GNU Lesser General Public License as published + * by the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This header is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public + * License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this header; if not, write to the Free Software Foundation, + * Inc., 59 Temple Place, Suite 330, Boston, MA 01222-1307 USA + */ + +/** @file + * C header for the LV2 URI Map extension <http://lv2plug.in/ns/ext/uri-map>. + * + * This extension defines a simple mechanism for plugins to map URIs to + * integers, usually for performance reasons (e.g. processing events + * typed by URIs in real time). The expected use case is for plugins to + * map URIs to integers for things they 'understand' at instantiation time, + * and store those values for use in the audio thread without doing any string + * comparison. This allows the extensibility of RDF with the performance of + * integers (or centrally defined enumerations). + */ + +#ifndef LV2_URI_MAP_H +#define LV2_URI_MAP_H + +#define LV2_URI_MAP_URI "http://lv2plug.in/ns/ext/uri-map" + +#include <stdint.h> + + +/** Opaque pointer to host data. */ +typedef void* LV2_URI_Map_Callback_Data; + + +/** The data field of the LV2_Feature for this extension. + * + * To support this feature the host must pass an LV2_Feature struct to the + * plugin's instantiate method with URI "http://lv2plug.in/ns/ext/uri-map" + * and data pointed to an instance of this struct. + */ +typedef struct { + + /** Opaque pointer to host data. + * + * The plugin MUST pass this to any call to functions in this struct. + * Otherwise, it must not be interpreted in any way. + */ + LV2_URI_Map_Callback_Data callback_data; + + /** Get the numeric ID of a URI from the host. + * + * @param callback_data Must be the callback_data member of this struct. + * @param map The 'context' of this URI. Certain extensions may define a + * URI that must be passed here with certain restrictions on the + * return value (e.g. limited range). This value may be NULL if + * the plugin needs an ID for a URI in general. + * @param uri The URI to be mapped to an integer ID. + * + * This function is referentially transparent - any number of calls with + * the same arguments is guaranteed to return the same value over the life + * of a plugin instance (though the same URI may return different values + * with a different map parameter). However, this function is not + * necessarily very fast: plugins should cache any IDs they might need in + * performance critical situations. + * The return value 0 is reserved and means an ID for that URI could not + * be created for whatever reason. Extensions may define more precisely + * what this means, but in general plugins should gracefully handle 0 + * and consider whatever they wanted the URI for "unsupported". + */ + uint32_t (*uri_to_id)(LV2_URI_Map_Callback_Data callback_data, + const char* map, + const char* uri); + +} LV2_URI_Map_Feature; + + +#endif /* LV2_URI_MAP_H */ +
View file
linuxsampler-2342.tar.bz2/src/hostplugins/vst/Info.plist
Added
@@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> +<plist version="1.0"> +<dict> + <key>CFBundleDevelopmentRegion</key> + <string>English</string> + <key>CFBundleExecutable</key> + <string>LinuxSampler</string> + <key>CFBundleIdentifier</key> + <string>org.linuxsampler.LinuxSampler</string> + <key>CFBundleInfoDictionaryVersion</key> + <string>6.0</string> + <key>CFBundlePackageType</key> + <string>BNDL</string> + <key>CFBundleSignature</key> + <string>????</string> + <key>CFBundleVersion</key> + <string>1.0</string> +</dict> +</plist>
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/vst/Makefile.am -> linuxsampler-2342.tar.bz2/src/hostplugins/vst/Makefile.am
Changed
@@ -2,26 +2,51 @@ plugindir = $(libdir)/vst plugin_LTLIBRARIES = LinuxSampler.la -INCLUDES = -I@VSTSDK_DIR@ -I@VSTSDK_DIR@/public.sdk/source/vst2.x \ +INCLUDES = -I$(VSTSDK_DIR) -I$(VSTSDK_DIR)/public.sdk/source/vst2.x \ $(GIG_CFLAGS) $(SQLITE3_CFLAGS) LinuxSampler_la_SOURCES = PluginVst.cpp PluginVst.h nodist_LinuxSampler_la_SOURCES = \ - @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffectx.cpp \ - @VSTSDK_DIR@/public.sdk/source/vst2.x/audioeffect.cpp \ - @VSTSDK_DIR@/public.sdk/source/vst2.x/vstplugmain.cpp + $(VSTSDK_DIR)/public.sdk/source/vst2.x/audioeffectx.cpp \ + $(VSTSDK_DIR)/public.sdk/source/vst2.x/audioeffect.cpp \ + $(VSTSDK_DIR)/public.sdk/source/vst2.x/vstplugmain.cpp -LinuxSampler_la_LDFLAGS = -module -avoid-version -no-undefined -Wl,-s +LinuxSampler_la_LDFLAGS = -module -avoid-version -no-undefined LinuxSampler_la_LIBADD = $(top_builddir)/src/liblinuxsampler.la -EXTRA_DIST = PluginVst.def - if HAVE_WINDOWS -LinuxSampler_la_LDFLAGS += -Wl,$(srcdir)/PluginVst.def +LinuxSampler_la_LDFLAGS += -Wl,$(srcdir)/PluginVst.def -Wl,-s LinuxSampler_la_LIBADD += -lws2_32 else LinuxSampler_la_CPPFLAGS = -D__cdecl= -LinuxSampler_la_LDFLAGS += -Wl,--defsym -Wl,main=VSTPluginMain +if LINUX +LinuxSampler_la_LDFLAGS += -Wl,--defsym -Wl,main=VSTPluginMain -Wl,-s +endif +endif + +if MAC +all-local: LinuxSampler.vst + +LinuxSampler.vst: LinuxSampler.la $(srcdir)/Info.plist $(srcdir)/PkgInfo + mkdir -p LinuxSampler.vst/Contents/MacOS + cp $(srcdir)/Info.plist LinuxSampler.vst/Contents + cp $(srcdir)/PkgInfo LinuxSampler.vst/Contents + if test -f .libs/LinuxSampler.so ; then cp .libs/LinuxSampler.so LinuxSampler.vst/Contents/MacOS/LinuxSampler ; fi + @touch $@ + +clean-local: + rm -rf LinuxSampler.vst + +install-exec-hook: + if mkdir -p $(MAC_PLUGIN_INSTALL_DIR)/VST && \ + test -w $(MAC_PLUGIN_INSTALL_DIR)/VST ; then \ + cp -r LinuxSampler.vst $(MAC_PLUGIN_INSTALL_DIR)/VST/ ; \ + if test -n "$(INSTALL_STRIP_FLAG)" ; then $(STRIP) -x $(MAC_PLUGIN_INSTALL_DIR)/VST/LinuxSampler.vst/Contents/MacOS/LinuxSampler ; fi ; fi + +uninstall-hook: + rm -rf $(MAC_PLUGIN_INSTALL_DIR)/VST/LinuxSampler.vst endif endif + +EXTRA_DIST = PluginVst.def PkgInfo Info.plist
View file
linuxsampler-2342.tar.bz2/src/hostplugins/vst/PkgInfo
Added
@@ -0,0 +1,1 @@ +BNDL???? \ No newline at end of file
View file
linuxsampler-1.0.0.tar.bz2/src/hostplugins/vst/PluginVst.cpp -> linuxsampler-2342.tar.bz2/src/hostplugins/vst/PluginVst.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2008 - 2009 Andreas Persson * + * Copyright (C) 2008 - 2011 Andreas Persson * * * * 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 * @@ -43,7 +43,7 @@ void log(const char* fmt, ...) { logmutex.Lock(); - FILE* f = fopen("C:\\linuxsamplervst.log", "a"); + FILE* f = fopen((String(getenv("TEMP")) + "\\linuxsamplervst.log").c_str(), "a"); va_list ap; va_start(ap, fmt); vfprintf(f, fmt, ap); @@ -113,16 +113,37 @@ FindClose(hFind); // start a java process - STARTUPINFO si; - PROCESS_INFORMATION pi; - ZeroMemory(&si, sizeof(si)); - si.cb = sizeof(si); - ZeroMemory(&pi, sizeof(pi)); - - Command = _tcsdup(TEXT((String("javaw -jar \"") + lspath + fantasia + "\"").c_str())); - CreateProcess(NULL, Command, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi); - ProcessHandle = pi.hProcess; - CloseHandle(pi.hThread); + String path; // look in PATH first + for (int i = 0 ; i < 2 ; i++) { // two tries + STARTUPINFO si; + PROCESS_INFORMATION pi; + ZeroMemory(&si, sizeof(si)); + si.cb = sizeof(si); + ZeroMemory(&pi, sizeof(pi)); + + Command = _tcsdup(TEXT((String("\"") + path + "javaw\" -jar \"" + + lspath + fantasia + "\"").c_str())); + if (CreateProcess(NULL, Command, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) { + ProcessHandle = pi.hProcess; + CloseHandle(pi.hThread); + break; + } else { + free(Command); + if (path.empty()) { + // java wasn't found in PATH, try again + // with an alternative directory + char* windir = getenv("windir"); + if (!windir) break; +#ifdef _WIN64 + // LS plugin is 64 bit - look for 32 bit java + path = String(windir) + "\\SysWOW64\\"; +#else + // LS plugin is 32 bit - look for 64 bit java + path = String(windir) + "\\Sysnative\\"; +#endif + } + } + } } } #endif @@ -189,7 +210,7 @@ InitState(); } } else { - Init(int(sampleRate), blockSize); + Init(int(sampleRate), blockSize, CHANNELS); } AudioEffectX::resume(); dmsg(2, ("<--resume\n"));
View file
linuxsampler-2342.tar.bz2/src/hostplugins/vst/PluginVst.def
Added
@@ -0,0 +1,5 @@ +LIBRARY LINUXSAMPLER +DESCRIPTION 'LinuxSampler VST' +EXPORTS +main=VSTPluginMain @1 +VSTPluginMain @2
View file
linuxsampler-1.0.0.tar.bz2/src/linuxsampler.cpp -> linuxsampler-2342.tar.bz2/src/linuxsampler.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003-2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005-2009 Christian Schoenebeck * + * Copyright (C) 2005-2012 Christian Schoenebeck * * * * 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 * @@ -41,6 +41,7 @@ #include "plugins/InstrumentEditorFactory.h" #include "drivers/midi/MidiInputDeviceFactory.h" #include "drivers/audio/AudioOutputDeviceFactory.h" +#include "effects/EffectFactory.h" #include "engines/gig/Profiler.h" #include "network/lscpserver.h" #include "common/stacktrace.h" @@ -72,6 +73,7 @@ static bool bShowStackTrace = false; unsigned long int lscp_addr; unsigned short int lscp_port; +String ExecAfterInit; void parse_options(int argc, char **argv); void signal_handler(int signal); @@ -117,7 +119,7 @@ dmsg(1,("LinuxSampler %s\n", VERSION)); dmsg(1,("Copyright (C) 2003,2004 by Benno Senoner and Christian Schoenebeck\n")); - dmsg(1,("Copyright (C) 2005-2009 Christian Schoenebeck\n")); + dmsg(1,("Copyright (C) 2005-2012 Christian Schoenebeck\n")); #if defined(WIN32) #if 0 @@ -188,6 +190,8 @@ dmsg(1,("Registered MIDI input drivers: %s\n", MidiInputDeviceFactory::AvailableDriversAsString().c_str())); dmsg(1,("Registered audio output drivers: %s\n", AudioOutputDeviceFactory::AvailableDriversAsString().c_str())); dmsg(1,("Registered instrument editors: %s\n", InstrumentEditorFactory::AvailableEditorsAsString().c_str())); + dmsg(1,("Registered internal effect systems: %s\n", EffectFactory::AvailableEffectSystemsAsString().c_str())); + dmsg(1,("Registered internal effects: %d\n", EffectFactory::AvailableEffectsCount())); // start LSCP network server struct in_addr addr; @@ -208,6 +212,13 @@ } printf("LinuxSampler initialization completed. :-)\n\n"); + + if (ExecAfterInit != "") { + printf("Executing command: %s\n\n", ExecAfterInit.c_str()); + if (system(ExecAfterInit.c_str()) == -1) { + std::cerr << "Failed to execute the command" << std::endl; + } + } while (atomic_read(&running)) { if (bPrintStatistics) { @@ -312,6 +323,7 @@ {"lscp-addr",1,0,0}, {"lscp-port",1,0,0}, {"stacktrace",0,0,0}, + {"exec-after-init",1,0,0}, {0,0,0,0} }; @@ -337,6 +349,7 @@ printf("--instruments-db-location specifies the instruments DB file\n"); printf("--stacktrace automatically shows stacktrace if crashes\n"); printf(" (broken on most systems at the moment)\n"); + printf("--exec-after-init executes a command after initialization\n"); exit(EXIT_SUCCESS); break; case 1: // --version @@ -345,6 +358,9 @@ break; case 2: // --profile profile = true; + //FIXME: profiling code is currently broken! + std::cerr << "Option '--profile' is currently not supported, since the profiling code is currently broken!" << std::endl; + exit(EXIT_FAILURE); break; case 3: // --no-tune tune = false; @@ -426,6 +442,9 @@ case 9: // --stacktrace bShowStackTrace = true; break; + case 10: // --exec-after-init + ExecAfterInit = optarg; + break; } } }
View file
linuxsampler-1.0.0.tar.bz2/src/network/Makefile.am -> linuxsampler-2342.tar.bz2/src/network/Makefile.am
Changed
@@ -26,12 +26,12 @@ # automatically (re)generate lscpsymbols.h with bison / yacc if the # yacc source file(s) have been changed lscpsymbols.h: $(yacc_sources) - $(top_builddir)/scripts/generate_parser.sh + $(top_srcdir)/scripts/generate_parser.sh # automatically (re)generate lscpparser.cpp with bison / yacc if the # yacc source file(s) have been changed lscpparser.cpp: $(yacc_sources) - $(top_builddir)/scripts/generate_parser.sh + $(top_srcdir)/scripts/generate_parser.sh .PHONY: parser
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscp.y -> linuxsampler-2342.tar.bz2/src/network/lscp.y
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2008 Christian Schoenebeck * + * Copyright (C) 2005 - 2010 Christian Schoenebeck * * * * 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 * @@ -119,9 +119,9 @@ %token <Char> EXT_ASCII_CHAR %type <Char> char char_base alpha_char digit digit_oct digit_hex escape_seq escape_seq_octal escape_seq_hex -%type <Dotnum> dotnum volume_value boolean -%type <Number> number sampler_channel instrument_index fx_send_id audio_channel_index device_index midi_input_channel_index midi_input_port_index midi_map midi_bank midi_prog midi_ctrl -%type <String> string string_escaped text text_escaped text_escaped_base stringval stringval_escaped digits param_val_list param_val query_val filename db_path map_name entry_name fx_send_name engine_name command add_instruction create_instruction destroy_instruction get_instruction list_instruction load_instruction send_instruction set_chan_instruction load_instr_args load_engine_args audio_output_type_name midi_input_type_name remove_instruction unmap_instruction set_instruction subscribe_event unsubscribe_event map_instruction reset_instruction clear_instruction find_instruction move_instruction copy_instruction scan_mode edit_instruction format_instruction +%type <Dotnum> real dotnum volume_value boolean control_value +%type <Number> number sampler_channel instrument_index fx_send_id audio_channel_index device_index effect_index effect_instance effect_chain chain_pos input_control midi_input_channel_index midi_input_port_index midi_map midi_bank midi_prog midi_ctrl +%type <String> string string_escaped text text_escaped text_escaped_base stringval stringval_escaped digits param_val_list param_val query_val filename module effect_system db_path map_name entry_name fx_send_name effect_name engine_name command add_instruction create_instruction destroy_instruction get_instruction list_instruction load_instruction send_instruction set_chan_instruction load_instr_args load_engine_args audio_output_type_name midi_input_type_name remove_instruction unmap_instruction set_instruction subscribe_event unsubscribe_event map_instruction reset_instruction clear_instruction find_instruction move_instruction copy_instruction scan_mode edit_instruction format_instruction append_instruction insert_instruction %type <FillResponse> buffer_size_type %type <KeyValList> key_val_list query_val_list %type <LoadMode> instr_load_mode @@ -180,6 +180,8 @@ | EDIT SP edit_instruction { $$ = $3; } | FORMAT SP format_instruction { $$ = $3; } | SEND SP send_instruction { $$ = $3; } + | APPEND SP append_instruction { $$ = $3; } + | INSERT SP insert_instruction { $$ = $3; } | RESET { $$ = LSCPSERVER->ResetSampler(); } | QUIT { LSCPSERVER->AnswerClient("Bye!\r\n"); return LSCP_QUIT; } ; @@ -196,6 +198,7 @@ | DB_INSTRUMENTS SP db_path SP filename SP instrument_index { $$ = LSCPSERVER->AddDbInstruments($3,$5,$7); } | MIDI_INSTRUMENT_MAP { $$ = LSCPSERVER->AddMidiInstrumentMap(); } | MIDI_INSTRUMENT_MAP SP map_name { $$ = LSCPSERVER->AddMidiInstrumentMap($3); } + | SEND_EFFECT_CHAIN SP device_index { $$ = LSCPSERVER->AddSendEffectChain($3); } ; subscribe_event : AUDIO_OUTPUT_DEVICE_COUNT { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_audio_device_count); } @@ -224,6 +227,10 @@ | TOTAL_STREAM_COUNT { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_total_stream_count); } | TOTAL_VOICE_COUNT { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_total_voice_count); } | GLOBAL_INFO { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_global_info); } + | EFFECT_INSTANCE_COUNT { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_fx_instance_count); } + | EFFECT_INSTANCE_INFO { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_fx_instance_info); } + | SEND_EFFECT_CHAIN_COUNT { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_send_fx_chain_count); } + | SEND_EFFECT_CHAIN_INFO { $$ = LSCPSERVER->SubscribeNotification(LSCPEvent::event_send_fx_chain_info); } ; unsubscribe_event : AUDIO_OUTPUT_DEVICE_COUNT { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_audio_device_count); } @@ -252,6 +259,10 @@ | TOTAL_STREAM_COUNT { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_total_stream_count); } | TOTAL_VOICE_COUNT { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_total_voice_count); } | GLOBAL_INFO { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_global_info); } + | EFFECT_INSTANCE_COUNT { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_fx_instance_count); } + | EFFECT_INSTANCE_INFO { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_fx_instance_info); } + | SEND_EFFECT_CHAIN_COUNT { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_send_fx_chain_count); } + | SEND_EFFECT_CHAIN_INFO { $$ = LSCPSERVER->UnsubscribeNotification(LSCPEvent::event_send_fx_chain_info); } ; map_instruction : MIDI_INSTRUMENT SP modal_arg midi_map SP midi_bank SP midi_prog SP engine_name SP filename SP instrument_index SP volume_value { $$ = LSCPSERVER->AddOrReplaceMIDIInstrumentMapping($4,$6,$8,$10,$12,$14,$16,MidiInstrumentMapper::DONTCARE,"",$3); } @@ -266,12 +277,22 @@ remove_instruction : CHANNEL SP sampler_channel { $$ = LSCPSERVER->RemoveChannel($3); } | MIDI_INSTRUMENT_MAP SP midi_map { $$ = LSCPSERVER->RemoveMidiInstrumentMap($3); } | MIDI_INSTRUMENT_MAP SP ALL { $$ = LSCPSERVER->RemoveAllMidiInstrumentMaps(); } + | SEND_EFFECT_CHAIN SP device_index SP effect_chain { $$ = LSCPSERVER->RemoveSendEffectChain($3,$5); } + | SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP chain_pos { $$ = LSCPSERVER->RemoveSendEffectChainEffect($5,$7,$9); } + | FX_SEND SP EFFECT SP sampler_channel SP fx_send_id { $$ = LSCPSERVER->SetFxSendEffect($5,$7,-1,-1); } | DB_INSTRUMENT_DIRECTORY SP FORCE SP db_path { $$ = LSCPSERVER->RemoveDbInstrumentDirectory($5, true); } | DB_INSTRUMENT_DIRECTORY SP db_path { $$ = LSCPSERVER->RemoveDbInstrumentDirectory($3); } | DB_INSTRUMENT SP db_path { $$ = LSCPSERVER->RemoveDbInstrument($3); } ; get_instruction : AVAILABLE_ENGINES { $$ = LSCPSERVER->GetAvailableEngines(); } + | AVAILABLE_EFFECTS { $$ = LSCPSERVER->GetAvailableEffects(); } + | EFFECT_INSTANCES { $$ = LSCPSERVER->GetEffectInstances(); } + | EFFECT SP INFO SP effect_index { $$ = LSCPSERVER->GetEffectInfo($5); } + | EFFECT_INSTANCE SP INFO SP effect_instance { $$ = LSCPSERVER->GetEffectInstanceInfo($5); } + | EFFECT_INSTANCE_INPUT_CONTROL SP INFO SP effect_instance SP input_control { $$ = LSCPSERVER->GetEffectInstanceInputControlInfo($5,$7); } + | SEND_EFFECT_CHAINS SP device_index { $$ = LSCPSERVER->GetSendEffectChains($3); } + | SEND_EFFECT_CHAIN SP INFO SP device_index SP effect_chain { $$ = LSCPSERVER->GetSendEffectChainInfo($5,$7); } | AVAILABLE_MIDI_INPUT_DRIVERS { $$ = LSCPSERVER->GetAvailableMidiInputDrivers(); } | MIDI_INPUT_DRIVER SP INFO SP string { $$ = LSCPSERVER->GetMidiInputDriverInfo($5); } | MIDI_INPUT_DRIVER_PARAMETER SP INFO SP string SP string { $$ = LSCPSERVER->GetMidiInputDriverParameterInfo($5, $7); } @@ -324,12 +345,14 @@ | MIDI_INPUT_DEVICE_PARAMETER SP number SP string '=' param_val_list { $$ = LSCPSERVER->SetMidiInputDeviceParameter($3, $5, $7); } | MIDI_INPUT_PORT_PARAMETER SP number SP number SP string '=' NONE { $$ = LSCPSERVER->SetMidiInputPortParameter($3, $5, $7, ""); } | MIDI_INPUT_PORT_PARAMETER SP number SP number SP string '=' param_val_list { $$ = LSCPSERVER->SetMidiInputPortParameter($3, $5, $7, $9); } + | EFFECT_INSTANCE_INPUT_CONTROL SP VALUE SP effect_instance SP input_control SP control_value { $$ = LSCPSERVER->SetEffectInstanceInputControlValue($5, $7, $9); } | CHANNEL SP set_chan_instruction { $$ = $3; } | MIDI_INSTRUMENT_MAP SP NAME SP midi_map SP map_name { $$ = LSCPSERVER->SetMidiInstrumentMapName($5, $7); } | FX_SEND SP NAME SP sampler_channel SP fx_send_id SP fx_send_name { $$ = LSCPSERVER->SetFxSendName($5,$7,$9); } | FX_SEND SP AUDIO_OUTPUT_CHANNEL SP sampler_channel SP fx_send_id SP audio_channel_index SP audio_channel_index { $$ = LSCPSERVER->SetFxSendAudioOutputChannel($5,$7,$9,$11); } | FX_SEND SP MIDI_CONTROLLER SP sampler_channel SP fx_send_id SP midi_ctrl { $$ = LSCPSERVER->SetFxSendMidiController($5,$7,$9); } | FX_SEND SP LEVEL SP sampler_channel SP fx_send_id SP volume_value { $$ = LSCPSERVER->SetFxSendLevel($5,$7,$9); } + | FX_SEND SP EFFECT SP sampler_channel SP fx_send_id SP effect_chain SP chain_pos { $$ = LSCPSERVER->SetFxSendEffect($5,$7,$9,$11); } | DB_INSTRUMENT_DIRECTORY SP NAME SP db_path SP stringval_escaped { $$ = LSCPSERVER->SetDbInstrumentDirectoryName($5,$7); } | DB_INSTRUMENT_DIRECTORY SP DESCRIPTION SP db_path SP stringval_escaped { $$ = LSCPSERVER->SetDbInstrumentDirectoryDescription($5,$7); } | DB_INSTRUMENT SP NAME SP db_path SP stringval_escaped { $$ = LSCPSERVER->SetDbInstrumentName($5,$7); } @@ -347,6 +370,8 @@ | MIDI_INPUT_DEVICE SP string { $$ = LSCPSERVER->CreateMidiInputDevice($3); } | FX_SEND SP sampler_channel SP midi_ctrl { $$ = LSCPSERVER->CreateFxSend($3,$5); } | FX_SEND SP sampler_channel SP midi_ctrl SP fx_send_name { $$ = LSCPSERVER->CreateFxSend($3,$5,$7); } + | EFFECT_INSTANCE SP effect_index { $$ = LSCPSERVER->CreateEffectInstance($3); } + | EFFECT_INSTANCE SP effect_system SP module SP effect_name { $$ = LSCPSERVER->CreateEffectInstance($3,$5,$7); } ; reset_instruction : CHANNEL SP sampler_channel { $$ = LSCPSERVER->ResetChannel($3); } @@ -374,12 +399,19 @@ destroy_instruction : AUDIO_OUTPUT_DEVICE SP number { $$ = LSCPSERVER->DestroyAudioOutputDevice($3); } | MIDI_INPUT_DEVICE SP number { $$ = LSCPSERVER->DestroyMidiInputDevice($3); } | FX_SEND SP sampler_channel SP fx_send_id { $$ = LSCPSERVER->DestroyFxSend($3,$5); } + | EFFECT_INSTANCE SP number { $$ = LSCPSERVER->DestroyEffectInstance($3); } ; load_instruction : INSTRUMENT SP load_instr_args { $$ = $3; } | ENGINE SP load_engine_args { $$ = $3; } ; +append_instruction : SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP effect_instance { $$ = LSCPSERVER->AppendSendEffectChainEffect($5,$7,$9); } + ; + +insert_instruction : SEND_EFFECT_CHAIN SP EFFECT SP device_index SP effect_chain SP chain_pos SP effect_instance { $$ = LSCPSERVER->InsertSendEffectChainEffect($5,$7,$9,$11); } + ; + set_chan_instruction : AUDIO_OUTPUT_DEVICE SP sampler_channel SP device_index { $$ = LSCPSERVER->SetAudioOutputDevice($5, $3); } | AUDIO_OUTPUT_CHANNEL SP sampler_channel SP audio_channel_index SP audio_channel_index { $$ = LSCPSERVER->SetAudioOutputChannel($5, $7, $3); } | AUDIO_OUTPUT_TYPE SP sampler_channel SP audio_output_type_name { $$ = LSCPSERVER->SetAudioOutputType($5, $3); } @@ -418,6 +450,9 @@ | MIDI_INPUT_DEVICES { $$ = LSCPSERVER->GetMidiInputDevices(); } | CHANNELS { $$ = LSCPSERVER->ListChannels(); } | AVAILABLE_ENGINES { $$ = LSCPSERVER->ListAvailableEngines(); } + | AVAILABLE_EFFECTS { $$ = LSCPSERVER->ListAvailableEffects(); } + | EFFECT_INSTANCES { $$ = LSCPSERVER->ListEffectInstances(); } + | SEND_EFFECT_CHAINS SP number { $$ = LSCPSERVER->ListSendEffectChains($3); } | AVAILABLE_MIDI_INPUT_DRIVERS { $$ = LSCPSERVER->ListAvailableMidiInputDrivers(); } | AVAILABLE_AUDIO_OUTPUT_DRIVERS { $$ = LSCPSERVER->ListAvailableAudioOutputDrivers(); } | MIDI_INSTRUMENTS SP midi_map { $$ = LSCPSERVER->ListMidiInstrumentMappings($3); } @@ -446,6 +481,9 @@ | PERSISTENT { $$ = MidiInstrumentMapper::PERSISTENT; } ; +effect_instance : number + ; + device_index : number ; @@ -481,6 +519,9 @@ | number { $$ = $1; } ; +control_value : real + ; + sampler_channel : number ; @@ -515,6 +556,21 @@ fx_send_name : stringval_escaped ; +effect_name : stringval_escaped + ; + +effect_index : number + ; + +effect_chain : number + ; + +chain_pos : number + ; + +input_control : number + ; + param_val_list : param_val | param_val_list','param_val { $$ = $1 + "," + $3; } ; @@ -523,7 +579,7 @@ param_val : string { $$ = "\'" + $1 + "\'"; } | stringval { $$ = "\'" + $1 + "\'"; } | number { std::stringstream ss; ss << "\'" << $1 << "\'"; $$ = ss.str(); } - | dotnum { std::stringstream ss; ss << "\'" << $1 << "\'"; $$ = ss.str(); } + | dotnum { std::stringstream ss; ss << "\'" << $1 << "\'"; $$ = ss.str(); } //TODO: maybe better using 'real' instead of 'number' and 'dotnum' rules ; query_val_list : string '=' query_val { $$$1 = $3; } @@ -539,6 +595,12 @@ | FLAT { $$ = "FLAT"; } ; +effect_system : string + ; + +module : filename + ; + // GRAMMAR_BNF_END - do NOT delete or modify this line !!! @@ -553,6 +615,14 @@ | '-' digits '.' digits { std::stringstream ss("-" + $2 + "." + $4); ss.imbue(std::locale::classic()); ss >> $$; } ; +real : digits '.' digits { std::stringstream ss($1 + "." + $3); ss.imbue(std::locale::classic()); ss >> $$; } + | '+' digits '.' digits { std::stringstream ss($2 + "." + $4); ss.imbue(std::locale::classic()); ss >> $$; } + | '-' digits '.' digits { std::stringstream ss("-" + $2 + "." + $4); ss.imbue(std::locale::classic()); ss >> $$; } + | digits { std::stringstream ss($1); ss.imbue(std::locale::classic()); ss >> $$; } + | '+' digits { std::stringstream ss($2); ss.imbue(std::locale::classic()); ss >> $$; } + | '-' digits { std::stringstream ss("-" + $2); ss.imbue(std::locale::classic()); ss >> $$; } + ; + digits : digit { $$ = $1; } | digits digit { $$ = $1 + $2; } @@ -780,6 +850,12 @@ SET : 'S''E''T' ; +APPEND : 'A''P''P''E''N''D' + ; + +INSERT : 'I''N''S''E''R''T' + ; + SUBSCRIBE : 'S''U''B''S''C''R''I''B''E' ; @@ -882,6 +958,18 @@ GLOBAL_INFO : 'G''L''O''B''A''L''_''I''N''F''O' ; +EFFECT_INSTANCE_COUNT : 'E''F''F''E''C''T''_''I''N''S''T''A''N''C''E''_''C''O''U''N''T' + ; + +EFFECT_INSTANCE_INFO : 'E''F''F''E''C''T''_''I''N''S''T''A''N''C''E''_''I''N''F''O' + ; + +SEND_EFFECT_CHAIN_COUNT : 'S''E''N''D''_''E''F''F''E''C''T''_''C''H''A''I''N''_''C''O''U''N''T' + ; + +SEND_EFFECT_CHAIN_INFO : 'S''E''N''D''_''E''F''F''E''C''T''_''C''H''A''I''N''_''I''N''F''O' + ; + INSTRUMENT : 'I''N''S''T''R''U''M''E''N''T' ; @@ -924,6 +1012,27 @@ AUDIO_OUTPUT_TYPE : 'A''U''D''I''O''_''O''U''T''P''U''T''_''T''Y''P''E' ; +AVAILABLE_EFFECTS : 'A''V''A''I''L''A''B''L''E''_''E''F''F''E''C''T''S' + ; + +EFFECT : 'E''F''F''E''C''T' + ; + +EFFECT_INSTANCE : 'E''F''F''E''C''T''_''I''N''S''T''A''N''C''E' + ; + +EFFECT_INSTANCES : 'E''F''F''E''C''T''_''I''N''S''T''A''N''C''E''S' + ; + +EFFECT_INSTANCE_INPUT_CONTROL : 'E''F''F''E''C''T''_''I''N''S''T''A''N''C''E''_''I''N''P''U''T''_''C''O''N''T''R''O''L' + ; + +SEND_EFFECT_CHAIN : 'S''E''N''D''_''E''F''F''E''C''T''_''C''H''A''I''N' + ; + +SEND_EFFECT_CHAINS : 'S''E''N''D''_''E''F''F''E''C''T''_''C''H''A''I''N''S' + ; + AVAILABLE_MIDI_INPUT_DRIVERS : 'A''V''A''I''L''A''B''L''E''_''M''I''D''I''_''I''N''P''U''T''_''D''R''I''V''E''R''S' ; @@ -1029,6 +1138,9 @@ LEVEL : 'L''E''V''E''L' ; +VALUE : 'V''A''L''U''E' + ; + MUTE : 'M''U''T''E' ;
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpevent.h -> linuxsampler-2342.tar.bz2/src/network/lscpevent.h
Changed
@@ -67,7 +67,11 @@ event_total_voice_count, event_global_info, event_channel_midi, - event_device_midi + event_device_midi, + event_fx_instance_count, + event_fx_instance_info, + event_send_fx_chain_count, + event_send_fx_chain_info }; /* This constructor will do type lookup based on name
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpresultset.cpp -> linuxsampler-2342.tar.bz2/src/network/lscpresultset.cpp
Changed
@@ -120,6 +120,16 @@ count = 1; } +void LSCPResultSet::Add(String Label, const std::vector<float>& v) { + std::stringstream ss; + ss.imbue(std::locale::classic()); + for (int i = 0; i < v.size(); i++) { + if (!ss.str().empty()) ss << ","; + ss << std::fixed << std::setprecision(3) << vi; + } + Add(Label, ss.str()); +} + //Generate an error result set from an exception. //Per LSCP spec, error result is a sinle line in the following format: //ERR:<CODE>:Message text\r\n
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpresultset.h -> linuxsampler-2342.tar.bz2/src/network/lscpresultset.h
Changed
@@ -26,6 +26,7 @@ #include <iostream> #include <sstream> #include <string> +#include <vector> #include "../Sampler.h" #include "../common/global.h" #include "../common/Exception.h" @@ -47,6 +48,7 @@ void Add(String, int); void Add(String, bool); void Add(int); + void Add(String Label, const std::vector<float>& v); void Error(String message = "Undefined Error", int code = 0); void Error(Exception e); void Warning(String message = "Undefined Warning", int code = 0);
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpserver.cpp -> linuxsampler-2342.tar.bz2/src/network/lscpserver.cpp
Changed
@@ -3,7 +3,7 @@ * LinuxSampler - modular, streaming capable sampler * * * * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * - * Copyright (C) 2005 - 2009 Christian Schoenebeck * + * Copyright (C) 2005 - 2012 Christian Schoenebeck * * * * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -43,6 +43,7 @@ #include "../engines/EngineChannelFactory.h" #include "../drivers/audio/AudioOutputDeviceFactory.h" #include "../drivers/midi/MidiInputDeviceFactory.h" +#include "../effects/EffectFactory.h" namespace LinuxSampler { @@ -137,6 +138,10 @@ LSCPEvent::RegisterEvent(LSCPEvent::event_global_info, "GLOBAL_INFO"); LSCPEvent::RegisterEvent(LSCPEvent::event_channel_midi, "CHANNEL_MIDI"); LSCPEvent::RegisterEvent(LSCPEvent::event_device_midi, "DEVICE_MIDI"); + LSCPEvent::RegisterEvent(LSCPEvent::event_fx_instance_count, "EFFECT_INSTANCE_COUNT"); + LSCPEvent::RegisterEvent(LSCPEvent::event_fx_instance_info, "EFFECT_INSTANCE_INFO"); + LSCPEvent::RegisterEvent(LSCPEvent::event_send_fx_chain_count, "SEND_EFFECT_CHAIN_COUNT"); + LSCPEvent::RegisterEvent(LSCPEvent::event_send_fx_chain_info, "SEND_EFFECT_CHAIN_INFO"); hSocket = -1; } @@ -442,6 +447,7 @@ #endif // check if some engine channel's parameter / status changed, if so notify the respective LSCP event subscribers { + EngineChannelFactory::EngineChannelsMutex.Lock(); std::set<EngineChannel*> engineChannels = EngineChannelFactory::EngineChannelInstances(); std::set<EngineChannel*>::iterator itEngineChannel = engineChannels.begin(); std::set<EngineChannel*>::iterator itEnd = engineChannels.end(); @@ -459,6 +465,7 @@ } } } + EngineChannelFactory::EngineChannelsMutex.Unlock(); } // check if MIDI data arrived on some engine channel @@ -2382,11 +2389,17 @@ AudioRouting += ToString(pFxSend->DestinationChannel(chan)); } + const String sEffectRouting = + (pFxSend->DestinationEffectChain() >= 0 && pFxSend->DestinationEffectChainPosition() >= 0) + ? ToString(pFxSend->DestinationEffectChain()) + "," + ToString(pFxSend->DestinationEffectChainPosition()) + : "NONE"; + // success result.Add("NAME", _escapeLscpResponse(pFxSend->Name())); result.Add("MIDI_CONTROLLER", pFxSend->MidiController()); result.Add("LEVEL", ToString(pFxSend->Level())); result.Add("AUDIO_OUTPUT_ROUTING", AudioRouting); + result.Add("EFFECT", sEffectRouting); } catch (Exception e) { result.Error(e); } @@ -2449,6 +2462,473 @@ return result.Produce(); } +String LSCPServer::SetFxSendEffect(uint uiSamplerChannel, uint FxSendID, int iSendEffectChain, int iEffectChainPosition) { + dmsg(2,("LSCPServer: SetFxSendEffect(%d,%d)\n", iSendEffectChain, iEffectChainPosition)); + LSCPResultSet result; + try { + FxSend* pFxSend = GetFxSend(uiSamplerChannel, FxSendID); + + pFxSend->SetDestinationEffect(iSendEffectChain, iEffectChainPosition); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_fx_send_info, uiSamplerChannel, FxSendID)); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::GetAvailableEffects() { + dmsg(2,("LSCPServer: GetAvailableEffects()\n")); + LSCPResultSet result; + try { + int n = EffectFactory::AvailableEffectsCount(); + result.Add(n); + } + catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::ListAvailableEffects() { + dmsg(2,("LSCPServer: ListAvailableEffects()\n")); + LSCPResultSet result; + String list; + try { + //FIXME: for now we simply enumerate from 0 .. EffectFactory::AvailableEffectsCount() here, in future we should use unique IDs for effects during the whole sampler session. This issue comes into game when the user forces a reload of available effect plugins + int n = EffectFactory::AvailableEffectsCount(); + for (int i = 0; i < n; i++) { + if (i) list += ","; + list += ToString(i); + } + } + catch (Exception e) { + result.Error(e); + } + result.Add(list); + return result.Produce(); +} + +String LSCPServer::GetEffectInfo(int iEffectIndex) { + dmsg(2,("LSCPServer: GetEffectInfo(%d)\n", iEffectIndex)); + LSCPResultSet result; + try { + EffectInfo* pEffectInfo = EffectFactory::GetEffectInfo(iEffectIndex); + if (!pEffectInfo) + throw Exception("There is no effect with index " + ToString(iEffectIndex)); + + // convert the filename into the correct encoding as defined for LSCP + // (especially in terms of special characters -> escape sequences) +#if WIN32 + const String dllFileName = Path::fromWindows(pEffectInfo->Module()).toLscp(); +#else + // assuming POSIX + const String dllFileName = Path::fromPosix(pEffectInfo->Module()).toLscp(); +#endif + + result.Add("SYSTEM", pEffectInfo->EffectSystem()); + result.Add("MODULE", dllFileName); + result.Add("NAME", _escapeLscpResponse(pEffectInfo->Name())); + result.Add("DESCRIPTION", _escapeLscpResponse(pEffectInfo->Description())); + } + catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::GetEffectInstanceInfo(int iEffectInstance) { + dmsg(2,("LSCPServer: GetEffectInstanceInfo(%d)\n", iEffectInstance)); + LSCPResultSet result; + try { + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with ID " + ToString(iEffectInstance)); + + EffectInfo* pEffectInfo = pEffect->GetEffectInfo(); + + // convert the filename into the correct encoding as defined for LSCP + // (especially in terms of special characters -> escape sequences) +#if WIN32 + const String dllFileName = Path::fromWindows(pEffectInfo->Module()).toLscp(); +#else + // assuming POSIX + const String dllFileName = Path::fromPosix(pEffectInfo->Module()).toLscp(); +#endif + + result.Add("SYSTEM", pEffectInfo->EffectSystem()); + result.Add("MODULE", dllFileName); + result.Add("NAME", _escapeLscpResponse(pEffectInfo->Name())); + result.Add("DESCRIPTION", _escapeLscpResponse(pEffectInfo->Description())); + result.Add("INPUT_CONTROLS", ToString(pEffect->InputControlCount())); + } + catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::GetEffectInstanceInputControlInfo(int iEffectInstance, int iInputControlIndex) { + dmsg(2,("LSCPServer: GetEffectInstanceInputControlInfo(%d,%d)\n", iEffectInstance, iInputControlIndex)); + LSCPResultSet result; + try { + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with ID " + ToString(iEffectInstance)); + + EffectControl* pEffectControl = pEffect->InputControl(iInputControlIndex); + if (!pEffectControl) + throw Exception( + "Effect instance " + ToString(iEffectInstance) + + " does not have an input control with index " + + ToString(iInputControlIndex) + ); + + result.Add("DESCRIPTION", _escapeLscpResponse(pEffectControl->Description())); + result.Add("VALUE", pEffectControl->Value()); + if (pEffectControl->MinValue()) + result.Add("RANGE_MIN", *pEffectControl->MinValue()); + if (pEffectControl->MaxValue()) + result.Add("RANGE_MAX", *pEffectControl->MaxValue()); + if (!pEffectControl->Possibilities().empty()) + result.Add("POSSIBILITIES", pEffectControl->Possibilities()); + if (pEffectControl->DefaultValue()) + result.Add("DEFAULT", *pEffectControl->DefaultValue()); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::SetEffectInstanceInputControlValue(int iEffectInstance, int iInputControlIndex, double dValue) { + dmsg(2,("LSCPServer: SetEffectInstanceInputControlValue(%d,%d,%f)\n", iEffectInstance, iInputControlIndex, dValue)); + LSCPResultSet result; + try { + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with ID " + ToString(iEffectInstance)); + + EffectControl* pEffectControl = pEffect->InputControl(iInputControlIndex); + if (!pEffectControl) + throw Exception( + "Effect instance " + ToString(iEffectInstance) + + " does not have an input control with index " + + ToString(iInputControlIndex) + ); + + pEffectControl->SetValue(dValue); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_fx_instance_info, iEffectInstance)); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::CreateEffectInstance(int iEffectIndex) { + dmsg(2,("LSCPServer: CreateEffectInstance(%d)\n", iEffectIndex)); + LSCPResultSet result; + try { + EffectInfo* pEffectInfo = EffectFactory::GetEffectInfo(iEffectIndex); + if (!pEffectInfo) + throw Exception("There is no effect with index " + ToString(iEffectIndex)); + Effect* pEffect = EffectFactory::Create(pEffectInfo); + result = pEffect->ID(); // success + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_fx_instance_count, EffectFactory::EffectInstancesCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::CreateEffectInstance(String effectSystem, String module, String effectName) { + dmsg(2,("LSCPServer: CreateEffectInstance('%s','%s','%s')\n", effectSystem.c_str(), module.c_str(), effectName.c_str())); + LSCPResultSet result; + try { + // to allow loading the same LSCP session file on different systems + // successfully, probably with different effect plugin DLL paths or even + // running completely different operating systems, we do the following + // for finding the right effect: + // + // first try to search for an exact match of the effect plugin DLL + // (a.k.a 'module'), to avoid picking the wrong DLL with the same + // effect name ... + EffectInfo* pEffectInfo = EffectFactory::GetEffectInfo(effectSystem, module, effectName, EffectFactory::MODULE_MATCH_EXACTLY); + // ... if no effect with exactly matchin DLL filename was found, then + // try to lower the restrictions of matching the effect plugin DLL + // filename and try again and again ... + if (!pEffectInfo) { + dmsg(2,("no exact module match, trying MODULE_IGNORE_PATH\n")); + pEffectInfo = EffectFactory::GetEffectInfo(effectSystem, module, effectName, EffectFactory::MODULE_IGNORE_PATH); + } + if (!pEffectInfo) { + dmsg(2,("no module match, trying MODULE_IGNORE_PATH | MODULE_IGNORE_CASE\n")); + pEffectInfo = EffectFactory::GetEffectInfo(effectSystem, module, effectName, EffectFactory::MODULE_IGNORE_PATH | EffectFactory::MODULE_IGNORE_CASE); + } + if (!pEffectInfo) { + dmsg(2,("no module match, trying MODULE_IGNORE_PATH | MODULE_IGNORE_CASE | MODULE_IGNORE_EXTENSION\n")); + pEffectInfo = EffectFactory::GetEffectInfo(effectSystem, module, effectName, EffectFactory::MODULE_IGNORE_PATH | EffectFactory::MODULE_IGNORE_CASE | EffectFactory::MODULE_IGNORE_EXTENSION); + } + // ... if there was still no effect found, then completely ignore the + // DLL plugin filename argument and just search for the matching effect + // system type and effect name + if (!pEffectInfo) { + dmsg(2,("no module match, trying MODULE_IGNORE_ALL\n")); + pEffectInfo = EffectFactory::GetEffectInfo(effectSystem, module, effectName, EffectFactory::MODULE_IGNORE_ALL); + } + if (!pEffectInfo) + throw Exception("There is no such effect '" + effectSystem + "' '" + module + "' '" + effectName + "'"); + + Effect* pEffect = EffectFactory::Create(pEffectInfo); + result = LSCPResultSet(pEffect->ID()); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_fx_instance_count, EffectFactory::EffectInstancesCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::DestroyEffectInstance(int iEffectInstance) { + dmsg(2,("LSCPServer: DestroyEffectInstance(%d)\n", iEffectInstance)); + LSCPResultSet result; + try { + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with ID " + ToString(iEffectInstance)); + EffectFactory::Destroy(pEffect); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_fx_instance_count, EffectFactory::EffectInstancesCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::GetEffectInstances() { + dmsg(2,("LSCPServer: GetEffectInstances()\n")); + LSCPResultSet result; + try { + int n = EffectFactory::EffectInstancesCount(); + result.Add(n); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::ListEffectInstances() { + dmsg(2,("LSCPServer: ListEffectInstances()\n")); + LSCPResultSet result; + String list; + try { + int n = EffectFactory::EffectInstancesCount(); + for (int i = 0; i < n; i++) { + Effect* pEffect = EffectFactory::GetEffectInstance(i); + if (i) list += ","; + list += ToString(pEffect->ID()); + } + } catch (Exception e) { + result.Error(e); + } + result.Add(list); + return result.Produce(); +} + +String LSCPServer::GetSendEffectChains(int iAudioOutputDevice) { + dmsg(2,("LSCPServer: GetSendEffectChains(%d)\n", iAudioOutputDevice)); + LSCPResultSet result; + try { + std::map<uint,AudioOutputDevice*> devices = pSampler->GetAudioOutputDevices(); + if (!devices.count(iAudioOutputDevice)) + throw Exception("There is no audio output device with index " + ToString(iAudioOutputDevice) + "."); + AudioOutputDevice* pDevice = devicesiAudioOutputDevice; + int n = pDevice->SendEffectChainCount(); + result.Add(n); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::ListSendEffectChains(int iAudioOutputDevice) { + dmsg(2,("LSCPServer: ListSendEffectChains(%d)\n", iAudioOutputDevice)); + LSCPResultSet result; + String list; + try { + std::map<uint,AudioOutputDevice*> devices = pSampler->GetAudioOutputDevices(); + if (!devices.count(iAudioOutputDevice)) + throw Exception("There is no audio output device with index " + ToString(iAudioOutputDevice) + "."); + AudioOutputDevice* pDevice = devicesiAudioOutputDevice; + int n = pDevice->SendEffectChainCount(); + for (int i = 0; i < n; i++) { + EffectChain* pEffectChain = pDevice->SendEffectChain(i); + if (i) list += ","; + list += ToString(pEffectChain->ID()); + } + } catch (Exception e) { + result.Error(e); + } + result.Add(list); + return result.Produce(); +} + +String LSCPServer::AddSendEffectChain(int iAudioOutputDevice) { + dmsg(2,("LSCPServer: AddSendEffectChain(%d)\n", iAudioOutputDevice)); + LSCPResultSet result; + try { + std::map<uint,AudioOutputDevice*> devices = pSampler->GetAudioOutputDevices(); + if (!devices.count(iAudioOutputDevice)) + throw Exception("There is no audio output device with index " + ToString(iAudioOutputDevice) + "."); + AudioOutputDevice* pDevice = devicesiAudioOutputDevice; + EffectChain* pEffectChain = pDevice->AddSendEffectChain(); + result = pEffectChain->ID(); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_send_fx_chain_count, iAudioOutputDevice, pDevice->SendEffectChainCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::RemoveSendEffectChain(int iAudioOutputDevice, int iSendEffectChain) { + dmsg(2,("LSCPServer: RemoveSendEffectChain(%d,%d)\n", iAudioOutputDevice, iSendEffectChain)); + LSCPResultSet result; + try { + std::map<uint,AudioOutputDevice*> devices = pSampler->GetAudioOutputDevices(); + if (!devices.count(iAudioOutputDevice)) + throw Exception("There is no audio output device with index " + ToString(iAudioOutputDevice) + "."); + + std::set<EngineChannel*> engineChannels = EngineChannelFactory::EngineChannelInstances(); + std::set<EngineChannel*>::iterator itEngineChannel = engineChannels.begin(); + std::set<EngineChannel*>::iterator itEnd = engineChannels.end(); + for (; itEngineChannel != itEnd; ++itEngineChannel) { + AudioOutputDevice* pDev = (*itEngineChannel)->GetAudioOutputDevice(); + if (pDev != NULL && pDev->deviceId() == iAudioOutputDevice) { + for (int i = 0; i < (*itEngineChannel)->GetFxSendCount(); i++) { + FxSend* fxs = (*itEngineChannel)->GetFxSend(i); + if(fxs != NULL && fxs->DestinationEffectChain() == iSendEffectChain) { + throw Exception("The effect chain is still in use by channel " + ToString((*itEngineChannel)->GetSamplerChannel()->Index())); + } + } + } + } + + AudioOutputDevice* pDevice = devicesiAudioOutputDevice; + for (int i = 0; i < pDevice->SendEffectChainCount(); i++) { + EffectChain* pEffectChain = pDevice->SendEffectChain(i); + if (pEffectChain->ID() == iSendEffectChain) { + pDevice->RemoveSendEffectChain(i); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_send_fx_chain_count, iAudioOutputDevice, pDevice->SendEffectChainCount())); + return result.Produce(); + } + } + throw Exception( + "There is no send effect chain with ID " + + ToString(iSendEffectChain) + " for audio output device " + + ToString(iAudioOutputDevice) + "." + ); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +static EffectChain* _getSendEffectChain(Sampler* pSampler, int iAudioOutputDevice, int iSendEffectChain) throw (Exception) { + std::map<uint,AudioOutputDevice*> devices = pSampler->GetAudioOutputDevices(); + if (!devices.count(iAudioOutputDevice)) + throw Exception( + "There is no audio output device with index " + + ToString(iAudioOutputDevice) + "." + ); + AudioOutputDevice* pDevice = devicesiAudioOutputDevice; + EffectChain* pEffectChain = pDevice->SendEffectChainByID(iSendEffectChain); + if(pEffectChain != NULL) return pEffectChain; + throw Exception( + "There is no send effect chain with ID " + + ToString(iSendEffectChain) + " for audio output device " + + ToString(iAudioOutputDevice) + "." + ); +} + +String LSCPServer::GetSendEffectChainInfo(int iAudioOutputDevice, int iSendEffectChain) { + dmsg(2,("LSCPServer: GetSendEffectChainInfo(%d,%d)\n", iAudioOutputDevice, iSendEffectChain)); + LSCPResultSet result; + try { + EffectChain* pEffectChain = + _getSendEffectChain(pSampler, iAudioOutputDevice, iSendEffectChain); + String sEffectSequence; + for (int i = 0; i < pEffectChain->EffectCount(); i++) { + if (i) sEffectSequence += ","; + sEffectSequence += ToString(pEffectChain->GetEffect(i)->ID()); + } + result.Add("EFFECT_COUNT", pEffectChain->EffectCount()); + result.Add("EFFECT_SEQUENCE", sEffectSequence); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::AppendSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectInstance) { + dmsg(2,("LSCPServer: AppendSendEffectChainEffect(%d,%d,%d)\n", iAudioOutputDevice, iSendEffectChain, iEffectInstance)); + LSCPResultSet result; + try { + EffectChain* pEffectChain = + _getSendEffectChain(pSampler, iAudioOutputDevice, iSendEffectChain); + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with ID " + ToString(iEffectInstance)); + pEffectChain->AppendEffect(pEffect); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_send_fx_chain_info, iAudioOutputDevice, iSendEffectChain, pEffectChain->EffectCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::InsertSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectChainPosition, int iEffectInstance) { + dmsg(2,("LSCPServer: InsertSendEffectChainEffect(%d,%d,%d,%d)\n", iAudioOutputDevice, iSendEffectChain, iEffectChainPosition, iEffectInstance)); + LSCPResultSet result; + try { + EffectChain* pEffectChain = + _getSendEffectChain(pSampler, iAudioOutputDevice, iSendEffectChain); + Effect* pEffect = EffectFactory::GetEffectInstanceByID(iEffectInstance); + if (!pEffect) + throw Exception("There is no effect instance with index " + ToString(iEffectInstance)); + pEffectChain->InsertEffect(pEffect, iEffectChainPosition); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_send_fx_chain_info, iAudioOutputDevice, iSendEffectChain, pEffectChain->EffectCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + +String LSCPServer::RemoveSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectChainPosition) { + dmsg(2,("LSCPServer: RemoveSendEffectChainEffect(%d,%d,%d)\n", iAudioOutputDevice, iSendEffectChain, iEffectChainPosition)); + LSCPResultSet result; + try { + EffectChain* pEffectChain = + _getSendEffectChain(pSampler, iAudioOutputDevice, iSendEffectChain); + + std::set<EngineChannel*> engineChannels = EngineChannelFactory::EngineChannelInstances(); + std::set<EngineChannel*>::iterator itEngineChannel = engineChannels.begin(); + std::set<EngineChannel*>::iterator itEnd = engineChannels.end(); + for (; itEngineChannel != itEnd; ++itEngineChannel) { + AudioOutputDevice* pDev = (*itEngineChannel)->GetAudioOutputDevice(); + if (pDev != NULL && pDev->deviceId() == iAudioOutputDevice) { + for (int i = 0; i < (*itEngineChannel)->GetFxSendCount(); i++) { + FxSend* fxs = (*itEngineChannel)->GetFxSend(i); + if(fxs != NULL && fxs->DestinationEffectChain() == iSendEffectChain && fxs->DestinationEffectChainPosition() == iEffectChainPosition) { + throw Exception("The effect instance is still in use by channel " + ToString((*itEngineChannel)->GetSamplerChannel()->Index())); + } + } + } + } + + pEffectChain->RemoveEffect(iEffectChainPosition); + LSCPServer::SendLSCPNotify(LSCPEvent(LSCPEvent::event_send_fx_chain_info, iAudioOutputDevice, iSendEffectChain, pEffectChain->EffectCount())); + } catch (Exception e) { + result.Error(e); + } + return result.Produce(); +} + String LSCPServer::EditSamplerChannelInstrument(uint uiSamplerChannel) { dmsg(2,("LSCPServer: EditSamplerChannelInstrument(SamplerChannel=%d)\n", uiSamplerChannel)); LSCPResultSet result; @@ -2497,6 +2977,10 @@ pMidiDevice->SendNoteOffToDevice(Arg1, Arg2); bool b = pMidiDevice->SendNoteOffToSampler(Arg1, Arg2); if (!b) throw Exception("MIDI event failed: " + MidiMsg + " " + ToString(Arg1) + " " + ToString(Arg2)); + } else if (MidiMsg == "CC") { + pMidiDevice->SendCCToDevice(Arg1, Arg2); + bool b = pMidiDevice->SendCCToSampler(Arg1, Arg2); + if (!b) throw Exception("MIDI event failed: " + MidiMsg + " " + ToString(Arg1) + " " + ToString(Arg2)); } else { throw Exception("Unknown MIDI message type: " + MidiMsg); }
View file
linuxsampler-1.0.0.tar.bz2/src/network/lscpserver.h -> linuxsampler-2342.tar.bz2/src/network/lscpserver.h
Changed
@@ -166,6 +166,29 @@ String SetFxSendAudioOutputChannel(uint uiSamplerChannel, uint FxSendID, uint FxSendChannel, uint DeviceChannel); String SetFxSendMidiController(uint uiSamplerChannel, uint FxSendID, uint MidiController); String SetFxSendLevel(uint uiSamplerChannel, uint FxSendID, double dLevel); + String SetFxSendEffect(uint uiSamplerChannel, uint FxSendID, int iSendEffectChain, int iEffectChainPosition); + + // effect commands + String GetAvailableEffects(); + String ListAvailableEffects(); + String GetEffectInfo(int iEffectIndex); + String CreateEffectInstance(int iEffectIndex); + String CreateEffectInstance(String effectSystem, String module, String effectName); + String DestroyEffectInstance(int iEffectInstance); + String GetEffectInstances(); + String ListEffectInstances(); + String GetEffectInstanceInfo(int iEffectInstance); + String GetEffectInstanceInputControlInfo(int iEffectInstance, int iInputControlIndex); + String SetEffectInstanceInputControlValue(int iEffectInstance, int iInputControlIndex, double dValue); + String GetSendEffectChains(int iAudioOutputDevice); + String ListSendEffectChains(int iAudioOutputDevice); + String AddSendEffectChain(int iAudioOutputDevice); + String RemoveSendEffectChain(int iAudioOutputDevice, int iSendEffectChain); + String GetSendEffectChainInfo(int iAudioOutputDevice, int iSendEffectChain); + String AppendSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectInstance); + String InsertSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectChainPosition, int iEffectInstance); + String RemoveSendEffectChainEffect(int iAudioOutputDevice, int iSendEffectChain, int iEffectChainPosition); + String AddDbInstrumentDirectory(String Dir); String RemoveDbInstrumentDirectory(String Dir, bool Force = false); String GetDbInstrumentDirectoryCount(String Dir, bool Recursive = false);
View file
linuxsampler-1.0.0.tar.bz2/src/plugins/InstrumentEditorFactory.cpp -> linuxsampler-2342.tar.bz2/src/plugins/InstrumentEditorFactory.cpp
Changed
@@ -1,6 +1,6 @@ /*************************************************************************** * * - * Copyright (C) 2007 - 2009 Christian Schoenebeck * + * Copyright (C) 2007 - 2010 Christian Schoenebeck * * * * 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 * @@ -101,13 +101,20 @@ void InstrumentEditorFactory::LoadPlugins() { if (!bPluginsLoaded) { dmsg(1,("Loading instrument editor plugins...")); + // getenv() is available on Posix and Windows + char* pcPluginDir = getenv("LINUXSAMPLER_PLUGIN_DIR"); #if defined(WIN32) - String dir = Sampler::GetInstallDir(); + String installDir = Sampler::GetInstallDir(); + String pluginDir; + if (pcPluginDir) + pluginDir = pcPluginDir; + if (pluginDir.empty()) + pluginDir = installDir + "\\plugins"; // Put the LS installation directory first in DLL search // path, so the plugin finds for example the bundled GTK // libraries before any other installed versions - if (!dir.empty()) { + if (!installDir.empty()) { // The SetDllDirectory function is only available on // XP and higher, so we call it dynamically HMODULE k32 = GetModuleHandleA("kernel32.dll"); @@ -115,24 +122,29 @@ BOOL WINAPI (*setDllDirectory)(LPCSTR) = (BOOL WINAPI (*)(LPCSTR))GetProcAddress(k32, "SetDllDirectoryA"); if (setDllDirectory) { - setDllDirectory(dir.c_str()); + setDllDirectory(installDir.c_str()); } } } - if (dir.empty() || !LoadPlugins(dir + "\\plugins")) { + if (pluginDir.empty() || !LoadPlugins(pluginDir)) { if (!LoadPlugins(CONFIG_PLUGIN_DIR)) { std::cerr << "Could not open instrument editor plugins " - << "directory (" << dir << "\\plugins or " - << CONFIG_PLUGIN_DIR << "), Error: " + << "directory ('" << pluginDir << "' or '" + << CONFIG_PLUGIN_DIR << "'), Error: " << GetLastError() << std::endl; return; } } #else - if (!LoadPlugins(CONFIG_PLUGIN_DIR)) { + String dir; + if (pcPluginDir) + dir = pcPluginDir; + if (dir.empty()) + dir = CONFIG_PLUGIN_DIR; + if (!LoadPlugins(dir)) { std::cerr << "Could not open instrument editor plugins " - << "directory (" << CONFIG_PLUGIN_DIR << "): " + << "directory ('" << dir << "'): " << strerror(errno) << std::endl; return; }
View file
linuxsampler-2342.tar.bz2/templates
Added
+(directory)
View file
linuxsampler-2342.tar.bz2/templates/cpp
Added
@@ -0,0 +1,21 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/
View file
linuxsampler-2342.tar.bz2/templates/h
Added
@@ -0,0 +1,21 @@ +/*************************************************************************** + * * + * LinuxSampler - modular, streaming capable sampler * + * * + * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck * + * * + * This program is free software; you can redistribute it and/or modify * + * it under the terms of the GNU General Public License as published by * + * the Free Software Foundation; either version 2 of the License, or * + * (at your option) any later version. * + * * + * This program is distributed in the hope that it will be useful, * + * but WITHOUT ANY WARRANTY; without even the implied warranty of * + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * + * GNU General Public License for more details. * + * * + * You should have received a copy of the GNU General Public License * + * along with this program; if not, write to the Free Software * + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * + * MA 02111-1307 USA * + ***************************************************************************/
Locations
Projects
Search
Status Monitor
Help
Open Build Service
OBS Manuals
API Documentation
OBS Portal
Reporting a Bug
Contact
Mailing List
Forums
Chat (IRC)
Twitter
Open Build Service (OBS)
is an
openSUSE project
.