X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=asn%2Fprt-acc.c;h=0e3817f28b4176c78f2086d88c4abb940f884512;hp=dfc024e195281748aaf6b2755aaad1ffdadfeac6;hb=59526fbbf2e3b54ce94b3e79e6c7fef9e4f456fb;hpb=fb9fcec623beac87912604f17c680fad3def4a1b diff --git a/asn/prt-acc.c b/asn/prt-acc.c index dfc024e..0e3817f 100644 --- a/asn/prt-acc.c +++ b/asn/prt-acc.c @@ -1,10 +1,20 @@ /* - * Copyright (c) 1995-1998, Index Data. + * Copyright (c) 1995-1999, Index Data. * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * * $Log: prt-acc.c,v $ - * Revision 1.6 1998-01-05 09:04:57 adam + * Revision 1.9 1999-11-30 13:47:11 adam + * Improved installation. Moved header files to include/yaz. + * + * Revision 1.8 1999/04/20 09:56:47 adam + * Added 'name' paramter to encoder/decoder routines (typedef Odr_fun). + * Modified all encoders/decoders to reflect this change. + * + * Revision 1.7 1998/02/11 11:53:32 adam + * Changed code so that it compiles as C++. + * + * Revision 1.6 1998/01/05 09:04:57 adam * Fixed bugs in encoders/decoders - Not operator (!) missing. * * Revision 1.5 1995/09/29 17:11:53 quinn @@ -25,157 +35,167 @@ * */ -#include +#include -int z_Encryption1(ODR o, Z_Encryption1 **p, int opt) +int z_Encryption1(ODR o, Z_Encryption1 **p, int opt, const char *name) { - if (!odr_sequence_begin(o, p, sizeof(**p))) + if (!odr_sequence_begin(o, p, sizeof(**p), 0)) return opt && odr_ok(o); return - odr_implicit(o, odr_octetstring, &(*p)->cryptType, ODR_CONTEXT, 1, 1) && - odr_implicit(o, odr_octetstring, &(*p)->credential, ODR_CONTEXT, 2, - 1) && + odr_implicit(o, odr_octetstring, &(*p)->cryptType, + ODR_CONTEXT, 1, 1) && + odr_implicit(o, odr_octetstring, &(*p)->credential, + ODR_CONTEXT, 2, 1) && odr_implicit(o, odr_octetstring, &(*p)->data, ODR_CONTEXT, 3, 0) && odr_sequence_end(o); } -int z_EnumeratedPrompt1(ODR o, Z_EnumeratedPrompt1 **p, int opt) +int z_EnumeratedPrompt1(ODR o, Z_EnumeratedPrompt1 **p, int opt, + const char *name) { - if (!odr_sequence_begin(o, p, sizeof(**p))) + if (!odr_sequence_begin(o, p, sizeof(**p), 0)) return opt && odr_ok(o); return odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 1, 0) && odr_implicit(o, odr_visiblestring, &(*p)->suggestedString, ODR_CONTEXT, - 2, 1) && + 2, 1) && odr_sequence_end(o); } -int z_PromptId1(ODR o, Z_PromptId1 **p, int opt) +int z_PromptId1(ODR o, Z_PromptId1 **p, int opt, const char *name) { static Odr_arm arm[] = { {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptId1_enumeratedPrompt, - z_EnumeratedPrompt1}, + (Odr_fun)z_EnumeratedPrompt1, 0}, {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptId1_nonEnumeratedPrompt, - odr_visiblestring}, - {-1, -1, -1, -1, 0} + odr_visiblestring, 0}, + {-1, -1, -1, -1, 0, 0} }; - + if (o->direction == ODR_DECODE) - *p = odr_malloc(o, sizeof(**p)); + *p = (Z_PromptId1 *)odr_malloc(o, sizeof(**p)); else if (!*p) return opt; - if (odr_choice(o, arm, &(*p)->u, &(*p)->which)) + if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0)) return 1; *p = 0; return opt && odr_ok(o); } -int z_PromptInfo1(ODR o, Z_PromptInfo1 **p, int opt) +int z_PromptInfo1(ODR o, Z_PromptInfo1 **p, int opt, const char *name) { static Odr_arm arm[] = { {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Challenge1_character, - odr_visiblestring}, + odr_visiblestring, 0}, {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Challenge1_encrypted, - z_Encryption1}, - {-1, -1, -1, -1, 0} + (Odr_fun)z_Encryption1, 0}, + {-1, -1, -1, -1, 0, 0} }; - + if (o->direction == ODR_DECODE) - *p = odr_malloc(o, sizeof(**p)); + *p = (Z_PromptInfo1 *)odr_malloc(o, sizeof(**p)); else if (!*p) return opt; - if (odr_choice(o, arm, &(*p)->u, &(*p)->which)) + if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0)) return 1; *p = 0; return opt && odr_ok(o); } -int z_ChallengeUnit1(ODR o, Z_ChallengeUnit1 **p, int opt) +int z_ChallengeUnit1(ODR o, Z_ChallengeUnit1 **p, int opt, const char *name) { - if (!odr_sequence_begin(o, p, sizeof(**p))) + if (!odr_sequence_begin(o, p, sizeof(**p), 0)) return opt && odr_ok(o); return odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) && - odr_implicit(o, odr_visiblestring, &(*p)->defaultResponse, ODR_CONTEXT, - 2, 1) && - odr_explicit(o, z_PromptInfo1, &(*p)->promptInfo, ODR_CONTEXT, 3, 1) && - odr_implicit(o, odr_visiblestring, &(*p)->regExpr, ODR_CONTEXT, 4, 1) && - odr_implicit(o, odr_null, &(*p)->responseRequired, ODR_CONTEXT, 5, 1) && + odr_implicit(o, odr_visiblestring, &(*p)->defaultResponse, + ODR_CONTEXT, 2, 1) && + odr_explicit(o, z_PromptInfo1, &(*p)->promptInfo, + ODR_CONTEXT, 3, 1) && + odr_implicit(o, odr_visiblestring, &(*p)->regExpr, + ODR_CONTEXT, 4, 1) && + odr_implicit(o, odr_null, &(*p)->responseRequired, + ODR_CONTEXT, 5, 1) && odr_implicit_settag(o, ODR_CONTEXT, 6) && (odr_sequence_of(o, odr_visiblestring, &(*p)->allowedValues, - &(*p)->num_values) || odr_ok(o)) && + &(*p)->num_values, 0) || odr_ok(o)) && odr_implicit(o, odr_null, &(*p)->shouldSave, ODR_CONTEXT, 7, 1) && odr_implicit(o, odr_integer, &(*p)->dataType, ODR_CONTEXT, 8, 1) && odr_implicit(o, z_External, &(*p)->diagnostic, ODR_CONTEXT, 9, 1) && odr_sequence_end(o); } -int z_Challenge1(ODR o, Z_Challenge1 **p, int opt) +int z_Challenge1(ODR o, Z_Challenge1 **p, int opt, const char *name) { if (o->direction == ODR_ENCODE) - *p = odr_malloc(o, sizeof(**p)); + *p = (Z_Challenge1 *)odr_malloc(o, sizeof(**p)); else if (!*p) return opt; - if (odr_sequence_of(o, z_ChallengeUnit1, &(*p)->list, - &(*p)->num_challenges)) + if (odr_sequence_of(o, (Odr_fun)z_ChallengeUnit1, &(*p)->list, + &(*p)->num_challenges, 0)) return 1; *p = 0; return opt && odr_ok(o); } -int z_DiagRec(ODR, Z_DiagRec **, int); - -int z_ResponseUnit1(ODR o, Z_ResponseUnit1 **p, int opt) +int z_ResponseUnit1(ODR o, Z_ResponseUnit1 **p, int opt, const char *name) { static Odr_arm arm[] = { - {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Response1_string, odr_visiblestring}, - {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Response1_accept, odr_bool}, - {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_Response1_acknowledge, odr_null}, - {ODR_EXPLICIT, ODR_CONTEXT, 4, Z_Response1_diagnostic, z_DiagRec}, - {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_Response1_encrypted, z_Encryption1}, - {-1, -1, -1, -1, 0} + {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Response1_string, + odr_visiblestring, 0}, + {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Response1_accept, + (Odr_fun)odr_bool, 0}, + {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_Response1_acknowledge, + (Odr_fun)odr_null, 0}, + {ODR_EXPLICIT, ODR_CONTEXT, 4, Z_Response1_diagnostic, + (Odr_fun)z_DiagRec, 0}, + {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_Response1_encrypted, + (Odr_fun)z_Encryption1, 0}, + {-1, -1, -1, -1, 0, 0} }; - - if (!odr_sequence_begin(o, p, sizeof(**p))) + + if (!odr_sequence_begin(o, p, sizeof(**p), 0)) return opt && odr_ok(o); return odr_explicit(o, z_PromptId1, &(*p)->promptId, ODR_CONTEXT, 1, 0) && - odr_constructed_begin(o, p, ODR_CONTEXT, 2) && - odr_choice(o, arm, &(*p)->u, &(*p)->which) && + odr_constructed_begin(o, p, ODR_CONTEXT, 2, 0) && + odr_choice(o, arm, &(*p)->u, &(*p)->which, 0) && odr_constructed_end(o) && odr_sequence_end(o); } -int z_Response1(ODR o, Z_Response1 **p, int opt) +int z_Response1(ODR o, Z_Response1 **p, int opt, const char *name) { if (o->direction == ODR_ENCODE) - *p = odr_malloc(o, sizeof(**p)); + *p = (Z_Response1 *)odr_malloc(o, sizeof(**p)); else if (!*p) return opt; - if (odr_sequence_of(o, z_ResponseUnit1, &(*p)->list, - &(*p)->num_responses)) + if (odr_sequence_of(o, (Odr_fun)z_ResponseUnit1, &(*p)->list, + &(*p)->num_responses, 0)) return 1; *p = 0; return opt && odr_ok(o); } -int z_PromptObject1(ODR o, Z_PromptObject1 **p, int opt) +int z_PromptObject1(ODR o, Z_PromptObject1 **p, int opt, const char *name) { static Odr_arm arm[] = { - {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptObject1_challenge, z_Challenge1}, - {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptObject1_response, z_Response1}, - {-1, -1, -1, -1, 0} + {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_PromptObject1_challenge, + (Odr_fun)z_Challenge1, 0}, + {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_PromptObject1_response, + (Odr_fun)z_Response1, 0}, + {-1, -1, -1, -1, 0, 0} }; - + if (o->direction == ODR_DECODE) - *p = odr_malloc(o, sizeof(**p)); + *p = (Z_PromptObject1 *)odr_malloc(o, sizeof(**p)); else if (!*p) return opt; - if (odr_choice(o, arm, &(*p)->u, &(*p)->which)) + if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0)) return 1; *p = 0; return opt && odr_ok(o);