php-internal-docs 8.4.8
Unofficial docs for php/php-src
Loading...
Searching...
No Matches
dba_db1.c
Go to the documentation of this file.
1/*
2 +----------------------------------------------------------------------+
3 | Copyright (c) The PHP Group |
4 +----------------------------------------------------------------------+
5 | This source file is subject to version 3.01 of the PHP license, |
6 | that is bundled with this package in the file LICENSE, and is |
7 | available through the world-wide-web at the following url: |
8 | https://www.php.net/license/3_01.txt |
9 | If you did not receive a copy of the PHP license and are unable to |
10 | obtain it through the world-wide-web, please send a note to |
11 | license@php.net so we can mail you a copy immediately. |
12 +----------------------------------------------------------------------+
13 | Author: Shen Cheng-Da <cdsheen@gmail.com> |
14 +----------------------------------------------------------------------+
15 */
16
17#ifdef HAVE_CONFIG_H
18#include <config.h>
19#endif
20
21#include "php.h"
22
23#ifdef DBA_DB1
24#include "php_db1.h"
25
26#ifdef DB1_INCLUDE_FILE
27#include DB1_INCLUDE_FILE
28#endif
29
30#include <sys/types.h>
31#include <sys/stat.h>
32#include <fcntl.h>
33
34typedef struct {
35 DB *dbp;
36} dba_db1_data;
37
38DBA_OPEN_FUNC(db1)
39{
40 dba_db1_data *dba;
41 DB *db;
42
43 int gmode;
44 int filemode = info->file_permission;
45
46 gmode = 0;
47 switch (info->mode) {
48 case DBA_READER:
49 gmode = O_RDONLY;
50 break;
51 case DBA_WRITER:
52 gmode = O_RDWR;
53 break;
54 case DBA_CREAT:
55 gmode = O_RDWR | O_CREAT;
56 break;
57 case DBA_TRUNC:
58 gmode = O_RDWR | O_CREAT | O_TRUNC;
59 break;
60 default:
61 return FAILURE; /* not possible */
62 }
63
64 db = dbopen((char *)ZSTR_VAL(info->path), gmode, filemode, DB_HASH, NULL);
65
66 if (db == NULL) {
67 return FAILURE;
68 }
69
70 dba = pemalloc(sizeof(*dba), info->flags&DBA_PERSISTENT);
71 dba->dbp = db;
72
73 info->dbf = dba;
74
75 return SUCCESS;
76}
77
78DBA_CLOSE_FUNC(db1)
79{
80 dba_db1_data *dba = info->dbf;
81 dba->dbp->close(dba->dbp);
82 pefree(info->dbf, info->flags&DBA_PERSISTENT);
83}
84
85DBA_FETCH_FUNC(db1)
86{
87 dba_db1_data *dba = info->dbf;
88 DBT gval;
89 DBT gkey;
90
91 gkey.data = ZSTR_VAL(key);
92 gkey.size = ZSTR_LEN(key);
93
94 memset(&gval, 0, sizeof(gval));
95 if (dba->dbp->get(dba->dbp, &gkey, &gval, 0) == RET_SUCCESS) {
96 return zend_string_init(gval.data, gval.size, /* persistent */ false);
97 }
98 return NULL;
99}
100
101DBA_UPDATE_FUNC(db1)
102{
103 dba_db1_data *dba = info->dbf;
104 DBT gval;
105 DBT gkey;
106
107 gkey.data = ZSTR_VAL(key);
108 gkey.size = ZSTR_LEN(key);
109
110 gval.data = ZSTR_VAL(val);
111 gval.size = ZSTR_LEN(val);
112
113 return dba->dbp->put(dba->dbp, &gkey, &gval, mode == 1 ? R_NOOVERWRITE : 0) != RET_SUCCESS ? FAILURE : SUCCESS;
114}
115
116DBA_EXISTS_FUNC(db1)
117{
118 dba_db1_data *dba = info->dbf;
119 DBT gval;
120 DBT gkey;
121
122 gkey.data = ZSTR_VAL(key);
123 gkey.size = ZSTR_LEN(key);
124
125 return dba->dbp->get(dba->dbp, &gkey, &gval, 0) != RET_SUCCESS ? FAILURE : SUCCESS;
126}
127
128DBA_DELETE_FUNC(db1)
129{
130 dba_db1_data *dba = info->dbf;
131 DBT gkey;
132
133 gkey.data = ZSTR_VAL(key);
134 gkey.size = ZSTR_LEN(key);
135
136 return dba->dbp->del(dba->dbp, &gkey, 0) != RET_SUCCESS ? FAILURE : SUCCESS;
137}
138
139DBA_FIRSTKEY_FUNC(db1)
140{
141 dba_db1_data *dba = info->dbf;
142 DBT gkey;
143 DBT gval;
144
145 memset(&gkey, 0, sizeof(gkey));
146 memset(&gval, 0, sizeof(gval));
147
148 if (dba->dbp->seq(dba->dbp, &gkey, &gval, R_FIRST) == RET_SUCCESS) {
149 return zend_string_init(gkey.data, gkey.size, /* persistent */ false);
150 }
151 return NULL;
152}
153
154DBA_NEXTKEY_FUNC(db1)
155{
156 dba_db1_data *dba = info->dbf;
157 DBT gkey;
158 DBT gval;
159
160 memset(&gkey, 0, sizeof(gkey));
161 memset(&gval, 0, sizeof(gval));
162
163 if (dba->dbp->seq(dba->dbp, &gkey, &gval, R_NEXT) == RET_SUCCESS) {
164 return zend_string_init(gkey.data, gkey.size, /* persistent */ false);
165 }
166 return NULL;
167}
168
169DBA_OPTIMIZE_FUNC(db1)
170{
171 /* dummy */
172 return SUCCESS;
173}
174
175DBA_SYNC_FUNC(db1)
176{
177 return SUCCESS;
178}
179
180DBA_INFO_FUNC(db1)
181{
182 return estrdup(DB1_VERSION);
183}
184
185#endif
memset(ptr, 0, type->size)
zval * val
Definition ffi.c:4262
char * mode
#define NULL
Definition gdcache.h:45
#define SUCCESS
Definition hash_sha3.c:261
#define DB(x)
Definition ir_gdb.c:289
#define gval(n)
Definition minilua.c:766
#define gkey(n)
Definition minilua.c:765
unsigned char key[REFLECTION_KEY_LEN]
#define estrdup(s)
Definition zend_alloc.h:164
#define pefree(ptr, persistent)
Definition zend_alloc.h:191
#define pemalloc(size, persistent)
Definition zend_alloc.h:189
#define ZSTR_VAL(zstr)
Definition zend_string.h:68
#define ZSTR_LEN(zstr)
Definition zend_string.h:69
@ FAILURE
Definition zend_types.h:61