X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=rset%2Frsisamb.c;h=f2697d5dda58858ec349bed38632b84c3aa9a656;hb=668b136879471079ce03b26981a5fd1b3a210bc1;hp=2d732af6345a539c3dc8d6640c935a6b16c1ec01;hpb=152a0ee011a478b0ee8c3ba4045bdd707e702d0b;p=idzebra-moved-to-github.git diff --git a/rset/rsisamb.c b/rset/rsisamb.c index 2d732af..f2697d5 100644 --- a/rset/rsisamb.c +++ b/rset/rsisamb.c @@ -1,5 +1,5 @@ -/* $Id: rsisamb.c,v 1.8 2004-06-01 15:22:58 adam Exp $ - Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004 +/* $Id: rsisamb.c,v 1.10.2.3 2006-08-14 10:39:20 adam Exp $ + Copyright (C) 1995-2005 Index Data Aps This file is part of the Zebra server. @@ -15,9 +15,9 @@ 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 @@ -39,7 +39,7 @@ static void r_rewind (RSFD rfd); static int r_forward(RSET ct, RSFD rfd, void *buf, int *term_index, int (*cmpfunc)(const void *p1, const void *p2), const void *untilbuf); -static int r_count (RSET ct); +static void r_pos (RSFD rfd, int *current, int *total); static int r_read (RSFD rfd, void *buf, int *term_index); static int r_write (RSFD rfd, const void *buf); @@ -51,13 +51,32 @@ static const struct rset_control control = r_close, r_delete, r_rewind, - r_forward, /* rset_default_forward, */ - r_count, + rset_default_forward, + r_pos, + r_read, + r_write, +}; + +static const struct rset_control control_forward = +{ + "isamb", + r_create, + r_open, + r_close, + r_delete, + r_rewind, + r_forward, + r_pos, r_read, r_write, }; +/* FIXME - using the default forward reads all items from the isam */ +/* and thus makes the term counts work OK. On the other hand, it */ +/* negates the speedup from forwarding */ + const struct rset_control *rset_kind_isamb = &control; +const struct rset_control *rset_kind_isamb_forward = &control_forward; struct rset_pp_info { ISAMB_PP pt; @@ -156,7 +175,7 @@ static int r_forward(RSET ct, RSFD rfd, void *buf, int *term_index, int (*cmpfunc)(const void *p1, const void *p2), const void *untilbuf) { - int i; /*!*/ + int i; struct rset_pp_info *pinfo = (struct rset_pp_info *) rfd; #if RSET_DEBUG logf (LOG_DEBUG, "rset_rsisamb_forward starting '%s' (ct=%p rfd=%p)", @@ -172,9 +191,11 @@ static int r_forward(RSET ct, RSFD rfd, void *buf, int *term_index, return i; } -static int r_count (RSET ct) +static void r_pos (RSFD rfd, int *current, int *total) { - return 0; + struct rset_pp_info *pinfo = (struct rset_pp_info *) rfd; + assert(rfd); + isamb_pp_pos(pinfo->pt, current, total); } static int r_read (RSFD rfd, void *buf, int *term_index)