2
* Copyright (c) 2004 Lev Walkin <vlm@lionet.info>. All rights reserved.
3
* Redistribution and modifications are permitted subject to BSD license.
6
* Please read the NativeInteger.h for the explanation wrt. differences between
7
* INTEGER and NativeInteger.
8
* Basically, both are decoders and encoders of ASN.1 INTEGER type, but this
9
* implementation deals with the standard (machine-specific) representation
10
* of them instead of using the platform-independent buffer.
12
#include <asn_internal.h>
13
#include <NativeEnumerated.h>
16
* NativeEnumerated basic type description.
18
static ber_tlv_tag_t asn_DEF_NativeEnumerated_tags[] = {
19
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))
21
asn_TYPE_descriptor_t asn_DEF_NativeEnumerated = {
22
"ENUMERATED", /* The ASN.1 type is still ENUMERATED */
26
asn_generic_no_constraint,
27
NativeInteger_decode_ber,
28
NativeInteger_encode_der,
29
NativeInteger_decode_xer,
30
NativeEnumerated_encode_xer,
31
0, /* Use generic outmost tag fetcher */
32
asn_DEF_NativeEnumerated_tags,
33
sizeof(asn_DEF_NativeEnumerated_tags) / sizeof(asn_DEF_NativeEnumerated_tags[0]),
34
asn_DEF_NativeEnumerated_tags, /* Same as above */
35
sizeof(asn_DEF_NativeEnumerated_tags) / sizeof(asn_DEF_NativeEnumerated_tags[0]),
36
0, 0, /* No members */
41
NativeEnumerated_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
42
int ilevel, enum xer_encoder_flags_e flags,
43
asn_app_consume_bytes_f *cb, void *app_key) {
44
asn_INTEGER_specifics_t *specs=(asn_INTEGER_specifics_t *)td->specifics;
46
const long *native = (const long *)sptr;
47
const asn_INTEGER_enum_map_t *el;
52
if(!native) _ASN_ENCODE_FAILED;
54
el = INTEGER_map_value2enum(specs, *native);
56
size_t srcsize = el->enum_len + 5;
57
char *src = (char *)alloca(srcsize);
59
er.encoded = snprintf(src, srcsize, "<%s/>", el->enum_name);
60
assert(er.encoded > 0 && (size_t)er.encoded < srcsize);
61
if(cb(src, er.encoded, app_key) < 0) _ASN_ENCODE_FAILED;
64
ASN_DEBUG("ASN.1 forbids dealing with "
65
"unknown value of ENUMERATED type");