diff --git a/src/core/data.c b/src/core/data.c
index 914946fbec6761d3e7b4345742ddbd63668106c1..44353057b5df70bcb8db19da6600166d4786500d 100644 (file)
--- a/src/core/data.c
+++ b/src/core/data.c
char d1_str[sdb_data_strlen(d1) + 1];
char d2_str[sdb_data_strlen(d2) + 1];
- if ((d1->type & SDB_TYPE_ARRAY) || (d2->type & SDB_TYPE_ARRAY)) {
- /* TODO */
- errno = ENOTSUP;
- return -1;
- }
-
if (sdb_data_isnull(d1))
d1 = NULL;
if (sdb_data_isnull(d2))
char **v = array->data.array.values;
tmp.data.string = v[i];
}
+ else if (type == SDB_TYPE_DATETIME) {
+ sdb_time_t *v = array->data.array.values;
+ tmp.data.datetime = v[i];
+ }
+ else if (type == SDB_TYPE_BINARY) {
+ struct {
+ size_t length;
+ unsigned char *datum;
+ } *v = array->data.array.values;
+ assert(sizeof(tmp.data.binary) == sizeof(v[i]));
+ memcpy(&tmp.data.binary, &v[i], sizeof(v[i]));
+ }
+ else if (type == SDB_TYPE_REGEX) {
+ struct {
+ char *raw;
+ regex_t regex;
+ } *v = array->data.array.values;
+ assert(sizeof(tmp.data.re) == sizeof(v[i]));
+ memcpy(&tmp.data.re, &v[i], sizeof(v[i]));
+ }
else {
- /* TODO */
- errno = ENOTSUP;
+ errno = EINVAL;
return -1;
}