X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=include%2Fyaz%2Fsortspec.h;h=9f8324614a86c30dfd4bf7748192ba76e0185812;hp=2b166d9056d9252b578a9603e7d10a09f4bbdebb;hb=487b5074b34ff24575136df048d9c7970ccaf98f;hpb=43a9d38d20c1b1bcd1a03b2445a501d27526bd35 diff --git a/include/yaz/sortspec.h b/include/yaz/sortspec.h index 2b166d9..9f83246 100644 --- a/include/yaz/sortspec.h +++ b/include/yaz/sortspec.h @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2011 Index Data. + * Copyright (C) 1995-2012 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: @@ -33,12 +33,70 @@ #define SORTSPEC_H #include -#include +#include +#include YAZ_BEGIN_CDECL -YAZ_EXPORT Z_SortKeySpecList *yaz_sort_spec (ODR out, const char *arg); +/** \brief parse sort spec string + \param odr memory for result + \param arg sort spec string + \returns Z39.50 SortKeySpecList or NULL on error + + The sort spec list is of the form: + (field flags)+ + where field is either a string or one or more attribute pairs + key=value (there must be no blanks in either field of flags). + flags is a character list: + dD> : descending + aA< : ascending (default) + iI : ignoreccase / case-insensitive (default) + sS : respectcase / case-sensitive + ! : abort of key is omitted in result + =value : missing value + + Examples: + title a + + 1=4 ia 1=1003 sd +*/ +YAZ_EXPORT Z_SortKeySpecList *yaz_sort_spec(ODR odr, const char *arg); + +/* \brief converts SortKeySpecList to CQL sortby string + \param sksl SortKeySpecList + \param w resulting CQL SORTBY string (of string to be appended) + \retval 0 successful + \retval -1 failure +*/ +YAZ_EXPORT int yaz_sort_spec_to_cql(Z_SortKeySpecList *sksl, WRBUF w); + +/* \brief adds PQF type-7 sorting to existing PQF from SortKeySpecList + \param sksl SortKeySpecList + \param w original PQF (without the Type-7) + \retval 0 successful + \retval -1 failure + + If successful, the pqf WRBUF holds the new PQF including the Type-7 + part. +*/ +YAZ_EXPORT int yaz_sort_spec_to_type7(Z_SortKeySpecList *sksl, WRBUF pqf); + +/* \brief converts Z39.50 SortKeySpecList to SRU 1.1 sort key + \param sksl SortKeySpecList + \param w resulting sortkey will be appended to this + \retval 0 successful + \retval -1 failure +*/ +YAZ_EXPORT int yaz_sort_spec_to_srw_sortkeys(Z_SortKeySpecList *sksl, WRBUF w); + +/* \brief converts SRU/SRW 1.1 sortkeys to Z39.50 sortspec (WRBUF) + \param srw_sortkeys SRU sortkeys string + \param w resulting Z39.50 sortspec, WRBUF string + \retval 0 successful + \retval -1 failure +*/ +YAZ_EXPORT int yaz_srw_sortkeys_to_sort_spec(const char *srw_sortkeys, WRBUF w); YAZ_END_CDECL #endif