X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fsortidx.c;h=6cddaf41532bc9dd6c19b2104d9c17c53e28b0ea;hb=54bf7dc88056fa2a813786e72dfea55b7c0e3e40;hp=9524b97790d090e7a9c1551c46cc3cb4b0278c65;hpb=896c0427df9d8eff5de6a1735dcd992e067df844;p=idzebra-moved-to-github.git diff --git a/index/sortidx.c b/index/sortidx.c index 9524b97..6cddaf4 100644 --- a/index/sortidx.c +++ b/index/sortidx.c @@ -1,6 +1,6 @@ -/* $Id: sortidx.c,v 1.7 2002-08-02 19:26:55 adam Exp $ - Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 - Index Data Aps +/* $Id: sortidx.c,v 1.17 2006-05-18 12:03:05 adam Exp $ + Copyright (C) 1995-2006 + Index Data ApS This file is part of the Zebra server. @@ -21,17 +21,19 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA */ - +#include #include #include -#include +#include +#include #include +#include "recindex.h" #define SORT_IDX_BLOCKSIZE 64 struct sortFileHead { - int sysno_max; + SYSNO sysno_max; }; struct sortFile { @@ -44,7 +46,7 @@ struct sortFile { struct sortIdx { BFiles bfs; int write_flag; - int sysno; + SYSNO sysno; char *entry_buf; struct sortFile *current_file; struct sortFile *files; @@ -92,7 +94,7 @@ int sortIdx_type (SortIdx si, int type) sf->type = type; sf->bf = NULL; sprintf (fname, "sort%d", type); - logf (LOG_DEBUG, "sort idx %s wr=%d", fname, si->write_flag); + yaz_log (YLOG_DEBUG, "sort idx %s wr=%d", fname, si->write_flag); sf->bf = bf_open (si->bfs, fname, SORT_IDX_BLOCKSIZE, si->write_flag); if (!sf->bf) { @@ -114,9 +116,9 @@ int sortIdx_type (SortIdx si, int type) return 0; } -void sortIdx_sysno (SortIdx si, int sysno) +void sortIdx_sysno (SortIdx si, SYSNO sysno) { - si->sysno = sysno; + si->sysno = rec_sysno_to_int(sysno); } void sortIdx_add (SortIdx si, const char *buf, int len) @@ -138,5 +140,18 @@ void sortIdx_add (SortIdx si, const char *buf, int len) void sortIdx_read (SortIdx si, char *buf) { - bf_read (si->current_file->bf, si->sysno+1, 0, 0, buf); + int r; + + assert(si->current_file); + r = bf_read (si->current_file->bf, si->sysno+1, 0, 0, buf); + if (!r) + memset (buf, 0, SORT_IDX_ENTRYSIZE); } +/* + * Local variables: + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +