123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- /*
- +----------------------------------------------------------------------+
- | Copyright (c) The PHP Group |
- +----------------------------------------------------------------------+
- | This source file is subject to version 3.01 of the PHP license, |
- | that is bundled with this package in the file LICENSE, and is |
- | available through the world-wide-web at the following url: |
- | https://www.php.net/license/3_01.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 |
- | license@php.net so we can mail you a copy immediately. |
- +----------------------------------------------------------------------+
- | Author: Marcus Boerger <helly@php.net> |
- +----------------------------------------------------------------------+
- */
- #ifdef HAVE_CONFIG_H
- #include "config.h"
- #endif
- #include "php.h"
- #if DBA_FLATFILE
- #include "php_flatfile.h"
- #include "libflatfile/flatfile.h"
- #ifdef HAVE_UNISTD_H
- #include <unistd.h>
- #endif
- #include <sys/types.h>
- #include <sys/stat.h>
- #include <fcntl.h>
- #define FLATFILE_DATA flatfile *dba = info->dbf
- #define FLATFILE_GKEY datum gkey; gkey.dptr = (char *) key; gkey.dsize = keylen
- DBA_OPEN_FUNC(flatfile)
- {
- info->dbf = pemalloc(sizeof(flatfile), info->flags&DBA_PERSISTENT);
- memset(info->dbf, 0, sizeof(flatfile));
- ((flatfile*)info->dbf)->fp = info->fp;
- return SUCCESS;
- }
- DBA_CLOSE_FUNC(flatfile)
- {
- FLATFILE_DATA;
- if (dba->nextkey.dptr) {
- efree(dba->nextkey.dptr);
- }
- pefree(dba, info->flags&DBA_PERSISTENT);
- }
- DBA_FETCH_FUNC(flatfile)
- {
- datum gval;
- char *new = NULL;
- FLATFILE_DATA;
- FLATFILE_GKEY;
- gval = flatfile_fetch(dba, gkey);
- if (gval.dptr) {
- if (newlen) {
- *newlen = gval.dsize;
- }
- new = estrndup(gval.dptr, gval.dsize);
- efree(gval.dptr);
- }
- return new;
- }
- DBA_UPDATE_FUNC(flatfile)
- {
- datum gval;
- FLATFILE_DATA;
- FLATFILE_GKEY;
- gval.dptr = (char *) val;
- gval.dsize = vallen;
- switch(flatfile_store(dba, gkey, gval, mode==1 ? FLATFILE_INSERT : FLATFILE_REPLACE)) {
- case 0:
- return SUCCESS;
- case 1:
- return FAILURE;
- case -1:
- php_error_docref1(NULL, key, E_WARNING, "Operation not possible");
- return FAILURE;
- default:
- php_error_docref2(NULL, key, val, E_WARNING, "Unknown return value");
- return FAILURE;
- }
- }
- DBA_EXISTS_FUNC(flatfile)
- {
- datum gval;
- FLATFILE_DATA;
- FLATFILE_GKEY;
- gval = flatfile_fetch(dba, gkey);
- if (gval.dptr) {
- efree(gval.dptr);
- return SUCCESS;
- }
- return FAILURE;
- }
- DBA_DELETE_FUNC(flatfile)
- {
- FLATFILE_DATA;
- FLATFILE_GKEY;
- return(flatfile_delete(dba, gkey) == -1 ? FAILURE : SUCCESS);
- }
- DBA_FIRSTKEY_FUNC(flatfile)
- {
- FLATFILE_DATA;
- if (dba->nextkey.dptr) {
- efree(dba->nextkey.dptr);
- }
- dba->nextkey = flatfile_firstkey(dba);
- if (dba->nextkey.dptr) {
- if (newlen) {
- *newlen = dba->nextkey.dsize;
- }
- return estrndup(dba->nextkey.dptr, dba->nextkey.dsize);
- }
- return NULL;
- }
- DBA_NEXTKEY_FUNC(flatfile)
- {
- FLATFILE_DATA;
- if (!dba->nextkey.dptr) {
- return NULL;
- }
- if (dba->nextkey.dptr) {
- efree(dba->nextkey.dptr);
- }
- dba->nextkey = flatfile_nextkey(dba);
- if (dba->nextkey.dptr) {
- if (newlen) {
- *newlen = dba->nextkey.dsize;
- }
- return estrndup(dba->nextkey.dptr, dba->nextkey.dsize);
- }
- return NULL;
- }
- DBA_OPTIMIZE_FUNC(flatfile)
- {
- /* dummy */
- return SUCCESS;
- }
- DBA_SYNC_FUNC(flatfile)
- {
- /* dummy */
- return SUCCESS;
- }
- DBA_INFO_FUNC(flatfile)
- {
- return estrdup(flatfile_version());
- }
- #endif
|