00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #include "bdb.h"
00030
00031 int bdb_srow_db2bdb(db_con_t* _h, db_key_t* _k, db_op_t* _op, db_val_t* _v, int _n, bdb_srow_p *_r)
00032 {
00033 bdb_srow_p r;
00034 bdb_table_p t;
00035 bdb_column_p c;
00036
00037 int found;
00038 int use_key, found_key, key_idx;
00039 int i;
00040 int c_idx;
00041 bdb_sval_p v;
00042
00043 *_r = NULL;
00044
00045 if ((t = bdb_find_table(CON_TABLE(_h))) == NULL) {
00046 #ifdef BDB_EXTRA_DEBUG
00047 LOG(L_ERR, "BDB:bdb_srow_db2bdb: no table in use\n");
00048 #endif
00049 return -1;
00050 };
00051
00052 key_idx = -1;
00053 use_key = 0;
00054
00055
00056 for (i = 0; i < _n; i++) {
00057 found = 0;
00058
00059 for (c = t->cols, found_key = 1; c != NULL; c = c->next, found_key = 0) {
00060 if (!strcmp(_k[i], c->name.s)) {
00061 found = 1;
00062 break;
00063 }
00064 }
00065 if (found_key == 1) {
00066
00067 if (!use_key && (_op == NULL || (_op != NULL && !strcmp(_op[i], OP_EQ)))) {
00068 key_idx = i;
00069 use_key = 1;
00070 }
00071 }
00072 if (!found) {
00073 LOG(L_ERR, "BDB:bdb_srow_db2bdb: column '%s' does not exist\n", _k[i]);
00074 return -1;
00075 }
00076 }
00077
00078 r = pkg_malloc(sizeof(*r));
00079 memset(r, 0, sizeof(*r));
00080
00081
00082 for (c = t->cols, c_idx = 0; c != NULL; c = c->next, c_idx++) {
00083 for (i = 0; i < _n; i++) {
00084 if (!strcmp(_k[i], c->name.s)) {
00085 #ifdef BDB_EXTRA_DEBUG
00086 LOG(L_NOTICE, "BDB:bdb_srow_db2bdb: filling column '%.*s', c_idx = %0d\n", c->name.len, c->name.s, c_idx);
00087 #endif
00088 v = pkg_malloc(sizeof(*v));
00089 memset(v, 0, sizeof(*v));
00090
00091 v->c_idx = c_idx;
00092
00093 bdb_push_sfield(r, v);
00094
00095 if (bdb_sfield_db2bdb(v, &_v[i], (!_op) ? NULL : _op[i]) < 0) {
00096 bdb_free_srow(r);
00097 return -1;
00098 };
00099
00100 if (use_key && i == key_idx) {
00101 bdb_set_skey(r, v);
00102 }
00103 }
00104 }
00105 };
00106
00107 *_r = r;
00108
00109 return 0;
00110 };
00111
00112
00113 void bdb_free_srow(bdb_srow_p _r)
00114 {
00115 if (_r->fields != NULL) {
00116 bdb_free_sfield_list(_r->fields);
00117 }
00118
00119 pkg_free(_r);
00120 };
00121
00122
00123 void bdb_free_sfield(bdb_sval_p _v)
00124 {
00125 if (!VAL_NULL(&(_v->v))) {
00126 if (VAL_TYPE(&(_v->v)) == DB_STR || VAL_TYPE(&(_v->v)) == DB_STRING ||
00127 VAL_TYPE(&(_v->v)) == DB_BLOB) {
00128 pkg_free(VAL_STR(&(_v->v)).s);
00129 }
00130 }
00131 pkg_free(_v);
00132 };
00133
00134
00135 void bdb_free_sfield_list(bdb_sval_p _v)
00136 {
00137 bdb_sval_p curr, next;
00138
00139 for (curr = _v; curr != NULL;) {
00140 next = curr->next;
00141 bdb_free_sfield(curr);
00142 curr = next;
00143 }
00144 };
00145
00146
00147 void bdb_push_sfield(bdb_srow_p _r, bdb_sval_p _v)
00148 {
00149 bdb_sval_p f;
00150
00151 if (_r->fields == NULL) {
00152 _r->fields = _v;
00153 return;
00154 }
00155 f = _r->fields;
00156 while (f->next != NULL) {
00157 f = f->next;
00158 }
00159 f->next = _v;
00160 };
00161
00162
00163 void bdb_set_skey(bdb_srow_p _r, bdb_sval_p _v)
00164 {
00165
00166 if (VAL_NULL(&(_v->v)))
00167 return;
00168
00169 switch (VAL_TYPE(&(_v->v))) {
00170 case DB_INT:
00171 _r->key.data = &VAL_INT(&(_v->v));
00172 _r->key.size = sizeof(VAL_INT(&(_v->v)));
00173 break;
00174 case DB_FLOAT:
00175 _r->key.data = &VAL_FLOAT(&(_v->v));
00176 _r->key.size = sizeof(VAL_FLOAT(&(_v->v)));
00177 break;
00178 case DB_DATETIME:
00179 _r->key.data = &VAL_TIME(&(_v->v));
00180 _r->key.size = sizeof(VAL_TIME(&(_v->v)));
00181 break;
00182 case DB_BLOB:
00183 _r->key.data = VAL_BLOB(&(_v->v)).s;
00184 _r->key.size = VAL_BLOB(&(_v->v)).len;
00185 break;
00186 case DB_DOUBLE:
00187 _r->key.data = &VAL_DOUBLE(&(_v->v));
00188 _r->key.size = sizeof(VAL_DOUBLE(&(_v->v)));
00189 break;
00190 case DB_STRING:
00191 _r->key.data = (void *)VAL_STRING(&(_v->v));
00192 _r->key.size = strlen(VAL_STRING(&(_v->v))) + 1;
00193 break;
00194 case DB_STR:
00195 _r->key.data = VAL_STR(&(_v->v)).s;
00196 _r->key.size = VAL_STR(&(_v->v)).len;
00197 break;
00198 case DB_BITMAP:
00199 _r->key.data = &VAL_BITMAP(&(_v->v));
00200 _r->key.size = sizeof(VAL_BITMAP(&(_v->v)));
00201 break;
00202 default:
00203 LOG(L_ERR, "BDB:bdb_set_skey: unknown column type: %0X\n", VAL_TYPE(&(_v->v)));
00204 break;
00205 }
00206
00207 #ifdef BDB_EXTRA_DEBUG
00208 LOG(L_NOTICE, "BDB:bdb_set_skey: use key '%.*s' (%d bytes)\n", _r->key.size, (char *)_r->key.data, _r->key.size);
00209 #endif
00210 };
00211
00212
00213 int bdb_sfield_db2bdb(bdb_sval_p v, db_val_t* _v, db_op_t _op)
00214 {
00215 char *s;
00216
00217 VAL_NULL(&(v->v)) = VAL_NULL(_v);
00218 VAL_TYPE(&(v->v)) = VAL_TYPE(_v);
00219
00220 if (!VAL_NULL(&(v->v))) {
00221 switch (VAL_TYPE(_v)) {
00222 case DB_INT:
00223 VAL_INT(&(v->v)) = VAL_INT(_v);
00224 break;
00225 case DB_FLOAT:
00226 VAL_FLOAT(&(v->v)) = VAL_FLOAT(_v);
00227 break;
00228 case DB_DATETIME:
00229 VAL_TIME(&(v->v)) = VAL_TIME(_v);
00230 break;
00231 case DB_BLOB:
00232 s = pkg_malloc(VAL_BLOB(_v).len);
00233 memcpy(s, VAL_BLOB(_v).s, VAL_BLOB(_v).len);
00234 VAL_BLOB(&(v->v)).s = s;
00235 VAL_BLOB(&(v->v)).len = VAL_BLOB(_v).len;
00236 break;
00237 case DB_DOUBLE:
00238 VAL_DOUBLE(&(v->v)) = VAL_DOUBLE(_v);
00239 break;
00240 case DB_STRING:
00241 VAL_STR(&(v->v)).len = strlen(VAL_STRING(_v)) + 1;
00242 s = pkg_malloc(VAL_STR(&(v->v)).len);
00243 strcpy(s, VAL_STRING(_v));
00244 VAL_STRING(&(v->v)) = s;
00245 break;
00246 case DB_STR:
00247 s = pkg_malloc(VAL_STR(_v).len);
00248 memcpy(s, VAL_STR(_v).s, VAL_STR(_v).len);
00249 VAL_STR(&(v->v)).s = s;
00250 VAL_STR(&(v->v)).len = VAL_STR(_v).len;
00251 break;
00252 case DB_BITMAP:
00253 VAL_BITMAP(&(v->v)) = VAL_BITMAP(_v);
00254 break;
00255 default:
00256 LOG(L_ERR, "BDB:bdb_sfield_db2bdb: unknown column type: %0X\n", VAL_TYPE(_v));
00257 return -1;
00258 break;
00259 }
00260
00261 if (!_op || !strcmp(_op, OP_EQ)) {
00262 v->op = BDB_OP_EQ;
00263 } else if (!strcmp(_op, OP_LT)) {
00264 v->op = BDB_OP_LT;
00265 } else if (!strcmp(_op, OP_GT)) {
00266 v->op = BDB_OP_GT;
00267 } else if (!strcmp(_op, OP_LEQ)) {
00268 v->op = BDB_OP_LEQ;
00269 } else if (!strcmp(_op, OP_GEQ)) {
00270 v->op = BDB_OP_GEQ;
00271 } else {
00272 LOG(L_ERR, "BDB:sbdb_field_db2bdb: unknown operator: %s\n", _op);
00273 return -1;
00274 }
00275 }
00276
00277 return 0;
00278 };
00279
00280