New function yaz_srw_sortkeys_to_sort_spec
[yaz-moved-to-github.git] / include / yaz / sortspec.h
1 /* This file is part of the YAZ toolkit.
2  * Copyright (C) 1995-2011 Index Data.
3  * All rights reserved.
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  *
7  *     * Redistributions of source code must retain the above copyright
8  *       notice, this list of conditions and the following disclaimer.
9  *     * Redistributions in binary form must reproduce the above copyright
10  *       notice, this list of conditions and the following disclaimer in the
11  *       documentation and/or other materials provided with the distribution.
12  *     * Neither the name of Index Data nor the names of its contributors
13  *       may be used to endorse or promote products derived from this
14  *       software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
17  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19  * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27
28 /**
29  * \file sortspec.h
30  * \brief Header for SortSpec parsing.
31  */
32 #ifndef SORTSPEC_H
33 #define SORTSPEC_H
34
35 #include <yaz/yconfig.h>
36 #include <yaz/wrbuf.h>
37 #include <yaz/z-core.h>
38
39 YAZ_BEGIN_CDECL
40
41 /** \brief parse sort spec string
42     \param odr memory for result
43     \param arg sort spec string
44     \returns Z39.50 SortKeySpecList or NULL on error
45     
46     The sort spec list is of the form:
47     (field flags)+ 
48     where field is either a string or one or more attribute pairs
49     key=value (there must be no blanks in either field of flags).
50     flags is a character list:
51     dD>    : descending
52     aA<    : ascending   (default)
53     iI     : ignoreccase / case-insensitive (default)
54     sS     : respectcase / case-sensitive
55     !      : abort of key is omitted in result
56     =value : missing value
57     
58     Examples:
59
60       title a
61
62       1=4 ia 1=1003 sd
63 */
64 YAZ_EXPORT Z_SortKeySpecList *yaz_sort_spec(ODR odr, const char *arg);
65
66 /* \brief converts SortKeySpecList to CQL sortby string
67    \param sksl SortKeySpecList
68    \param w resulting CQL SORTBY string (of string to be appended)
69    \retval 0 successful
70    \retval -1 failure
71 */
72 YAZ_EXPORT int yaz_sort_spec_to_cql(Z_SortKeySpecList *sksl, WRBUF w);
73
74 /* \brief adds PQF type-7 sorting to existing PQF from SortKeySpecList
75    \param sksl SortKeySpecList
76    \param w original PQF (without the Type-7)
77    \retval 0 successful
78    \retval -1 failure
79
80    If successful, the pqf WRBUF holds the new PQF including the Type-7
81    part.
82 */
83 YAZ_EXPORT int yaz_sort_spec_to_type7(Z_SortKeySpecList *sksl, WRBUF pqf);
84
85 /* \brief converts Z39.50 SortKeySpecList to SRU 1.1 sort key
86    \param sksl SortKeySpecList
87    \param w resulting sortkey will be appended to this
88    \retval 0 successful
89    \retval -1 failure
90 */
91 YAZ_EXPORT int yaz_sort_spec_to_srw_sortkeys(Z_SortKeySpecList *sksl, WRBUF w);
92
93 /* \brief converts SRU/SRW 1.1 sortkeys to Z39.50 sortspec (WRBUF)
94    \param srw_sortkeys SRU sortkeys string
95    \param w resulting Z39.50 sortspec, WRBUF string
96    \retval 0 successful
97    \retval -1 failure
98 */
99 int yaz_srw_sortkeys_to_sort_spec(const char *srw_sortkeys, WRBUF w);
100 YAZ_END_CDECL
101
102 #endif
103
104 /*
105  * Local variables:
106  * c-basic-offset: 4
107  * c-file-style: "Stroustrup"
108  * indent-tabs-mode: nil
109  * End:
110  * vim: shiftwidth=4 tabstop=8 expandtab
111  */
112