$(monodir)/mono/metadata/libmonoruntime.la \
$(monodir)/mono/io-layer/libwapi.la \
$(monodir)/mono/utils/libmonoutils.la \
- $(GMODULE_LIBS) \
$(GLIB_LIBS) \
- $(libgc_libs) \
- $(ICU_LIBS)
+ $(libgc_libs)
static_libs= \
$(monodir)/mono/metadata/libmonoruntime-static.la \
$(monodir)/mono/io-layer/libwapi.la \
$(monodir)/mono/utils/libmonoutils.la \
- $(GMODULE_LIBS) \
$(GLIB_LIBS) \
- $(libgc_static_libs) \
- $(ICU_LIBS)
+ $(libgc_static_libs)
-CLASS1=$(mcs_topdir)/class/lib/default
-CLASS2=$(mcs_topdir)/class/lib/net_2_0
+CLASS=$(mcs_topdir)/class/lib/net_2_0
-RUNTIME = MONO_PATH=$(CLASS1) $(top_builddir)/runtime/mono-wrapper
-RUNTIME2 = MONO_PATH=$(CLASS2) $(top_builddir)/runtime/mono-wrapper
-
-MCS = $(RUNTIME) $(CLASS1)/mcs.exe -unsafe -nowarn:0162
-GMCS = $(RUNTIME2) $(CLASS2)/gmcs.exe -unsafe -nowarn:0162
-ILASM = $(RUNTIME) $(CLASS1)/ilasm.exe
+RUNTIME = MONO_PATH=$(CLASS) $(top_builddir)/runtime/mono-wrapper
+RUNTIME_AOTCHECK = MONO_PATH=$(CLASS):. $(top_builddir)/runtime/mono-wrapper
+MCS = $(RUNTIME) $(CLASS)/gmcs.exe -unsafe -nowarn:0162
+ILASM = $(RUNTIME) $(CLASS)/ilasm.exe
AM_CFLAGS = \
-I$(top_srcdir) \
$(LIBGC_CFLAGS) \
- $(GMODULE_CFLAGS) \
$(GLIB_CFLAGS)
$(PLATFORM_CFLAGS) $(ARCH_CFLAGS)
PLATFORM_CFLAGS = -O
endif
-PLATFORM_LIB = ../os/libmonoos.la
-
# hack for automake to have the same source file in a library and a bin
genmdesc_CFLAGS = $(AM_CFLAGS)
if NO_VERSION_SCRIPT
-monoldflags=
-monobinldflags=
+monoldflags=$(export_ldflags)
+monobinldflags=$(export_ldflags)
else
-monoldflags=-Wl,-version-script=$(srcdir)/ldscript
-monobinldflags=-Wl,-version-script=$(srcdir)/ldscript.mono
+monoldflags=-Wl,-version-script=$(srcdir)/ldscript $(export_ldflags)
+monobinldflags=-Wl,-version-script=$(srcdir)/ldscript.mono $(export_ldflags)
endif
if PLATFORM_WIN32
-libmono_la_LDFLAGS=-no-undefined -version-info 1:0:0 $(monoldflags)
+libmono_la_LDFLAGS=-no-undefined -avoid-version -Wl,--kill-at $(monoldflags)
else
libmono_la_LDFLAGS=$(monoldflags)
endif
if JIT_SUPPORTED
+
+if PLATFORM_WIN32
+bin_PROGRAMS = mono monow
+else
bin_PROGRAMS = mono
+endif
noinst_PROGRAMS = genmdesc
mono_SOURCES = \
main.c
+# We build this after libmono was built so it contains the date when the final
+# link was done
+buildver.h: libmono-static.la
+ @echo "const char *build_date = \"`date`\";" > buildver.h
+
+main.$(OBJEXT): buildver.h
+
+if DTRACE_G_REQUIRED
+LIBMONO_DTRACE_OBJECT = .libs/mono-dtrace.$(OBJEXT)
+if STATIC_MONO
+MONO_DTRACE_OBJECT = mono-dtrace.$(OBJEXT)
+else
+MONO_DTRACE_OBJECT =
+endif
+else
+MONO_DTRACE_OBJECT =
+LIBMONO_DTRACE_OBJECT =
+endif
+
if STATIC_MONO
# Link libmono into mono statically
# This leads to higher performance, especially with TLS
mono_LDADD = \
$(MONO_LIB) \
- $(PLATFORM_LIB) \
$(GLIB_LIBS) \
- $(GMODULE_LIBS) -lm \
- $(ICU_LIBS)
+ -lm \
+ $(MONO_DTRACE_OBJECT)
mono_LDFLAGS = \
$(static_flags) -export-dynamic $(monobinldflags)
+if DTRACE_G_REQUIRED
+
+mono-dtrace.$(OBJEXT): $(top_srcdir)/data/mono.d mini.lo $(monodir)/mono/metadata/libmonoruntime-static.la
+ DTRACE="$(DTRACE)" DTRACEFLAGS="$(DTRACEFLAGS)" AR="$(AR)" $(SHELL) $(top_srcdir)/dtrace-prelink.sh \
+ $@ $(top_srcdir)/data/mono.d $(monodir)/mono/metadata/libmonoruntime-static.la mini.lo
+
+.libs/mono-dtrace.$(OBJEXT): $(top_srcdir)/data/mono.d mini.lo $(monodir)/mono/metadata/libmonoruntime.la
+ DTRACE="$(DTRACE)" DTRACEFLAGS="$(DTRACEFLAGS)" AR="$(AR)" $(SHELL) $(top_srcdir)/dtrace-prelink.sh \
+ --pic $@ $(top_srcdir)/data/mono.d $(monodir)/mono/metadata/libmonoruntime.la mini.lo
+
+endif
+
+# Create monow.exe, linked for the 'windows' subsystem
+if PLATFORM_WIN32
+monow_LDADD = $(mono_LDADD)
+monow_LDFLAGS = $(mono_LDFLAGS) -mwindows
+monow_SOURCES = $(mono_SOURCES)
+endif
+
genmdesc_SOURCES = \
mini.h \
genmdesc.c \
# Don't link this against libmonoruntime to speed up rebuilds
genmdesc_LDADD = \
$(monodir)/mono/utils/libmonoutils.la $(monodir)/mono/metadata/opcodes.lo -lm \
- $(PLATFORM_LIB) \
- $(GLIB_LIBS) \
- $(GMODULE_LIBS)
+ $(GLIB_LIBS)
x86_sources = \
mini-x86.c \
mini-x86.h \
exceptions-x86.c \
- tramp-x86.c \
- mini-codegen.c \
- mini-trampolines.c
+ tramp-x86.c
amd64_sources = \
mini-amd64.c \
mini-amd64.h \
exceptions-amd64.c \
- tramp-amd64.c \
- mini-codegen.c \
- mini-trampolines.c
+ tramp-amd64.c
ppc_sources = \
mini-ppc.c \
exceptions-ppc.c \
tramp-ppc.c
+ppc64_sources = \
+ mini-ppc64.c \
+ mini-ppc.h \
+ exceptions-ppc.c \
+ tramp-ppc.c
+
arm_sources = \
mini-arm.c \
mini-arm.h \
exceptions-arm.c \
- tramp-arm.c \
- mini-codegen.c
+ tramp-arm.c
+
+mips_sources = \
+ mini-mips.c \
+ mini-mips.h \
+ exceptions-mips.c \
+ tramp-mips.c
sparc_sources = \
mini-sparc.c \
mini-sparc.h \
exceptions-sparc.c \
- tramp-sparc.c \
- mini-codegen.c \
- mini-trampolines.c
+ tramp-sparc.c
s390_sources = \
mini-s390.c \
mini-s390.h \
exceptions-s390.c \
- mini-codegen.c \
tramp-s390.c
s390x_sources = \
mini-s390x.c \
mini-s390x.h \
exceptions-s390x.c \
- mini-codegen.c \
tramp-s390x.c
ia64_sources = \
mini-ia64.c \
mini-ia64.h \
exceptions-ia64.c \
- tramp-ia64.c \
- mini-codegen.c \
- mini-trampolines.c
+ tramp-ia64.c
+
+alpha_sources = \
+ mini-alpha.c \
+ mini-alpha.h \
+ exceptions-alpha.c \
+ tramp-alpha.c
+
+hppa_sources = \
+ mini-hppa.c \
+ mini-hppa.h \
+ exceptions-hppa.c \
+ tramp-hppa.c
common_sources = \
mini.c \
+ ir-emit.h \
+ method-to-ir.c \
+ decompose.c \
mini.h \
+ version.h \
+ optflags-def.h \
+ jit-icalls.h \
+ jit-icalls.c \
trace.c \
trace.h \
+ patch-info.h \
mini-ops.h \
mini-arch.h \
dominators.c \
abcremoval.h \
ssapre.c \
ssapre.h \
- aliasing.c \
- aliasing.h \
- ssapre-cee-ops.h \
- ssapre-mini-ops.h \
+ local-propagation.c \
driver.c \
debug-mini.c \
+ debug-mini.h \
linear-scan.c \
- aot.c \
+ aot-compiler.c \
+ aot-runtime.c \
graph.c \
mini-exceptions.c \
+ mini-codegen.c \
+ mini-trampolines.c \
declsec.c \
declsec.h \
- branch-opts.c
+ wapihandles.c \
+ branch-opts.c \
+ generic-sharing.c \
+ regalloc2.c \
+ simd-methods.h \
+ simd-intrinsics.c \
+ unwind.h \
+ unwind.c
test_sources = \
basic-calls.cs \
basic-math.cs \
basic.cs \
exceptions.cs \
- iltests.il \
- test.cs
-
-test_sources2 = generics.2.cs
+ devirtualization.cs \
+ iltests.il.in \
+ test.cs \
+ generics.cs \
+ generics-variant-types.il \
+ basic-simd.cs
if MONO_DEBUGGER_SUPPORTED
-mono_debugger_sources = debug-debugger.c
+if AMD64
+mono_debugger_arch_sources = mdb-debug-info64.s
+else
+if X86
+mono_debugger_arch_sources = mdb-debug-info32.s
+endif
+endif
+mono_debugger_sources = debug-debugger.c debug-debugger.h $(mono_debugger_arch_sources)
else
mono_debugger_sources =
endif
-regtests=basic.exe arrays.exe basic-float.exe basic-math.exe basic-long.exe objects.exe basic-calls.exe iltests.exe exceptions.exe bench.exe
-regtests2=generics.exe
-common_BURGSRC= $(srcdir)/inssel.brg $(srcdir)/inssel-float.brg
+regtests=basic.exe basic-float.exe basic-long.exe basic-calls.exe objects.exe arrays.exe basic-math.exe exceptions.exe iltests.exe devirtualization.exe generics.exe basic-simd.exe
if X86
-libmono_la_SOURCES = \
- $(common_sources) $(x86_sources) $(mono_debugger_sources)
-
-arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-x86.brg
-arch_built=cpu-pentium.h
+arch_sources = $(x86_sources) $(mono_debugger_sources)
+arch_built=cpu-x86.h
+arch_define=__i386__
endif
if AMD64
-libmono_la_SOURCES = \
- $(common_sources) $(amd64_sources) $(mono_debugger_sources)
-arch_BURGSRC= $(srcdir)/inssel-long.brg $(srcdir)/inssel-amd64.brg
+arch_sources = $(amd64_sources) $(mono_debugger_sources)
arch_built=cpu-amd64.h
+arch_define=__x86_64__
endif
if POWERPC
-libmono_la_SOURCES = \
- $(common_sources) $(ppc_sources)
+arch_sources = $(ppc_sources)
+arch_built=cpu-ppc.h
+arch_define=__ppc__
+endif
-arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-ppc.brg
-arch_built=cpu-g4.h
+if POWERPC64
+arch_sources = $(ppc64_sources)
+arch_built=cpu-ppc64.h
+arch_define=__ppc64__
endif
-if ARM
+if MIPS
+arch_sources = $(mips_sources)
+arch_built=cpu-mips.h
+arch_define=__mips__
+endif
+if ARM
# pick up arm_dpimacros.h and arm_fpamacros.h
ARCH_CFLAGS = -I../arch/arm
-
-libmono_la_SOURCES = \
- $(common_sources) $(arm_sources)
-
-arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-arm.brg
+arch_sources = $(arm_sources)
arch_built=cpu-arm.h
+arch_define=__arm__
endif
if SPARC
-libmono_la_SOURCES = \
- $(common_sources) $(sparc_sources)
-
-arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-sparc.brg
+arch_sources = $(sparc_sources)
arch_built=cpu-sparc.h
+arch_define=__sparc__
endif
if SPARC64
-libmono_la_SOURCES = \
- $(common_sources) $(sparc_sources)
-
-arch_BURGSRC= $(srcdir)/inssel-long.brg $(srcdir)/inssel-sparc.brg
+arch_sources = $(sparc_sources)
arch_built=cpu-sparc.h
+arch_define=__sparc__
endif
if S390
-libmono_la_SOURCES = \
- $(common_sources) $(s390_sources)
-
+arch_sources = $(s390_sources)
arch_BURGSRC= $(srcdir)/inssel-long32.brg $(srcdir)/inssel-s390.brg
arch_built=cpu-s390.h
+arch_define=__s390__
endif
if S390x
-libmono_la_SOURCES = \
- $(common_sources) $(s390x_sources)
-
-arch_BURGSRC= $(srcdir)/inssel-long.brg $(srcdir)/inssel-s390x.brg
+arch_sources = $(s390x_sources)
arch_built=cpu-s390x.h
+arch_define=__s390__
endif
if IA64
-libmono_la_SOURCES = \
- $(common_sources) $(ia64_sources)
-
-arch_BURGSRC = $(srcdir)/inssel-long.brg $(srcdir)/inssel-ia64.brg
+arch_sources = $(ia64_sources)
arch_built = cpu-ia64.h
+arch_define=__ia64__
+endif
+
+if ALPHA
+arch_sources = $(alpha_sources) $(mono_debugger_sources)
+arch_built = cpu-alpha.h
+arch_define=__alpha__
+endif
+
+if HPPA
+# Only support 32-bit targets for now
+arch_sources = $(hppa_sources)
+arch_built = cpu-hppa.h
+arch_define=__hppa__
endif
-nodist_libmono_la_SOURCES = inssel.c inssel.h
+libmono_la_SOURCES = $(common_sources) $(arch_sources)
libmono_static_la_SOURCES = $(libmono_la_SOURCES)
nodist_libmono_static_la_SOURCES = $(nodist_libmono_la_SOURCES)
libmono_static_la_LDFLAGS = -static
-libmono_static_la_LIBADD = $(static_libs) $(PLATFORM_LIB)
+libmono_static_la_LIBADD = $(static_libs) $(MONO_DTRACE_OBJECT)
BURGSRC= $(common_BURGSRC) $(arch_BURGSRC)
-libmonoincludedir = $(includedir)/mono/jit
+libmonoincludedir = $(includedir)/mono-$(API_VER)/mono/jit
libmonoinclude_HEADERS = jit.h
libmono_la_LIBADD = \
- $(libs) \
- $(PLATFORM_LIB)
+ $(libs) $(LIBMONO_DTRACE_OBJECT)
-%.exe: %.2.cs TestDriver.dll
- $(GMCS) -out:$@ $< -r:TestDriver.dll
+basic-simd.exe: basic-simd.cs
+ $(MCS) -out:$@ $< -r:TestDriver.dll -r:Mono.Simd.dll
+
+generics.exe: generics.cs TestDriver.dll generics-variant-types.dll
+ $(MCS) -out:$@ $< -r:TestDriver.dll -r:generics-variant-types.dll
%.exe: %.cs TestDriver.dll
$(MCS) -out:$@ -unsafe $< -r:TestDriver.dll
+iltests.il: iltests.il.in Makefile.am
+ echo '// DO NOT EDIT: This file has been generated from iltests.il.in' > iltests.il
+ cpp -Darch=$(arch_define) < $(srcdir)/iltests.il.in | sed 's/^#.*//' >> iltests.il
+
%.exe: %.il
$(ILASM) -output=$@ $<
TestDriver.dll: $(srcdir)/TestDriver.cs
$(MCS) -out:$@ -target:library $<
-if CROSS_COMPILING
-
-cpu-pentium.h: cpu-pentium.md
-cpu-amd64.h: cpu-amd64.md
-cpu-g4.h: cpu-g4.md
-cpu-arm.h: cpu-arm.md
-cpu-sparc.h: cpu-sparc.md
-cpu-s390.h: cpu-s390.md
-cpu-s390x.h: cpu-s390x.md
-cpu-ia64.h: cpu-ia64.md
-
-## Gross hack. Making 'genmdesc' a host binary takes more effort
-$(arch_built):
- echo "*** please build $(arch_built) on a native build tree and copy it here"
- exit 1
+generics-variant-types.dll: generics-variant-types.il
+ $(ILASM) -dll -output=$@ $<
+# we don't always use the perl impl because it's an additional
+# build dependency for the poor windows users
+# $(arch_define) is the preprocessor symbol that enables all the opcodes
+# for the specific platform in mini-ops.h
+if CROSS_COMPILING
+GENMDESC_PRG=perl $(srcdir)/genmdesc.pl $(arch_define) $(srcdir)
else !CROSS_COMPILING
+GENMDESC_PRG=./genmdesc
+endif !CROSS_COMPILING
-cpu-pentium.h: cpu-pentium.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-pentium.md cpu-pentium.h pentium_desc
+cpu-x86.h: cpu-x86.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-x86.md cpu-x86.h x86_desc
cpu-amd64.h: cpu-amd64.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-amd64.md cpu-amd64.h amd64_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-amd64.md cpu-amd64.h amd64_desc
-cpu-g4.h: cpu-g4.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-g4.md cpu-g4.h ppcg4
+cpu-ppc.h: cpu-ppc.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-ppc.md cpu-ppc.h ppcg4
+
+cpu-ppc64.h: cpu-ppc64.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-ppc64.md cpu-ppc64.h ppc64_cpu_desc
cpu-arm.h: cpu-arm.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-arm.md cpu-arm.h arm_cpu_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-arm.md cpu-arm.h arm_cpu_desc
cpu-sparc.h: cpu-sparc.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-sparc.md cpu-sparc.h sparc_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-sparc.md cpu-sparc.h sparc_desc
cpu-s390.h: cpu-s390.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-s390.md cpu-s390.h s390_cpu_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-s390.md cpu-s390.h s390_cpu_desc
cpu-s390x.h: cpu-s390x.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-s390x.md cpu-s390x.h s390x_cpu_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-s390x.md cpu-s390x.h s390x_cpu_desc
cpu-ia64.h: cpu-ia64.md genmdesc$(EXEEXT)
- ./genmdesc $(srcdir)/cpu-ia64.md cpu-ia64.h ia64_desc
+ $(GENMDESC_PRG) $(srcdir)/cpu-ia64.md cpu-ia64.h ia64_desc
-endif !CROSS_COMPILING
+cpu-alpha.h: cpu-alpha.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-alpha.md cpu-alpha.h alpha_desc
-inssel.c inssel.h: $(BURGSRC)
- $(monodir)/mono/monoburg/monoburg -c 1 -p -e $(BURGSRC) -d inssel.h -s inssel.c
+cpu-hppa.h: cpu-hppa.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-hppa.md cpu-hppa.h hppa_desc
+
+cpu-mips.h: cpu-mips.md genmdesc$(EXEEXT)
+ $(GENMDESC_PRG) $(srcdir)/cpu-mips.md cpu-mips.h mips_desc
testi: mono test.exe
$(RUNTIME) -v -v --ncompile 1 --compile Test:$(mtest) test.exe
checktests: $(regtests)
for i in $(regtests); do $(RUNTIME) $$i; done
-checktests2: $(regtests2)
- for i in $(regtests); do $(RUNTIME2) $$i; done
-
-rcheck: mono $(regtests) $(regtests2)
+rcheck: mono $(regtests)
$(RUNTIME) --regression $(regtests)
- $(RUNTIME2) --regression $(regtests2)
aotcheck: mono $(regtests)
- for i in $(regtests); do $(RUNTIME) --aot $$i; done
- for i in $(regtests2); do $(RUNTIME2) --aot $$i; done
- $(RUNTIME) --verbose --regression $(regtests)
- $(RUNTIME2) --verbose --regression $(regtests2)
+ rm -f *.exe.so
+ $(RUNTIME) --aot $(regtests) || exit 1
+ for i in $(regtests); do $(RUNTIME_AOTCHECK) --regression $$i || exit 1; done
rm -f *.exe.so
bench: mono test.exe
check-local: rcheck
clean-local:
- rm -f mono a.out gmon.out *.o test.exe
+ rm -f mono a.out gmon.out *.o buildver.h test.exe
pkgconfigdir = $(libdir)/pkgconfig
if JIT_SUPPORTED
-BUILT_SOURCES= inssel.c inssel.h $(arch_built)
+BUILT_SOURCES = version.h $(arch_built)
+else
+BUILT_SOURCES = version.h
endif
CLEANFILES= $(BUILT_SOURCES) *.exe *.dll
-EXTRA_DIST = $(common_BURGSRC) jit-icalls.c cprop.c TestDriver.cs ldscript ldscript.mono \
- $(test_sources) $(test_sources2) \
- inssel-long.brg inssel-long32.brg \
- $(x86_sources) inssel-x86.brg cpu-pentium.md \
- $(amd64_sources) inssel-amd64.brg cpu-amd64.md \
- $(ppc_sources) inssel-ppc.brg cpu-g4.md \
- $(arm_sources) inssel-arm.brg cpu-arm.md \
- $(sparc_sources) inssel-sparc.brg cpu-sparc.md \
- $(s390_sources) inssel-s390.brg cpu-s390.md \
- $(s390x_sources) inssel-s390x.brg cpu-s390x.md \
- $(ia64_sources) inssel-ia64.brg cpu-ia64.md
+EXTRA_DIST = $(common_BURGSRC) cprop.c TestDriver.cs ldscript ldscript.mono \
+ genmdesc.pl \
+ $(test_sources) \
+ $(x86_sources) cpu-x86.md \
+ $(amd64_sources) cpu-amd64.md \
+ $(ppc_sources) cpu-ppc.md cpu-ppc64.md \
+ $(arm_sources) cpu-arm.md \
+ $(mips_sources) cpu-mips.md \
+ $(sparc_sources) cpu-sparc.md \
+ $(s390_sources) cpu-s390.md \
+ $(s390x_sources) cpu-s390x.md \
+ $(ia64_sources) cpu-ia64.md \
+ $(alpha_sources) cpu-alpha.md \
+ $(hppa_sources) cpu-hppa.md
+
+version.h: Makefile
+ if test -d $(top_srcdir)/.git/svn; then svn_info='git svn info'; fi; \
+ if test -d $(srcdir)/.svn; then svn_info='svn info'; fi; \
+ if test -n "$$svn_info"; then \
+ (cd $(top_srcdir); \
+ LANG=C; export LANG; \
+ branch=`$$svn_info | grep URL | sed -e 's/.*source//' -e 's,mono/?$$,,'`; \
+ version=`$$svn_info | grep Revision | sed 's/.*: //'`; \
+ echo "#define FULL_VERSION \"$$branch r$$version\""; \
+ ); \
+ else \
+ echo "#define FULL_VERSION \"tarball\""; \
+ fi > version.h
+
+# Utility target for patching libtool to speed up linking
+patch-libtool:
+ sed -e 's,if (for obj in $$oldobjs,if (for obj in "",g' < ../../libtool > 2; mv 2 ../../libtool
+ chmod a+x ../../libtool
\ No newline at end of file