X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fcqltransform.c;h=90dcb37617c4cd334a3eb278d6c9a2c6be02d9a2;hp=efb15e80a8767f3e10e437bfe35dbebd9d26fece;hb=1d174be5d92bd388583905b152b0183665460bf6;hpb=0c46d2e66bdeea1600e700124a81a5d0a65d349e diff --git a/src/cqltransform.c b/src/cqltransform.c index efb15e8..90dcb37 100644 --- a/src/cqltransform.c +++ b/src/cqltransform.c @@ -586,7 +586,6 @@ static int has_modifier(struct cql_node *cn, const char *name) { return 0; } - static void emit_term(cql_transform_t ct, struct cql_node *cn, const char *term, int length, @@ -600,6 +599,8 @@ static void emit_term(cql_transform_t ct, if (has_modifier(cn, "regexp")) process_term = 0; + else if (has_modifier(cn, "unmasked")) + process_term = 0; else if (cql_lookup_property(ct, "truncation", 0, "cql")) { process_term = 0; @@ -609,7 +610,7 @@ static void emit_term(cql_transform_t ct, assert(cn->which == CQL_NODE_ST); if (process_term) - { + { /* convert term via truncation.things */ unsigned anchor = 0; unsigned trunc = 0; for (i = 0; i < length; i++) @@ -761,29 +762,10 @@ static void emit_term(cql_transform_t ct, static void emit_terms(cql_transform_t ct, struct cql_node *cn, void (*pr)(const char *buf, void *client_data), - void *client_data, - const char *op) + void *client_data) { - struct cql_node *ne = cn->u.st.extra_terms; - if (ne) - { - (*pr)("@", client_data); - (*pr)(op, client_data); - (*pr)(" ", client_data); - } emit_term(ct, cn, cn->u.st.term, strlen(cn->u.st.term), pr, client_data); - for (; ne; ne = ne->u.st.extra_terms) - { - if (ne->u.st.extra_terms) - { - (*pr)("@", client_data); - (*pr)(op, client_data); - (*pr)(" ", client_data); - } - emit_term(ct, cn, ne->u.st.term, strlen(ne->u.st.term), - pr, client_data); - } } static void emit_wordlist(cql_transform_t ct, @@ -862,7 +844,7 @@ void cql_transform_r(cql_transform_t ct, else if (cn->u.st.relation && !cql_strcmp(cn->u.st.relation, "any")) emit_wordlist(ct, cn, pr, client_data, "or"); else - emit_terms(ct, cn, pr, client_data, "and"); + emit_terms(ct, cn, pr, client_data); break; case CQL_NODE_BOOL: (*pr)("@", client_data);