moriyoshi               Sun Aug 24 18:46:14 2003 EDT

  Modified files:              
    /php-src/ext/mbstring       config.m4 mbstring.h 
  Log:
  Allow usage of external libmbfl
  
  
Index: php-src/ext/mbstring/config.m4
diff -u php-src/ext/mbstring/config.m4:1.32 php-src/ext/mbstring/config.m4:1.33
--- php-src/ext/mbstring/config.m4:1.32 Sun Aug 24 18:15:49 2003
+++ php-src/ext/mbstring/config.m4      Sun Aug 24 18:46:13 2003
@@ -1,9 +1,10 @@
 dnl
-dnl $Id: config.m4,v 1.32 2003/08/24 22:15:49 moriyoshi Exp $
+dnl $Id: config.m4,v 1.33 2003/08/24 22:46:13 moriyoshi Exp $
 dnl
 
 AC_DEFUN([PHP_MBSTRING_INIT], [
   PHP_MBSTRING_SOURCES=""
+  PHP_MBSTRING_EXTRA_INCLUDES=""
   PHP_MBSTRING_EXTRA_BUILD_DIRS=""
   PHP_MBSTRING_EXTRA_CONFIG_HEADERS=""
   PHP_MBSTRING=""
@@ -19,23 +20,29 @@
   PHP_MBSTRING_EXTRA_BUILD_DIRS="$PHP_MBSTRING_EXTRA_BUILD_DIRS $1"
 ])
 
+AC_DEFUN([PHP_MBSTRING_ADD_INCLUDE], [
+  PHP_MBSTRING_EXTRA_INCLUDES="$PHP_MBSTRING_EXTRA_INCLUDES $1"
+])
+
 AC_DEFUN([PHP_MBSTRING_CONFIG_HEADER], [
   PHP_MBSTRING_EXTRA_CONFIG_HEADERS="$PHP_MBSTRING_EXTRA_CONFIG_HEADERS $1"
 ])
 
+AC_DEFUN([PHP_MBSTRING_ADD_CFLAG], [
+  PHP_MBSTRING_CFLAGS="$PHP_MBSTRING_CFLAGS $1"
+])
+
 AC_DEFUN([PHP_MBSTRING_EXTENSION], [
   PHP_NEW_EXTENSION(mbstring, $PHP_MBSTRING_SOURCES, $ext_shared,, 
\\$(PHP_MBSTRING_CFLAGS))
+  for dir in $PHP_MBSTRING_EXTRA_INCLUDES; do
+    PHP_ADD_INCLUDE([$ext_builddir/$dir])
+  done
   for dir in $PHP_MBSTRING_EXTRA_BUILD_DIRS; do
     PHP_ADD_BUILD_DIR([$ext_builddir/$dir])
   done
   for cfg in $PHP_MBSTRING_EXTRA_CONFIG_HEADERS; do
     AC_CONFIG_HEADER([$ext_builddir/$cfg])
   done
-
-  if test "$LIBMBFL_MODULE_TYPE" = "builtin"; then
-    PHP_MBSTRING_CFLAGS="-I$ext_srcdir/libmbfl/mbfl $PHP_MBSTRING_CFLAGS"
-    PHP_MBSTRING_CFLAGS="-I$ext_srcdir/libmbfl $PHP_MBSTRING_CFLAGS"
-  fi
   PHP_SUBST(PHP_MBSTRING_CFLAGS)
 ])
 
@@ -43,8 +50,12 @@
 AC_DEFUN([PHP_MBSTRING_SETUP], [
   PHP_ARG_ENABLE(mbstring, whether to enable multibyte string support,
   [  --enable-mbstring       Enable multibyte string support])
-
-  if test "$PHP_MBSTRING" != "no"; then  
+  if test "$PHP_MBSTRING" != "no"; then
+    PHP_ARG_WITH(libmbfl-dir, [for libmbfl installation prefix],
+      [  --with-libmbfl-dir[=DIR]   Include libmbfl support where DIR is libmbfl 
install prefix.
+                           If DIR is not set, the bundled libmbfl will be used.],
+      [yes], [no]
+    )
     AC_DEFINE([HAVE_MBSTRING],1,[whether to have multibyte string support])
 
     if test -z "$PHP_MBSTRING" -o "$PHP_MBSTRING" = "all" -o "$PHP_MBSTRING" = "ja"; 
then
@@ -62,6 +73,110 @@
     if test "$PHP_MBSTRING" = "all" -o "$PHP_MBSTRING" = "ru"; then
       AC_DEFINE([HAVE_MBSTR_RU],1,[whether to have russian support])
     fi
+
+    if test "$PHP_LIBMBFL_DIR" = "yes"; then
+      AC_DEFINE([HAVE_LIBMBFL], 1, [whether to have libmbfl support])
+      PHP_MBSTRING_ADD_BUILD_DIR([libmbfl])
+      PHP_MBSTRING_ADD_INCLUDE([libmbfl])
+      PHP_MBSTRING_ADD_INCLUDE([libmbfl/mbfl])
+      PHP_MBSTRING_ADD_SOURCES([
+        libmbfl/filters/html_entities.c
+        libmbfl/filters/mbfilter_7bit.c
+        libmbfl/filters/mbfilter_ascii.c
+        libmbfl/filters/mbfilter_base64.c
+        libmbfl/filters/mbfilter_big5.c
+        libmbfl/filters/mbfilter_byte2.c
+        libmbfl/filters/mbfilter_byte4.c
+        libmbfl/filters/mbfilter_cp1251.c
+        libmbfl/filters/mbfilter_cp1252.c
+        libmbfl/filters/mbfilter_cp866.c
+        libmbfl/filters/mbfilter_cp932.c
+        libmbfl/filters/mbfilter_cp936.c
+        libmbfl/filters/mbfilter_euc_cn.c
+        libmbfl/filters/mbfilter_euc_jp.c
+        libmbfl/filters/mbfilter_euc_jp_win.c
+        libmbfl/filters/mbfilter_euc_kr.c
+        libmbfl/filters/mbfilter_euc_tw.c
+        libmbfl/filters/mbfilter_htmlent.c
+        libmbfl/filters/mbfilter_hz.c
+        libmbfl/filters/mbfilter_iso2022_kr.c
+        libmbfl/filters/mbfilter_iso8859_1.c
+        libmbfl/filters/mbfilter_iso8859_10.c
+        libmbfl/filters/mbfilter_iso8859_13.c
+        libmbfl/filters/mbfilter_iso8859_14.c
+        libmbfl/filters/mbfilter_iso8859_15.c
+        libmbfl/filters/mbfilter_iso8859_2.c
+        libmbfl/filters/mbfilter_iso8859_3.c
+        libmbfl/filters/mbfilter_iso8859_4.c
+        libmbfl/filters/mbfilter_iso8859_5.c
+        libmbfl/filters/mbfilter_iso8859_6.c
+        libmbfl/filters/mbfilter_iso8859_7.c
+        libmbfl/filters/mbfilter_iso8859_8.c
+        libmbfl/filters/mbfilter_iso8859_9.c
+        libmbfl/filters/mbfilter_jis.c
+        libmbfl/filters/mbfilter_koi8r.c
+        libmbfl/filters/mbfilter_qprint.c
+        libmbfl/filters/mbfilter_sjis.c
+        libmbfl/filters/mbfilter_ucs2.c
+        libmbfl/filters/mbfilter_ucs4.c
+        libmbfl/filters/mbfilter_uhc.c
+        libmbfl/filters/mbfilter_utf16.c
+        libmbfl/filters/mbfilter_utf32.c
+        libmbfl/filters/mbfilter_utf7.c
+        libmbfl/filters/mbfilter_utf7imap.c
+        libmbfl/filters/mbfilter_utf8.c
+        libmbfl/filters/mbfilter_uuencode.c
+        libmbfl/mbfl/mbfilter.c
+        libmbfl/mbfl/mbfilter_8bit.c
+        libmbfl/mbfl/mbfilter_pass.c
+        libmbfl/mbfl/mbfilter_wchar.c
+        libmbfl/mbfl/mbfl_convert.c
+        libmbfl/mbfl/mbfl_encoding.c
+        libmbfl/mbfl/mbfl_filter_output.c
+        libmbfl/mbfl/mbfl_ident.c
+        libmbfl/mbfl/mbfl_language.c
+        libmbfl/mbfl/mbfl_memory_device.c
+        libmbfl/mbfl/mbfl_string.c
+        libmbfl/mbfl/mbfl_allocators.c
+        libmbfl/nls/nls_de.c
+        libmbfl/nls/nls_en.c
+        libmbfl/nls/nls_ja.c
+        libmbfl/nls/nls_kr.c
+        libmbfl/nls/nls_neutral.c
+        libmbfl/nls/nls_ru.c
+        libmbfl/nls/nls_uni.c
+        libmbfl/nls/nls_zh.c
+      ])
+    else
+      PHP_LIBMBFL_INCLUDE=
+      PHP_LIBMBFL_LIB=
+
+      if test "$PHP_LIBMBFL_DIR" != "no"; then
+        for prefix in "$PHP_LIBMBFL_DIR" "/usr" "/usr/local"; do
+          for inc in "$prefix/include/mbfl" "$prefix/include/mbfl-1.0" 
"$prefix/include"; do
+            if test -f "$inc/mbfilter.h"; then
+              PHP_LIBMBFL_INCLUDE="$inc"
+            fi
+          done
+        done
+        for prefix in "$PHP_LIBMBFL_DIR" "/usr" "/usr/local"; do
+          for lib in "$prefix/lib" "$prefix/lib/mbfl" "$prefix/lib/mbfl-1.0"; do
+            if test -f "$lib/libmbfl.so" || test -f "$lib/libmbfl.a"; then
+              PHP_CHECK_LIBRARY(mbfl, [mbfl_buffer_converter_new], [
+                PHP_LIBMBFL_LIB="$lib"
+              ],[], [-L$lib $MBSTRING_SHARED_LIBADD])
+            fi
+          done
+        done
+        if test -z "$PHP_LIBMBFL_INCLUDE" || test -z "$PHP_LIBMBFL_LIB"; then
+          AC_MSG_ERROR([Please reinstall libmbfl library.])
+        fi
+        AC_DEFINE([HAVE_LIBMBFL], 1, [whether to have libmbfl support])
+        PHP_ADD_LIBRARY_WITH_PATH(mbfl, "$PHP_LIBMBFL_LIB", MBSTRING_SHARED_LIBADD)
+        PHP_ADD_INCLUDE([$PHP_LIBMBFL_INCLUDE])
+        PHP_SUBST([MBSTRING_SHARED_LIBADD])
+      fi
+    fi
        
     PHP_MBSTRING_ADD_SOURCES([
       mbstring.c php_unicode.c mb_gpc.c
@@ -91,7 +206,7 @@
       AC_DEFINE([HAVE_STDARG_PROTOTYPES], 1, [Define if stdarg.h is available])
     fi
     AC_DEFINE([HAVE_MBREGEX], 1, [whether to have multibyte regex support])
-    PHP_MBSTRING_CFLAGS="-DNOT_RUBY $PHP_MBSTRING_CFLAGS"
+    PHP_MBSTRING_ADD_CFLAG([-DNOT_RUBY])
 
     PHP_MBSTRING_ADD_BUILD_DIR([oniguruma])
     PHP_MBSTRING_CONFIG_HEADER([oniguruma/config.h])
@@ -107,90 +222,8 @@
   fi
 ])
 
-AC_DEFUN([PHP_MBSTRING_SETUP_LIBMBFL], [
-  PHP_ARG_WITH(libmbfl, [ include libmbfl support],
-  [  --with-libmbfl[=DIR]  Include libmbfl support where DIR is libmbfl install 
prefix.
-                           If DIR is not set, the bundled libmbfl will be used.], no, 
no)
-
-  if test "$PHP_MBSTRING" != "no"; then
-    LIBMBFL_MODULE_TYPE=builtin
-    AC_DEFINE([HAVE_LIBMBFL], 1, [whether to have libmbfl support])
-    PHP_MBSTRING_ADD_BUILD_DIR([libmbfl])
-    PHP_MBSTRING_CONFIG_HEADER([libmbfl/config.h])
-    PHP_MBSTRING_ADD_SOURCES([
-     libmbfl/filters/html_entities.c
-     libmbfl/filters/mbfilter_7bit.c
-     libmbfl/filters/mbfilter_ascii.c
-     libmbfl/filters/mbfilter_base64.c
-     libmbfl/filters/mbfilter_big5.c
-     libmbfl/filters/mbfilter_byte2.c
-     libmbfl/filters/mbfilter_byte4.c
-     libmbfl/filters/mbfilter_cp1251.c
-     libmbfl/filters/mbfilter_cp1252.c
-     libmbfl/filters/mbfilter_cp866.c
-     libmbfl/filters/mbfilter_cp932.c
-     libmbfl/filters/mbfilter_cp936.c
-     libmbfl/filters/mbfilter_euc_cn.c
-     libmbfl/filters/mbfilter_euc_jp.c
-     libmbfl/filters/mbfilter_euc_jp_win.c
-     libmbfl/filters/mbfilter_euc_kr.c
-     libmbfl/filters/mbfilter_euc_tw.c
-     libmbfl/filters/mbfilter_htmlent.c
-     libmbfl/filters/mbfilter_hz.c
-     libmbfl/filters/mbfilter_iso2022_kr.c
-     libmbfl/filters/mbfilter_iso8859_1.c
-     libmbfl/filters/mbfilter_iso8859_10.c
-     libmbfl/filters/mbfilter_iso8859_13.c
-     libmbfl/filters/mbfilter_iso8859_14.c
-     libmbfl/filters/mbfilter_iso8859_15.c
-     libmbfl/filters/mbfilter_iso8859_2.c
-     libmbfl/filters/mbfilter_iso8859_3.c
-     libmbfl/filters/mbfilter_iso8859_4.c
-     libmbfl/filters/mbfilter_iso8859_5.c
-     libmbfl/filters/mbfilter_iso8859_6.c
-     libmbfl/filters/mbfilter_iso8859_7.c
-     libmbfl/filters/mbfilter_iso8859_8.c
-     libmbfl/filters/mbfilter_iso8859_9.c
-     libmbfl/filters/mbfilter_jis.c
-     libmbfl/filters/mbfilter_koi8r.c
-     libmbfl/filters/mbfilter_qprint.c
-     libmbfl/filters/mbfilter_sjis.c
-     libmbfl/filters/mbfilter_ucs2.c
-     libmbfl/filters/mbfilter_ucs4.c
-     libmbfl/filters/mbfilter_uhc.c
-     libmbfl/filters/mbfilter_utf16.c
-     libmbfl/filters/mbfilter_utf32.c
-     libmbfl/filters/mbfilter_utf7.c
-     libmbfl/filters/mbfilter_utf7imap.c
-     libmbfl/filters/mbfilter_utf8.c
-     libmbfl/filters/mbfilter_uuencode.c
-     libmbfl/mbfl/mbfilter.c
-     libmbfl/mbfl/mbfilter_8bit.c
-     libmbfl/mbfl/mbfilter_pass.c
-     libmbfl/mbfl/mbfilter_wchar.c
-     libmbfl/mbfl/mbfl_convert.c
-     libmbfl/mbfl/mbfl_encoding.c
-     libmbfl/mbfl/mbfl_filter_output.c
-     libmbfl/mbfl/mbfl_ident.c
-     libmbfl/mbfl/mbfl_language.c
-     libmbfl/mbfl/mbfl_memory_device.c
-     libmbfl/mbfl/mbfl_string.c
-     libmbfl/mbfl/mbfl_allocators.c
-     libmbfl/nls/nls_de.c
-     libmbfl/nls/nls_en.c
-     libmbfl/nls/nls_ja.c
-     libmbfl/nls/nls_kr.c
-     libmbfl/nls/nls_neutral.c
-     libmbfl/nls/nls_ru.c
-     libmbfl/nls/nls_uni.c
-     libmbfl/nls/nls_zh.c
-    ])
-  fi
-])
-
 PHP_MBSTRING_INIT
 PHP_MBSTRING_SETUP
 PHP_MBSTRING_SETUP_MBREGEX
-PHP_MBSTRING_SETUP_LIBMBFL
 PHP_MBSTRING_EXTENSION
 
Index: php-src/ext/mbstring/mbstring.h
diff -u php-src/ext/mbstring/mbstring.h:1.57 php-src/ext/mbstring/mbstring.h:1.58
--- php-src/ext/mbstring/mbstring.h:1.57        Sat Aug 23 02:18:34 2003
+++ php-src/ext/mbstring/mbstring.h     Sun Aug 24 18:46:13 2003
@@ -16,7 +16,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: mbstring.h,v 1.57 2003/08/23 06:18:34 hirokawa Exp $ */
+/* $Id: mbstring.h,v 1.58 2003/08/24 22:46:13 moriyoshi Exp $ */
 
 /*
  * PHP4 Multibyte String module "mbstring" (currently only for Japanese)
@@ -66,7 +66,7 @@
 
 #if HAVE_MBSTRING
 
-#include "ext/mbstring/libmbfl/mbfl/mbfilter.h"
+#include "mbfilter.h"
 #include "SAPI.h"
 
 #define PHP_MBSTRING_API 20021024

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to