Use different object files for libs and plugins.
This allows building a shared and static lib at once.
This commit is contained in:
parent
f6125d9bb3
commit
03f94ad79c
2 changed files with 113 additions and 66 deletions
105
buildsys.mk.in
105
buildsys.mk.in
|
@ -90,11 +90,14 @@ OBJS8 = ${OBJS7:.py=.pyc}
|
||||||
OBJS9 = ${OBJS8:.xpm=.o}
|
OBJS9 = ${OBJS8:.xpm=.o}
|
||||||
OBJS += ${OBJS9:.S=.o}
|
OBJS += ${OBJS9:.S=.o}
|
||||||
|
|
||||||
|
LIB_OBJS = ${OBJS:.o=.lib.o}
|
||||||
|
PLUGIN_OBJS = ${OBJS:.o=.plugin.o}
|
||||||
|
|
||||||
MO_FILES = ${LOCALES:.po=.mo}
|
MO_FILES = ${LOCALES:.po=.mo}
|
||||||
|
|
||||||
.SILENT:
|
.SILENT:
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
.SUFFIXES: .beam .c .cc .cxx .d .dep .erl .mo .m .mm .o .po .py .pyc .xpm .S
|
.SUFFIXES: .beam .c .cc .cxx .d .dep .erl .lib.o .mo .m .mm .o .plugin.o .po .py .pyc .xpm .S
|
||||||
.PHONY: all subdirs pre-depend depend install install-extra uninstall uninstall-extra clean distclean
|
.PHONY: all subdirs pre-depend depend install install-extra uninstall uninstall-extra clean distclean
|
||||||
|
|
||||||
all:
|
all:
|
||||||
|
@ -169,14 +172,14 @@ ${PROG} ${PROG_NOINST}: ${EXT_DEPS} ${OBJS}
|
||||||
${LINK_FAILED}; \
|
${LINK_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
${LIB} ${LIB_NOINST}: ${EXT_DEPS} ${OBJS}
|
${LIB} ${LIB_NOINST}: ${EXT_DEPS} ${LIB_OBJS}
|
||||||
case $@ in \
|
case $@ in \
|
||||||
*.a) \
|
*.a) \
|
||||||
${MAKE} ${MFLAGS} STATIC_LIB=${LIB} LIB= $@ || exit 1 \
|
${MAKE} ${MFLAGS} STATIC_LIB=${LIB} LIB= $@ || exit 1 \
|
||||||
;; \
|
;; \
|
||||||
*) \
|
*) \
|
||||||
${LINK_STATUS}; \
|
${LINK_STATUS}; \
|
||||||
if ${LD} -o $@ ${OBJS} ${LIB_LDFLAGS} ${LDFLAGS} ${LIBS}; then \
|
if ${LD} -o $@ ${LIB_OBJS} ${LIB_LDFLAGS} ${LDFLAGS} ${LIBS}; then \
|
||||||
${LINK_OK}; \
|
${LINK_OK}; \
|
||||||
else \
|
else \
|
||||||
${LINK_FAILED}; \
|
${LINK_FAILED}; \
|
||||||
|
@ -184,9 +187,9 @@ ${LIB} ${LIB_NOINST}: ${EXT_DEPS} ${OBJS}
|
||||||
;; \
|
;; \
|
||||||
esac
|
esac
|
||||||
|
|
||||||
${PLUGIN} ${PLUGIN_NOINST}: ${EXT_DEPS} ${OBJS}
|
${PLUGIN} ${PLUGIN_NOINST}: ${EXT_DEPS} ${PLUGIN_OBJS}
|
||||||
${LINK_STATUS}
|
${LINK_STATUS}
|
||||||
if ${LD} -o $@ ${OBJS} ${PLUGIN_LDFLAGS} ${LDFLAGS} ${LIBS}; then \
|
if ${LD} -o $@ ${PLUGIN_OBJS} ${PLUGIN_LDFLAGS} ${LDFLAGS} ${LIBS}; then \
|
||||||
${LINK_OK}; \
|
${LINK_OK}; \
|
||||||
else \
|
else \
|
||||||
${LINK_FAILED}; \
|
${LINK_FAILED}; \
|
||||||
|
@ -210,6 +213,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.c.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${CC} ${LIB_CFLAGS} ${CFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.c.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${CC} ${PLUGIN_CFLAGS} ${CFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
.cc.o .cxx.o:
|
.cc.o .cxx.o:
|
||||||
${COMPILE_STATUS}
|
${COMPILE_STATUS}
|
||||||
|
@ -218,6 +235,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.cc.lib.o .cxx.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${CXX} ${LIB_CFLAGS} ${CXXFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.cc.plugin.o .cxx.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${CXX} ${PLUGIN_CFLAGS} ${CXXFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
.d.o:
|
.d.o:
|
||||||
${COMPILE_STATUS}
|
${COMPILE_STATUS}
|
||||||
|
@ -250,6 +281,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.m.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${OBJC} ${LIB_CFLAGS} ${OBJCFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.m.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${OBJC} ${PLUGIN_CFLAGS} ${OBJCFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
.mm.o:
|
.mm.o:
|
||||||
${COMPILE_STATUS}
|
${COMPILE_STATUS}
|
||||||
|
@ -258,6 +303,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.mm.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${OBJCXX} ${LIB_CFLAGS} ${OBJCXXFLAGS} ${OBJCFLAGS} ${CXXFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.mm.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${OBJCXX} ${PLUGIN_CFLAGS} ${OBJCXXFLAGS} ${OBJCFLAGS} ${CXXFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
.po.mo:
|
.po.mo:
|
||||||
${COMPILE_STATUS}
|
${COMPILE_STATUS}
|
||||||
|
@ -282,6 +341,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.xpm.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${CC} ${LIB_CFLAGS} ${CFLAGS} ${CPPFLAGS} -x c -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.xpm.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${CC} ${PLUGIN_CFLAGS} ${CFLAGS} ${CPPFLAGS} -x c -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
.S.o:
|
.S.o:
|
||||||
${COMPILE_STATUS}
|
${COMPILE_STATUS}
|
||||||
|
@ -290,6 +363,20 @@ locales: ${MO_FILES}
|
||||||
else \
|
else \
|
||||||
${COMPILE_FAILED}; \
|
${COMPILE_FAILED}; \
|
||||||
fi
|
fi
|
||||||
|
.S.lib.o:
|
||||||
|
${COMPILE_LIB_STATUS}
|
||||||
|
if ${AS} ${LIB_CFLAGS} ${ASFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_LIB_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_LIB_FAILED}; \
|
||||||
|
fi
|
||||||
|
.S.plugin.o:
|
||||||
|
${COMPILE_PLUGIN_STATUS}
|
||||||
|
if ${AS} ${PLUGIN_CFLAGS} ${ASFLAGS} ${CPPFLAGS} -c -o $@ $<; then \
|
||||||
|
${COMPILE_PLUGIN_OK}; \
|
||||||
|
else \
|
||||||
|
${COMPILE_PLUGIN_FAILED}; \
|
||||||
|
fi
|
||||||
|
|
||||||
install: ${LIB} ${STATIC_LIB} ${PLUGIN} ${PROG} install-extra
|
install: ${LIB} ${STATIC_LIB} ${PLUGIN} ${PROG} install-extra
|
||||||
for i in ${SUBDIRS}; do \
|
for i in ${SUBDIRS}; do \
|
||||||
|
@ -472,7 +559,7 @@ clean:
|
||||||
${DIR_LEAVE}; \
|
${DIR_LEAVE}; \
|
||||||
done
|
done
|
||||||
|
|
||||||
for i in ${DEPS} ${OBJS} ${PROG} ${PROG_NOINST} ${LIB} ${LIB_NOINST} ${STATIC_LIB} ${STATIC_LIB_NOINST} ${PLUGIN} ${PLUGIN_NOINST} ${CLEAN_LIB} ${MO_FILES} ${CLEAN}; do \
|
for i in ${DEPS} ${OBJS} ${LIB_OBJS} ${PLUGIN_OBJS} ${PROG} ${PROG_NOINST} ${LIB} ${LIB_NOINST} ${STATIC_LIB} ${STATIC_LIB_NOINST} ${PLUGIN} ${PLUGIN_NOINST} ${CLEAN_LIB} ${MO_FILES} ${CLEAN}; do \
|
||||||
if test -f $$i -o -d $$i; then \
|
if test -f $$i -o -d $$i; then \
|
||||||
if rm -fr $$i; then \
|
if rm -fr $$i; then \
|
||||||
${DELETE_OK}; \
|
${DELETE_OK}; \
|
||||||
|
@ -507,6 +594,12 @@ DEPEND_FAILED = printf "\033[K\033[0;31mFailed to generate dependencies!\033[0m\
|
||||||
COMPILE_STATUS = printf "\033[K\033[0;33mCompiling \033[1;33m$<\033[0;33m...\033[0m\r"
|
COMPILE_STATUS = printf "\033[K\033[0;33mCompiling \033[1;33m$<\033[0;33m...\033[0m\r"
|
||||||
COMPILE_OK = printf "\033[K\033[0;32mSuccessfully compiled \033[1;32m$<\033[0;32m.\033[0m\n"
|
COMPILE_OK = printf "\033[K\033[0;32mSuccessfully compiled \033[1;32m$<\033[0;32m.\033[0m\n"
|
||||||
COMPILE_FAILED = printf "\033[K\033[0;31mFailed to compile \033[1;31m$<\033[0;31m!\033[0m\n"; exit 1
|
COMPILE_FAILED = printf "\033[K\033[0;31mFailed to compile \033[1;31m$<\033[0;31m!\033[0m\n"; exit 1
|
||||||
|
COMPILE_LIB_STATUS = printf "\033[K\033[0;33mCompiling \033[1;33m$<\033[0;33m (lib)...\033[0m\r"
|
||||||
|
COMPILE_LIB_OK = printf "\033[K\033[0;32mSuccessfully compiled \033[1;32m$<\033[0;32m (lib).\033[0m\n"
|
||||||
|
COMPILE_LIB_FAILED = printf "\033[K\033[0;31mFailed to compile \033[1;31m$<\033[0;31m (lib)!\033[0m\n"; exit 1
|
||||||
|
COMPILE_PLUGIN_STATUS = printf "\033[K\033[0;33mCompiling \033[1;33m$<\033[0;33m (plugin)...\033[0m\r"
|
||||||
|
COMPILE_PLUGIN_OK = printf "\033[K\033[0;32mSuccessfully compiled \033[1;32m$<\033[0;32m (plugin).\033[0m\n"
|
||||||
|
COMPILE_PLUGIN_FAILED = printf "\033[K\033[0;31mFailed to compile \033[1;31m$<\033[0;31m (plugin)!\033[0m\n"; exit 1
|
||||||
LINK_STATUS = printf "\033[K\033[0;33mLinking \033[1;33m$@\033[0;33m...\033[0m\r"
|
LINK_STATUS = printf "\033[K\033[0;33mLinking \033[1;33m$@\033[0;33m...\033[0m\r"
|
||||||
LINK_OK = printf "\033[K\033[0;32mSuccessfully linked \033[1;32m$@\033[0;32m.\033[0m\n"
|
LINK_OK = printf "\033[K\033[0;32mSuccessfully linked \033[1;32m$@\033[0;32m.\033[0m\n"
|
||||||
LINK_FAILED = printf "\033[K\033[0;31mFailed to link \033[1;31m$@\033[0;31m!\033[0m\n"; exit 1
|
LINK_FAILED = printf "\033[K\033[0;31mFailed to link \033[1;31m$@\033[0;31m!\033[0m\n"; exit 1
|
||||||
|
|
|
@ -20,15 +20,6 @@ dnl ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
dnl POSSIBILITY OF SUCH DAMAGE.
|
dnl POSSIBILITY OF SUCH DAMAGE.
|
||||||
dnl
|
dnl
|
||||||
|
|
||||||
AC_DEFUN([BUILDSYS_LIB], [
|
|
||||||
AC_ARG_ENABLE(shared,
|
|
||||||
AS_HELP_STRING([--disable-shared], [don't build shared libraries]))
|
|
||||||
|
|
||||||
AS_IF([test x"$enable_shared" = x"no"],
|
|
||||||
[BUILDSYS_STATIC_LIB_ONLY],
|
|
||||||
[BUILDSYS_SHARED_LIB])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([BUILDSYS_PROG_IMPLIB], [
|
AC_DEFUN([BUILDSYS_PROG_IMPLIB], [
|
||||||
AC_REQUIRE([AC_CANONICAL_HOST])
|
AC_REQUIRE([AC_CANONICAL_HOST])
|
||||||
AC_MSG_CHECKING(whether we need an implib)
|
AC_MSG_CHECKING(whether we need an implib)
|
||||||
|
@ -55,14 +46,12 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
case "$host_os" in
|
case "$host_os" in
|
||||||
darwin*)
|
darwin*)
|
||||||
AC_MSG_RESULT(Darwin)
|
AC_MSG_RESULT(Darwin)
|
||||||
LIB_CPPFLAGS='-DPIC'
|
LIB_CFLAGS='-fPIC -DPIC'
|
||||||
LIB_CFLAGS='-fPIC'
|
|
||||||
LIB_LDFLAGS='-dynamiclib -current_version ${LIB_MAJOR}.${LIB_MINOR} -compatibility_version ${LIB_MAJOR}'
|
LIB_LDFLAGS='-dynamiclib -current_version ${LIB_MAJOR}.${LIB_MINOR} -compatibility_version ${LIB_MAJOR}'
|
||||||
LIB_PREFIX='lib'
|
LIB_PREFIX='lib'
|
||||||
LIB_SUFFIX='.dylib'
|
LIB_SUFFIX='.dylib'
|
||||||
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
||||||
PLUGIN_CPPFLAGS='-DPIC'
|
PLUGIN_CFLAGS='-fPIC -DPIC'
|
||||||
PLUGIN_CFLAGS='-fPIC'
|
|
||||||
PLUGIN_LDFLAGS='-bundle -undefined dynamic_lookup'
|
PLUGIN_LDFLAGS='-bundle -undefined dynamic_lookup'
|
||||||
PLUGIN_SUFFIX='.impl'
|
PLUGIN_SUFFIX='.impl'
|
||||||
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib && ${LN_S} -f $${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib ${DESTDIR}${libdir}/$${i%.dylib}.${LIB_MAJOR}.dylib && ${LN_S} -f $${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib ${DESTDIR}${libdir}/$$i'
|
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib && ${LN_S} -f $${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib ${DESTDIR}${libdir}/$${i%.dylib}.${LIB_MAJOR}.dylib && ${LN_S} -f $${i%.dylib}.${LIB_MAJOR}.${LIB_MINOR}.dylib ${DESTDIR}${libdir}/$$i'
|
||||||
|
@ -71,15 +60,13 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
;;
|
;;
|
||||||
solaris*)
|
solaris*)
|
||||||
AC_MSG_RESULT(Solaris)
|
AC_MSG_RESULT(Solaris)
|
||||||
LIB_CPPFLAGS='-DPIC'
|
LIB_CFLAGS='-fPIC -DPIC'
|
||||||
LIB_CFLAGS='-fPIC'
|
LIB_LDFLAGS='-shared -Wl,-soname=${LIB}.${LIB_MAJOR}.${LIB_MINOR}'
|
||||||
LIB_LDFLAGS='-shared -fPIC -Wl,-soname=${LIB}.${LIB_MAJOR}.${LIB_MINOR}'
|
|
||||||
LIB_PREFIX='lib'
|
LIB_PREFIX='lib'
|
||||||
LIB_SUFFIX='.so'
|
LIB_SUFFIX='.so'
|
||||||
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
||||||
PLUGIN_CPPFLAGS='-DPIC'
|
PLUGIN_CFLAGS='-fPIC -DPIC'
|
||||||
PLUGIN_CFLAGS='-fPIC'
|
PLUGIN_LDFLAGS='-shared'
|
||||||
PLUGIN_LDFLAGS='-shared -fPIC'
|
|
||||||
PLUGIN_SUFFIX='.so'
|
PLUGIN_SUFFIX='.so'
|
||||||
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR} && rm -f ${DESTDIR}${libdir}/$$i && ${LN_S} $$i.${LIB_MAJOR}.${LIB_MINOR} ${DESTDIR}${libdir}/$$i'
|
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR} && rm -f ${DESTDIR}${libdir}/$$i && ${LN_S} $$i.${LIB_MAJOR}.${LIB_MINOR} ${DESTDIR}${libdir}/$$i'
|
||||||
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}'
|
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}'
|
||||||
|
@ -87,15 +74,13 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
;;
|
;;
|
||||||
openbsd* | mirbsd*)
|
openbsd* | mirbsd*)
|
||||||
AC_MSG_RESULT(OpenBSD)
|
AC_MSG_RESULT(OpenBSD)
|
||||||
LIB_CPPFLAGS='-DPIC'
|
LIB_CFLAGS='-fPIC -DPIC'
|
||||||
LIB_CFLAGS='-fPIC'
|
LIB_LDFLAGS='-shared'
|
||||||
LIB_LDFLAGS='-shared -fPIC'
|
|
||||||
LIB_PREFIX='lib'
|
LIB_PREFIX='lib'
|
||||||
LIB_SUFFIX='.so.${LIB_MAJOR}.${LIB_MINOR}'
|
LIB_SUFFIX='.so.${LIB_MAJOR}.${LIB_MINOR}'
|
||||||
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
||||||
PLUGIN_CPPFLAGS='-DPIC'
|
PLUGIN_CFLAGS='-fPIC -DPIC'
|
||||||
PLUGIN_CFLAGS='-fPIC'
|
PLUGIN_LDFLAGS='-shared'
|
||||||
PLUGIN_LDFLAGS='-shared -fPIC'
|
|
||||||
PLUGIN_SUFFIX='.so'
|
PLUGIN_SUFFIX='.so'
|
||||||
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i'
|
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i'
|
||||||
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i'
|
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i'
|
||||||
|
@ -103,13 +88,11 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
;;
|
;;
|
||||||
cygwin* | mingw*)
|
cygwin* | mingw*)
|
||||||
AC_MSG_RESULT(Win32)
|
AC_MSG_RESULT(Win32)
|
||||||
LIB_CPPFLAGS='-DPIC'
|
|
||||||
LIB_CFLAGS=''
|
LIB_CFLAGS=''
|
||||||
LIB_LDFLAGS='-shared -Wl,--out-implib,${LIB}.a'
|
LIB_LDFLAGS='-shared -Wl,--out-implib,${LIB}.a'
|
||||||
LIB_PREFIX='lib'
|
LIB_PREFIX='lib'
|
||||||
LIB_SUFFIX='.dll'
|
LIB_SUFFIX='.dll'
|
||||||
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
||||||
PLUGIN_CPPFLAGS=''
|
|
||||||
PLUGIN_CFLAGS=''
|
PLUGIN_CFLAGS=''
|
||||||
PLUGIN_LDFLAGS='-shared'
|
PLUGIN_LDFLAGS='-shared'
|
||||||
PLUGIN_SUFFIX='.dll'
|
PLUGIN_SUFFIX='.dll'
|
||||||
|
@ -119,15 +102,13 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
AC_MSG_RESULT(GNU)
|
AC_MSG_RESULT(GNU)
|
||||||
LIB_CPPFLAGS='-DPIC'
|
LIB_CFLAGS='-fPIC -DPIC'
|
||||||
LIB_CFLAGS='-fPIC'
|
LIB_LDFLAGS='-shared -Wl,-soname=${LIB}.${LIB_MAJOR}'
|
||||||
LIB_LDFLAGS='-shared -fPIC -Wl,-soname=${LIB}.${LIB_MAJOR}'
|
|
||||||
LIB_PREFIX='lib'
|
LIB_PREFIX='lib'
|
||||||
LIB_SUFFIX='.so'
|
LIB_SUFFIX='.so'
|
||||||
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
LDFLAGS_RPATH='-Wl,-rpath,${libdir}'
|
||||||
PLUGIN_CPPFLAGS='-DPIC'
|
PLUGIN_CFLAGS='-fPIC -DPIC'
|
||||||
PLUGIN_CFLAGS='-fPIC'
|
PLUGIN_LDFLAGS='-shared'
|
||||||
PLUGIN_LDFLAGS='-shared -fPIC'
|
|
||||||
PLUGIN_SUFFIX='.so'
|
PLUGIN_SUFFIX='.so'
|
||||||
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}.0 && ${LN_S} -f $$i.${LIB_MAJOR}.${LIB_MINOR}.0 ${DESTDIR}${libdir}/$$i.${LIB_MAJOR} && ${LN_S} -f $$i.${LIB_MAJOR}.${LIB_MINOR}.0 ${DESTDIR}${libdir}/$$i'
|
INSTALL_LIB='${INSTALL} -m 755 $$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}.0 && ${LN_S} -f $$i.${LIB_MAJOR}.${LIB_MINOR}.0 ${DESTDIR}${libdir}/$$i.${LIB_MAJOR} && ${LN_S} -f $$i.${LIB_MAJOR}.${LIB_MINOR}.0 ${DESTDIR}${libdir}/$$i'
|
||||||
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR} ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}.0'
|
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i ${DESTDIR}${libdir}/$$i.${LIB_MAJOR} ${DESTDIR}${libdir}/$$i.${LIB_MAJOR}.${LIB_MINOR}.0'
|
||||||
|
@ -135,13 +116,11 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
AC_SUBST(LIB_CPPFLAGS)
|
|
||||||
AC_SUBST(LIB_CFLAGS)
|
AC_SUBST(LIB_CFLAGS)
|
||||||
AC_SUBST(LIB_LDFLAGS)
|
AC_SUBST(LIB_LDFLAGS)
|
||||||
AC_SUBST(LIB_PREFIX)
|
AC_SUBST(LIB_PREFIX)
|
||||||
AC_SUBST(LIB_SUFFIX)
|
AC_SUBST(LIB_SUFFIX)
|
||||||
AC_SUBST(LDFLAGS_RPATH)
|
AC_SUBST(LDFLAGS_RPATH)
|
||||||
AC_SUBST(PLUGIN_CPPFLAGS)
|
|
||||||
AC_SUBST(PLUGIN_CFLAGS)
|
AC_SUBST(PLUGIN_CFLAGS)
|
||||||
AC_SUBST(PLUGIN_LDFLAGS)
|
AC_SUBST(PLUGIN_LDFLAGS)
|
||||||
AC_SUBST(PLUGIN_SUFFIX)
|
AC_SUBST(PLUGIN_SUFFIX)
|
||||||
|
@ -150,31 +129,6 @@ AC_DEFUN([BUILDSYS_SHARED_LIB], [
|
||||||
AC_SUBST(CLEAN_LIB)
|
AC_SUBST(CLEAN_LIB)
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN([BUILDSYS_STATIC_LIB_ONLY], [
|
|
||||||
AC_REQUIRE([AC_PROG_RANLIB])
|
|
||||||
AC_PATH_TOOL(AR, ar)
|
|
||||||
|
|
||||||
LIB_CPPFLAGS=''
|
|
||||||
LIB_CFLAGS=''
|
|
||||||
LIB_LDFLAGS=''
|
|
||||||
LIB_PREFIX='lib'
|
|
||||||
LIB_SUFFIX='.a'
|
|
||||||
LDFLAGS_RPATH=''
|
|
||||||
INSTALL_LIB='${INSTALL} -m 644 $$i ${DESTDIR}${libdir}/$$i'
|
|
||||||
UNINSTALL_LIB='rm -f ${DESTDIR}${libdir}/$$i'
|
|
||||||
CLEAN_LIB=''
|
|
||||||
|
|
||||||
AC_SUBST(LIB_CPPFLAGS)
|
|
||||||
AC_SUBST(LIB_CFLAGS)
|
|
||||||
AC_SUBST(LIB_LDFLAGS)
|
|
||||||
AC_SUBST(LIB_PREFIX)
|
|
||||||
AC_SUBST(LIB_SUFFIX)
|
|
||||||
AC_SUBST(LDFLAGS_RPATH)
|
|
||||||
AC_SUBST(INSTALL_LIB)
|
|
||||||
AC_SUBST(UNINSTALL_LIB)
|
|
||||||
AC_SUBST(CLEAN_LIB)
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([BUILDSYS_TOUCH_DEPS], [
|
AC_DEFUN([BUILDSYS_TOUCH_DEPS], [
|
||||||
${as_echo:="echo"} "${as_me:="configure"}: touching .deps files"
|
${as_echo:="echo"} "${as_me:="configure"}: touching .deps files"
|
||||||
for i in $(find . -name Makefile); do
|
for i in $(find . -name Makefile); do
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue