X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=retrieval%2Fd1_write.c;h=b63190318496c9830a848de4a27efe7ac00800e6;hb=144325b3bf52d2408a6fe1c395ee955ec3b208c6;hp=6a7d2c05284563da02510fd3c0c0eb6dbfe01964;hpb=6517fa53d35512887780fd07de5667940da18a9e;p=yaz-moved-to-github.git diff --git a/retrieval/d1_write.c b/retrieval/d1_write.c index 6a7d2c0..b631903 100644 --- a/retrieval/d1_write.c +++ b/retrieval/d1_write.c @@ -1,10 +1,18 @@ /* - * Copyright (c) 1995-1997, Index Data. + * Copyright (c) 1995-1998, Index Data. * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * * $Log: d1_write.c,v $ - * Revision 1.3 1997-09-17 12:10:39 adam + * Revision 1.5 1998-06-05 08:57:43 adam + * Fixed problem with function wordlen. + * + * Revision 1.4 1998/05/18 13:07:08 adam + * Changed the way attribute sets are handled by the retriaval module. + * Extended Explain conversion / schema. + * Modified server and client to work with ASN.1 compiled protocol handlers. + * + * Revision 1.3 1997/09/17 12:10:39 adam * YAZ version 1.4. * * Revision 1.2 1995/12/13 17:14:27 quinn @@ -24,11 +32,11 @@ #define IDSGML_MARGIN 75 -static int wordlen(char *b) +static int wordlen(char *b, int max) { int l = 0; - while (*b && !isspace(*b)) + while (l < max && !isspace(*b)) l++, b++; return l; } @@ -67,8 +75,9 @@ static int nodetoidsgml(data1_node *n, int select, WRBUF b, int col) int l = c->u.data.len; int first = 1; - if (c->u.data.what == DATA1I_text) + switch (c->u.data.what) { + case DATA1I_text: while (l) { int wlen; @@ -78,7 +87,7 @@ static int nodetoidsgml(data1_node *n, int select, WRBUF b, int col) if (!l) break; /* break if we'll cross margin and word is not too long */ - if (col + (wlen = wordlen(p)) > IDSGML_MARGIN && wlen < + if (col + (wlen = wordlen(p, l)) > IDSGML_MARGIN && wlen < IDSGML_MARGIN) { sprintf(line, "\n"); @@ -112,9 +121,12 @@ static int nodetoidsgml(data1_node *n, int select, WRBUF b, int col) } wrbuf_write(b, "\n", 1); col = 0; - } - else if (c->u.data.what == DATA1I_num) - { + break; + case DATA1I_num: + wrbuf_putc(b, ' '); + wrbuf_write(b, c->u.data.data, c->u.data.len); + break; + case DATA1I_oid: wrbuf_putc(b, ' '); wrbuf_write(b, c->u.data.data, c->u.data.len); }