X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=include%2Fodr.h;h=24a5780008eed420b1c0b5d9c11b777e2bd12d1a;hp=55e0f08411126619c1a8af3cf774bc81a0dbecaa;hb=a807bde38544a7aa45dd2988e504a1acb3fd30c0;hpb=9c459af695605b44a044ad206562818be10034f1 diff --git a/include/odr.h b/include/odr.h index 55e0f08..24a5780 100644 --- a/include/odr.h +++ b/include/odr.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 1995, Index Data. + * Copyright (c) 1995-1997, Index Data. * * Permission to use, copy, modify, distribute, and sell this software and * its documentation, in whole or in part, for any purpose, is hereby granted, @@ -24,7 +24,43 @@ * OF THIS SOFTWARE. * * $Log: odr.h,v $ - * Revision 1.13 1995-09-29 17:01:49 quinn + * Revision 1.24 1997-11-24 11:33:56 adam + * Using function odr_nullval() instead of global ODR_NULLVAL when + * appropriate. + * + * Revision 1.23 1997/09/01 08:49:49 adam + * New windows NT/95 port using MSV5.0. To export DLL functions the + * YAZ_EXPORT modifier was added. Defined in yconfig.h. + * + * Revision 1.22 1997/07/21 12:44:30 adam + * Moved definitions of nmem_block and nmem_control. + * + * Revision 1.21 1997/05/14 06:53:41 adam + * C++ support. + * + * Revision 1.20 1997/04/30 08:52:08 quinn + * Null + * + * Revision 1.19 1996/10/08 12:58:08 adam + * New ODR function, odr_choice_enable_bias, to control behaviour of + * odr_choice_bias. + * + * Revision 1.18 1996/07/26 13:38:14 quinn + * Various smaller things. Gathered header-files. + * + * Revision 1.17 1995/11/08 17:41:27 quinn + * Smallish. + * + * Revision 1.16 1995/11/01 13:54:36 quinn + * Minor adjustments + * + * Revision 1.15 1995/10/18 16:12:36 quinn + * Better diagnostics. + * + * Revision 1.14 1995/09/29 17:12:04 quinn + * Smallish + * + * Revision 1.13 1995/09/29 17:01:49 quinn * More Windows work * * Revision 1.12 1995/09/27 15:02:48 quinn @@ -117,8 +153,13 @@ #include #include +#include #include +#ifdef __cplusplus +extern "C" { +#endif + #ifndef bool_t #define bool_t int #endif @@ -199,9 +240,6 @@ typedef struct odr_constack int lenlen; /* length of length-field */ } odr_constack; -struct odr_memblock; /* defined in odr_mem.c */ -typedef struct odr_memblock *ODR_MEM; - #define ODR_S_SET 0 #define ODR_S_CUR 1 #define ODR_S_END 2 @@ -215,6 +253,12 @@ typedef struct odr_ecblock int size; /* current buffer size */ } odr_ecblock; +typedef struct { /* used to be statics in ber_tag... */ + int lclass; + int ltag; + int br; + int lcons; +} Odr_ber_tag; typedef struct odr { @@ -231,25 +275,29 @@ typedef struct odr int t_class; /* implicit tagging (-1==default tag) */ int t_tag; + int enable_bias; /* force choice enable flag */ int choice_bias; /* force choice */ + int lenlen; /* force length-of-lenght (odr_setlen()) */ FILE *print; /* output file for direction print */ int indent; /* current indent level for printing */ - struct odr_memblock *mem; + NMEM mem; /* memory handle for decoding (primarily) */ /* stack for constructed types */ #define ODR_MAX_STACK 50 int stackp; /* top of stack (-1 == initial state) */ odr_constack stack[ODR_MAX_STACK]; + + Odr_ber_tag odr_ber_tag; } *ODR; -typedef int MDF (*Odr_fun)(); +typedef int (*Odr_fun)(); typedef struct odr_arm { int tagmode; - int class; + int zclass; int tag; int which; Odr_fun fun; @@ -269,20 +317,23 @@ typedef struct odr_arm #define ODATA 8 #define OSTACK 9 #define OCONLEN 10 +#define OLENOV 11 extern char *odr_errlist[]; -int MDF odr_geterror(ODR o); -void MDF odr_perror(ODR o, char *message); -void MDF odr_setprint(ODR o, FILE *file); -ODR MDF odr_createmem(int direction); -void MDF odr_reset(ODR o); -void MDF odr_destroy(ODR o); -void MDF odr_setbuf(ODR o, char *buf, int len, int can_grow); -char MDF *odr_getbuf(ODR o, int *len, int *size); -void MDF *odr_malloc(ODR o, int size); -ODR_MEM MDF odr_extract_mem(ODR o); -void MDF odr_release_mem(ODR_MEM p); +YAZ_EXPORT int odr_geterror(ODR o); +YAZ_EXPORT void odr_perror(ODR o, char *message); +YAZ_EXPORT void odr_setprint(ODR o, FILE *file); +YAZ_EXPORT ODR odr_createmem(int direction); +YAZ_EXPORT void odr_reset(ODR o); +YAZ_EXPORT void odr_destroy(ODR o); +YAZ_EXPORT void odr_setbuf(ODR o, char *buf, int len, int can_grow); +YAZ_EXPORT char *odr_getbuf(ODR o, int *len, int *size); +YAZ_EXPORT void *odr_malloc(ODR o, int size); +YAZ_EXPORT NMEM odr_extract_mem(ODR o); +YAZ_EXPORT Odr_null *odr_nullval(void); +#define odr_release_mem(m) nmem_destroy(m) +#define ODR_MEM NMEM #define odr_implicit(o, t, p, cl, tg, opt)\ (odr_implicit_settag((o), cl, tg), t ((o), (p), opt) ) @@ -344,11 +395,18 @@ void MDF odr_release_mem(ODR_MEM p); ) \ #define odr_tell(o) ((o)->ecb.pos) +#define odr_offset(o) ((o)->bp - (o)->buf) #define odr_ok(o) (!(o)->error) +#define odr_getmem(o) ((o)->mem) +#define odr_setmem(o, v) ((o)->mem = (v)) #define ODR_MAXNAME 256 +#ifdef __cplusplus +} +#endif + #include -#include +#include #endif