X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=include%2Fyaz%2Fcql.h;h=cd36fe977cb992ecc2e46d68cb3370ff5b9e720c;hp=84c4827bf8a0c1f78c7bffd1ad4d4d9bf09bd542;hb=5ae2f74ba9b27bb7e926d5908471ac79371f7823;hpb=379504a233e3e2cc85bca1e7b6d864f1395aec7c diff --git a/include/yaz/cql.h b/include/yaz/cql.h index 84c4827..cd36fe9 100644 --- a/include/yaz/cql.h +++ b/include/yaz/cql.h @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2009 Index Data. + * Copyright (C) 1995-2013 Index Data. * All rights reserved. * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: @@ -41,10 +41,10 @@ typedef struct cql_parser *CQL_parser; /** \brief creates a CQL parser. \returns CCL parser - + Returns CQL parser or NULL if parser could not be created. */ -YAZ_EXPORT +YAZ_EXPORT CQL_parser cql_parser_create(void); /** \brief destroys a CQL parser. @@ -52,7 +52,7 @@ CQL_parser cql_parser_create(void); This function does nothing if NULL if received. */ -YAZ_EXPORT +YAZ_EXPORT void cql_parser_destroy(CQL_parser cp); /** \brief parses a CQL query (string) @@ -61,7 +61,7 @@ void cql_parser_destroy(CQL_parser cp); \retval 0 success \retval !=0 failure */ -YAZ_EXPORT +YAZ_EXPORT int cql_parser_string(CQL_parser cp, const char *str); /** \brief parses CQL query (query stream) @@ -71,14 +71,14 @@ int cql_parser_string(CQL_parser cp, const char *str); \param client_data data to be passed to stream functions \retval 0 success \retval !=0 failure - + This function is similar to cql_parser_string but takes a functions to read each query character from a stream. - + The functions pointers getbytes, ungetbyte are similar to that known from stdios getc, ungetc. */ -YAZ_EXPORT +YAZ_EXPORT int cql_parser_stream(CQL_parser cp, int (*getbyte)(void *client_data), void (*ungetbyte)(int b, void *client_data), @@ -89,17 +89,30 @@ int cql_parser_stream(CQL_parser cp, \param f file where query is read from \retval 0 success \retval !=0 failure - - This function is similar to cql_parser_string but reads from + + This function is similar to cql_parser_string but reads from stdio FILE handle instead. */ YAZ_EXPORT int cql_parser_stdio(CQL_parser cp, FILE *f); +/** \brief configures strict mode + \param cp CQL parser + \param mode 1=enable strict mode, 0=disable strict mode + + This function is similar to cql_parser_string but reads from + stdio FILE handle instead. +*/ +YAZ_EXPORT +void cql_parser_strict(CQL_parser cp, int mode); + /** \brief Node type: search term */ #define CQL_NODE_ST 1 /** \brief Node type: boolean */ #define CQL_NODE_BOOL 2 +/** \brief Node type: sortby single spec */ +#define CQL_NODE_SORT 3 + /** \brief CQL parse tree (node) */ struct cql_node { @@ -129,11 +142,21 @@ struct cql_node { char *value; /** left operand */ struct cql_node *left; - /** right operand */ + /** right operand */ struct cql_node *right; /** modifiers (NULL for no list) */ struct cql_node *modifiers; } boolean; + /** which == CQL_NODE_SORT */ + struct { + char *index; + /** next spec */ + struct cql_node *next; + /** modifiers (NULL for no list) */ + struct cql_node *modifiers; + /** search node */ + struct cql_node *search; + } sort; } u; }; @@ -178,6 +201,11 @@ struct cql_node *cql_apply_prefix(NMEM nmem, struct cql_node *cn, YAZ_EXPORT struct cql_node *cql_node_mk_boolean(NMEM nmem, const char *op); +/** \brief creates a sort single spec node. */ +YAZ_EXPORT +struct cql_node *cql_node_mk_sort(NMEM nmem, const char *index, + struct cql_node *modifiers); + /** \brief destroys a node and its children. */ YAZ_EXPORT void cql_node_destroy(struct cql_node *cn); @@ -193,13 +221,20 @@ struct cql_node *cql_node_dup (NMEM nmem, struct cql_node *cp); YAZ_EXPORT struct cql_node *cql_parser_result(CQL_parser cp); +/** \brief returns the sortby tree of the most recently parsed CQL query. + \param cp CQL parser + \returns CQL node or NULL for failure +*/ +YAZ_EXPORT +struct cql_node *cql_parser_sort_result(CQL_parser cp); + /** \brief converts CQL tree to XCQL and writes to user-defined stream \param cn CQL node (tree) \param pr print function \param client_data data to be passed to pr function */ YAZ_EXPORT -void cql_to_xml(struct cql_node *cn, +void cql_to_xml(struct cql_node *cn, void (*pr)(const char *buf, void *client_data), void *client_data); /** \brief converts CQL tree to XCQL and writes to file @@ -218,6 +253,34 @@ void cql_to_xml_stdio(struct cql_node *cn, FILE *f); YAZ_EXPORT int cql_to_xml_buf(struct cql_node *cn, char *out, int max); +/** \brief converts CQL tree to CCL and writes to user-defined stream + \param cn CQL node (tree) + \param pr print function + \param client_data data to be passed to pr function + */ +YAZ_EXPORT +int cql_to_ccl(struct cql_node *cn, + void (*pr)(const char *buf, void *client_data), + void *client_data); + +/** \brief converts CQL tree to CCL and writes to file + \param cn CQL node (tree) + \param f file handle + */ +YAZ_EXPORT +void cql_to_ccl_stdio(struct cql_node *cn, FILE *f); + +/** \brief converts CQL tree to CCL and writes result to buffer + \param cn CQL node (tree) + \param out buffer + \param max size of buffer (max chars to write) + \retval 0 OK + \retval -1 conversion error + \retval -2 buffer too small (truncated) + */ +YAZ_EXPORT +int cql_to_ccl_buf(struct cql_node *cn, char *out, int max); + /** \brief stream handle for file (used by cql_to_xml_stdio) */ YAZ_EXPORT void cql_fputs(const char *buf, void *client_data); @@ -260,7 +323,7 @@ cql_transform_t cql_transform_open_fname(const char *fname); YAZ_EXPORT int cql_transform_define_pattern(cql_transform_t ct, const char *pattern, const char *value); - + /** \brief destroys a CQL transform handle @@ -361,6 +424,47 @@ int cql_strcmp(const char *s1, const char *s2); YAZ_EXPORT int cql_strncmp(const char *s1, const char *s2, size_t n); +/** \brief converts CQL sortby to sortkeys (ala versions 1.1) + \param cn CQL tree + \param pr print function + \param client_data data to be passed to pr function + + This will take CQL_NODE_SORT entries and conver them to + + path,schema,ascending,caseSensitive,missingValue + items.. + + One for each sort keys. Where + + path is string index for sorting + + schema is schema for sort index + + ascending is a boolean (0=false, 1=true). Default is true. + + caseSensitive is a boolean. Default is false. + + missingValue is a string and one of 'abort', 'highValue', 'lowValue', + or 'omit'. Default is 'highValue'. + + See also + http://www.loc.gov/standards/sru/sru1-1archive/search-retrieve-operation.html#sort +*/ +YAZ_EXPORT +int cql_sortby_to_sortkeys(struct cql_node *cn, + void (*pr)(const char *buf, void *client_data), + void *client_data); + +/** \brief converts CQL sortby to sortkeys .. + \param cn CQL tree + \param out result buffer + \param max size of buffer (allocated) + \retval 0 OK + \retval -1 ERROR +*/ +YAZ_EXPORT +int cql_sortby_to_sortkeys_buf(struct cql_node *cn, char *out, int max); + YAZ_END_CDECL #endif