X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fkey_block.c;fp=index%2Fkey_block.c;h=537cbbdc9f11c1b71f0f06df63baa7ba5ff5bf29;hb=75fc9c6f0432202b6689a06af1dbfe2aab79321f;hp=19a3a1ad9f530d909407ee44ae2f82faee249c28;hpb=6587ec659336a07b71dd50d6874f8b316eca4191;p=idzebra-moved-to-github.git diff --git a/index/key_block.c b/index/key_block.c index 19a3a1a..537cbbd 100644 --- a/index/key_block.c +++ b/index/key_block.c @@ -1,4 +1,4 @@ -/* $Id: key_block.c,v 1.10 2007-04-07 22:24:12 adam Exp $ +/* $Id: key_block.c,v 1.11 2008-01-09 22:59:44 adam Exp $ Copyright (C) 1995-2007 Index Data ApS @@ -104,10 +104,16 @@ static void encode_key_write (char *k, struct encode_info *i, FILE *outf) struct it_key key; char *bp = i->buf, *bp0; const char *src = (char *) &key; + size_t klen = strlen(k); + + if (fwrite (k, klen+1, 1, outf) != 1) + { + yaz_log (YLOG_FATAL|YLOG_ERRNO, "fwrite"); + zebra_exit("encode_key_write"); + } + + k = k + klen+1; - /* copy term to output buf */ - while ((*bp++ = *k++)) - ; /* and copy & align key so we can mangle */ memcpy (&key, k+1, sizeof(struct it_key)); /* *k is insert/delete */