/* Generated from /home/biorn/src/lib/libkrb5/../../kerberosV/src/lib/asn1/k5.asn1 */ /* Do not edit */ #include #include #include #include #include #include #include #include #include #define BACK if (e) return e; p -= l; len -= l; ret += l int encode_AD_IF_RELEVANT(unsigned char *p, size_t len, const AD_IF_RELEVANT *data, size_t *size) { size_t ret = 0; size_t l; int i, e; i = 0; e = encode_AuthorizationData(p, len, data, &l); BACK; *size = ret; return 0; } #define FORW if(e) goto fail; p += l; len -= l; ret += l int decode_AD_IF_RELEVANT(const unsigned char *p, size_t len, AD_IF_RELEVANT *data, size_t *size) { size_t ret = 0, reallen; size_t l; int e; memset(data, 0, sizeof(*data)); reallen = 0; e = decode_AuthorizationData(p, len, data, &l); FORW; if(size) *size = ret; return 0; fail: free_AD_IF_RELEVANT(data); return e; } void free_AD_IF_RELEVANT(AD_IF_RELEVANT *data) { free_AuthorizationData(data); } size_t length_AD_IF_RELEVANT(const AD_IF_RELEVANT *data) { size_t ret = 0; ret += length_AuthorizationData(data); return ret; } int copy_AD_IF_RELEVANT(const AD_IF_RELEVANT *from, AD_IF_RELEVANT *to) { if(copy_AuthorizationData(from, to)) return ENOMEM; return 0; }