X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr.c;h=aaaec46904c56005d9ee20000f8b888fd84bd1ae;hb=29a22396d7d7b1219f5b83c35983c8fb1cd79e8f;hp=948043c30c2cebe736ab3c3ee3d74a7c3eb7bbed;hpb=94f604cea006e77285967d3e2f8a2ee32db7c434;p=yaz-moved-to-github.git diff --git a/odr/odr.c b/odr/odr.c index 948043c..aaaec46 100644 --- a/odr/odr.c +++ b/odr/odr.c @@ -2,7 +2,7 @@ * Copyright (c) 1995-2003, Index Data * See the file LICENSE for details. * - * $Id: odr.c,v 1.42 2003-05-19 14:37:38 adam Exp $ + * $Id: odr.c,v 1.46 2003-10-16 10:37:06 adam Exp $ * */ #if HAVE_CONFIG_H @@ -36,7 +36,7 @@ char *odr_errlist[] = "Stack overflow", "Length of constructed type different from sum of members", "Overflow writing definite length of constructed type", - "HTTP Bad Request" + "Bad HTTP Request" }; char *odr_errmsg(int n) @@ -44,9 +44,16 @@ char *odr_errmsg(int n) return odr_errlist[n]; } -void odr_perror(ODR o, char *message) +void odr_perror(ODR o, const char *message) { - fprintf(stderr, "%s: %s\n", message, odr_errlist[o->error]); + const char *e = odr_getelement(o); + int err, x; + + err = odr_geterrorx(o, &x); + fprintf(stderr, "%s: %s (code %d:%d)", message, odr_errlist[err], err, x); + if (e && *e) + fprintf (stderr, " element %s", e); + fprintf(stderr, "\n"); } int odr_geterror(ODR o) @@ -61,10 +68,25 @@ int odr_geterrorx(ODR o, int *x) return o->error; } +char *odr_getelement(ODR o) +{ + return o->op->element; +} + void odr_seterror(ODR o, int error, int id) { o->error = error; o->op->error_id = id; + o->op->element[0] = '\0'; +} + +void odr_setelement(ODR o, const char *element) +{ + if (element) + { + strncpy(o->op->element, element, sizeof(o->op->element)-1); + o->op->element[sizeof(o->op->element)-1] = '\0'; + } } void odr_setprint(ODR o, FILE *file)