X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fcore%2Fstore-private.h;h=d2ea3f9a08c9f443584a4d021df97e02d1638111;hb=0d7d7ec733f740fa35a41aa857a89abc1b8b8881;hp=6e232ddf145fcc6b76816c98e1bbadd9291288aa;hpb=4a5eb5e9a97fac1ad51a1e7be94c460d2f071ae3;p=sysdb.git diff --git a/src/core/store-private.h b/src/core/store-private.h index 6e232dd..d2ea3f9 100644 --- a/src/core/store-private.h +++ b/src/core/store-private.h @@ -106,6 +106,7 @@ typedef struct { /* * expressions */ + enum { ATTR_VALUE = -2, /* attr name stored in data.data.string */ FIELD_VALUE = -1, /* field type stored in data.data.integer */ @@ -117,6 +118,7 @@ struct sdb_store_expr { sdb_object_t super; int type; /* see above */ + int data_type; sdb_store_expr_t *left; sdb_store_expr_t *right; @@ -134,47 +136,44 @@ enum { MATCHER_OR, MATCHER_AND, MATCHER_NOT, - MATCHER_NAME, - MATCHER_ATTR, - MATCHER_SERVICE, - MATCHER_METRIC, - MATCHER_ATTRIBUTE, - MATCHER_CMP_LT, - MATCHER_CMP_LE, - MATCHER_CMP_EQ, - MATCHER_CMP_NE, - MATCHER_CMP_GE, - MATCHER_CMP_GT, + MATCHER_ANY, + MATCHER_ALL, MATCHER_IN, - MATCHER_REGEX, - MATCHER_NREGEX, + + /* unary operators */ MATCHER_ISNULL, MATCHER_ISNNULL, + + /* ary operators */ + MATCHER_LT, + MATCHER_LE, + MATCHER_EQ, + MATCHER_NE, + MATCHER_GE, + MATCHER_GT, + MATCHER_REGEX, + MATCHER_NREGEX, }; #define MATCHER_SYM(t) \ (((t) == MATCHER_OR) ? "OR" \ : ((t) == MATCHER_AND) ? "AND" \ : ((t) == MATCHER_NOT) ? "NOT" \ - : ((t) == MATCHER_NAME) ? "NAME" \ - : ((t) == MATCHER_ATTR) ? "ATTR" \ - : ((t) == MATCHER_SERVICE) ? "SERVICE" \ - : ((t) == MATCHER_METRIC) ? "METRIC" \ - : ((t) == MATCHER_ATTRIBUTE) ? "ATTRIBUTE" \ - : ((t) == MATCHER_CMP_NE) ? "!=" \ + : ((t) == MATCHER_ANY) ? "ANY" \ + : ((t) == MATCHER_ALL) ? "ALL" \ : ((t) == MATCHER_IN) ? "IN" \ - : ((t) == MATCHER_REGEX) ? "=~" \ - : ((t) == MATCHER_NREGEX) ? "!~" \ : ((t) == MATCHER_ISNULL) ? "IS NULL" \ : ((t) == MATCHER_ISNNULL) ? "IS NOT NULL" \ + : ((t) == MATCHER_LT) ? "<" \ + : ((t) == MATCHER_LE) ? "<=" \ + : ((t) == MATCHER_EQ) ? "=" \ + : ((t) == MATCHER_NE) ? "!=" \ + : ((t) == MATCHER_GE) ? ">=" \ + : ((t) == MATCHER_GT) ? ">" \ + : ((t) == MATCHER_REGEX) ? "=~" \ + : ((t) == MATCHER_NREGEX) ? "!~" \ : "UNKNOWN") -/* match the name of something */ -typedef struct { - char *name; - regex_t *name_re; -} string_matcher_t; - /* matcher base type */ struct sdb_store_matcher { sdb_object_t super; @@ -202,12 +201,13 @@ typedef struct { } uop_matcher_t; #define UOP_M(m) ((uop_matcher_t *)(m)) -/* child matcher */ +/* iter matcher */ typedef struct { sdb_store_matcher_t super; + int type; sdb_store_matcher_t *m; -} child_matcher_t; -#define CHILD_M(m) ((child_matcher_t *)(m)) +} iter_matcher_t; +#define ITER_M(m) ((iter_matcher_t *)(m)) /* compare operator matcher */ typedef struct { @@ -219,23 +219,6 @@ typedef struct { } cmp_matcher_t; #define CMP_M(m) ((cmp_matcher_t *)(m)) -/* match any type of object by it's name */ -typedef struct { - sdb_store_matcher_t super; - - int obj_type; - string_matcher_t name; -} name_matcher_t; -#define NAME_M(m) ((name_matcher_t *)(m)) - -/* match attributes */ -typedef struct { - sdb_store_matcher_t super; - char *name; - string_matcher_t value; -} attr_matcher_t; -#define ATTR_M(m) ((attr_matcher_t *)(m)) - typedef struct { sdb_store_matcher_t super; sdb_store_expr_t *expr;