/* Generated from /home/biorn/src/lib/libkrb5/../../kerberosV/src/lib/asn1/k5.asn1 */
/* Do not edit */

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
#include <errno.h>
#include <krb5_asn1.h>
#include <asn1_err.h>
#include <der.h>
#include <parse_units.h>

#define BACK if (e) return e; p -= l; len -= l; ret += l

int
encode_KDCOptions(unsigned char *p, size_t len, const KDCOptions *data, size_t *size)
{
size_t ret = 0;
size_t l;
int i, e;

i = 0;
{
unsigned char c = 0;
if(data->validate) c |= 1<<0;
if(data->renew) c |= 1<<1;
if(data->enc_tkt_in_skey) c |= 1<<3;
if(data->renewable_ok) c |= 1<<4;
if(data->disable_transited_check) c |= 1<<5;
*p-- = c; len--; ret++;
c = 0;
*p-- = c; len--; ret++;
c = 0;
if(data->canonicalize) c |= 1<<0;
if(data->request_anonymous) c |= 1<<1;
if(data->unused11) c |= 1<<4;
if(data->unused10) c |= 1<<5;
if(data->unused9) c |= 1<<6;
if(data->renewable) c |= 1<<7;
*p-- = c; len--; ret++;
c = 0;
if(data->unused7) c |= 1<<0;
if(data->postdated) c |= 1<<1;
if(data->allow_postdate) c |= 1<<2;
if(data->proxy) c |= 1<<3;
if(data->proxiable) c |= 1<<4;
if(data->forwarded) c |= 1<<5;
if(data->forwardable) c |= 1<<6;
if(data->reserved) c |= 1<<7;
*p-- = c;
*p-- = 0;
len -= 2;
ret += 2;
}

e = der_put_length_and_tag (p, len, ret, ASN1_C_UNIV, PRIM,UT_BitString, &l);
BACK;
*size = ret;
return 0;
}

#define FORW if(e) goto fail; p += l; len -= l; ret += l

int
decode_KDCOptions(const unsigned char *p, size_t len, KDCOptions *data, size_t *size)
{
size_t ret = 0, reallen;
size_t l;
int e;

memset(data, 0, sizeof(*data));
reallen = 0;
e = der_match_tag_and_length (p, len, ASN1_C_UNIV, PRIM, UT_BitString,&reallen, &l);
FORW;
if(len < reallen)
return ASN1_OVERRUN;
p++;
len--;
reallen--;
ret++;
data->reserved = (*p >> 7) & 1;
data->forwardable = (*p >> 6) & 1;
data->forwarded = (*p >> 5) & 1;
data->proxiable = (*p >> 4) & 1;
data->proxy = (*p >> 3) & 1;
data->allow_postdate = (*p >> 2) & 1;
data->postdated = (*p >> 1) & 1;
data->unused7 = (*p >> 0) & 1;
p++; len--; reallen--; ret++;
data->renewable = (*p >> 7) & 1;
data->unused9 = (*p >> 6) & 1;
data->unused10 = (*p >> 5) & 1;
data->unused11 = (*p >> 4) & 1;
data->request_anonymous = (*p >> 1) & 1;
data->canonicalize = (*p >> 0) & 1;
p++; len--; reallen--; ret++;
p++; len--; reallen--; ret++;
data->disable_transited_check = (*p >> 5) & 1;
data->renewable_ok = (*p >> 4) & 1;
data->enc_tkt_in_skey = (*p >> 3) & 1;
data->renew = (*p >> 1) & 1;
data->validate = (*p >> 0) & 1;
p += reallen; len -= reallen; ret += reallen;
if(size) *size = ret;
return 0;
fail:
free_KDCOptions(data);
return e;
}

void
free_KDCOptions(KDCOptions *data)
{
}

size_t
length_KDCOptions(const KDCOptions *data)
{
size_t ret = 0;
ret += 7;
return ret;
}

int
copy_KDCOptions(const KDCOptions *from, KDCOptions *to)
{
*(to) = *(from);
return 0;
}

unsigned KDCOptions2int(KDCOptions f)
{
unsigned r = 0;
if(f.reserved) r |= (1U << 0);
if(f.forwardable) r |= (1U << 1);
if(f.forwarded) r |= (1U << 2);
if(f.proxiable) r |= (1U << 3);
if(f.proxy) r |= (1U << 4);
if(f.allow_postdate) r |= (1U << 5);
if(f.postdated) r |= (1U << 6);
if(f.unused7) r |= (1U << 7);
if(f.renewable) r |= (1U << 8);
if(f.unused9) r |= (1U << 9);
if(f.unused10) r |= (1U << 10);
if(f.unused11) r |= (1U << 11);
if(f.request_anonymous) r |= (1U << 14);
if(f.canonicalize) r |= (1U << 15);
if(f.disable_transited_check) r |= (1U << 26);
if(f.renewable_ok) r |= (1U << 27);
if(f.enc_tkt_in_skey) r |= (1U << 28);
if(f.renew) r |= (1U << 30);
if(f.validate) r |= (1U << 31);
return r;
}

KDCOptions int2KDCOptions(unsigned n)
{
	KDCOptions flags;

	flags.reserved = (n >> 0) & 1;
	flags.forwardable = (n >> 1) & 1;
	flags.forwarded = (n >> 2) & 1;
	flags.proxiable = (n >> 3) & 1;
	flags.proxy = (n >> 4) & 1;
	flags.allow_postdate = (n >> 5) & 1;
	flags.postdated = (n >> 6) & 1;
	flags.unused7 = (n >> 7) & 1;
	flags.renewable = (n >> 8) & 1;
	flags.unused9 = (n >> 9) & 1;
	flags.unused10 = (n >> 10) & 1;
	flags.unused11 = (n >> 11) & 1;
	flags.request_anonymous = (n >> 14) & 1;
	flags.canonicalize = (n >> 15) & 1;
	flags.disable_transited_check = (n >> 26) & 1;
	flags.renewable_ok = (n >> 27) & 1;
	flags.enc_tkt_in_skey = (n >> 28) & 1;
	flags.renew = (n >> 30) & 1;
	flags.validate = (n >> 31) & 1;
	return flags;
}

static struct units KDCOptions_units[] = {
	{"validate",	1U << 31},
	{"renew",	1U << 30},
	{"enc_tkt_in_skey",	1U << 28},
	{"renewable_ok",	1U << 27},
	{"disable_transited_check",	1U << 26},
	{"canonicalize",	1U << 15},
	{"request_anonymous",	1U << 14},
	{"unused11",	1U << 11},
	{"unused10",	1U << 10},
	{"unused9",	1U << 9},
	{"renewable",	1U << 8},
	{"unused7",	1U << 7},
	{"postdated",	1U << 6},
	{"allow_postdate",	1U << 5},
	{"proxy",	1U << 4},
	{"proxiable",	1U << 3},
	{"forwarded",	1U << 2},
	{"forwardable",	1U << 1},
	{"reserved",	1U << 0},
	{NULL,	0}
};

const struct units * asn1_KDCOptions_units(void){
return KDCOptions_units;
}