> The patch in attachment adds QDBM support for dba functions. It is based on

Oops, something killed whitespace formatting... attaching corrected patch.

-- 
mg
diff -U 3 -H -d -r -N -a -- php-4.3.3-old/ext/dba/config.m4 php-4.3.3/ext/dba/config.m4
--- php-4.3.3-old/ext/dba/config.m4	2003-09-22 01:23:28.000000000 +0200
+++ php-4.3.3/ext/dba/config.m4	2003-09-22 01:21:47.000000000 +0200
@@ -129,6 +129,38 @@
 ])
 AC_DBA_STD_RESULT(ndbm)
 
+AC_ARG_WITH(qdbm,
+[  --with-qdbm[=DIR]         DBA: Include QDBM support],[
+  if test "$withval" != "no"; then
+    PHP_DBA_STD_BEGIN
+    for i in $withval /usr/local /usr; do
+      if test -f "$i/include/depot.h"; then
+        THIS_PREFIX=$i
+        THIS_INCLUDE=$i/include/depot.h
+        break
+      fi
+    done
+
+    if test -n "$THIS_INCLUDE"; then
+      for LIB in qdbm; do
+        PHP_CHECK_LIBRARY($LIB, dpopen, [
+          AC_DEFINE_UNQUOTED(QDBM_INCLUDE_FILE, "$THIS_INCLUDE", [ ])
+          AC_DEFINE(DBA_QDBM, 1, [ ])
+          THIS_LIBS=$LIB
+        ], [], [-L$THIS_PREFIX/lib])
+        if test -n "$THIS_LIBS"; then
+          break
+        fi
+      done
+    fi
+
+    PHP_DBA_STD_ASSIGN
+    PHP_DBA_STD_CHECK
+    PHP_DBA_STD_ATTACH
+  fi
+])
+AC_DBA_STD_RESULT(qdbm)
+
 dnl Berkeley specific (library and version test)
 dnl parameters(version, library list, function)
 AC_DEFUN(PHP_DBA_DB_CHECK,[
@@ -429,7 +461,7 @@
 if test "$HAVE_DBA" = "1"; then
   AC_MSG_RESULT(yes)
   AC_DEFINE(HAVE_DBA, 1, [ ])
-  PHP_NEW_EXTENSION(dba, dba.c dba_cdb.c dba_db2.c dba_dbm.c dba_gdbm.c dba_ndbm.c dba_db3.c dba_db4.c dba_flatfile.c dba_inifile.c $cdb_sources $flat_sources $ini_sources, $ext_shared)
+  PHP_NEW_EXTENSION(dba, dba.c dba_cdb.c dba_db2.c dba_dbm.c dba_gdbm.c dba_ndbm.c dba_db3.c dba_db4.c dba_flatfile.c dba_inifile.c dba_qdbm.c $cdb_sources $flat_sources $ini_sources, $ext_shared)
   PHP_ADD_BUILD_DIR($ext_builddir/libinifile)
   PHP_ADD_BUILD_DIR($ext_builddir/libcdb)
   PHP_ADD_BUILD_DIR($ext_builddir/libflatfile)
diff -U 3 -H -d -r -N -a -- php-4.3.3-old/ext/dba/dba.c php-4.3.3/ext/dba/dba.c
--- php-4.3.3-old/ext/dba/dba.c	2003-09-22 01:23:28.000000000 +0200
+++ php-4.3.3/ext/dba/dba.c	2003-09-22 01:16:00.000000000 +0200
@@ -48,6 +48,7 @@
 #include "php_db4.h"
 #include "php_flatfile.h"
 #include "php_inifile.h"
+#include "php_qdbm.h"
 
 /* {{{ dba_functions[]
  */
@@ -252,6 +253,9 @@
 #if DBA_FLATFILE
 	DBA_HND(flatfile, DBA_STREAM_OPEN|DBA_LOCK_ALL) /* No lock in lib */
 #endif
+#if DBA_QDBM
+	DBA_HND(qdbm, DBA_LOCK_EXT)
+#endif
 	{ NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL }
 };
 
@@ -269,6 +273,8 @@
 #define DBA_DEFAULT "ndbm"
 #elif DBA_DBM
 #define DBA_DEFAULT "dbm"
+#elif DBA_QDBM
+#define DBA_DEFAULT "qdbm"
 #else
 #define DBA_DEFAULT ""
 #endif
diff -U 3 -H -d -r -N -a -- php-4.3.3-old/ext/dba/dba_qdbm.c php-4.3.3/ext/dba/dba_qdbm.c
--- php-4.3.3-old/ext/dba/dba_qdbm.c	1970-01-01 01:00:00.000000000 +0100
+++ php-4.3.3/ext/dba/dba_qdbm.c	2003-09-22 01:57:49.000000000 +0200
@@ -0,0 +1,186 @@
+/*
+   +----------------------------------------------------------------------+
+   | PHP Version 4                                                        |
+   +----------------------------------------------------------------------+
+   | Copyright (c) 1997-2003 The PHP Group                                |
+   +----------------------------------------------------------------------+
+   | This source file is subject to version 2.02 of the PHP license,      |
+   | that is bundled with this package in the file LICENSE, and is        |
+   | available at through the world-wide-web at                           |
+   | http://www.php.net/license/2_02.txt.                                 |
+   | If you did not receive a copy of the PHP license and are unable to   |
+   | obtain it through the world-wide-web, please send a note to          |
+   | [EMAIL PROTECTED] so we can mail you a copy immediately.               |
+   +----------------------------------------------------------------------+
+   | Author: Marcin Gibula <[EMAIL PROTECTED]>                                  |
+   +----------------------------------------------------------------------+
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include "php.h"
+
+#if DBA_QDBM
+#include "php_qdbm.h"
+
+#ifdef QDBM_INCLUDE_FILE
+#include QDBM_INCLUDE_FILE
+#endif
+
+#define QDBM_DATA dba_qdbm_data *dba = info->dbf
+
+typedef struct {
+	DEPOT *dbf;
+} dba_qdbm_data;
+
+DBA_OPEN_FUNC(qdbm)
+{
+	DEPOT *dbf;
+	int dmode = 0;
+
+	dmode = info->mode == DBA_READER ? DP_OREADER :
+		info->mode == DBA_WRITER ? DP_OWRITER :
+		info->mode == DBA_CREAT ? DP_OWRITER | DP_OCREAT :
+		info->mode == DBA_TRUNC ? DP_OWRITER | DP_OTRUNC : -1;
+
+	if (dmode == -1)
+		return FAILURE;
+
+	dbf = dpopen(info->path, dmode, 0);
+
+	if (dbf) {
+		info->dbf = pemalloc(sizeof(dba_qdbm_data), info->flags & DBA_PERSISTENT);
+		memset(info->dbf, 0, sizeof(dba_qdbm_data));
+		((dba_qdbm_data *) info->dbf)->dbf = dbf;
+		return SUCCESS;
+	}
+
+	*error = (char *) dperrmsg(dpecode);
+	return FAILURE;
+}
+
+DBA_CLOSE_FUNC(qdbm)
+{
+	QDBM_DATA;
+
+	dpclose(dba->dbf);
+	pefree(dba, info->flags & DBA_PERSISTENT);
+}
+
+DBA_FETCH_FUNC(qdbm)
+{
+	QDBM_DATA;
+	char *value, *new = NULL;
+	int value_size;
+
+	value = dpget(dba->dbf, key, keylen, 0, -1, &value_size);
+	if (value) {
+		if (newlen) *newlen = value_size;
+		new = estrndup(value, value_size);
+		free(value);
+	}
+
+	return new;
+}
+
+DBA_UPDATE_FUNC(qdbm)
+{
+	QDBM_DATA;
+	int result;
+
+	result = dpput(dba->dbf, key, keylen, val, vallen, mode == 1 ? DP_DKEEP : DP_DOVER);
+	if (result)
+    	return SUCCESS;
+
+	php_error_docref2(NULL TSRMLS_CC, key, val, E_WARNING, "%s", dperrmsg(dpecode));
+	return FAILURE;
+}
+
+DBA_EXISTS_FUNC(qdbm)
+{
+	QDBM_DATA;
+	char *value;
+
+	value = dpget(dba->dbf, key, keylen, 0, -1, NULL);
+	if (value) {
+		free(value);
+		return SUCCESS;
+	}
+
+	return FAILURE;
+}
+
+DBA_DELETE_FUNC(qdbm)
+{
+	QDBM_DATA;
+
+	return dpout(dba->dbf, key, keylen) ? SUCCESS : FAILURE;
+}
+
+DBA_FIRSTKEY_FUNC(qdbm)
+{
+	QDBM_DATA;
+	int value_size;
+	char *value, *new = NULL;
+
+	dpiterinit(dba->dbf);
+
+	value = dpiternext(dba->dbf, &value_size);
+	if (value) {
+		if (newlen) *newlen = value_size;
+		new = estrndup(value, value_size);
+		free(value);
+	}
+
+	return new;
+}
+
+DBA_NEXTKEY_FUNC(qdbm)
+{
+	QDBM_DATA;
+	int value_size;
+	char *value, *new = NULL;
+
+	value = dpiternext(dba->dbf, &value_size);
+	if (value) {
+		if (newlen) *newlen = value_size;
+		new = estrndup(value, value_size);
+        free(value);
+	}
+
+	return new;
+}
+
+DBA_OPTIMIZE_FUNC(qdbm)
+{
+	QDBM_DATA;
+
+	dpoptimize(dba->dbf, 0);
+	return SUCCESS;
+}
+
+DBA_SYNC_FUNC(qdbm)
+{
+	QDBM_DATA;
+
+	dpsync(dba->dbf);
+	return SUCCESS;
+}
+
+DBA_INFO_FUNC(qdbm)
+{
+	return estrdup(dpversion);
+}
+
+#endif
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: sw=4 ts=4 fdm=marker
+ * vim<600: sw=4 ts=4
+ */
diff -U 3 -H -d -r -N -a -- php-4.3.3-old/ext/dba/php_qdbm.h php-4.3.3/ext/dba/php_qdbm.h
--- php-4.3.3-old/ext/dba/php_qdbm.h	1970-01-01 01:00:00.000000000 +0100
+++ php-4.3.3/ext/dba/php_qdbm.h	2003-09-22 01:16:00.000000000 +0200
@@ -0,0 +1,12 @@
+#ifndef PHP_QDBM_H
+#define PHP_QDBM_H
+
+#if DBA_QDBM
+
+#include "php_dba.h"
+
+DBA_FUNCS(qdbm);
+
+#endif
+
+#endif

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to