Add two tests in tests-asn1c-compiler directory

This commit is contained in:
Bi-Ruei, Chiu 2017-10-20 22:38:01 +08:00 committed by Lev Walkin
parent e460c3b7a3
commit bc6ef1f98a
4 changed files with 996 additions and 0 deletions

View File

@ -0,0 +1,58 @@
-- OK: Everything is fine
-- iso.org.dod.internet.private.enterprise (1.3.6.1.4.1)
-- .spelio.software.asn1c.test (9363.1.5.1)
-- .155
ModuleParameterizationMoreThanTwoLevel
{ iso org(3) dod(6) internet(1) private(4) enterprise(1)
spelio(9363) software(1) asn1c(5) test(1) 155 }
DEFINITIONS ::= BEGIN
id-TYPE1 PacketId ::= 1
PacketId ::= INTEGER (0..65535)
Color ::= ENUMERATED { red(0), green, blue }
Valid ::= ENUMERATED { crc-nok, crc-ok(1) }
PACKET ::= CLASS {
&id PacketId UNIQUE,
&color Color,
&Value,
&valid Valid
}
WITH SYNTAX {
ID &id
COLOR &color
TYPE &Value
VALID &valid
}
ClassItem PACKET ::= {
{ ID id-TYPE1 COLOR blue TYPE OCTET STRING VALID crc-ok },
...
}
Packet-List ::= UpperLayer-List { {ClassItem} }
UpperLayer-List {PACKET : Param} ::= LowerLayer-List { 1, max-items, {Param} }
LowerLayer-List {INTEGER : low, INTEGER : high, PACKET : Param} ::=
SEQUENCE (SIZE (low..high)) OF
SinglePacket {{Param}}
SinglePacket {PACKET : Param} ::=
Packet {{Param}}
Packet {PACKET : Param} ::= SEQUENCE {
id PACKET.&id ({Param}),
color PACKET.&color ({Param}{@id}),
value PACKET.&Value ({Param}{@id})
}
max-items INTEGER ::= 256
END

View File

@ -0,0 +1,768 @@
/*** <<< INCLUDES [PacketId] >>> ***/
#include <NativeInteger.h>
/*** <<< TYPE-DECLS [PacketId] >>> ***/
typedef long PacketId_t;
/*** <<< FUNC-DECLS [PacketId] >>> ***/
extern asn_per_constraints_t asn_PER_type_PacketId_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_PacketId;
asn_struct_free_f PacketId_free;
asn_struct_print_f PacketId_print;
asn_constr_check_f PacketId_constraint;
ber_type_decoder_f PacketId_decode_ber;
der_type_encoder_f PacketId_encode_der;
xer_type_decoder_f PacketId_decode_xer;
xer_type_encoder_f PacketId_encode_xer;
per_type_decoder_f PacketId_decode_uper;
per_type_encoder_f PacketId_encode_uper;
/*** <<< CODE [PacketId] >>> ***/
int
PacketId_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
long value;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
value = *(const long *)sptr;
if((value >= 0 && value <= 65535)) {
/* Constraint check succeeded */
return 0;
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using NativeInteger,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [PacketId] >>> ***/
asn_per_constraints_t asn_PER_type_PacketId_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 16, 16, 0, 65535 } /* (0..65535) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [PacketId] >>> ***/
static const ber_tlv_tag_t asn_DEF_PacketId_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn_TYPE_descriptor_t asn_DEF_PacketId = {
"PacketId",
"PacketId",
&asn_OP_NativeInteger,
asn_DEF_PacketId_tags_1,
sizeof(asn_DEF_PacketId_tags_1)
/sizeof(asn_DEF_PacketId_tags_1[0]), /* 1 */
asn_DEF_PacketId_tags_1, /* Same as above */
sizeof(asn_DEF_PacketId_tags_1)
/sizeof(asn_DEF_PacketId_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_PacketId_constr_1, PacketId_constraint },
0, 0, /* No members */
0 /* No specifics */
};
/*** <<< INCLUDES [Color] >>> ***/
#include <NativeEnumerated.h>
/*** <<< DEPS [Color] >>> ***/
typedef enum Color {
Color_red = 0,
Color_green = 1,
Color_blue = 2
} e_Color;
/*** <<< TYPE-DECLS [Color] >>> ***/
typedef long Color_t;
/*** <<< FUNC-DECLS [Color] >>> ***/
extern asn_per_constraints_t asn_PER_type_Color_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_Color;
extern const asn_INTEGER_specifics_t asn_SPC_Color_specs_1;
asn_struct_free_f Color_free;
asn_struct_print_f Color_print;
asn_constr_check_f Color_constraint;
ber_type_decoder_f Color_decode_ber;
der_type_encoder_f Color_encode_der;
xer_type_decoder_f Color_decode_xer;
xer_type_encoder_f Color_encode_xer;
per_type_decoder_f Color_decode_uper;
per_type_encoder_f Color_encode_uper;
/*** <<< CODE [Color] >>> ***/
/*
* This type is implemented using NativeEnumerated,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Color] >>> ***/
asn_per_constraints_t asn_PER_type_Color_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 2, 2, 0, 2 } /* (0..2) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Color] >>> ***/
static const asn_INTEGER_enum_map_t asn_MAP_Color_value2enum_1[] = {
{ 0, 3, "red" },
{ 1, 5, "green" },
{ 2, 4, "blue" }
};
static const unsigned int asn_MAP_Color_enum2value_1[] = {
2, /* blue(2) */
1, /* green(1) */
0 /* red(0) */
};
const asn_INTEGER_specifics_t asn_SPC_Color_specs_1 = {
asn_MAP_Color_value2enum_1, /* "tag" => N; sorted by tag */
asn_MAP_Color_enum2value_1, /* N => "tag"; sorted by N */
3, /* Number of elements in the maps */
0, /* Enumeration is not extensible */
1, /* Strict enumeration */
0, /* Native long size */
0
};
static const ber_tlv_tag_t asn_DEF_Color_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Color = {
"Color",
"Color",
&asn_OP_NativeEnumerated,
asn_DEF_Color_tags_1,
sizeof(asn_DEF_Color_tags_1)
/sizeof(asn_DEF_Color_tags_1[0]), /* 1 */
asn_DEF_Color_tags_1, /* Same as above */
sizeof(asn_DEF_Color_tags_1)
/sizeof(asn_DEF_Color_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Color_constr_1, NativeEnumerated_constraint },
0, 0, /* Defined elsewhere */
&asn_SPC_Color_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Valid] >>> ***/
#include <NativeEnumerated.h>
/*** <<< DEPS [Valid] >>> ***/
typedef enum Valid {
Valid_crc_nok = 0,
Valid_crc_ok = 1
} e_Valid;
/*** <<< TYPE-DECLS [Valid] >>> ***/
typedef long Valid_t;
/*** <<< FUNC-DECLS [Valid] >>> ***/
extern asn_per_constraints_t asn_PER_type_Valid_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_Valid;
extern const asn_INTEGER_specifics_t asn_SPC_Valid_specs_1;
asn_struct_free_f Valid_free;
asn_struct_print_f Valid_print;
asn_constr_check_f Valid_constraint;
ber_type_decoder_f Valid_decode_ber;
der_type_encoder_f Valid_encode_der;
xer_type_decoder_f Valid_decode_xer;
xer_type_encoder_f Valid_encode_xer;
per_type_decoder_f Valid_decode_uper;
per_type_encoder_f Valid_encode_uper;
/*** <<< CODE [Valid] >>> ***/
/*
* This type is implemented using NativeEnumerated,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Valid] >>> ***/
asn_per_constraints_t asn_PER_type_Valid_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 1, 1, 0, 1 } /* (0..1) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Valid] >>> ***/
static const asn_INTEGER_enum_map_t asn_MAP_Valid_value2enum_1[] = {
{ 0, 7, "crc-nok" },
{ 1, 6, "crc-ok" }
};
static const unsigned int asn_MAP_Valid_enum2value_1[] = {
0, /* crc-nok(0) */
1 /* crc-ok(1) */
};
const asn_INTEGER_specifics_t asn_SPC_Valid_specs_1 = {
asn_MAP_Valid_value2enum_1, /* "tag" => N; sorted by tag */
asn_MAP_Valid_enum2value_1, /* N => "tag"; sorted by N */
2, /* Number of elements in the maps */
0, /* Enumeration is not extensible */
1, /* Strict enumeration */
0, /* Native long size */
0
};
static const ber_tlv_tag_t asn_DEF_Valid_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Valid = {
"Valid",
"Valid",
&asn_OP_NativeEnumerated,
asn_DEF_Valid_tags_1,
sizeof(asn_DEF_Valid_tags_1)
/sizeof(asn_DEF_Valid_tags_1[0]), /* 1 */
asn_DEF_Valid_tags_1, /* Same as above */
sizeof(asn_DEF_Valid_tags_1)
/sizeof(asn_DEF_Valid_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Valid_constr_1, NativeEnumerated_constraint },
0, 0, /* Defined elsewhere */
&asn_SPC_Valid_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Packet-List] >>> ***/
#include "UpperLayer-List.h"
/*** <<< TYPE-DECLS [Packet-List] >>> ***/
typedef UpperLayer_List_41P0_t Packet_List_t;
/*** <<< FUNC-DECLS [Packet-List] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_Packet_List;
asn_struct_free_f Packet_List_free;
asn_struct_print_f Packet_List_print;
asn_constr_check_f Packet_List_constraint;
ber_type_decoder_f Packet_List_decode_ber;
der_type_encoder_f Packet_List_encode_der;
xer_type_decoder_f Packet_List_decode_xer;
xer_type_encoder_f Packet_List_encode_xer;
per_type_decoder_f Packet_List_decode_uper;
per_type_encoder_f Packet_List_encode_uper;
/*** <<< CODE [Packet-List] >>> ***/
int
Packet_List_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
size_t size;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
/* Determine the number of elements */
size = _A_CSEQUENCE_FROM_VOID(sptr)->count;
if((size >= 1 && size <= 256)) {
/* Perform validation of the inner elements */
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using UpperLayer_List_41P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Packet-List] >>> ***/
static asn_per_constraints_t asn_PER_type_Packet_List_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Packet-List] >>> ***/
static const ber_tlv_tag_t asn_DEF_Packet_List_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Packet_List = {
"Packet-List",
"Packet-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_Packet_List_tags_1,
sizeof(asn_DEF_Packet_List_tags_1)
/sizeof(asn_DEF_Packet_List_tags_1[0]), /* 1 */
asn_DEF_Packet_List_tags_1, /* Same as above */
sizeof(asn_DEF_Packet_List_tags_1)
/sizeof(asn_DEF_Packet_List_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Packet_List_constr_1, Packet_List_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [UpperLayer-List] >>> ***/
#include "LowerLayer-List.h"
/*** <<< TYPE-DECLS [UpperLayer-List] >>> ***/
typedef LowerLayer_List_45P0_t UpperLayer_List_41P0_t;
/*** <<< FUNC-DECLS [UpperLayer-List] >>> ***/
extern asn_per_constraints_t asn_PER_type_UpperLayer_List_41P0_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_UpperLayer_List_41P0;
asn_struct_free_f UpperLayer_List_41P0_free;
asn_struct_print_f UpperLayer_List_41P0_print;
asn_constr_check_f UpperLayer_List_41P0_constraint;
ber_type_decoder_f UpperLayer_List_41P0_decode_ber;
der_type_encoder_f UpperLayer_List_41P0_encode_der;
xer_type_decoder_f UpperLayer_List_41P0_decode_xer;
xer_type_encoder_f UpperLayer_List_41P0_encode_xer;
per_type_decoder_f UpperLayer_List_41P0_decode_uper;
per_type_encoder_f UpperLayer_List_41P0_encode_uper;
/*** <<< CODE [UpperLayer-List] >>> ***/
int
UpperLayer_List_41P0_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
size_t size;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
/* Determine the number of elements */
size = _A_CSEQUENCE_FROM_VOID(sptr)->count;
if((size >= 1 && size <= 256)) {
/* Perform validation of the inner elements */
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using LowerLayer_List_45P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [UpperLayer-List] >>> ***/
asn_per_constraints_t asn_PER_type_UpperLayer_List_41P0_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [UpperLayer-List] >>> ***/
static const ber_tlv_tag_t asn_DEF_UpperLayer_List_41P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_UpperLayer_List_41P0 = {
"UpperLayer-List",
"UpperLayer-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_UpperLayer_List_41P0_tags_1,
sizeof(asn_DEF_UpperLayer_List_41P0_tags_1)
/sizeof(asn_DEF_UpperLayer_List_41P0_tags_1[0]), /* 1 */
asn_DEF_UpperLayer_List_41P0_tags_1, /* Same as above */
sizeof(asn_DEF_UpperLayer_List_41P0_tags_1)
/sizeof(asn_DEF_UpperLayer_List_41P0_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_UpperLayer_List_41P0_constr_1, UpperLayer_List_41P0_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [LowerLayer-List] >>> ***/
#include <asn_SEQUENCE_OF.h>
#include <constr_SEQUENCE_OF.h>
/*** <<< FWD-DECLS [LowerLayer-List] >>> ***/
struct SinglePacket;
/*** <<< TYPE-DECLS [LowerLayer-List] >>> ***/
typedef struct LowerLayer_List_45P0 {
A_SEQUENCE_OF(struct SinglePacket) list;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} LowerLayer_List_45P0_t;
/*** <<< FUNC-DECLS [LowerLayer-List] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_LowerLayer_List_45P0;
extern asn_SET_OF_specifics_t asn_SPC_LowerLayer_List_45P0_specs_1;
extern asn_TYPE_member_t asn_MBR_LowerLayer_List_45P0_1[1];
extern asn_per_constraints_t asn_PER_type_LowerLayer_List_45P0_constr_1;
/*** <<< POST-INCLUDE [LowerLayer-List] >>> ***/
#include "SinglePacket.h"
/*** <<< CTDEFS [LowerLayer-List] >>> ***/
asn_per_constraints_t asn_PER_type_LowerLayer_List_45P0_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [LowerLayer-List] >>> ***/
asn_TYPE_member_t asn_MBR_LowerLayer_List_45P0_1[] = {
{ ATF_POINTER, 0, 0,
.tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)),
.tag_mode = 0,
.type = &asn_DEF_SinglePacket_48P0,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 },
0, 0, /* No default value */
.name = ""
},
};
static const ber_tlv_tag_t asn_DEF_LowerLayer_List_45P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_SET_OF_specifics_t asn_SPC_LowerLayer_List_45P0_specs_1 = {
sizeof(struct LowerLayer_List_45P0),
offsetof(struct LowerLayer_List_45P0, _asn_ctx),
0, /* XER encoding is XMLDelimitedItemList */
};
asn_TYPE_descriptor_t asn_DEF_LowerLayer_List_45P0 = {
"LowerLayer-List",
"LowerLayer-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_LowerLayer_List_45P0_tags_1,
sizeof(asn_DEF_LowerLayer_List_45P0_tags_1)
/sizeof(asn_DEF_LowerLayer_List_45P0_tags_1[0]), /* 1 */
asn_DEF_LowerLayer_List_45P0_tags_1, /* Same as above */
sizeof(asn_DEF_LowerLayer_List_45P0_tags_1)
/sizeof(asn_DEF_LowerLayer_List_45P0_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_LowerLayer_List_45P0_constr_1, SEQUENCE_OF_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [SinglePacket] >>> ***/
#include "Packet.h"
/*** <<< TYPE-DECLS [SinglePacket] >>> ***/
typedef Packet_51P0_t SinglePacket_48P0_t;
/*** <<< FUNC-DECLS [SinglePacket] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_SinglePacket_48P0;
asn_struct_free_f SinglePacket_48P0_free;
asn_struct_print_f SinglePacket_48P0_print;
asn_constr_check_f SinglePacket_48P0_constraint;
ber_type_decoder_f SinglePacket_48P0_decode_ber;
der_type_encoder_f SinglePacket_48P0_encode_der;
xer_type_decoder_f SinglePacket_48P0_decode_xer;
xer_type_encoder_f SinglePacket_48P0_encode_xer;
per_type_decoder_f SinglePacket_48P0_decode_uper;
per_type_encoder_f SinglePacket_48P0_encode_uper;
/*** <<< CODE [SinglePacket] >>> ***/
/*
* This type is implemented using Packet_51P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< STAT-DEFS [SinglePacket] >>> ***/
static const ber_tlv_tag_t asn_DEF_SinglePacket_48P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_SinglePacket_48P0 = {
"SinglePacket",
"SinglePacket",
&asn_OP_SEQUENCE,
asn_DEF_SinglePacket_48P0_tags_1,
sizeof(asn_DEF_SinglePacket_48P0_tags_1)
/sizeof(asn_DEF_SinglePacket_48P0_tags_1[0]), /* 1 */
asn_DEF_SinglePacket_48P0_tags_1, /* Same as above */
sizeof(asn_DEF_SinglePacket_48P0_tags_1)
/sizeof(asn_DEF_SinglePacket_48P0_tags_1[0]), /* 1 */
{ 0, 0, SEQUENCE_constraint },
asn_MBR_Packet_51P0_1,
3, /* Elements count */
&asn_SPC_Packet_51P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Packet] >>> ***/
#include "PacketId.h"
#include "Color.h"
#include <ANY.h>
#include <asn_ioc.h>
#include <OPEN_TYPE.h>
#include <constr_CHOICE.h>
#include <constr_SEQUENCE.h>
/*** <<< DEPS [Packet] >>> ***/
typedef enum value_PR {
value_PR_NOTHING, /* No components present */
} value_PR;
/*** <<< TYPE-DECLS [Packet] >>> ***/
typedef struct Packet_51P0 {
PacketId_t id;
Color_t color;
struct value {
value_PR present;
union Packet_51P0__value_u {
} choice;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} value;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} Packet_51P0_t;
/*** <<< FUNC-DECLS [Packet] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_Packet_51P0;
extern asn_SEQUENCE_specifics_t asn_SPC_Packet_51P0_specs_1;
extern asn_TYPE_member_t asn_MBR_Packet_51P0_1[3];
/*** <<< IOC-TABLES [Packet] >>> ***/
static const asn_ioc_cell_t asn_IOS_ClassItem_1_rows[] = {
};
static const asn_ioc_set_t asn_IOS_ClassItem_1[] = {
0, 0, asn_IOS_ClassItem_1_rows
};
/*** <<< CODE [Packet] >>> ***/
static int
memb_id_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
long value;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
value = *(const long *)sptr;
if((value >= 0 && value <= 65535)) {
/* Constraint check succeeded */
return 0;
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
static int
memb_color_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
if(1 /* No applicable constraints whatsoever */) {
/* Nothing is here. See below */
}
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
}
static int
memb_value_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
if(1 /* No applicable constraints whatsoever */) {
/* Nothing is here. See below */
}
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
}
/*** <<< CTDEFS [Packet] >>> ***/
static asn_per_constraints_t asn_PER_memb_id_constr_2 CC_NOTUSED = {
{ APC_CONSTRAINED, 16, 16, 0, 65535 } /* (0..65535) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
static asn_per_constraints_t asn_PER_memb_color_constr_3 CC_NOTUSED = {
{ APC_CONSTRAINED, 2, 2, 0, 2 } /* (0..2) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
static asn_per_constraints_t asn_PER_memb_value_constr_4 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Packet] >>> ***/
static asn_CHOICE_specifics_t asn_SPC_value_specs_4 = {
sizeof(struct value),
offsetof(struct value, _asn_ctx),
offsetof(struct value, present),
sizeof(((struct value *)0)->present),
0, /* No top level tags */
0, /* No tags in the map */
0, 0,
.ext_start = -1 /* Extensions start */
};
static /* Use -fall-defs-global to expose */
asn_TYPE_descriptor_t asn_DEF_value_4 = {
"value",
"value",
&asn_OP_OPEN_TYPE,
0, /* No effective tags (pointer) */
0, /* No effective tags (count) */
0, /* No tags (pointer) */
0, /* No tags (count) */
{ 0, 0, OPEN_TYPE_constraint },
0, 0, /* No members */
&asn_SPC_value_specs_4 /* Additional specs */
};
asn_TYPE_member_t asn_MBR_Packet_51P0_1[] = {
{ ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, id),
.tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)),
.tag_mode = 0,
.type = &asn_DEF_PacketId,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_id_constr_2, .general_constraints = memb_id_constraint_1 },
0, 0, /* No default value */
.name = "id"
},
{ ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, color),
.tag = (ASN_TAG_CLASS_UNIVERSAL | (10 << 2)),
.tag_mode = 0,
.type = &asn_DEF_Color,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_color_constr_3, .general_constraints = memb_color_constraint_1 },
0, 0, /* No default value */
.name = "color"
},
{ ATF_OPEN_TYPE | ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, value),
.tag = -1 /* Ambiguous tag (ANY?) */,
.tag_mode = 0,
.type = &asn_DEF_value_4,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_value_constr_4, .general_constraints = memb_value_constraint_1 },
0, 0, /* No default value */
.name = "value"
},
};
static const ber_tlv_tag_t asn_DEF_Packet_51P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
static const asn_TYPE_tag2member_t asn_MAP_Packet_51P0_tag2el_1[] = {
{ (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 0, 0, 0 }, /* id */
{ (ASN_TAG_CLASS_UNIVERSAL | (10 << 2)), 1, 0, 0 } /* color */
};
asn_SEQUENCE_specifics_t asn_SPC_Packet_51P0_specs_1 = {
sizeof(struct Packet_51P0),
offsetof(struct Packet_51P0, _asn_ctx),
.tag2el = asn_MAP_Packet_51P0_tag2el_1,
.tag2el_count = 2, /* Count of tags in the map */
0, 0, 0, /* Optional elements (not needed) */
-1, /* Start extensions */
-1 /* Stop extensions */
};
asn_TYPE_descriptor_t asn_DEF_Packet_51P0 = {
"Packet",
"Packet",
&asn_OP_SEQUENCE,
asn_DEF_Packet_51P0_tags_1,
sizeof(asn_DEF_Packet_51P0_tags_1)
/sizeof(asn_DEF_Packet_51P0_tags_1[0]), /* 1 */
asn_DEF_Packet_51P0_tags_1, /* Same as above */
sizeof(asn_DEF_Packet_51P0_tags_1)
/sizeof(asn_DEF_Packet_51P0_tags_1[0]), /* 1 */
{ 0, 0, SEQUENCE_constraint },
asn_MBR_Packet_51P0_1,
3, /* Elements count */
&asn_SPC_Packet_51P0_specs_1 /* Additional specs */
};

View File

@ -0,0 +1,62 @@
-- OK: Everything is fine
-- iso.org.dod.internet.private.enterprise (1.3.6.1.4.1)
-- .spelio.software.asn1c.test (9363.1.5.1)
-- .156
ModuleParameterizationMoreThanTwoLevel
{ iso org(3) dod(6) internet(1) private(4) enterprise(1)
spelio(9363) software(1) asn1c(5) test(1) 156 }
DEFINITIONS ::= BEGIN
TOTAL-CLASS SAMPLE-CLASS ::= {
CLASS-1 |
CLASS-2,
...
}
CLASS-1 SAMPLE-CLASS ::= {
item1-1 |
item1-2,
...,
item1-3
}
CLASS-2 SAMPLE-CLASS ::= {
item2-1,
...,
item2-2 |
item2-3
}
SAMPLE-CLASS ::= CLASS {
&id RELATIVE-OID UNIQUE,
&code ENUMERATED { request, response, status }
DEFAULT request,
&Type OPTIONAL
} WITH SYNTAX { [TYPE &Type] [WITH CODE &code] IDENTIFIED BY &id }
item1-1 SAMPLE-CLASS ::= { IDENTIFIED BY id1-1 }
item1-2 SAMPLE-CLASS ::= { WITH CODE 1 IDENTIFIED BY id1-2 }
item1-3 SAMPLE-CLASS ::= { TYPE SampleType WITH CODE 2 IDENTIFIED BY id1-3 }
item2-1 SAMPLE-CLASS ::= { IDENTIFIED BY id2-1 }
item2-2 SAMPLE-CLASS ::= { WITH CODE 1 IDENTIFIED BY id2-2 }
item2-3 SAMPLE-CLASS ::= { TYPE SampleType WITH CODE 2 IDENTIFIED BY id2-3 }
id1-1 RELATIVE-OID ::= { 1 1 }
id1-2 RELATIVE-OID ::= { 1 2 }
id1-3 RELATIVE-OID ::= { 1 3 }
id2-1 RELATIVE-OID ::= { 2 1 }
id2-2 RELATIVE-OID ::= { 2 2 }
id2-3 RELATIVE-OID ::= { 2 3 }
SampleType ::= SEQUENCE { ... }
Salt ::= SET { ... }
END

View File

@ -0,0 +1,108 @@
ModuleParameterizationMoreThanTwoLevel { iso org(3) dod(6) internet(1)
private(4) enterprise(1) spelio(9363) software(1) asn1c(5) test(1)
156 }
DEFINITIONS ::=
BEGIN
TOTAL-CLASS SAMPLE-CLASS ::= {({ IDENTIFIED BY id1-1 } | { WITH CODE 1 IDENTIFIED BY id1-2 }) ({ IDENTIFIED BY id1-1 } | { WITH CODE 1 IDENTIFIED BY id1-2 }) | ({ IDENTIFIED BY id2-1 }) ({ IDENTIFIED BY id2-1 }),...}
-- Information Object Set has 4 entries:
-- [ &id][ &code][ &Type]
-- [1] id1-1 <no entry> <no entry>
-- [2] id1-2 1 <no entry>
-- [3] id2-2 1 <no entry>
-- [4] id2-3 2 SampleType
CLASS-1 SAMPLE-CLASS ::= {{ IDENTIFIED BY id1-1 } | { WITH CODE 1 IDENTIFIED BY id1-2 },...,{ TYPE SampleType WITH CODE 2 IDENTIFIED BY id1-3 }}
-- Information Object Set has 2 entries:
-- [ &id][&code][&Type]
-- [1] id1-1 <no entry> <no entry>
-- [2] id1-2 1 <no entry>
-- [ ] ...
CLASS-2 SAMPLE-CLASS ::= {{ IDENTIFIED BY id2-1 },...,{ WITH CODE 1 IDENTIFIED BY id2-2 } | { TYPE SampleType WITH CODE 2 IDENTIFIED BY id2-3 }}
-- Information Object Set has 2 entries:
-- [ &id][ &code][ &Type]
-- [1] id2-2 1 <no entry>
-- [2] id2-3 2 SampleType
-- [ ] ...
SAMPLE-CLASS ::= CLASS {
&id RELATIVE-OID UNIQUE,
&code ENUMERATED {
request(0),
response(1),
status(2)
} DEFAULT 0,
&Type OPTIONAL
} WITH SYNTAX { [TYPE &Type] [WITH CODE &code] IDENTIFIED BY &id }
-- Information Object Set has 6 entries:
-- [ &id][ &code][ &Type]
-- [1] id1-1 <no entry> <no entry>
-- [2] id1-2 1 <no entry>
-- [3] id2-2 1 <no entry>
-- [4] id2-3 2 SampleType
-- [5] id1-3 2 SampleType
-- [6] id2-1 <no entry> <no entry>
item1-1 SAMPLE-CLASS ::= { IDENTIFIED BY id1-1 }
-- Information Object Set has 1 entry:
-- [ &id][&code][&Type]
-- [1] id1-1 <no entry> <no entry>
item1-2 SAMPLE-CLASS ::= { WITH CODE 1 IDENTIFIED BY id1-2 }
-- Information Object Set has 1 entry:
-- [ &id][&code][&Type]
-- [1] id1-2 1 <no entry>
item1-3 SAMPLE-CLASS ::= { TYPE SampleType WITH CODE 2 IDENTIFIED BY id1-3 }
-- Information Object Set has 1 entry:
-- [ &id][ &code][ &Type]
-- [1] id1-3 2 SampleType
item2-1 SAMPLE-CLASS ::= { IDENTIFIED BY id2-1 }
-- Information Object Set has 1 entry:
-- [ &id][&code][&Type]
-- [1] id2-1 <no entry> <no entry>
item2-2 SAMPLE-CLASS ::= { WITH CODE 1 IDENTIFIED BY id2-2 }
-- Information Object Set has 1 entry:
-- [ &id][&code][&Type]
-- [1] id2-2 1 <no entry>
item2-3 SAMPLE-CLASS ::= { TYPE SampleType WITH CODE 2 IDENTIFIED BY id2-3 }
-- Information Object Set has 1 entry:
-- [ &id][ &code][ &Type]
-- [1] id2-3 2 SampleType
id1-1 RELATIVE-OID ::= { 1 1 }
id1-2 RELATIVE-OID ::= { 1 2 }
id1-3 RELATIVE-OID ::= { 1 3 }
id2-1 RELATIVE-OID ::= { 2 1 }
id2-2 RELATIVE-OID ::= { 2 2 }
id2-3 RELATIVE-OID ::= { 2 3 }
SampleType ::= SEQUENCE {
...
}
Salt ::= SET {
...
}
END