X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fsortidx.c;h=08b16e691325a905e50e2b2cbd1d289068f645a0;hb=9757a9ac857180889850aec2756595c04501aeb7;hp=4dd91b79d2ef9333d41e75e8001e569bcc9f371d;hpb=05b9b8ed020c5bfa48a913d6a2e2b50ddf1bab8e;p=idzebra-moved-to-github.git diff --git a/index/sortidx.c b/index/sortidx.c index 4dd91b7..08b16e6 100644 --- a/index/sortidx.c +++ b/index/sortidx.c @@ -1,6 +1,6 @@ -/* $Id: sortidx.c,v 1.11 2004-12-08 12:23:09 adam Exp $ - Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004 - Index Data Aps +/* $Id: sortidx.c,v 1.19 2006-11-21 22:17:49 adam Exp $ + Copyright (C) 1995-2006 + Index Data ApS This file is part of the Zebra server. @@ -15,23 +15,25 @@ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License -along with Zebra; see the file LICENSE.zebra. If not, write to the -Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ - +#include #include -#include +#include +#include #include #include +#include "recindex.h" #define SORT_IDX_BLOCKSIZE 64 struct sortFileHead { - SYSNO sysno_max; + zint sysno_max; }; struct sortFile { @@ -44,7 +46,7 @@ struct sortFile { struct sortIdx { BFiles bfs; int write_flag; - SYSNO sysno; + zint sysno; char *entry_buf; struct sortFile *current_file; struct sortFile *files; @@ -114,12 +116,12 @@ int sortIdx_type (SortIdx si, int type) return 0; } -void sortIdx_sysno (SortIdx si, SYSNO sysno) +void sortIdx_sysno(SortIdx si, zint sysno) { - si->sysno = sysno; + si->sysno = rec_sysno_to_int(sysno); } -void sortIdx_add (SortIdx si, const char *buf, int len) +void sortIdx_add(SortIdx si, const char *buf, int len) { if (!si->current_file || !si->current_file->bf) return; @@ -138,7 +140,18 @@ void sortIdx_add (SortIdx si, const char *buf, int len) void sortIdx_read (SortIdx si, char *buf) { - int r = 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 + */ +