diff options
author | Jouni Ahto <jah@php.net> | 2000-06-27 21:36:26 +0000 |
---|---|---|
committer | Jouni Ahto <jah@php.net> | 2000-06-27 21:36:26 +0000 |
commit | 1dfe76f5f6bfb7b866fd0ff88fff0d47ab7251b5 (patch) | |
tree | b6d19e2cab2fc0be1cccea6543fc31bd33b043da /ext/dba | |
parent | c860633741a1931d9f9e5298b21a8dc8efbc0fad (diff) | |
download | php-git-1dfe76f5f6bfb7b866fd0ff88fff0d47ab7251b5.tar.gz |
- dba_[p]open accepts now a new parameter, which kind of database to create
(DBA_BTREE or DBA_HASH), if the handler is either 'db2' or 'db3' and
mode 'c' or 'n'. It is ignored if mode is 'c' and the db already exists.
# Asked on the list 4 1/2 hours ago if anyone's got to say something to this,
# no response, so I'm assuming it's ok. And yes, I did test this.
Diffstat (limited to 'ext/dba')
-rw-r--r-- | ext/dba/dba.c | 3 | ||||
-rw-r--r-- | ext/dba/dba_db2.c | 15 | ||||
-rw-r--r-- | ext/dba/dba_db3.c | 15 | ||||
-rw-r--r-- | ext/dba/php_dba.h | 6 |
4 files changed, 39 insertions, 0 deletions
diff --git a/ext/dba/dba.c b/ext/dba/dba.c index b84de998c9..934b801e7e 100644 --- a/ext/dba/dba.c +++ b/ext/dba/dba.c @@ -191,6 +191,9 @@ static PHP_MINIT_FUNCTION(dba) zend_hash_init(&ht_keys, 0, NULL, NULL, 1); GLOBAL(le_db) = register_list_destructors(dba_close, NULL); GLOBAL(le_pdb) = register_list_destructors(NULL, dba_close); + REGISTER_LONG_CONSTANT("DBA_BTREE", DBA_BTREE, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("DBA_HASH", DBA_HASH, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("DBA_RECNO", DBA_RECNO, CONST_CS | CONST_PERSISTENT); return SUCCESS; } diff --git a/ext/dba/dba_db2.c b/ext/dba/dba_db2.c index de68974358..67eb366c60 100644 --- a/ext/dba/dba_db2.c +++ b/ext/dba/dba_db2.c @@ -76,6 +76,21 @@ DBA_OPEN_FUNC(db2) filemode = (*info->argv[0])->value.lval; } + if(info->argc > 1 + && ((info->mode == DBA_CREAT && type != DB_UNKNOWN) + || info->mode == DBA_TRUNC)) { + convert_to_long_ex(info->argv[1]); + switch ((*info->argv[1])->value.lval) { + case DBA_HASH: + type = DB_HASH; + break; + case DBA_BTREE: + default: + type = DB_BTREE; + break; + } + } + if(!db_open(info->path, type, gmode, filemode, NULL, NULL, &dbp)) { info->dbf = malloc(sizeof(dba_db2_data)); memset(info->dbf, 0, sizeof(dba_db2_data)); diff --git a/ext/dba/dba_db3.c b/ext/dba/dba_db3.c index ae1405705d..809c5408eb 100644 --- a/ext/dba/dba_db3.c +++ b/ext/dba/dba_db3.c @@ -76,6 +76,21 @@ DBA_OPEN_FUNC(db3) filemode = (*info->argv[0])->value.lval; } + if(info->argc > 1 + && ((info->mode == DBA_CREAT && type != DB_UNKNOWN) + || info->mode == DBA_TRUNC)) { + convert_to_long_ex(info->argv[1]); + switch ((*info->argv[1])->value.lval) { + case DBA_HASH: + type = DB_HASH; + break; + case DBA_BTREE: + default: + type = DB_BTREE; + break; + } + } + if (db_create(&dbp, NULL, 0) == 0 && dbp->open(dbp, info->path, NULL, type, gmode, filemode) == 0) { dba_db3_data *data; diff --git a/ext/dba/php_dba.h b/ext/dba/php_dba.h index a504e972d1..0eeb38c027 100644 --- a/ext/dba/php_dba.h +++ b/ext/dba/php_dba.h @@ -41,6 +41,12 @@ typedef enum { DBA_CREAT } dba_mode_t; +typedef enum { + DBA_BTREE = 1, + DBA_HASH, + DBA_RECNO +} dba_type_t; + typedef struct dba_info { /* public */ void *dbf; /* ptr to private data or whatever */ |