Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64
User : palandch ( 1163)
PHP Version : 7.1.33
Disable Function : NONE
Directory :  /usr/include/yaz/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //usr/include/yaz/sortspec.h
/* This file is part of the YAZ toolkit.
 * Copyright (C) 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:
 *
 *     * Redistributions of source code must retain the above copyright
 *       notice, this list of conditions and the following disclaimer.
 *     * Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *     * Neither the name of Index Data nor the names of its contributors
 *       may be used to endorse or promote products derived from this
 *       software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/**
 * \file sortspec.h
 * \brief Header for SortSpec parsing.
 */
#ifndef SORTSPEC_H
#define SORTSPEC_H

#include <yaz/yconfig.h>
#include <yaz/wrbuf.h>
#include <yaz/z-core.h>

YAZ_BEGIN_CDECL

/** \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);

/* \brief converts Z39.50 SortKeySpecList to Solr 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_solr_sortkeys(Z_SortKeySpecList *sksl, WRBUF w);

/* \brief converts Solr sortkeys to Z39.50 sortspec (WRBUF)
   \param srw_sortkeys Solr sortkeys string
   \param w resulting Z39.50 sortspec, WRBUF string
   \retval 0 successful
   \retval -1 failure
*/
YAZ_EXPORT int yaz_solr_sortkeys_to_sort_spec(const char *srw_sortkeys, WRBUF w);

YAZ_END_CDECL

#endif

/*
 * Local variables:
 * c-basic-offset: 4
 * c-file-style: "Stroustrup"
 * indent-tabs-mode: nil
 * End:
 * vim: shiftwidth=4 tabstop=8 expandtab
 */


Spamworldpro Mini