2004-06-03 03:38:44 +00:00
|
|
|
/*-
|
2006-10-09 12:07:58 +00:00
|
|
|
* Copyright (c) 2003, 2006 Lev Walkin <vlm@lionet.info>. All rights reserved.
|
2004-06-03 03:38:44 +00:00
|
|
|
* Redistribution and modifications are permitted subject to BSD license.
|
|
|
|
*/
|
2004-09-22 16:06:28 +00:00
|
|
|
#include <asn_internal.h>
|
2004-06-03 03:38:44 +00:00
|
|
|
#include <VisibleString.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* VisibleString basic type description.
|
|
|
|
*/
|
2014-07-29 18:30:10 +00:00
|
|
|
static const ber_tlv_tag_t asn_DEF_VisibleString_tags[] = {
|
2004-09-13 08:31:01 +00:00
|
|
|
(ASN_TAG_CLASS_UNIVERSAL | (26 << 2)), /* [UNIVERSAL 26] IMPLICIT ...*/
|
|
|
|
(ASN_TAG_CLASS_UNIVERSAL | (4 << 2)) /* ... OCTET STRING */
|
2004-06-03 03:38:44 +00:00
|
|
|
};
|
2006-10-09 12:07:58 +00:00
|
|
|
static asn_per_constraints_t asn_DEF_VisibleString_constraints = {
|
|
|
|
{ APC_CONSTRAINED, 7, 7, 0x20, 0x7e }, /* Value */
|
|
|
|
{ APC_SEMI_CONSTRAINED, -1, -1, 0, 0 }, /* Size */
|
|
|
|
0, 0
|
|
|
|
};
|
Move type operations to another structure
Every type has free, print, check_constraints, ber_decoder, der_encoder,
xer_decoder, xer_encoder, uper_decoder, uper_encoder and outmost_tag
operations. We move them out to a separate structure asn_TYPE_operation_t.
Combined with previous logic simplification, these operations are based
on ASN.1 basic types, constructed types and string types. So we can
reduce the space occupied by asn_TYPE_descriptor_t variables.
2017-08-19 17:25:45 +00:00
|
|
|
asn_TYPE_operation_t asn_OP_VisibleString = {
|
2004-09-22 16:06:28 +00:00
|
|
|
OCTET_STRING_free,
|
2004-10-20 15:50:55 +00:00
|
|
|
OCTET_STRING_print_utf8, /* ASCII subset */
|
2017-08-10 09:14:59 +00:00
|
|
|
OCTET_STRING_compare,
|
2004-06-03 03:38:44 +00:00
|
|
|
OCTET_STRING_decode_ber, /* Implemented in terms of OCTET STRING */
|
2004-10-20 15:50:55 +00:00
|
|
|
OCTET_STRING_encode_der,
|
|
|
|
OCTET_STRING_decode_xer_utf8,
|
|
|
|
OCTET_STRING_encode_xer_utf8,
|
2017-07-06 15:26:36 +00:00
|
|
|
#ifdef ASN_DISABLE_OER_SUPPORT
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
#else
|
2017-07-25 14:58:05 +00:00
|
|
|
OCTET_STRING_decode_oer,
|
|
|
|
OCTET_STRING_encode_oer,
|
2017-07-06 15:26:36 +00:00
|
|
|
#endif /* ASN_DISABLE_OER_SUPPORT */
|
2017-07-14 10:59:52 +00:00
|
|
|
#ifdef ASN_DISABLE_PER_SUPPORT
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
#else
|
|
|
|
OCTET_STRING_decode_uper,
|
|
|
|
OCTET_STRING_encode_uper,
|
|
|
|
#endif /* ASN_DISABLE_PER_SUPPORT */
|
2017-09-30 06:15:58 +00:00
|
|
|
OCTET_STRING_random_fill,
|
Move type operations to another structure
Every type has free, print, check_constraints, ber_decoder, der_encoder,
xer_decoder, xer_encoder, uper_decoder, uper_encoder and outmost_tag
operations. We move them out to a separate structure asn_TYPE_operation_t.
Combined with previous logic simplification, these operations are based
on ASN.1 basic types, constructed types and string types. So we can
reduce the space occupied by asn_TYPE_descriptor_t variables.
2017-08-19 17:25:45 +00:00
|
|
|
0 /* Use generic outmost tag fetcher */
|
|
|
|
};
|
|
|
|
asn_TYPE_descriptor_t asn_DEF_VisibleString = {
|
|
|
|
"VisibleString",
|
|
|
|
"VisibleString",
|
|
|
|
&asn_OP_VisibleString,
|
2004-09-29 13:21:39 +00:00
|
|
|
asn_DEF_VisibleString_tags,
|
|
|
|
sizeof(asn_DEF_VisibleString_tags)
|
|
|
|
/ sizeof(asn_DEF_VisibleString_tags[0]) - 1,
|
|
|
|
asn_DEF_VisibleString_tags,
|
|
|
|
sizeof(asn_DEF_VisibleString_tags)
|
|
|
|
/ sizeof(asn_DEF_VisibleString_tags[0]),
|
2017-09-30 06:15:58 +00:00
|
|
|
{ 0, &asn_DEF_VisibleString_constraints, VisibleString_constraint },
|
2004-08-20 13:23:42 +00:00
|
|
|
0, 0, /* No members */
|
2004-06-05 08:17:50 +00:00
|
|
|
0 /* No specifics */
|
2004-06-03 03:38:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
int
|
2017-10-18 04:27:33 +00:00
|
|
|
VisibleString_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
|
|
|
|
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
|
|
|
|
const VisibleString_t *st = (const VisibleString_t *)sptr;
|
2004-06-03 03:38:44 +00:00
|
|
|
|
|
|
|
if(st && st->buf) {
|
|
|
|
uint8_t *buf = st->buf;
|
|
|
|
uint8_t *end = buf + st->size;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check the alphabet of the VisibleString.
|
|
|
|
* ISO646, ISOReg#6
|
2004-09-29 13:21:39 +00:00
|
|
|
* The alphabet is a subset of ASCII between the space
|
|
|
|
* and "~" (tilde).
|
2004-06-03 03:38:44 +00:00
|
|
|
*/
|
|
|
|
for(; buf < end; buf++) {
|
2004-09-29 13:21:39 +00:00
|
|
|
if(*buf < 0x20 || *buf > 0x7e) {
|
2016-03-14 10:08:15 +00:00
|
|
|
ASN__CTFAIL(app_key, td, sptr,
|
2004-10-26 09:59:42 +00:00
|
|
|
"%s: value byte %ld (%d) "
|
2004-08-22 13:47:59 +00:00
|
|
|
"not in VisibleString alphabet (%s:%d)",
|
2004-06-03 03:38:44 +00:00
|
|
|
td->name,
|
2004-10-26 09:59:42 +00:00
|
|
|
(long)((buf - st->buf) + 1),
|
2004-08-22 13:47:59 +00:00
|
|
|
*buf,
|
|
|
|
__FILE__, __LINE__);
|
2004-06-03 03:38:44 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2016-03-14 10:08:15 +00:00
|
|
|
ASN__CTFAIL(app_key, td, sptr,
|
2004-08-22 13:47:59 +00:00
|
|
|
"%s: value not given (%s:%d)",
|
|
|
|
td->name, __FILE__, __LINE__);
|
2004-06-03 03:38:44 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|