summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSascha Schumann <sas@php.net>2000-05-02 01:15:10 +0000
committerSascha Schumann <sas@php.net>2000-05-02 01:15:10 +0000
commitd4def2d2a324b1c8b5deb5bebc4286563afa67e5 (patch)
treeee723b8038889ed572f63b4bc3142e6f2aaff16d
parentb45ee4b1ed58b751fce8001d3dcfda4c675552c6 (diff)
downloadphp-git-d4def2d2a324b1c8b5deb5bebc4286563afa67e5.tar.gz
Make zlib buildable as shared module
-rw-r--r--ext/zlib/Makefile.in2
-rw-r--r--ext/zlib/config.m473
2 files changed, 41 insertions, 34 deletions
diff --git a/ext/zlib/Makefile.in b/ext/zlib/Makefile.in
index 946ae5ce58..3b767fb7fa 100644
--- a/ext/zlib/Makefile.in
+++ b/ext/zlib/Makefile.in
@@ -1,5 +1,7 @@
LTLIBRARY_NAME = libzlib.la
LTLIBRARY_SOURCES = zlib.c
+LTLIBRARY_SHARED_NAME = zlib.la
+LTLIBRARY_SHARED_LIBADD = $(ZLIB_SHARED_LIBADD)
include $(top_srcdir)/build/dynlib.mk
diff --git a/ext/zlib/config.m4 b/ext/zlib/config.m4
index 30cfd541dd..020c133fcd 100644
--- a/ext/zlib/config.m4
+++ b/ext/zlib/config.m4
@@ -1,38 +1,43 @@
dnl $Id$
-AC_MSG_CHECKING(whether to include zlib support)
-AC_ARG_WITH(zlib,
+
+
+PHP_ARG_WITH(zlib,whether to include zlib support,
[ --with-zlib[=DIR] Include zlib support (requires zlib >= 1.0.9).
DIR is the zlib install directory,
- defaults to /usr.],
-[
- case "$withval" in
- no)
- AC_MSG_RESULT(no) ;;
- yes)
- AC_MSG_RESULT(yes)
- PHP_EXTENSION(zlib)
- AC_CHECK_LIB(z, gzgets, [AC_DEFINE(HAVE_ZLIB,1,[ ])],
- [AC_MSG_ERROR(Zlib module requires zlib >= 1.0.9.)])
- AC_ADD_LIBRARY(z)
- ;;
- *)
- test -f $withval/include/zlib/zlib.h && ZLIB_INCLUDE="$withval/include/zlib"
- test -f $withval/include/zlib.h && ZLIB_INCLUDE="$withval/include"
- if test -n "$ZLIB_INCLUDE" ; then
- AC_MSG_RESULT(yes)
- PHP_EXTENSION(zlib)
- old_LIBS=$LIBS
- LIBS="$LIBS -L$withval/lib"
- AC_CHECK_LIB(z, gzgets, [AC_DEFINE(HAVE_ZLIB,1,[ ])],
- [AC_MSG_ERROR(Zlib module requires zlib >= 1.0.9.)])
- LIBS=$old_LIBS
- AC_ADD_LIBRARY_WITH_PATH(z, $withval/lib)
- AC_ADD_INCLUDE($ZLIB_INCLUDE)
- else
- AC_MSG_RESULT(no)
- fi ;;
- esac
-],[
- AC_MSG_RESULT(no)
-])
+ defaults to /usr.])
+
+if test "$PHP_ZLIB" != "no"; then
+ PHP_EXTENSION(zlib, $ext_shared)
+ for i in /usr/local /usr $PHP_ZLIB; do
+ if test -f $i/include/zlib/zlib.h; then
+ ZLIB_DIR=$i
+ ZLIB_INCDIR=$i/include/zlib
+ elif test -f $i/include/zlib.h; then
+ ZLIB_DIR=$i
+ ZLIB_INCDIR=$i/include
+ fi
+ done
+
+ if test -z "$ZLIB_DIR"; then
+ AC_MSG_ERROR(Cannot find libz)
+ fi
+
+ ZLIB_LIBDIR=$ZLIB_DIR/lib
+
+ old_LDFLAGS="$LDFLAGS"
+ old_LIBS="$LIBS"
+ AC_CHECK_LIB(z, gzgets, [AC_DEFINE(HAVE_ZLIB,1,[ ])],
+ [AC_MSG_ERROR(Zlib module requires zlib >= 1.0.9.)])
+ LIBS="$old_LIBS"
+ LDFLAGS="$old_LDFLAGS"
+
+ if test "$ext_shared" = "yes"; then
+ ZLIB_SHARED_LIBADD="-R$ZLIB_LIBDIR -L$ZLIB_LIBDIR -lz"
+ PHP_SUBST(ZLIB_SHARED_LIBADD)
+ else
+ AC_ADD_LIBRARY_WITH_PATH(z, $ZLIB_LIBDIR)
+ fi
+
+ AC_ADD_INCLUDE($ZLIB_INCLUDE)
+fi