
/*** <<< INCLUDES [Int1] >>> ***/

#include <INTEGER.h>

/*** <<< TYPE-DECLS [Int1] >>> ***/


typedef INTEGER_t	 Int1_t;

/*** <<< FUNC-DECLS [Int1] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Int1;
asn_struct_free_f Int1_free;
asn_struct_print_f Int1_print;
asn_constr_check_f Int1_constraint;
ber_type_decoder_f Int1_decode_ber;
der_type_encoder_f Int1_encode_der;
xer_type_encoder_f Int1_encode_xer;

/*** <<< CODE [Int1] >>> ***/

int
Int1_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	/* Make the underlying type checker permanent */
	td->check_constraints = asn1_DEF_INTEGER.check_constraints;
	return td->check_constraints
		(td, sptr, app_errlog, app_key);
}

/*
 * This type is implemented using INTEGER,
 * so here we adjust the DEF accordingly.
 */
static void
Int1_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_INTEGER.free_struct;
	td->print_struct   = asn1_DEF_INTEGER.print_struct;
	td->ber_decoder    = asn1_DEF_INTEGER.ber_decoder;
	td->der_encoder    = asn1_DEF_INTEGER.der_encoder;
	td->xer_decoder    = asn1_DEF_INTEGER.xer_decoder;
	td->xer_encoder    = asn1_DEF_INTEGER.xer_encoder;
	td->last_tag_form  = asn1_DEF_INTEGER.last_tag_form;
	td->elements       = asn1_DEF_INTEGER.elements;
	td->elements_count = asn1_DEF_INTEGER.elements_count;
	td->specifics      = asn1_DEF_INTEGER.specifics;
}

void
Int1_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Int1_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Int1_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Int1_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Int1_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Int1_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Int1_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int1_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Int1_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int1_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Int1] >>> ***/

static ber_tlv_tag_t asn1_DEF_Int1_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Int1 = {
	"Int1",
	Int1_free,
	Int1_print,
	Int1_constraint,
	Int1_decode_ber,
	Int1_encode_der,
	0,				/* Not implemented yet */
	Int1_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Int1_tags,
	sizeof(asn1_DEF_Int1_tags)
		/sizeof(asn1_DEF_Int1_tags[0]), /* 1 */
	asn1_DEF_Int1_tags,	/* Same as above */
	sizeof(asn1_DEF_Int1_tags)
		/sizeof(asn1_DEF_Int1_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Int2] >>> ***/

#include <Int1.h>

/*** <<< TYPE-DECLS [Int2] >>> ***/


typedef Int1_t	 Int2_t;

/*** <<< FUNC-DECLS [Int2] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Int2;
asn_struct_free_f Int2_free;
asn_struct_print_f Int2_print;
asn_constr_check_f Int2_constraint;
ber_type_decoder_f Int2_decode_ber;
der_type_encoder_f Int2_encode_der;
xer_type_encoder_f Int2_encode_xer;

/*** <<< CODE [Int2] >>> ***/

int
Int2_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Int1_t *st = sptr;
	long value;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	/* Check if the sign bit is present */
	value = st->buf ? ((st->buf[0] & 0x80) ? -1 : 1) : 0;
	
	if((value >= 0)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Int1,
 * so here we adjust the DEF accordingly.
 */
static void
Int2_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Int1.free_struct;
	td->print_struct   = asn1_DEF_Int1.print_struct;
	td->ber_decoder    = asn1_DEF_Int1.ber_decoder;
	td->der_encoder    = asn1_DEF_Int1.der_encoder;
	td->xer_decoder    = asn1_DEF_Int1.xer_decoder;
	td->xer_encoder    = asn1_DEF_Int1.xer_encoder;
	td->last_tag_form  = asn1_DEF_Int1.last_tag_form;
	td->elements       = asn1_DEF_Int1.elements;
	td->elements_count = asn1_DEF_Int1.elements_count;
	td->specifics      = asn1_DEF_Int1.specifics;
}

void
Int2_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Int2_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Int2_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Int2_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Int2_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Int2_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Int2_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int2_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Int2_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int2_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Int2] >>> ***/

static ber_tlv_tag_t asn1_DEF_Int2_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Int2 = {
	"Int2",
	Int2_free,
	Int2_print,
	Int2_constraint,
	Int2_decode_ber,
	Int2_encode_der,
	0,				/* Not implemented yet */
	Int2_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Int2_tags,
	sizeof(asn1_DEF_Int2_tags)
		/sizeof(asn1_DEF_Int2_tags[0]), /* 1 */
	asn1_DEF_Int2_tags,	/* Same as above */
	sizeof(asn1_DEF_Int2_tags)
		/sizeof(asn1_DEF_Int2_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Int3] >>> ***/

#include <Int2.h>

/*** <<< TYPE-DECLS [Int3] >>> ***/


typedef Int2_t	 Int3_t;

/*** <<< FUNC-DECLS [Int3] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Int3;
asn_struct_free_f Int3_free;
asn_struct_print_f Int3_print;
asn_constr_check_f Int3_constraint;
ber_type_decoder_f Int3_decode_ber;
der_type_encoder_f Int3_encode_der;
xer_type_encoder_f Int3_encode_xer;

/*** <<< CODE [Int3] >>> ***/

int
Int3_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Int2_t *st = sptr;
	long value;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if(asn1_INTEGER2long(st, &value)) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value too large (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if((value >= 0 && value <= 10)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Int2,
 * so here we adjust the DEF accordingly.
 */
static void
Int3_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Int2.free_struct;
	td->print_struct   = asn1_DEF_Int2.print_struct;
	td->ber_decoder    = asn1_DEF_Int2.ber_decoder;
	td->der_encoder    = asn1_DEF_Int2.der_encoder;
	td->xer_decoder    = asn1_DEF_Int2.xer_decoder;
	td->xer_encoder    = asn1_DEF_Int2.xer_encoder;
	td->last_tag_form  = asn1_DEF_Int2.last_tag_form;
	td->elements       = asn1_DEF_Int2.elements;
	td->elements_count = asn1_DEF_Int2.elements_count;
	td->specifics      = asn1_DEF_Int2.specifics;
}

void
Int3_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Int3_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Int3_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Int3_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Int3_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Int3_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Int3_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int3_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Int3_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int3_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Int3] >>> ***/

static ber_tlv_tag_t asn1_DEF_Int3_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Int3 = {
	"Int3",
	Int3_free,
	Int3_print,
	Int3_constraint,
	Int3_decode_ber,
	Int3_encode_der,
	0,				/* Not implemented yet */
	Int3_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Int3_tags,
	sizeof(asn1_DEF_Int3_tags)
		/sizeof(asn1_DEF_Int3_tags[0]), /* 1 */
	asn1_DEF_Int3_tags,	/* Same as above */
	sizeof(asn1_DEF_Int3_tags)
		/sizeof(asn1_DEF_Int3_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Int4] >>> ***/

#include <Int3.h>

/*** <<< TYPE-DECLS [Int4] >>> ***/


typedef Int3_t	 Int4_t;

/*** <<< FUNC-DECLS [Int4] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Int4;
asn_struct_free_f Int4_free;
asn_struct_print_f Int4_print;
asn_constr_check_f Int4_constraint;
ber_type_decoder_f Int4_decode_ber;
der_type_encoder_f Int4_encode_der;
xer_type_encoder_f Int4_encode_xer;

/*** <<< CODE [Int4] >>> ***/

int
Int4_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Int3_t *st = sptr;
	long value;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if(asn1_INTEGER2long(st, &value)) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value too large (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if((value >= 1 && value <= 10)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Int3,
 * so here we adjust the DEF accordingly.
 */
static void
Int4_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Int3.free_struct;
	td->print_struct   = asn1_DEF_Int3.print_struct;
	td->ber_decoder    = asn1_DEF_Int3.ber_decoder;
	td->der_encoder    = asn1_DEF_Int3.der_encoder;
	td->xer_decoder    = asn1_DEF_Int3.xer_decoder;
	td->xer_encoder    = asn1_DEF_Int3.xer_encoder;
	td->last_tag_form  = asn1_DEF_Int3.last_tag_form;
	td->elements       = asn1_DEF_Int3.elements;
	td->elements_count = asn1_DEF_Int3.elements_count;
	td->specifics      = asn1_DEF_Int3.specifics;
}

void
Int4_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Int4_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Int4_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Int4_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Int4_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Int4_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Int4_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int4_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Int4_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int4_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Int4] >>> ***/

static ber_tlv_tag_t asn1_DEF_Int4_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Int4 = {
	"Int4",
	Int4_free,
	Int4_print,
	Int4_constraint,
	Int4_decode_ber,
	Int4_encode_der,
	0,				/* Not implemented yet */
	Int4_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Int4_tags,
	sizeof(asn1_DEF_Int4_tags)
		/sizeof(asn1_DEF_Int4_tags[0]), /* 1 */
	asn1_DEF_Int4_tags,	/* Same as above */
	sizeof(asn1_DEF_Int4_tags)
		/sizeof(asn1_DEF_Int4_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Int5] >>> ***/

#include <Int4.h>

/*** <<< TYPE-DECLS [Int5] >>> ***/


typedef Int4_t	 Int5_t;

/*** <<< FUNC-DECLS [Int5] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Int5;
asn_struct_free_f Int5_free;
asn_struct_print_f Int5_print;
asn_constr_check_f Int5_constraint;
ber_type_decoder_f Int5_decode_ber;
der_type_encoder_f Int5_encode_der;
xer_type_encoder_f Int5_encode_xer;

/*** <<< CODE [Int5] >>> ***/

int
Int5_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Int4_t *st = sptr;
	long value;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if(asn1_INTEGER2long(st, &value)) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value too large (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if((value == 5)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Int4,
 * so here we adjust the DEF accordingly.
 */
static void
Int5_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Int4.free_struct;
	td->print_struct   = asn1_DEF_Int4.print_struct;
	td->ber_decoder    = asn1_DEF_Int4.ber_decoder;
	td->der_encoder    = asn1_DEF_Int4.der_encoder;
	td->xer_decoder    = asn1_DEF_Int4.xer_decoder;
	td->xer_encoder    = asn1_DEF_Int4.xer_encoder;
	td->last_tag_form  = asn1_DEF_Int4.last_tag_form;
	td->elements       = asn1_DEF_Int4.elements;
	td->elements_count = asn1_DEF_Int4.elements_count;
	td->specifics      = asn1_DEF_Int4.specifics;
}

void
Int5_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Int5_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Int5_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Int5_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Int5_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Int5_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Int5_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int5_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Int5_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Int5_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Int5] >>> ***/

static ber_tlv_tag_t asn1_DEF_Int5_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Int5 = {
	"Int5",
	Int5_free,
	Int5_print,
	Int5_constraint,
	Int5_decode_ber,
	Int5_encode_der,
	0,				/* Not implemented yet */
	Int5_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Int5_tags,
	sizeof(asn1_DEF_Int5_tags)
		/sizeof(asn1_DEF_Int5_tags[0]), /* 1 */
	asn1_DEF_Int5_tags,	/* Same as above */
	sizeof(asn1_DEF_Int5_tags)
		/sizeof(asn1_DEF_Int5_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [ExtensibleExtensions] >>> ***/

#include <INTEGER.h>

/*** <<< TYPE-DECLS [ExtensibleExtensions] >>> ***/


typedef INTEGER_t	 ExtensibleExtensions_t;

/*** <<< FUNC-DECLS [ExtensibleExtensions] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_ExtensibleExtensions;
asn_struct_free_f ExtensibleExtensions_free;
asn_struct_print_f ExtensibleExtensions_print;
asn_constr_check_f ExtensibleExtensions_constraint;
ber_type_decoder_f ExtensibleExtensions_decode_ber;
der_type_encoder_f ExtensibleExtensions_encode_der;
xer_type_encoder_f ExtensibleExtensions_encode_xer;

/*** <<< CODE [ExtensibleExtensions] >>> ***/

int
ExtensibleExtensions_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const INTEGER_t *st = sptr;
	long value;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if(asn1_INTEGER2long(st, &value)) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value too large (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	if((value >= 1 && value <= 256)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using INTEGER,
 * so here we adjust the DEF accordingly.
 */
static void
ExtensibleExtensions_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_INTEGER.free_struct;
	td->print_struct   = asn1_DEF_INTEGER.print_struct;
	td->ber_decoder    = asn1_DEF_INTEGER.ber_decoder;
	td->der_encoder    = asn1_DEF_INTEGER.der_encoder;
	td->xer_decoder    = asn1_DEF_INTEGER.xer_decoder;
	td->xer_encoder    = asn1_DEF_INTEGER.xer_encoder;
	td->last_tag_form  = asn1_DEF_INTEGER.last_tag_form;
	td->elements       = asn1_DEF_INTEGER.elements;
	td->elements_count = asn1_DEF_INTEGER.elements_count;
	td->specifics      = asn1_DEF_INTEGER.specifics;
}

void
ExtensibleExtensions_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	ExtensibleExtensions_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
ExtensibleExtensions_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	ExtensibleExtensions_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
ExtensibleExtensions_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	ExtensibleExtensions_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
ExtensibleExtensions_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	ExtensibleExtensions_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
ExtensibleExtensions_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	ExtensibleExtensions_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [ExtensibleExtensions] >>> ***/

static ber_tlv_tag_t asn1_DEF_ExtensibleExtensions_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_ExtensibleExtensions = {
	"ExtensibleExtensions",
	ExtensibleExtensions_free,
	ExtensibleExtensions_print,
	ExtensibleExtensions_constraint,
	ExtensibleExtensions_decode_ber,
	ExtensibleExtensions_encode_der,
	0,				/* Not implemented yet */
	ExtensibleExtensions_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_ExtensibleExtensions_tags,
	sizeof(asn1_DEF_ExtensibleExtensions_tags)
		/sizeof(asn1_DEF_ExtensibleExtensions_tags[0]), /* 1 */
	asn1_DEF_ExtensibleExtensions_tags,	/* Same as above */
	sizeof(asn1_DEF_ExtensibleExtensions_tags)
		/sizeof(asn1_DEF_ExtensibleExtensions_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Str1] >>> ***/

#include <IA5String.h>

/*** <<< TYPE-DECLS [Str1] >>> ***/


typedef IA5String_t	 Str1_t;

/*** <<< FUNC-DECLS [Str1] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Str1;
asn_struct_free_f Str1_free;
asn_struct_print_f Str1_print;
asn_constr_check_f Str1_constraint;
ber_type_decoder_f Str1_decode_ber;
der_type_encoder_f Str1_encode_der;
xer_type_encoder_f Str1_encode_xer;

/*** <<< CODE [Str1] >>> ***/

int
Str1_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	/* Make the underlying type checker permanent */
	td->check_constraints = asn1_DEF_IA5String.check_constraints;
	return td->check_constraints
		(td, sptr, app_errlog, app_key);
}

/*
 * This type is implemented using IA5String,
 * so here we adjust the DEF accordingly.
 */
static void
Str1_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_IA5String.free_struct;
	td->print_struct   = asn1_DEF_IA5String.print_struct;
	td->ber_decoder    = asn1_DEF_IA5String.ber_decoder;
	td->der_encoder    = asn1_DEF_IA5String.der_encoder;
	td->xer_decoder    = asn1_DEF_IA5String.xer_decoder;
	td->xer_encoder    = asn1_DEF_IA5String.xer_encoder;
	td->last_tag_form  = asn1_DEF_IA5String.last_tag_form;
	td->elements       = asn1_DEF_IA5String.elements;
	td->elements_count = asn1_DEF_IA5String.elements_count;
	td->specifics      = asn1_DEF_IA5String.specifics;
}

void
Str1_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Str1_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Str1_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Str1_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Str1_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Str1_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Str1_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str1_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Str1_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str1_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Str1] >>> ***/

static ber_tlv_tag_t asn1_DEF_Str1_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Str1 = {
	"Str1",
	Str1_free,
	Str1_print,
	Str1_constraint,
	Str1_decode_ber,
	Str1_encode_der,
	0,				/* Not implemented yet */
	Str1_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Str1_tags,
	sizeof(asn1_DEF_Str1_tags)
		/sizeof(asn1_DEF_Str1_tags[0]), /* 1 */
	asn1_DEF_Str1_tags,	/* Same as above */
	sizeof(asn1_DEF_Str1_tags)
		/sizeof(asn1_DEF_Str1_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Str2] >>> ***/

#include <Str1.h>

/*** <<< TYPE-DECLS [Str2] >>> ***/


typedef Str1_t	 Str2_t;

/*** <<< FUNC-DECLS [Str2] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Str2;
asn_struct_free_f Str2_free;
asn_struct_print_f Str2_print;
asn_constr_check_f Str2_constraint;
ber_type_decoder_f Str2_decode_ber;
der_type_encoder_f Str2_encode_der;
xer_type_encoder_f Str2_encode_xer;

/*** <<< CTABLES [Str2] >>> ***/

static int check_permitted_alphabet_1(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv <= 127)) return -1;
	}
	return 0;
}


/*** <<< CODE [Str2] >>> ***/

int
Str2_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Str1_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if(((size <= 20) || (size >= 25 && size <= 30))
		 && !check_permitted_alphabet_1(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Str1,
 * so here we adjust the DEF accordingly.
 */
static void
Str2_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Str1.free_struct;
	td->print_struct   = asn1_DEF_Str1.print_struct;
	td->ber_decoder    = asn1_DEF_Str1.ber_decoder;
	td->der_encoder    = asn1_DEF_Str1.der_encoder;
	td->xer_decoder    = asn1_DEF_Str1.xer_decoder;
	td->xer_encoder    = asn1_DEF_Str1.xer_encoder;
	td->last_tag_form  = asn1_DEF_Str1.last_tag_form;
	td->elements       = asn1_DEF_Str1.elements;
	td->elements_count = asn1_DEF_Str1.elements_count;
	td->specifics      = asn1_DEF_Str1.specifics;
}

void
Str2_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Str2_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Str2_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Str2_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Str2_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Str2_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Str2_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str2_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Str2_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str2_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Str2] >>> ***/

static ber_tlv_tag_t asn1_DEF_Str2_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Str2 = {
	"Str2",
	Str2_free,
	Str2_print,
	Str2_constraint,
	Str2_decode_ber,
	Str2_encode_der,
	0,				/* Not implemented yet */
	Str2_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Str2_tags,
	sizeof(asn1_DEF_Str2_tags)
		/sizeof(asn1_DEF_Str2_tags[0]), /* 1 */
	asn1_DEF_Str2_tags,	/* Same as above */
	sizeof(asn1_DEF_Str2_tags)
		/sizeof(asn1_DEF_Str2_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Str3] >>> ***/

#include <Str2.h>

/*** <<< TYPE-DECLS [Str3] >>> ***/


typedef Str2_t	 Str3_t;

/*** <<< FUNC-DECLS [Str3] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Str3;
asn_struct_free_f Str3_free;
asn_struct_print_f Str3_print;
asn_constr_check_f Str3_constraint;
ber_type_decoder_f Str3_decode_ber;
der_type_encoder_f Str3_encode_der;
xer_type_encoder_f Str3_encode_xer;

/*** <<< CTABLES [Str3] >>> ***/

static int permitted_alphabet_table_2[256] = {
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,	/*  ABC             */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,	/*     def          */
};

static int check_permitted_alphabet_2(const void *sptr) {
	int *table = permitted_alphabet_table_2;
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!table[cv]) return -1;
	}
	return 0;
}


/*** <<< CODE [Str3] >>> ***/

int
Str3_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Str2_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if(((size >= 10 && size <= 20) || (size >= 25 && size <= 27))
		 && !check_permitted_alphabet_2(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Str2,
 * so here we adjust the DEF accordingly.
 */
static void
Str3_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Str2.free_struct;
	td->print_struct   = asn1_DEF_Str2.print_struct;
	td->ber_decoder    = asn1_DEF_Str2.ber_decoder;
	td->der_encoder    = asn1_DEF_Str2.der_encoder;
	td->xer_decoder    = asn1_DEF_Str2.xer_decoder;
	td->xer_encoder    = asn1_DEF_Str2.xer_encoder;
	td->last_tag_form  = asn1_DEF_Str2.last_tag_form;
	td->elements       = asn1_DEF_Str2.elements;
	td->elements_count = asn1_DEF_Str2.elements_count;
	td->specifics      = asn1_DEF_Str2.specifics;
}

void
Str3_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Str3_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Str3_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Str3_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Str3_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Str3_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Str3_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str3_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Str3_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str3_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Str3] >>> ***/

static ber_tlv_tag_t asn1_DEF_Str3_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Str3 = {
	"Str3",
	Str3_free,
	Str3_print,
	Str3_constraint,
	Str3_decode_ber,
	Str3_encode_der,
	0,				/* Not implemented yet */
	Str3_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Str3_tags,
	sizeof(asn1_DEF_Str3_tags)
		/sizeof(asn1_DEF_Str3_tags[0]), /* 1 */
	asn1_DEF_Str3_tags,	/* Same as above */
	sizeof(asn1_DEF_Str3_tags)
		/sizeof(asn1_DEF_Str3_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Str4] >>> ***/

#include <IA5String.h>

/*** <<< TYPE-DECLS [Str4] >>> ***/


typedef IA5String_t	 Str4_t;

/*** <<< FUNC-DECLS [Str4] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Str4;
asn_struct_free_f Str4_free;
asn_struct_print_f Str4_print;
asn_constr_check_f Str4_constraint;
ber_type_decoder_f Str4_decode_ber;
der_type_encoder_f Str4_encode_der;
xer_type_encoder_f Str4_encode_xer;

/*** <<< CTABLES [Str4] >>> ***/

static int check_permitted_alphabet_3(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv <= 127)) return -1;
	}
	return 0;
}


/*** <<< CODE [Str4] >>> ***/

int
Str4_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const IA5String_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_3(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using IA5String,
 * so here we adjust the DEF accordingly.
 */
static void
Str4_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_IA5String.free_struct;
	td->print_struct   = asn1_DEF_IA5String.print_struct;
	td->ber_decoder    = asn1_DEF_IA5String.ber_decoder;
	td->der_encoder    = asn1_DEF_IA5String.der_encoder;
	td->xer_decoder    = asn1_DEF_IA5String.xer_decoder;
	td->xer_encoder    = asn1_DEF_IA5String.xer_encoder;
	td->last_tag_form  = asn1_DEF_IA5String.last_tag_form;
	td->elements       = asn1_DEF_IA5String.elements;
	td->elements_count = asn1_DEF_IA5String.elements_count;
	td->specifics      = asn1_DEF_IA5String.specifics;
}

void
Str4_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Str4_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Str4_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Str4_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Str4_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Str4_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Str4_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str4_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Str4_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Str4_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Str4] >>> ***/

static ber_tlv_tag_t asn1_DEF_Str4_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Str4 = {
	"Str4",
	Str4_free,
	Str4_print,
	Str4_constraint,
	Str4_decode_ber,
	Str4_encode_der,
	0,				/* Not implemented yet */
	Str4_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Str4_tags,
	sizeof(asn1_DEF_Str4_tags)
		/sizeof(asn1_DEF_Str4_tags[0]), /* 1 */
	asn1_DEF_Str4_tags,	/* Same as above */
	sizeof(asn1_DEF_Str4_tags)
		/sizeof(asn1_DEF_Str4_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [PER-Visible] >>> ***/

#include <IA5String.h>

/*** <<< TYPE-DECLS [PER-Visible] >>> ***/


typedef IA5String_t	 PER_Visible_t;

/*** <<< FUNC-DECLS [PER-Visible] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_PER_Visible;
asn_struct_free_f PER_Visible_free;
asn_struct_print_f PER_Visible_print;
asn_constr_check_f PER_Visible_constraint;
ber_type_decoder_f PER_Visible_decode_ber;
der_type_encoder_f PER_Visible_encode_der;
xer_type_encoder_f PER_Visible_encode_xer;

/*** <<< CTABLES [PER-Visible] >>> ***/

static int check_permitted_alphabet_4(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 70)) return -1;
	}
	return 0;
}


/*** <<< CODE [PER-Visible] >>> ***/

int
PER_Visible_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const IA5String_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_4(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using IA5String,
 * so here we adjust the DEF accordingly.
 */
static void
PER_Visible_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_IA5String.free_struct;
	td->print_struct   = asn1_DEF_IA5String.print_struct;
	td->ber_decoder    = asn1_DEF_IA5String.ber_decoder;
	td->der_encoder    = asn1_DEF_IA5String.der_encoder;
	td->xer_decoder    = asn1_DEF_IA5String.xer_decoder;
	td->xer_encoder    = asn1_DEF_IA5String.xer_encoder;
	td->last_tag_form  = asn1_DEF_IA5String.last_tag_form;
	td->elements       = asn1_DEF_IA5String.elements;
	td->elements_count = asn1_DEF_IA5String.elements_count;
	td->specifics      = asn1_DEF_IA5String.specifics;
}

void
PER_Visible_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	PER_Visible_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
PER_Visible_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
PER_Visible_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	PER_Visible_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
PER_Visible_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
PER_Visible_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [PER-Visible] >>> ***/

static ber_tlv_tag_t asn1_DEF_PER_Visible_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_PER_Visible = {
	"PER-Visible",
	PER_Visible_free,
	PER_Visible_print,
	PER_Visible_constraint,
	PER_Visible_decode_ber,
	PER_Visible_encode_der,
	0,				/* Not implemented yet */
	PER_Visible_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_PER_Visible_tags,
	sizeof(asn1_DEF_PER_Visible_tags)
		/sizeof(asn1_DEF_PER_Visible_tags[0]), /* 1 */
	asn1_DEF_PER_Visible_tags,	/* Same as above */
	sizeof(asn1_DEF_PER_Visible_tags)
		/sizeof(asn1_DEF_PER_Visible_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [PER-Visible-2] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [PER-Visible-2] >>> ***/


typedef PER_Visible_t	 PER_Visible_2_t;

/*** <<< FUNC-DECLS [PER-Visible-2] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_PER_Visible_2;
asn_struct_free_f PER_Visible_2_free;
asn_struct_print_f PER_Visible_2_print;
asn_constr_check_f PER_Visible_2_constraint;
ber_type_decoder_f PER_Visible_2_decode_ber;
der_type_encoder_f PER_Visible_2_encode_der;
xer_type_encoder_f PER_Visible_2_encode_xer;

/*** <<< CTABLES [PER-Visible-2] >>> ***/

static int check_permitted_alphabet_5(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 69 && cv <= 70)) return -1;
	}
	return 0;
}


/*** <<< CODE [PER-Visible-2] >>> ***/

int
PER_Visible_2_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_5(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
PER_Visible_2_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
PER_Visible_2_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	PER_Visible_2_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
PER_Visible_2_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
PER_Visible_2_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
PER_Visible_2_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
PER_Visible_2_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [PER-Visible-2] >>> ***/

static ber_tlv_tag_t asn1_DEF_PER_Visible_2_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_PER_Visible_2 = {
	"PER-Visible-2",
	PER_Visible_2_free,
	PER_Visible_2_print,
	PER_Visible_2_constraint,
	PER_Visible_2_decode_ber,
	PER_Visible_2_encode_der,
	0,				/* Not implemented yet */
	PER_Visible_2_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_PER_Visible_2_tags,
	sizeof(asn1_DEF_PER_Visible_2_tags)
		/sizeof(asn1_DEF_PER_Visible_2_tags[0]), /* 1 */
	asn1_DEF_PER_Visible_2_tags,	/* Same as above */
	sizeof(asn1_DEF_PER_Visible_2_tags)
		/sizeof(asn1_DEF_PER_Visible_2_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Not-PER-Visible-1] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [Not-PER-Visible-1] >>> ***/


typedef PER_Visible_t	 Not_PER_Visible_1_t;

/*** <<< FUNC-DECLS [Not-PER-Visible-1] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_1;
asn_struct_free_f Not_PER_Visible_1_free;
asn_struct_print_f Not_PER_Visible_1_print;
asn_constr_check_f Not_PER_Visible_1_constraint;
ber_type_decoder_f Not_PER_Visible_1_decode_ber;
der_type_encoder_f Not_PER_Visible_1_encode_der;
xer_type_encoder_f Not_PER_Visible_1_encode_xer;

/*** <<< CTABLES [Not-PER-Visible-1] >>> ***/

static int check_permitted_alphabet_6(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 70)) return -1;
	}
	return 0;
}


/*** <<< CODE [Not-PER-Visible-1] >>> ***/

int
Not_PER_Visible_1_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_6(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
Not_PER_Visible_1_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
Not_PER_Visible_1_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Not_PER_Visible_1_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Not_PER_Visible_1_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_1_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Not_PER_Visible_1_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Not_PER_Visible_1_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Not_PER_Visible_1_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_1_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Not_PER_Visible_1_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_1_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Not-PER-Visible-1] >>> ***/

static ber_tlv_tag_t asn1_DEF_Not_PER_Visible_1_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_1 = {
	"Not-PER-Visible-1",
	Not_PER_Visible_1_free,
	Not_PER_Visible_1_print,
	Not_PER_Visible_1_constraint,
	Not_PER_Visible_1_decode_ber,
	Not_PER_Visible_1_encode_der,
	0,				/* Not implemented yet */
	Not_PER_Visible_1_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Not_PER_Visible_1_tags,
	sizeof(asn1_DEF_Not_PER_Visible_1_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_1_tags[0]), /* 1 */
	asn1_DEF_Not_PER_Visible_1_tags,	/* Same as above */
	sizeof(asn1_DEF_Not_PER_Visible_1_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_1_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Not-PER-Visible-2] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [Not-PER-Visible-2] >>> ***/


typedef PER_Visible_t	 Not_PER_Visible_2_t;

/*** <<< FUNC-DECLS [Not-PER-Visible-2] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_2;
asn_struct_free_f Not_PER_Visible_2_free;
asn_struct_print_f Not_PER_Visible_2_print;
asn_constr_check_f Not_PER_Visible_2_constraint;
ber_type_decoder_f Not_PER_Visible_2_decode_ber;
der_type_encoder_f Not_PER_Visible_2_encode_der;
xer_type_encoder_f Not_PER_Visible_2_encode_xer;

/*** <<< CTABLES [Not-PER-Visible-2] >>> ***/

static int check_permitted_alphabet_7(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 66)) return -1;
	}
	return 0;
}


/*** <<< CODE [Not-PER-Visible-2] >>> ***/

int
Not_PER_Visible_2_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_7(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
Not_PER_Visible_2_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
Not_PER_Visible_2_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Not_PER_Visible_2_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Not_PER_Visible_2_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Not_PER_Visible_2_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Not_PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Not_PER_Visible_2_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Not_PER_Visible_2_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_2_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Not-PER-Visible-2] >>> ***/

static ber_tlv_tag_t asn1_DEF_Not_PER_Visible_2_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_2 = {
	"Not-PER-Visible-2",
	Not_PER_Visible_2_free,
	Not_PER_Visible_2_print,
	Not_PER_Visible_2_constraint,
	Not_PER_Visible_2_decode_ber,
	Not_PER_Visible_2_encode_der,
	0,				/* Not implemented yet */
	Not_PER_Visible_2_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Not_PER_Visible_2_tags,
	sizeof(asn1_DEF_Not_PER_Visible_2_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_2_tags[0]), /* 1 */
	asn1_DEF_Not_PER_Visible_2_tags,	/* Same as above */
	sizeof(asn1_DEF_Not_PER_Visible_2_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_2_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Not-PER-Visible-3] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [Not-PER-Visible-3] >>> ***/


typedef PER_Visible_t	 Not_PER_Visible_3_t;

/*** <<< FUNC-DECLS [Not-PER-Visible-3] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_3;
asn_struct_free_f Not_PER_Visible_3_free;
asn_struct_print_f Not_PER_Visible_3_print;
asn_constr_check_f Not_PER_Visible_3_constraint;
ber_type_decoder_f Not_PER_Visible_3_decode_ber;
der_type_encoder_f Not_PER_Visible_3_encode_der;
xer_type_encoder_f Not_PER_Visible_3_encode_xer;

/*** <<< CTABLES [Not-PER-Visible-3] >>> ***/

static int check_permitted_alphabet_8(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 66)) return -1;
	}
	return 0;
}


/*** <<< CODE [Not-PER-Visible-3] >>> ***/

int
Not_PER_Visible_3_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_8(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
Not_PER_Visible_3_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
Not_PER_Visible_3_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Not_PER_Visible_3_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Not_PER_Visible_3_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_3_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Not_PER_Visible_3_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Not_PER_Visible_3_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Not_PER_Visible_3_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_3_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Not_PER_Visible_3_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Not_PER_Visible_3_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Not-PER-Visible-3] >>> ***/

static ber_tlv_tag_t asn1_DEF_Not_PER_Visible_3_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Not_PER_Visible_3 = {
	"Not-PER-Visible-3",
	Not_PER_Visible_3_free,
	Not_PER_Visible_3_print,
	Not_PER_Visible_3_constraint,
	Not_PER_Visible_3_decode_ber,
	Not_PER_Visible_3_encode_der,
	0,				/* Not implemented yet */
	Not_PER_Visible_3_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Not_PER_Visible_3_tags,
	sizeof(asn1_DEF_Not_PER_Visible_3_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_3_tags[0]), /* 1 */
	asn1_DEF_Not_PER_Visible_3_tags,	/* Same as above */
	sizeof(asn1_DEF_Not_PER_Visible_3_tags)
		/sizeof(asn1_DEF_Not_PER_Visible_3_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [SIZE-but-not-FROM] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [SIZE-but-not-FROM] >>> ***/


typedef PER_Visible_t	 SIZE_but_not_FROM_t;

/*** <<< FUNC-DECLS [SIZE-but-not-FROM] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_SIZE_but_not_FROM;
asn_struct_free_f SIZE_but_not_FROM_free;
asn_struct_print_f SIZE_but_not_FROM_print;
asn_constr_check_f SIZE_but_not_FROM_constraint;
ber_type_decoder_f SIZE_but_not_FROM_decode_ber;
der_type_encoder_f SIZE_but_not_FROM_encode_der;
xer_type_encoder_f SIZE_but_not_FROM_encode_xer;

/*** <<< CTABLES [SIZE-but-not-FROM] >>> ***/

static int check_permitted_alphabet_9(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 68)) return -1;
	}
	return 0;
}


/*** <<< CODE [SIZE-but-not-FROM] >>> ***/

int
SIZE_but_not_FROM_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if((size >= 1 && size <= 4)
		 && !check_permitted_alphabet_9(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
SIZE_but_not_FROM_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
SIZE_but_not_FROM_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	SIZE_but_not_FROM_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
SIZE_but_not_FROM_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_but_not_FROM_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
SIZE_but_not_FROM_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	SIZE_but_not_FROM_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
SIZE_but_not_FROM_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_but_not_FROM_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
SIZE_but_not_FROM_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_but_not_FROM_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [SIZE-but-not-FROM] >>> ***/

static ber_tlv_tag_t asn1_DEF_SIZE_but_not_FROM_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_SIZE_but_not_FROM = {
	"SIZE-but-not-FROM",
	SIZE_but_not_FROM_free,
	SIZE_but_not_FROM_print,
	SIZE_but_not_FROM_constraint,
	SIZE_but_not_FROM_decode_ber,
	SIZE_but_not_FROM_encode_der,
	0,				/* Not implemented yet */
	SIZE_but_not_FROM_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_SIZE_but_not_FROM_tags,
	sizeof(asn1_DEF_SIZE_but_not_FROM_tags)
		/sizeof(asn1_DEF_SIZE_but_not_FROM_tags[0]), /* 1 */
	asn1_DEF_SIZE_but_not_FROM_tags,	/* Same as above */
	sizeof(asn1_DEF_SIZE_but_not_FROM_tags)
		/sizeof(asn1_DEF_SIZE_but_not_FROM_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [SIZE-and-FROM] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [SIZE-and-FROM] >>> ***/


typedef PER_Visible_t	 SIZE_and_FROM_t;

/*** <<< FUNC-DECLS [SIZE-and-FROM] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_SIZE_and_FROM;
asn_struct_free_f SIZE_and_FROM_free;
asn_struct_print_f SIZE_and_FROM_print;
asn_constr_check_f SIZE_and_FROM_constraint;
ber_type_decoder_f SIZE_and_FROM_decode_ber;
der_type_encoder_f SIZE_and_FROM_encode_der;
xer_type_encoder_f SIZE_and_FROM_encode_xer;

/*** <<< CTABLES [SIZE-and-FROM] >>> ***/

static int check_permitted_alphabet_10(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 68)) return -1;
	}
	return 0;
}


/*** <<< CODE [SIZE-and-FROM] >>> ***/

int
SIZE_and_FROM_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if((size >= 1 && size <= 4)
		 && !check_permitted_alphabet_10(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
SIZE_and_FROM_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
SIZE_and_FROM_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	SIZE_and_FROM_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
SIZE_and_FROM_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_and_FROM_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
SIZE_and_FROM_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	SIZE_and_FROM_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
SIZE_and_FROM_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_and_FROM_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
SIZE_and_FROM_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	SIZE_and_FROM_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [SIZE-and-FROM] >>> ***/

static ber_tlv_tag_t asn1_DEF_SIZE_and_FROM_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_SIZE_and_FROM = {
	"SIZE-and-FROM",
	SIZE_and_FROM_free,
	SIZE_and_FROM_print,
	SIZE_and_FROM_constraint,
	SIZE_and_FROM_decode_ber,
	SIZE_and_FROM_encode_der,
	0,				/* Not implemented yet */
	SIZE_and_FROM_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_SIZE_and_FROM_tags,
	sizeof(asn1_DEF_SIZE_and_FROM_tags)
		/sizeof(asn1_DEF_SIZE_and_FROM_tags[0]), /* 1 */
	asn1_DEF_SIZE_and_FROM_tags,	/* Same as above */
	sizeof(asn1_DEF_SIZE_and_FROM_tags)
		/sizeof(asn1_DEF_SIZE_and_FROM_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Neither-SIZE-nor-FROM] >>> ***/

#include <PER-Visible.h>

/*** <<< TYPE-DECLS [Neither-SIZE-nor-FROM] >>> ***/


typedef PER_Visible_t	 Neither_SIZE_nor_FROM_t;

/*** <<< FUNC-DECLS [Neither-SIZE-nor-FROM] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Neither_SIZE_nor_FROM;
asn_struct_free_f Neither_SIZE_nor_FROM_free;
asn_struct_print_f Neither_SIZE_nor_FROM_print;
asn_constr_check_f Neither_SIZE_nor_FROM_constraint;
ber_type_decoder_f Neither_SIZE_nor_FROM_decode_ber;
der_type_encoder_f Neither_SIZE_nor_FROM_encode_der;
xer_type_encoder_f Neither_SIZE_nor_FROM_encode_xer;

/*** <<< CTABLES [Neither-SIZE-nor-FROM] >>> ***/

static int check_permitted_alphabet_11(const void *sptr) {
	/* The underlying type is IA5String */
	const IA5String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!(cv >= 65 && cv <= 70)) return -1;
	}
	return 0;
}


/*** <<< CODE [Neither-SIZE-nor-FROM] >>> ***/

int
Neither_SIZE_nor_FROM_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const PER_Visible_t *st = sptr;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	
	if(!check_permitted_alphabet_11(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using PER_Visible,
 * so here we adjust the DEF accordingly.
 */
static void
Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_PER_Visible.free_struct;
	td->print_struct   = asn1_DEF_PER_Visible.print_struct;
	td->ber_decoder    = asn1_DEF_PER_Visible.ber_decoder;
	td->der_encoder    = asn1_DEF_PER_Visible.der_encoder;
	td->xer_decoder    = asn1_DEF_PER_Visible.xer_decoder;
	td->xer_encoder    = asn1_DEF_PER_Visible.xer_encoder;
	td->last_tag_form  = asn1_DEF_PER_Visible.last_tag_form;
	td->elements       = asn1_DEF_PER_Visible.elements;
	td->elements_count = asn1_DEF_PER_Visible.elements_count;
	td->specifics      = asn1_DEF_PER_Visible.specifics;
}

void
Neither_SIZE_nor_FROM_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Neither_SIZE_nor_FROM_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Neither_SIZE_nor_FROM_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Neither_SIZE_nor_FROM_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Neither_SIZE_nor_FROM_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Neither_SIZE_nor_FROM_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Neither-SIZE-nor-FROM] >>> ***/

static ber_tlv_tag_t asn1_DEF_Neither_SIZE_nor_FROM_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (22 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Neither_SIZE_nor_FROM = {
	"Neither-SIZE-nor-FROM",
	Neither_SIZE_nor_FROM_free,
	Neither_SIZE_nor_FROM_print,
	Neither_SIZE_nor_FROM_constraint,
	Neither_SIZE_nor_FROM_decode_ber,
	Neither_SIZE_nor_FROM_encode_der,
	0,				/* Not implemented yet */
	Neither_SIZE_nor_FROM_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Neither_SIZE_nor_FROM_tags,
	sizeof(asn1_DEF_Neither_SIZE_nor_FROM_tags)
		/sizeof(asn1_DEF_Neither_SIZE_nor_FROM_tags[0]), /* 1 */
	asn1_DEF_Neither_SIZE_nor_FROM_tags,	/* Same as above */
	sizeof(asn1_DEF_Neither_SIZE_nor_FROM_tags)
		/sizeof(asn1_DEF_Neither_SIZE_nor_FROM_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Utf8-3] >>> ***/

#include <Utf8-2.h>

/*** <<< TYPE-DECLS [Utf8-3] >>> ***/


typedef Utf8_2_t	 Utf8_3_t;

/*** <<< FUNC-DECLS [Utf8-3] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Utf8_3;
asn_struct_free_f Utf8_3_free;
asn_struct_print_f Utf8_3_print;
asn_constr_check_f Utf8_3_constraint;
ber_type_decoder_f Utf8_3_decode_ber;
der_type_encoder_f Utf8_3_encode_der;
xer_type_encoder_f Utf8_3_encode_xer;

/*** <<< CTABLES [Utf8-3] >>> ***/

static int permitted_alphabet_table_12[128] = {
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  ABCDEFGHIJKLMNO */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,	/* PQRSTUVWXYZ      */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  abcdefghijklmno */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,	/* pqrstuvwxyz      */
};

static int check_permitted_alphabet_12(const void *sptr) {
	int *table = permitted_alphabet_table_12;
	/* The underlying type is UTF8String */
	const UTF8String_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(cv >= 0x80) return -1;
		if(!table[cv]) return -1;
	}
	return 0;
}


/*** <<< CODE [Utf8-3] >>> ***/

int
Utf8_3_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Utf8_2_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = UTF8String_length(st, td->name, app_errlog, app_key);
	if(size == (size_t)-1) return -1;
	
	if((size >= 1 && size <= 2)
		 && !check_permitted_alphabet_12(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Utf8_2,
 * so here we adjust the DEF accordingly.
 */
static void
Utf8_3_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Utf8_2.free_struct;
	td->print_struct   = asn1_DEF_Utf8_2.print_struct;
	td->ber_decoder    = asn1_DEF_Utf8_2.ber_decoder;
	td->der_encoder    = asn1_DEF_Utf8_2.der_encoder;
	td->xer_decoder    = asn1_DEF_Utf8_2.xer_decoder;
	td->xer_encoder    = asn1_DEF_Utf8_2.xer_encoder;
	td->last_tag_form  = asn1_DEF_Utf8_2.last_tag_form;
	td->elements       = asn1_DEF_Utf8_2.elements;
	td->elements_count = asn1_DEF_Utf8_2.elements_count;
	td->specifics      = asn1_DEF_Utf8_2.specifics;
}

void
Utf8_3_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Utf8_3_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Utf8_3_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_3_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Utf8_3_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Utf8_3_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Utf8_3_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_3_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Utf8_3_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_3_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Utf8-3] >>> ***/

static ber_tlv_tag_t asn1_DEF_Utf8_3_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (12 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Utf8_3 = {
	"Utf8-3",
	Utf8_3_free,
	Utf8_3_print,
	Utf8_3_constraint,
	Utf8_3_decode_ber,
	Utf8_3_encode_der,
	0,				/* Not implemented yet */
	Utf8_3_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Utf8_3_tags,
	sizeof(asn1_DEF_Utf8_3_tags)
		/sizeof(asn1_DEF_Utf8_3_tags[0]), /* 1 */
	asn1_DEF_Utf8_3_tags,	/* Same as above */
	sizeof(asn1_DEF_Utf8_3_tags)
		/sizeof(asn1_DEF_Utf8_3_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Utf8-2] >>> ***/

#include <Utf8-1.h>

/*** <<< TYPE-DECLS [Utf8-2] >>> ***/


typedef Utf8_1_t	 Utf8_2_t;

/*** <<< FUNC-DECLS [Utf8-2] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Utf8_2;
asn_struct_free_f Utf8_2_free;
asn_struct_print_f Utf8_2_print;
asn_constr_check_f Utf8_2_constraint;
ber_type_decoder_f Utf8_2_decode_ber;
der_type_encoder_f Utf8_2_encode_der;
xer_type_encoder_f Utf8_2_encode_xer;

/*** <<< CODE [Utf8-2] >>> ***/

int
Utf8_2_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Utf8_1_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = UTF8String_length(st, td->name, app_errlog, app_key);
	if(size == (size_t)-1) return -1;
	
	if((size >= 1 && size <= 2)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Utf8_1,
 * so here we adjust the DEF accordingly.
 */
static void
Utf8_2_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Utf8_1.free_struct;
	td->print_struct   = asn1_DEF_Utf8_1.print_struct;
	td->ber_decoder    = asn1_DEF_Utf8_1.ber_decoder;
	td->der_encoder    = asn1_DEF_Utf8_1.der_encoder;
	td->xer_decoder    = asn1_DEF_Utf8_1.xer_decoder;
	td->xer_encoder    = asn1_DEF_Utf8_1.xer_encoder;
	td->last_tag_form  = asn1_DEF_Utf8_1.last_tag_form;
	td->elements       = asn1_DEF_Utf8_1.elements;
	td->elements_count = asn1_DEF_Utf8_1.elements_count;
	td->specifics      = asn1_DEF_Utf8_1.specifics;
}

void
Utf8_2_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Utf8_2_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Utf8_2_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_2_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Utf8_2_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Utf8_2_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Utf8_2_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_2_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Utf8_2_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_2_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Utf8-2] >>> ***/

static ber_tlv_tag_t asn1_DEF_Utf8_2_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (12 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Utf8_2 = {
	"Utf8-2",
	Utf8_2_free,
	Utf8_2_print,
	Utf8_2_constraint,
	Utf8_2_decode_ber,
	Utf8_2_encode_der,
	0,				/* Not implemented yet */
	Utf8_2_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Utf8_2_tags,
	sizeof(asn1_DEF_Utf8_2_tags)
		/sizeof(asn1_DEF_Utf8_2_tags[0]), /* 1 */
	asn1_DEF_Utf8_2_tags,	/* Same as above */
	sizeof(asn1_DEF_Utf8_2_tags)
		/sizeof(asn1_DEF_Utf8_2_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Utf8-1] >>> ***/

#include <UTF8String.h>

/*** <<< TYPE-DECLS [Utf8-1] >>> ***/


typedef UTF8String_t	 Utf8_1_t;

/*** <<< FUNC-DECLS [Utf8-1] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Utf8_1;
asn_struct_free_f Utf8_1_free;
asn_struct_print_f Utf8_1_print;
asn_constr_check_f Utf8_1_constraint;
ber_type_decoder_f Utf8_1_decode_ber;
der_type_encoder_f Utf8_1_encode_der;
xer_type_encoder_f Utf8_1_encode_xer;

/*** <<< CODE [Utf8-1] >>> ***/

int
Utf8_1_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	/* Make the underlying type checker permanent */
	td->check_constraints = asn1_DEF_UTF8String.check_constraints;
	return td->check_constraints
		(td, sptr, app_errlog, app_key);
}

/*
 * This type is implemented using UTF8String,
 * so here we adjust the DEF accordingly.
 */
static void
Utf8_1_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_UTF8String.free_struct;
	td->print_struct   = asn1_DEF_UTF8String.print_struct;
	td->ber_decoder    = asn1_DEF_UTF8String.ber_decoder;
	td->der_encoder    = asn1_DEF_UTF8String.der_encoder;
	td->xer_decoder    = asn1_DEF_UTF8String.xer_decoder;
	td->xer_encoder    = asn1_DEF_UTF8String.xer_encoder;
	td->last_tag_form  = asn1_DEF_UTF8String.last_tag_form;
	td->elements       = asn1_DEF_UTF8String.elements;
	td->elements_count = asn1_DEF_UTF8String.elements_count;
	td->specifics      = asn1_DEF_UTF8String.specifics;
}

void
Utf8_1_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Utf8_1_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Utf8_1_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_1_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Utf8_1_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Utf8_1_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Utf8_1_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_1_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Utf8_1_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Utf8_1_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Utf8-1] >>> ***/

static ber_tlv_tag_t asn1_DEF_Utf8_1_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (12 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Utf8_1 = {
	"Utf8-1",
	Utf8_1_free,
	Utf8_1_print,
	Utf8_1_constraint,
	Utf8_1_decode_ber,
	Utf8_1_encode_der,
	0,				/* Not implemented yet */
	Utf8_1_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Utf8_1_tags,
	sizeof(asn1_DEF_Utf8_1_tags)
		/sizeof(asn1_DEF_Utf8_1_tags[0]), /* 1 */
	asn1_DEF_Utf8_1_tags,	/* Same as above */
	sizeof(asn1_DEF_Utf8_1_tags)
		/sizeof(asn1_DEF_Utf8_1_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [VisibleIdentifier] >>> ***/

#include <Identifier.h>

/*** <<< TYPE-DECLS [VisibleIdentifier] >>> ***/


typedef Identifier_t	 VisibleIdentifier_t;

/*** <<< FUNC-DECLS [VisibleIdentifier] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_VisibleIdentifier;
asn_struct_free_f VisibleIdentifier_free;
asn_struct_print_f VisibleIdentifier_print;
asn_constr_check_f VisibleIdentifier_constraint;
ber_type_decoder_f VisibleIdentifier_decode_ber;
der_type_encoder_f VisibleIdentifier_encode_der;
xer_type_encoder_f VisibleIdentifier_encode_xer;

/*** <<< CTABLES [VisibleIdentifier] >>> ***/

static int permitted_alphabet_table_14[256] = {
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,	/*     $            */
1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,	/* 0123456789       */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  ABCDEFGHIJKLMNO */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,1,	/* PQRSTUVWXYZ    _ */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  abcdefghijklmno */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,	/* pqrstuvwxyz      */
};

static int check_permitted_alphabet_14(const void *sptr) {
	int *table = permitted_alphabet_table_14;
	/* The underlying type is VisibleString */
	const VisibleString_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!table[cv]) return -1;
	}
	return 0;
}


/*** <<< CODE [VisibleIdentifier] >>> ***/

int
VisibleIdentifier_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const Identifier_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if((size >= 1 && size <= 32)
		 && !check_permitted_alphabet_14(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using Identifier,
 * so here we adjust the DEF accordingly.
 */
static void
VisibleIdentifier_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_Identifier.free_struct;
	td->print_struct   = asn1_DEF_Identifier.print_struct;
	td->ber_decoder    = asn1_DEF_Identifier.ber_decoder;
	td->der_encoder    = asn1_DEF_Identifier.der_encoder;
	td->xer_decoder    = asn1_DEF_Identifier.xer_decoder;
	td->xer_encoder    = asn1_DEF_Identifier.xer_encoder;
	td->last_tag_form  = asn1_DEF_Identifier.last_tag_form;
	td->elements       = asn1_DEF_Identifier.elements;
	td->elements_count = asn1_DEF_Identifier.elements_count;
	td->specifics      = asn1_DEF_Identifier.specifics;
}

void
VisibleIdentifier_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	VisibleIdentifier_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
VisibleIdentifier_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	VisibleIdentifier_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
VisibleIdentifier_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	VisibleIdentifier_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
VisibleIdentifier_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	VisibleIdentifier_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
VisibleIdentifier_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	VisibleIdentifier_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [VisibleIdentifier] >>> ***/

static ber_tlv_tag_t asn1_DEF_VisibleIdentifier_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (26 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_VisibleIdentifier = {
	"VisibleIdentifier",
	VisibleIdentifier_free,
	VisibleIdentifier_print,
	VisibleIdentifier_constraint,
	VisibleIdentifier_decode_ber,
	VisibleIdentifier_encode_der,
	0,				/* Not implemented yet */
	VisibleIdentifier_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_VisibleIdentifier_tags,
	sizeof(asn1_DEF_VisibleIdentifier_tags)
		/sizeof(asn1_DEF_VisibleIdentifier_tags[0]), /* 1 */
	asn1_DEF_VisibleIdentifier_tags,	/* Same as above */
	sizeof(asn1_DEF_VisibleIdentifier_tags)
		/sizeof(asn1_DEF_VisibleIdentifier_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};


/*** <<< INCLUDES [Identifier] >>> ***/

#include <VisibleString.h>

/*** <<< TYPE-DECLS [Identifier] >>> ***/


typedef VisibleString_t	 Identifier_t;

/*** <<< FUNC-DECLS [Identifier] >>> ***/

extern asn1_TYPE_descriptor_t asn1_DEF_Identifier;
asn_struct_free_f Identifier_free;
asn_struct_print_f Identifier_print;
asn_constr_check_f Identifier_constraint;
ber_type_decoder_f Identifier_decode_ber;
der_type_encoder_f Identifier_encode_der;
xer_type_encoder_f Identifier_encode_xer;

/*** <<< CTABLES [Identifier] >>> ***/

static int permitted_alphabet_table_15[256] = {
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,	/*                  */
0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,	/*     $            */
1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,	/* 0123456789       */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  ABCDEFGHIJKLMNO */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,1,	/* PQRSTUVWXYZ    _ */
0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,	/*  abcdefghijklmno */
1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,	/* pqrstuvwxyz      */
};

static int check_permitted_alphabet_15(const void *sptr) {
	int *table = permitted_alphabet_table_15;
	/* The underlying type is VisibleString */
	const VisibleString_t *st = sptr;
	const uint8_t *ch = st->buf;
	const uint8_t *end = ch + st->size;
	
	for(; ch < end; ch++) {
		uint8_t cv = *ch;
		if(!table[cv]) return -1;
	}
	return 0;
}


/*** <<< CODE [Identifier] >>> ***/

int
Identifier_constraint(asn1_TYPE_descriptor_t *td, const void *sptr,
			asn_app_consume_bytes_f *app_errlog, void *app_key) {
	
	const VisibleString_t *st = sptr;
	size_t size;
	
	if(!sptr) {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: value not given (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
	
	size = st->size;
	
	if((size >= 1 && size <= 32)
		 && !check_permitted_alphabet_15(sptr)) {
		/* Constraint check succeeded */
		return 0;
	} else {
		_ASN_ERRLOG(app_errlog, app_key,
			"%s: constraint failed (%s:%d)",
			td->name, __FILE__, __LINE__);
		return -1;
	}
}

/*
 * This type is implemented using VisibleString,
 * so here we adjust the DEF accordingly.
 */
static void
Identifier_inherit_TYPE_descriptor(asn1_TYPE_descriptor_t *td) {
	td->free_struct    = asn1_DEF_VisibleString.free_struct;
	td->print_struct   = asn1_DEF_VisibleString.print_struct;
	td->ber_decoder    = asn1_DEF_VisibleString.ber_decoder;
	td->der_encoder    = asn1_DEF_VisibleString.der_encoder;
	td->xer_decoder    = asn1_DEF_VisibleString.xer_decoder;
	td->xer_encoder    = asn1_DEF_VisibleString.xer_encoder;
	td->last_tag_form  = asn1_DEF_VisibleString.last_tag_form;
	td->elements       = asn1_DEF_VisibleString.elements;
	td->elements_count = asn1_DEF_VisibleString.elements_count;
	td->specifics      = asn1_DEF_VisibleString.specifics;
}

void
Identifier_free(asn1_TYPE_descriptor_t *td,
		void *struct_ptr, int contents_only) {
	Identifier_inherit_TYPE_descriptor(td);
	td->free_struct(td, struct_ptr, contents_only);
}

int
Identifier_print(asn1_TYPE_descriptor_t *td, const void *struct_ptr,
		int ilevel, asn_app_consume_bytes_f *cb, void *app_key) {
	Identifier_inherit_TYPE_descriptor(td);
	return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}

ber_dec_rval_t
Identifier_decode_ber(asn1_TYPE_descriptor_t *td,
		void **structure, void *bufptr, size_t size, int tag_mode) {
	Identifier_inherit_TYPE_descriptor(td);
	return td->ber_decoder(td, structure, bufptr, size, tag_mode);
}

asn_enc_rval_t
Identifier_encode_der(asn1_TYPE_descriptor_t *td,
		void *structure, int tag_mode, ber_tlv_tag_t tag,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Identifier_inherit_TYPE_descriptor(td);
	return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}

asn_enc_rval_t
Identifier_encode_xer(asn1_TYPE_descriptor_t *td, void *structure,
		int ilevel, enum xer_encoder_flags_e flags,
		asn_app_consume_bytes_f *cb, void *app_key) {
	Identifier_inherit_TYPE_descriptor(td);
	return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}


/*** <<< STAT-DEFS [Identifier] >>> ***/

static ber_tlv_tag_t asn1_DEF_Identifier_tags[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (26 << 2))
};
asn1_TYPE_descriptor_t asn1_DEF_Identifier = {
	"Identifier",
	Identifier_free,
	Identifier_print,
	Identifier_constraint,
	Identifier_decode_ber,
	Identifier_encode_der,
	0,				/* Not implemented yet */
	Identifier_encode_xer,
	0,	/* Use generic outmost tag fetcher */
	asn1_DEF_Identifier_tags,
	sizeof(asn1_DEF_Identifier_tags)
		/sizeof(asn1_DEF_Identifier_tags[0]), /* 1 */
	asn1_DEF_Identifier_tags,	/* Same as above */
	sizeof(asn1_DEF_Identifier_tags)
		/sizeof(asn1_DEF_Identifier_tags[0]), /* 1 */
	-0,	/* Unknown yet */
	0, 0,	/* No members */
	0	/* No specifics */
};

