From c50cc2f57afed0c8ef8b6205fe9187a7b6260f73 Mon Sep 17 00:00:00 2001 From: Adam Dickmeiss Date: Tue, 7 Dec 2004 20:04:39 +0000 Subject: [PATCH] Fixed bug #232 --- dict/.cvsignore | 1 + dict/scan.c | 15 ++++++++++++--- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/dict/.cvsignore b/dict/.cvsignore index 413037d..da78c98 100644 --- a/dict/.cvsignore +++ b/dict/.cvsignore @@ -4,5 +4,6 @@ Makefile Makefile.in dictext dicttest +scantest *.lo *.la diff --git a/dict/scan.c b/dict/scan.c index 7236cb0..ad9c2d3 100644 --- a/dict/scan.c +++ b/dict/scan.c @@ -1,4 +1,4 @@ -/* $Id: scan.c,v 1.16 2004-11-19 10:26:55 heikki Exp $ +/* $Id: scan.c,v 1.17 2004-12-07 20:04:39 adam Exp $ Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 Index Data Aps @@ -81,7 +81,7 @@ int dict_scan_trav (Dict dict, Dict_ptr ptr, int pos, Dict_char *str, memcpy (&dc, info+sizeof(Dict_ptr), sizeof(Dict_char)); str[pos] = dc; memcpy (&subptr, info, sizeof(Dict_ptr)); - if (info[sizeof(Dict_ptr)+sizeof(Dict_char)]) + if (dir>0 && info[sizeof(Dict_ptr)+sizeof(Dict_char)]) { str[pos+1] = DICT_EOS; if ((*userfunc)((char*) str, @@ -90,13 +90,22 @@ int dict_scan_trav (Dict dict, Dict_ptr ptr, int pos, Dict_char *str, return 1; --(*count); } - if (*count > 0 && subptr) + if (*count>0 && subptr) { dict_scan_trav (dict, subptr, pos+1, str, -1, count, client, userfunc, dir); dict_bf_readp (dict->dbf, ptr, &p); indxp = (short*) ((char*) p+DICT_bsize(p)-sizeof(short)); } + if (*count>0 && dir<0 && info[sizeof(Dict_ptr)+sizeof(Dict_char)]) + { + str[pos+1] = DICT_EOS; + if ((*userfunc)((char*) str, + info+sizeof(Dict_ptr)+sizeof(Dict_char), + *count * dir, client)) + return 1; + --(*count); + } } lo += dir; } -- 1.7.10.4