X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=include%2Fsortidx.h;h=31d210ba9a9500b7004665799dfdd99da163da4b;hp=b4f74e527cef55800ef1dc94552388f91d00ac5a;hb=ce556bc293c5eed60090acaf82cc668d333abd7b;hpb=97a7adeb9e5059463f039495cc01cfa448463a27 diff --git a/include/sortidx.h b/include/sortidx.h index b4f74e5..31d210b 100644 --- a/include/sortidx.h +++ b/include/sortidx.h @@ -28,18 +28,63 @@ YAZ_BEGIN_CDECL #define SORT_IDX_ENTRYSIZE 64 +/** \var zebra_sort_index_t + \brief sort index handle +*/ typedef struct zebra_sort_index *zebra_sort_index_t; #define ZEBRA_SORT_TYPE_FLAT 1 #define ZEBRA_SORT_TYPE_ISAMB 2 + +/** \brief creates sort handle + \param bfs block files handle + \param write_flag (0=read-only, 1=write and read) + \param sort_type one of ZEBRA_SORT_TYPE_.. + \return sort index handle +*/ zebra_sort_index_t zebra_sort_open(BFiles bfs, int write_flag, int sort_type); + +/** \brief frees sort handle +*/ void zebra_sort_close(zebra_sort_index_t si); + +/** \brief sets type for sort usage + \param si sort index handle + \param type opaque type .. A sort file for each type is created +*/ int zebra_sort_type(zebra_sort_index_t si, int type); + +/** \brief sets sort system number for read / add / delete + \param si sort index handle + \param sysno system number +*/ void zebra_sort_sysno(zebra_sort_index_t si, zint sysno); + +/** \brief adds content to sort file + \param si sort index handle + \param buf buffer content + \param len length + + zebra_sort_type and zebra_sort_sysno must be called prior to this +*/ void zebra_sort_add(zebra_sort_index_t si, const char *buf, int len); + + +/** \brief delete sort entry + \param si sort index handle + + zebra_sort_type and zebra_sort_sysno must be called prior to this +*/ void zebra_sort_delete(zebra_sort_index_t si); -void zebra_sort_read(zebra_sort_index_t si, char *buf); + +/** \brief reads sort entry + \param si sort index handle + \param buf resulting buffer + \retval 0 could not be read + \retval 1 could be read (found) +*/ +int zebra_sort_read(zebra_sort_index_t si, char *buf); YAZ_END_CDECL