projects
/
yaz-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix idmetaversion strips n SA-743
[yaz-moved-to-github.git]
/
src
/
ber_any.c
diff --git
a/src/ber_any.c
b/src/ber_any.c
index
905b0c4
..
7243e3d
100644
(file)
--- a/
src/ber_any.c
+++ b/
src/ber_any.c
@@
-1,9
+1,9
@@
/* This file is part of the YAZ toolkit.
/* This file is part of the YAZ toolkit.
- * Copyright (C) 1995-2012 Index Data
+ * Copyright (C) Index Data
* See the file LICENSE for details.
*/
* See the file LICENSE for details.
*/
-/**
+/**
* \file ber_any.c
* \brief Implements BER ANY encoding and decoding.
*
* \file ber_any.c
* \brief Implements BER ANY encoding and decoding.
*
@@
-21,19
+21,19
@@
int ber_any(ODR o, Odr_any **p)
{
int res;
int ber_any(ODR o, Odr_any **p)
{
int res;
-
+
switch (o->direction)
{
case ODR_DECODE:
switch (o->direction)
{
case ODR_DECODE:
- if ((res = completeBER(o->bp, odr_max(o))) <= 0) /* FIX THIS */
+ if ((res = completeBER(o->op->bp, odr_max(o))) <= 0) /* FIX THIS */
{
odr_seterror(o, OPROTO, 2);
return 0;
}
{
odr_seterror(o, OPROTO, 2);
return 0;
}
- (*p)->buf = (unsigned char *)odr_malloc(o, res);
- memcpy((*p)->buf, o->bp, res);
- (*p)->len = (*p)->size = res;
- o->bp += res;
+ (*p)->buf = (char *)odr_malloc(o, res);
+ memcpy((*p)->buf, o->op->bp, res);
+ (*p)->len = res;
+ o->op->bp += res;
return 1;
case ODR_ENCODE:
if (odr_write(o, (*p)->buf, (*p)->len) < 0)
return 1;
case ODR_ENCODE:
if (odr_write(o, (*p)->buf, (*p)->len) < 0)
@@
-45,11
+45,11
@@
int ber_any(ODR o, Odr_any **p)
#define BER_ANY_DEBUG 0
#define BER_ANY_DEBUG 0
-int completeBER_n(const unsigned char *buf, int len, int level)
+int completeBER_n(const char *buf, int len, int level)
{
int res, ll, zclass, tag, cons;
{
int res, ll, zclass, tag, cons;
- const unsigned char *b = buf;
-
+ const char *b = buf;
+
if (level > 1000)
{
#if BER_ANY_DEBUG
if (level > 1000)
{
#if BER_ANY_DEBUG
@@
-74,7
+74,7
@@
int completeBER_n(const unsigned char *buf, int len, int level)
#endif
return -1; /* error */
}
#endif
return -1; /* error */
}
- if (res == -1)
+ if (res == -1)
{
#if BER_ANY_DEBUG
yaz_log(YLOG_LOG, "<<<<<<<<< return2 lev=%d res=%d", level, res);
{
#if BER_ANY_DEBUG
yaz_log(YLOG_LOG, "<<<<<<<<< return2 lev=%d res=%d", level, res);
@@
-120,7
+120,7
@@
int completeBER_n(const unsigned char *buf, int len, int level)
return (b - buf) + 2;
}
return (b - buf) + 2;
}
-int completeBER(const unsigned char *buf, int len)
+int completeBER(const char *buf, int len)
{
int res = completeBER_n(buf, len, 0);
#if BER_ANY_DEBUG
{
int res = completeBER_n(buf, len, 0);
#if BER_ANY_DEBUG