X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr.c;h=7bd3faea007cc840e3538a17b20199276565e1f1;hb=a4500a53ecbff46db730bcaa8703d2c9a0e6328b;hp=084b632919430929d8a0731345812b9c81fe2fe3;hpb=cf9f213fff1ae6b2471f8367114b93ae45ed8b75;p=yaz-moved-to-github.git diff --git a/odr/odr.c b/odr/odr.c index 084b632..7bd3fae 100644 --- a/odr/odr.c +++ b/odr/odr.c @@ -1,8 +1,8 @@ /* - * Copyright (c) 1995-2002, Index Data + * Copyright (c) 1995-2003, Index Data * See the file LICENSE for details. * - * $Id: odr.c,v 1.36 2002-08-28 07:53:51 adam Exp $ + * $Id: odr.c,v 1.41 2003-03-11 11:03:31 adam Exp $ * */ #if HAVE_CONFIG_H @@ -35,7 +35,8 @@ char *odr_errlist[] = "Malformed data", "Stack overflow", "Length of constructed type different from sum of members", - "Overflow writing definite length of constructed type" + "Overflow writing definite length of constructed type", + "HTTP Bad Request" }; char *odr_errmsg(int n) @@ -53,6 +54,19 @@ int odr_geterror(ODR o) return o->error; } +int odr_geterrorx(ODR o, int *x) +{ + if (x) + *x = o->op->error_id; + return o->error; +} + +void odr_seterror(ODR o, int error, int id) +{ + o->error = error; + o->op->error_id = id; +} + void odr_setprint(ODR o, FILE *file) { o->print = file; @@ -63,7 +77,7 @@ int odr_set_charset(ODR o, const char *to, const char *from) if (o->op->iconv_handle) yaz_iconv_close (o->op->iconv_handle); - o->op->iconv_handle = iconv_open (to, from); + o->op->iconv_handle = yaz_iconv_open (to, from); if (o->op->iconv_handle == 0) return -1; return 0; @@ -84,7 +98,7 @@ ODR odr_createmem(int direction) r->can_grow = 1; r->mem = nmem_create(); r->enable_bias = 1; - r->op = xmalloc (sizeof(*r->op)); + r->op = (struct Odr_private *) xmalloc (sizeof(*r->op)); r->op->odr_ber_tag.lclass = -1; r->op->iconv_handle = 0; odr_reset(r); @@ -94,7 +108,7 @@ ODR odr_createmem(int direction) void odr_reset(ODR o) { - o->error = ONONE; + odr_seterror(o, ONONE, 0); o->bp = o->buf; odr_seek(o, ODR_S_SET, 0); o->top = 0; @@ -141,3 +155,4 @@ char *odr_getbuf(ODR o, int *len, int *size) *size = o->size; return (char*) o->buf; } +