X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=retrieval%2Fd1_sutrs.c;h=ade87d0fc819961f95edcef4cccc889bedd1773a;hb=c9b7cb5f4ca3e9c570d921307e2d44ce32f51801;hp=fea2d02483dccbaacc598a388f70a5af6b7fe113;hpb=18ed9f15a489511014d4384a53b27e35824dd831;p=yaz-moved-to-github.git diff --git a/retrieval/d1_sutrs.c b/retrieval/d1_sutrs.c index fea2d02..ade87d0 100644 --- a/retrieval/d1_sutrs.c +++ b/retrieval/d1_sutrs.c @@ -1,38 +1,23 @@ /* - * Copyright (c) 1995-1997, Index Data. + * Copyright (c) 1995-2002, Index Data. * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * - * $Log: d1_sutrs.c,v $ - * Revision 1.5 1999-10-21 12:06:29 adam - * Retrieval module no longer uses ctype.h - functions. - * - * Revision 1.4 1997/09/17 12:10:38 adam - * YAZ version 1.4. - * - * Revision 1.3 1995/12/15 16:57:11 quinn - * Added formatted-text. - * - * Revision 1.2 1995/11/01 13:54:49 quinn - * Minor adjustments - * - * Revision 1.1 1995/11/01 11:56:09 quinn - * Added Retrieval (data management) functions en masse. - * + * $Id: d1_sutrs.c,v 1.8 2002-10-08 22:18:23 adam Exp $ * */ -#include +#include #define NTOBUF_INDENT 2 #define NTOBUF_MARGIN 75 -static int wordlen(char *b) +static int wordlen(char *b, int i) { int l = 0; - while (*b && !d1_isspace(*b)) - l++, b++; + while (i && !d1_isspace(*b)) + l++, b++, i--; return l; } @@ -70,7 +55,8 @@ static int nodetobuf(data1_node *n, int select, WRBUF b, int indent, int col) int l = c->u.data.len; int first = 0; - if (c->u.data.what == DATA1I_text && c->u.data.formatted_text) + if ((c->u.data.what == DATA1I_text || + c->u.data.what == DATA1I_xmltext) && c->u.data.formatted_text) { wrbuf_putc(b, '\n'); wrbuf_write(b, c->u.data.data, c->u.data.len); @@ -78,7 +64,8 @@ static int nodetobuf(data1_node *n, int select, WRBUF b, int indent, int col) wrbuf_write(b, line, strlen(line)); col = indent * NTOBUF_INDENT; } - else if (c->u.data.what == DATA1I_text) + else if (c->u.data.what == DATA1I_text || + c->u.data.what == DATA1I_xmltext) { while (l) { @@ -89,7 +76,7 @@ static int nodetobuf(data1_node *n, int select, WRBUF b, int indent, int col) if (!l) break; /* break if we'll cross margin and word is not too long */ - if (col + (wlen = wordlen(p)) > NTOBUF_MARGIN && wlen < + if (col + (wlen = wordlen(p, l)) > NTOBUF_MARGIN && wlen < NTOBUF_MARGIN - indent * NTOBUF_INDENT) { sprintf(line, "\n%*s", indent * NTOBUF_INDENT, "");