X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fpquery.c;h=65dcdd126a77428c27aa29e6408fb4e1926767d4;hp=3b416bb01cc5ec17f0dc0fd37d5dd7c46b9c613f;hb=b6aa93dcb5c07ed09b664c006b5f33b0135a0854;hpb=d2f977c26e0b16c544b69339c34ca9300b55b749 diff --git a/src/pquery.c b/src/pquery.c index 3b416bb..65dcdd1 100644 --- a/src/pquery.c +++ b/src/pquery.c @@ -823,6 +823,73 @@ Z_AttributeList *yaz_pqf_scan_attribute_list(YAZ_PQF_Parser p, ODR o, return p_query_scan_attributes_mk(p, o, attributeSetP); } +static Z_FacetField* parse_facet(ODR odr, const char *facet, int length) +{ + YAZ_PQF_Parser pqf_parser = yaz_pqf_create(); + char *buffer = odr_strdupn(odr, facet, length); + Odr_oid *attributeSetId; + Z_FacetField *facet_field = 0; + Z_AttributeList *attribute_list = + yaz_pqf_scan_attribute_list(pqf_parser, odr, &attributeSetId, buffer); + + if (attribute_list) + { + facet_field = odr_malloc(odr, sizeof(*facet_field)); + facet_field->attributes = attribute_list; + facet_field->num_terms = 0; + facet_field->terms = 0; + } + yaz_pqf_destroy(pqf_parser); + return facet_field; +} + +#define FACET_DElIMITER ',' + +static int scan_facet_argument(const char *arg) { + int index; + int length = strlen(arg); + int count = 1; + for (index = 0; index < length; index++) { + if (arg[index] == FACET_DElIMITER) + count++; + } + return count; +} + +/** + * yax_pdg_parse_facet_list: Parses a comma-separated list of AttributeList(s) into a FacetList. + * It does not handle the optional facet term(s). + * + */ +Z_FacetList *yaz_pqf_parse_facet_list(ODR odr, const char *facet) { + Z_FacetList *facet_list = 0; + Z_FacetField **elements; + int index = 0; + int num_elements = scan_facet_argument(facet); + if (num_elements == 0) + return facet_list; + facet_list = odr_malloc(odr, sizeof(*facet_list)); + facet_list->num = num_elements; + elements = odr_malloc(odr, num_elements * sizeof(*elements)); + facet_list->elements = elements; + for (index = 0; index < num_elements;) { + const char *pos = strchr(facet, FACET_DElIMITER); + if (pos == 0) + pos = facet + strlen(facet); + elements[index] = parse_facet(odr, (const char *) facet, (pos - facet)); + if (elements[index]) { + index++; + } + else { + num_elements--; + facet_list->num = num_elements; + } + facet = pos + 1; + } + return facet_list; +} + + int yaz_pqf_error(YAZ_PQF_Parser p, const char **msg, size_t *off) {