/*** <<< INCLUDES [PacketId] >>> ***/ #include /*** <<< TYPE-DECLS [PacketId] >>> ***/ typedef long PacketId_t; /*** <<< FUNC-DECLS [PacketId] >>> ***/ #define PacketId_id_TYPE1 ((PacketId_t)1) 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; per_type_decoder_f PacketId_decode_aper; per_type_encoder_f PacketId_encode_aper; /*** <<< 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 /*** <<< 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; per_type_decoder_f Color_decode_aper; per_type_encoder_f Color_encode_aper; /*** <<< 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 /*** <<< 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; per_type_decoder_f Valid_decode_aper; per_type_encoder_f Valid_encode_aper; /*** <<< 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; per_type_decoder_f Packet_List_decode_aper; per_type_encoder_f Packet_List_encode_aper; /*** <<< 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; per_type_decoder_f UpperLayer_List_41P0_decode_aper; per_type_encoder_f UpperLayer_List_41P0_encode_aper; /*** <<< 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 #include /*** <<< 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 ClassItem_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; per_type_decoder_f SinglePacket_48P0_decode_aper; per_type_encoder_f SinglePacket_48P0_encode_aper; /*** <<< CODE [SinglePacket] >>> ***/ /* * This type is implemented using ClassItem, * 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_ClassItem_1, 3, /* Elements count */ &asn_SPC_ClassItem_specs_1 /* Additional specs */ }; /*** <<< INCLUDES [Packet] >>> ***/ #include "PacketId.h" #include "Color.h" #include #include #include #include "Valid.h" #include #include #include /*** <<< DEPS [Packet] >>> ***/ typedef enum value_PR { value_PR_NOTHING, /* No components present */ value_PR_OCTET_STRING } value_PR; /*** <<< TYPE-DECLS [Packet] >>> ***/ typedef struct ClassItem { PacketId_t id; Color_t color; struct value { value_PR present; union ClassItem__value_u { OCTET_STRING_t OCTET_STRING; } 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; } ClassItem_t; /*** <<< FUNC-DECLS [Packet] >>> ***/ extern asn_TYPE_descriptor_t asn_DEF_ClassItem; extern asn_SEQUENCE_specifics_t asn_SPC_ClassItem_specs_1; extern asn_TYPE_member_t asn_MBR_ClassItem_1[3]; /*** <<< IOC-TABLES [Packet] >>> ***/ static const long asn_VAL_1_id_TYPE1 = 1; static const long asn_VAL_1_blue = 2; static const long asn_VAL_1_crc_ok = 1; static const asn_ioc_cell_t asn_IOS_ClassItem_1_rows[] = { { "&id", aioc__value, &asn_DEF_PacketId, &asn_VAL_1_id_TYPE1 }, { "&color", aioc__value, &asn_DEF_Color, &asn_VAL_1_blue }, { "&Value", aioc__type, &asn_DEF_OCTET_STRING }, { "&valid", aioc__value, &asn_DEF_Valid, &asn_VAL_1_crc_ok } }; static const asn_ioc_set_t asn_IOS_ClassItem_1[] = { { 1, 4, 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 asn_type_selector_result_t select_ClassItem_color_type(const asn_TYPE_descriptor_t *parent_type, const void *parent_sptr) { asn_type_selector_result_t result = {0, 0}; const asn_ioc_set_t *itable = asn_IOS_ClassItem_1; size_t constraining_column = 0; /* &id */ size_t for_column = 1; /* &color */ size_t row, presence_index = 0; const long *constraining_value = (const long *)((const char *)parent_sptr + offsetof(struct ClassItem, id)); for(row=0; row < itable->rows_count; row++) { const asn_ioc_cell_t *constraining_cell = &itable->rows[row * itable->columns_count + constraining_column]; const asn_ioc_cell_t *type_cell = &itable->rows[row * itable->columns_count + for_column]; if(type_cell->cell_kind == aioc__undefined) continue; presence_index++; if(constraining_cell->type_descriptor->op->compare_struct(constraining_cell->type_descriptor, constraining_value, constraining_cell->value_sptr) == 0) { result.type_descriptor = type_cell->type_descriptor; result.presence_index = presence_index; break; } } return result; } 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 asn_type_selector_result_t select_ClassItem_value_type(const asn_TYPE_descriptor_t *parent_type, const void *parent_sptr) { asn_type_selector_result_t result = {0, 0}; const asn_ioc_set_t *itable = asn_IOS_ClassItem_1; size_t constraining_column = 0; /* &id */ size_t for_column = 2; /* &Value */ size_t row, presence_index = 0; const long *constraining_value = (const long *)((const char *)parent_sptr + offsetof(struct ClassItem, id)); for(row=0; row < itable->rows_count; row++) { const asn_ioc_cell_t *constraining_cell = &itable->rows[row * itable->columns_count + constraining_column]; const asn_ioc_cell_t *type_cell = &itable->rows[row * itable->columns_count + for_column]; if(type_cell->cell_kind == aioc__undefined) continue; presence_index++; if(constraining_cell->type_descriptor->op->compare_struct(constraining_cell->type_descriptor, constraining_value, constraining_cell->value_sptr) == 0) { result.type_descriptor = type_cell->type_descriptor; result.presence_index = presence_index; break; } } return result; } 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_TYPE_member_t asn_MBR_value_4[] = { { ATF_NOFLAGS, 0, offsetof(struct value, choice.OCTET_STRING), .tag = (ASN_TAG_CLASS_UNIVERSAL | (4 << 2)), .tag_mode = 0, .type = &asn_DEF_OCTET_STRING, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "OCTET STRING" }, }; static const asn_TYPE_tag2member_t asn_MAP_value_tag2el_4[] = { { (ASN_TAG_CLASS_UNIVERSAL | (4 << 2)), 0, 0, 0 } /* OCTET STRING */ }; 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), .tag2el = asn_MAP_value_tag2el_4, .tag2el_count = 1, /* Count of tags in the map */ 0, 0, .first_extension = -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 }, asn_MBR_value_4, 1, /* Elements count */ &asn_SPC_value_specs_4 /* Additional specs */ }; asn_TYPE_member_t asn_MBR_ClassItem_1[] = { { ATF_NOFLAGS, 0, offsetof(struct ClassItem, 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 ClassItem, color), .tag = (ASN_TAG_CLASS_UNIVERSAL | (10 << 2)), .tag_mode = 0, .type = &asn_DEF_Color, .type_selector = select_ClassItem_color_type, { .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 ClassItem, value), .tag = -1 /* Ambiguous tag (ANY?) */, .tag_mode = 0, .type = &asn_DEF_value_4, .type_selector = select_ClassItem_value_type, { .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_ClassItem_tags_1[] = { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) }; static const asn_TYPE_tag2member_t asn_MAP_ClassItem_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_ClassItem_specs_1 = { sizeof(struct ClassItem), offsetof(struct ClassItem, _asn_ctx), .tag2el = asn_MAP_ClassItem_tag2el_1, .tag2el_count = 2, /* Count of tags in the map */ 0, 0, 0, /* Optional elements (not needed) */ -1, /* First extension addition */ }; asn_TYPE_descriptor_t asn_DEF_ClassItem = { "ClassItem", "ClassItem", &asn_OP_SEQUENCE, asn_DEF_ClassItem_tags_1, sizeof(asn_DEF_ClassItem_tags_1) /sizeof(asn_DEF_ClassItem_tags_1[0]), /* 1 */ asn_DEF_ClassItem_tags_1, /* Same as above */ sizeof(asn_DEF_ClassItem_tags_1) /sizeof(asn_DEF_ClassItem_tags_1[0]), /* 1 */ { 0, 0, SEQUENCE_constraint }, asn_MBR_ClassItem_1, 3, /* Elements count */ &asn_SPC_ClassItem_specs_1 /* Additional specs */ }; /*** <<< asn_constant.h >>> ***/ /* * Generated by asn1c-0.9.29 (http://lionet.info/asn1c) */ #ifndef _ASN_CONSTANT_H #define _ASN_CONSTANT_H #ifdef __cplusplus extern "C" { #endif #define max_items (256) #ifdef __cplusplus } #endif #endif /* _ASN_CONSTANT_H */