Code

store: Fixed handling of metric store values.
[sysdb.git] / src / core / data.c
index 914946fbec6761d3e7b4345742ddbd63668106c1..44353057b5df70bcb8db19da6600166d4786500d 100644 (file)
@@ -668,12 +668,6 @@ sdb_data_strcmp(const sdb_data_t *d1, const sdb_data_t *d2)
        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))
@@ -787,9 +781,28 @@ sdb_data_array_get(const sdb_data_t *array, size_t i, sdb_data_t *value)
                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;
        }