helly           Thu Dec 18 15:25:21 2003 EDT

  Added files:                 
    /php-src/ext/dba    dba_qdbm.c 
    /php-src/ext/dba/tests      dba_qdbm.phpt 

  Modified files:              
    /php-src    NEWS 
    /php-src/ext/dba    config.m4 dba.c 
  Log:
  dded qdbm handler (http://qdbm.sourceforge.net).
  
  
Index: php-src/NEWS
diff -u php-src/NEWS:1.1545 php-src/NEWS:1.1546
--- php-src/NEWS:1.1545 Thu Dec 18 15:07:29 2003
+++ php-src/NEWS        Thu Dec 18 15:25:19 2003
@@ -18,6 +18,7 @@
   support is used. (Derick)
 - Added iconv stream filter (convert.iconv.*). (Moriyoshi)
 - Added EXSLT support in ext/xsl. (Christian)
+- Added qdbm handler for dba extension. (mg at iceni dot pl, Marcus)
 - Added new functions:
   . dba_key_split() to split inifile keys in an array. (Marcus)
   . time_nanosleep() signal safe sleep (Magnus, Ilia)
Index: php-src/ext/dba/config.m4
diff -u php-src/ext/dba/config.m4:1.58 php-src/ext/dba/config.m4:1.59
--- php-src/ext/dba/config.m4:1.58      Sun Dec  7 10:59:13 2003
+++ php-src/ext/dba/config.m4   Thu Dec 18 15:25:20 2003
@@ -1,5 +1,5 @@
 dnl
-dnl $Id: config.m4,v 1.58 2003/12/07 15:59:13 helly Exp $
+dnl $Id: config.m4,v 1.59 2003/12/18 20:25:20 helly Exp $
 dnl
 
 dnl Suppose we need FlatFile if no support or only CDB is used.
@@ -65,10 +65,45 @@
 PHP_ARG_ENABLE(dba,whether to enable DBA,
 [  --enable-dba            Build DBA with builtin modules])
 
+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)
+
 AC_ARG_WITH(gdbm,
 [  --with-gdbm[=DIR]         DBA: Include GDBM support],[
   if test "$withval" != "no"; then
     PHP_DBA_STD_BEGIN
+    if test "$HAVE_QDBM" = "1"; then
+      AC_DBA_STD_RESULT(gdbm,gdbm,You cannot combine --with-gdbm with --with-qdbm)
+    fi
     for i in $withval /usr/local /usr; do
       if test -f "$i/include/gdbm.h"; then
         THIS_PREFIX=$i
@@ -300,6 +335,9 @@
 [  --with-dbm[=DIR]          DBA: Include DBM support],[
   if test "$withval" != "no"; then
     PHP_DBA_STD_BEGIN
+    if test "$HAVE_QDBM" = "1"; then
+      AC_DBA_STD_RESULT(dbm,dbm,You cannot combine --with-dbm with --with-qdbm)
+    fi
     for i in $withval /usr/local /usr; do
       if test -f "$i/include/dbm.h"; then
         THIS_PREFIX=$i
@@ -429,7 +467,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)
Index: php-src/ext/dba/dba.c
diff -u php-src/ext/dba/dba.c:1.107 php-src/ext/dba/dba.c:1.108
--- php-src/ext/dba/dba.c:1.107 Thu Dec 18 15:14:15 2003
+++ php-src/ext/dba/dba.c       Thu Dec 18 15:25:20 2003
@@ -17,7 +17,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: dba.c,v 1.107 2003/12/18 20:14:15 helly Exp $ */
+/* $Id: dba.c,v 1.108 2003/12/18 20:25:20 helly Exp $ */
 
 #ifdef HAVE_CONFIG_H
 #include "config.h"
@@ -48,6 +48,7 @@
 #include "php_db4.h"
 #include "php_flatfile.h"
 #include "php_inifile.h"
+#include "php_qdbm.h"
 
 /* {{{ dba_functions[]
  */
@@ -253,6 +254,9 @@
 #if DBA_FLATFILE
        DBA_HND(flatfile, DBA_STREAM_OPEN|DBA_LOCK_ALL|DBA_NO_APPEND) /* 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 }
 };
 
@@ -270,6 +274,8 @@
 #define DBA_DEFAULT "ndbm"
 #elif DBA_DBM
 #define DBA_DEFAULT "dbm"
+#elif DBA_QDBM
+#define DBA_DEFAULT "qdbm"
 #else
 #define DBA_DEFAULT ""
 #endif

Index: php-src/ext/dba/dba_qdbm.c
+++ php-src/ext/dba/dba_qdbm.c
/*
   +----------------------------------------------------------------------+
   | 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;

        switch(info->mode) {
                case DBA_READER:
                        dbf = dpopen(info->path, DP_OREADER, 0);
                        break;
                case DBA_WRITER:
                        dbf = dpopen(info->path, DP_OWRITER, 0);
                        break;
                case DBA_CREAT:
                        dbf = dpopen(info->path, DP_OWRITER | DP_OCREAT, 0);
                        break;
                case DBA_TRUNC:
                        dbf = dpopen(info->path, DP_OWRITER | DP_OCREAT | DP_OTRUNC, 
0);
                        break;
                default:
                        return FAILURE;
        }

        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
 */

Index: php-src/ext/dba/tests/dba_qdbm.phpt
+++ php-src/ext/dba/tests/dba_qdbm.phpt
--TEST--
DBA QDBM handler test
--SKIPIF--
<?php
        $handler = 'qdbm';
        require_once('skipif.inc');
?>
--FILE--
<?php
        $handler = 'qdbm';
        require_once('test.inc');
        $lock_flag = ''; // lock in library
        require_once('dba_handler.inc');
?>
===DONE===
--EXPECTF--
database handler: qdbm
3NYNYY
Content String 2
Content 2 replaced
Read during write:%sallowed
Content 2 replaced 2nd time
The 6th value
array(3) {
  ["key number 6"]=>
  string(13) "The 6th value"
  ["key2"]=>
  string(27) "Content 2 replaced 2nd time"
  ["key5"]=>
  string(23) "The last content string"
}

Warning: dba_popen(%stest0.dbm,r-): Locking cannot be disabled for handler qdbm in 
%sdba_handler.inc on line %d
===DONE===

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

Reply via email to