/* Generated from /usr/src/kerberosV/lib/asn1/../../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_Realm(unsigned char *p, size_t len, const Realm *data, size_t *size) { size_t ret = 0; size_t l; int i, e; i = 0; e = encode_general_string(p, len, data, &l); BACK; *size = ret; return 0; } #define FORW if(e) goto fail; p += l; len -= l; ret += l int decode_Realm(const unsigned char *p, size_t len, Realm *data, size_t *size) { size_t ret = 0, reallen; size_t l; int e; memset(data, 0, sizeof(*data)); reallen = 0; e = decode_general_string(p, len, data, &l); FORW; if(size) *size = ret; return 0; fail: free_Realm(data); return e; } void free_Realm(Realm *data) { free_general_string(data); } size_t length_Realm(const Realm *data) { size_t ret = 0; ret += length_general_string(data); return ret; } int copy_Realm(const Realm *from, Realm *to) { if(copy_general_string(from, to)) return ENOMEM; return 0; }