projects
/
idzebra-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Forgot to commit the new rset.h when removing rewind ops
[idzebra-moved-to-github.git]
/
recctrl
/
rectext.c
diff --git
a/recctrl/rectext.c
b/recctrl/rectext.c
index
1de6567
..
aac5eec
100644
(file)
--- a/
recctrl/rectext.c
+++ b/
recctrl/rectext.c
@@
-1,4
+1,4
@@
-/* $Id: rectext.c,v 1.16 2004-03-22 20:52:11 adam Exp $
+/* $Id: rectext.c,v 1.21 2004-09-28 10:15:03 adam Exp $
Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
Index Data Aps
Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
Index Data Aps
@@
-26,15
+26,29
@@
Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
#include <ctype.h>
#include <zebrautl.h>
#include <ctype.h>
#include <zebrautl.h>
-#include "rectext.h"
+#include <idzebra/recctrl.h>
-static void *text_init (RecType recType)
+struct text_info {
+ char *sep;
+};
+
+static void *text_init (Res res, RecType recType)
{
{
- return 0;
+ struct text_info *tinfo = (struct text_info *) xmalloc(sizeof(*tinfo));
+ tinfo->sep = 0;
+ return tinfo;
+}
+
+static void text_config(void *clientData, Res res, const char *args)
+{
+
}
static void text_destroy (void *clientData)
{
}
static void text_destroy (void *clientData)
{
+ struct text_info *tinfo = clientData;
+ xfree (tinfo->sep);
+ xfree (tinfo);
}
struct buf_info {
}
struct buf_info {
@@
-55,7
+69,7
@@
struct buf_info *buf_open (struct recExtractCtrl *p)
return fi;
}
return fi;
}
-int buf_read (struct buf_info *fi, char *dst)
+int buf_read (struct text_info *tinfo, struct buf_info *fi, char *dst)
{
if (fi->offset >= fi->max)
{
{
if (fi->offset >= fi->max)
{
@@
-67,6
+81,12
@@
int buf_read (struct buf_info *fi, char *dst)
return 0;
}
*dst = fi->buf[(fi->offset)++];
return 0;
}
*dst = fi->buf[(fi->offset)++];
+ if (tinfo->sep && *dst == *tinfo->sep)
+ {
+ off_t off = (*fi->p->tellf)(fi->p->fh);
+ (*fi->p->endf)(fi->p->fh, off - (fi->max - fi->offset));
+ return 0;
+ }
return 1;
}
return 1;
}
@@
-78,23
+98,30
@@
void buf_close (struct buf_info *fi)
static int text_extract (void *clientData, struct recExtractCtrl *p)
{
static int text_extract (void *clientData, struct recExtractCtrl *p)
{
+ struct text_info *tinfo = clientData;
char w[512];
RecWord recWord;
int r;
struct buf_info *fi = buf_open (p);
char w[512];
RecWord recWord;
int r;
struct buf_info *fi = buf_open (p);
+#if 0
+ yaz_log(LOG_LOG, "text_extract off=%ld",
+ (long) (*fi->p->tellf)(fi->p->fh));
+#endif
+ xfree(tinfo->sep);
+ tinfo->sep = 0;
(*p->init)(p, &recWord);
recWord.reg_type = 'w';
do
{
int i = 0;
(*p->init)(p, &recWord);
recWord.reg_type = 'w';
do
{
int i = 0;
- r = buf_read (fi, w);
+ r = buf_read (tinfo, fi, w);
while (r > 0 && i < 511 && w[i] != '\n' && w[i] != '\r')
{
i++;
while (r > 0 && i < 511 && w[i] != '\n' && w[i] != '\r')
{
i++;
- r = buf_read (fi, w + i);
- }
+ r = buf_read (tinfo, fi, w + i);
+ }
if (i)
{
recWord.string = w;
if (i)
{
recWord.string = w;
@@
-157,7
+184,8
@@
static int text_retrieve (void *clientData, struct recRetrieveCtrl *p)
sprintf (text_buf, "Rank: %d\n", p->score);
text_ptr = strlen(text_buf);
}
sprintf (text_buf, "Rank: %d\n", p->score);
text_ptr = strlen(text_buf);
}
- sprintf (text_buf + text_ptr, "Local Number: %d\n", p->localno);
+ sprintf (text_buf + text_ptr, "Local Number: " ZINT_FORMAT "\n",
+ p->localno);
text_ptr = strlen(text_buf);
if (p->fname)
{
text_ptr = strlen(text_buf);
if (p->fname)
{
@@
-203,9
+231,20
@@
static int text_retrieve (void *clientData, struct recRetrieveCtrl *p)
static struct recType text_type = {
"text",
text_init,
static struct recType text_type = {
"text",
text_init,
+ text_config,
text_destroy,
text_extract,
text_retrieve
};
text_destroy,
text_extract,
text_retrieve
};
-RecType recTypeText = &text_type;
+RecType
+#ifdef IDZEBRA_STATIC_TEXT
+idzebra_filter_text
+#else
+idzebra_filter
+#endif
+
+[] = {
+ &text_type,
+ 0,
+};