X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=tests%2Ftests-asn1c-compiler%2F43-recursion-OK.asn1.-Pfwide-types;fp=tests%2Ftests-asn1c-compiler%2F43-recursion-OK.asn1.-Pfwide-types;h=b3bc7e75b5a670476d608cd817519e73539cb047;hb=70ee6fc793ec8e828067a3569849b6c216054497;hp=0000000000000000000000000000000000000000;hpb=59f84608ec15c016958a6e0e0ddd813f376c0925;p=com%2Fasn1c.git diff --git a/tests/tests-asn1c-compiler/43-recursion-OK.asn1.-Pfwide-types b/tests/tests-asn1c-compiler/43-recursion-OK.asn1.-Pfwide-types new file mode 100644 index 0000000..b3bc7e7 --- /dev/null +++ b/tests/tests-asn1c-compiler/43-recursion-OK.asn1.-Pfwide-types @@ -0,0 +1,532 @@ + +/*** <<< INCLUDES [Test-structure-1] >>> ***/ + +#include +#include +#include +#include +#include +#include + +/*** <<< FWD-DECLS [Test-structure-1] >>> ***/ + +struct Test_structure_1; + +/*** <<< TYPE-DECLS [Test-structure-1] >>> ***/ + +typedef struct Test_structure_1 { + struct t_member1 { + A_SET_OF(struct Test_structure_1) list; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; + } t_member1; + struct t_member2 { + A_SEQUENCE_OF(struct Test_structure_1) list; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; + } t_member2; + struct Test_structure_1 *t_member3; /* OPTIONAL */ + INTEGER_t t_member4; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; +} Test_structure_1_t; + +/*** <<< FUNC-DECLS [Test-structure-1] >>> ***/ + +extern asn_TYPE_descriptor_t asn_DEF_Test_structure_1; +extern asn_SEQUENCE_specifics_t asn_SPC_Test_structure_1_specs_1; +extern asn_TYPE_member_t asn_MBR_Test_structure_1_1[4]; + +/*** <<< POST-INCLUDE [Test-structure-1] >>> ***/ + +#include "Test-structure-1.h" + +/*** <<< STAT-DEFS [Test-structure-1] >>> ***/ + +static asn_TYPE_member_t asn_MBR_t_member1_2[] = { + { ATF_POINTER, 0, 0, + .tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), + .tag_mode = 0, + .type = &asn_DEF_Test_structure_1, + .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_t_member1_tags_2[] = { + (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)) +}; +static asn_SET_OF_specifics_t asn_SPC_t_member1_specs_2 = { + sizeof(struct t_member1), + offsetof(struct t_member1, _asn_ctx), + 0, /* XER encoding is XMLDelimitedItemList */ +}; +static /* Use -fall-defs-global to expose */ +asn_TYPE_descriptor_t asn_DEF_t_member1_2 = { + "t-member1", + "t-member1", + &asn_OP_SET_OF, + asn_DEF_t_member1_tags_2, + sizeof(asn_DEF_t_member1_tags_2) + /sizeof(asn_DEF_t_member1_tags_2[0]), /* 1 */ + asn_DEF_t_member1_tags_2, /* Same as above */ + sizeof(asn_DEF_t_member1_tags_2) + /sizeof(asn_DEF_t_member1_tags_2[0]), /* 1 */ + { 0, 0, SET_OF_constraint }, + asn_MBR_t_member1_2, + 1, /* Single element */ + &asn_SPC_t_member1_specs_2 /* Additional specs */ +}; + +static asn_TYPE_member_t asn_MBR_t_member2_4[] = { + { ATF_POINTER, 0, 0, + .tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), + .tag_mode = 0, + .type = &asn_DEF_Test_structure_1, + .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_t_member2_tags_4[] = { + (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) +}; +static asn_SET_OF_specifics_t asn_SPC_t_member2_specs_4 = { + sizeof(struct t_member2), + offsetof(struct t_member2, _asn_ctx), + 0, /* XER encoding is XMLDelimitedItemList */ +}; +static /* Use -fall-defs-global to expose */ +asn_TYPE_descriptor_t asn_DEF_t_member2_4 = { + "t-member2", + "t-member2", + &asn_OP_SEQUENCE_OF, + asn_DEF_t_member2_tags_4, + sizeof(asn_DEF_t_member2_tags_4) + /sizeof(asn_DEF_t_member2_tags_4[0]), /* 1 */ + asn_DEF_t_member2_tags_4, /* Same as above */ + sizeof(asn_DEF_t_member2_tags_4) + /sizeof(asn_DEF_t_member2_tags_4[0]), /* 1 */ + { 0, 0, SEQUENCE_OF_constraint }, + asn_MBR_t_member2_4, + 1, /* Single element */ + &asn_SPC_t_member2_specs_4 /* Additional specs */ +}; + +asn_TYPE_member_t asn_MBR_Test_structure_1_1[] = { + { ATF_NOFLAGS, 0, offsetof(struct Test_structure_1, t_member1), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), + .tag_mode = 0, + .type = &asn_DEF_t_member1_2, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "t-member1" + }, + { ATF_NOFLAGS, 0, offsetof(struct Test_structure_1, t_member2), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), + .tag_mode = 0, + .type = &asn_DEF_t_member2_4, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "t-member2" + }, + { ATF_POINTER, 1, offsetof(struct Test_structure_1, t_member3), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), + .tag_mode = 0, + .type = &asn_DEF_Test_structure_1, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "t-member3" + }, + { ATF_NOFLAGS, 0, offsetof(struct Test_structure_1, t_member4), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), + .tag_mode = 0, + .type = &asn_DEF_INTEGER, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "t-member4" + }, +}; +static const ber_tlv_tag_t asn_DEF_Test_structure_1_tags_1[] = { + (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) +}; +static const asn_TYPE_tag2member_t asn_MAP_Test_structure_1_tag2el_1[] = { + { (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 3, 0, 0 }, /* t-member4 */ + { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), 1, 0, 1 }, /* t-member2 */ + { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)), 2, -1, 0 }, /* t-member3 */ + { (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), 0, 0, 0 } /* t-member1 */ +}; +asn_SEQUENCE_specifics_t asn_SPC_Test_structure_1_specs_1 = { + sizeof(struct Test_structure_1), + offsetof(struct Test_structure_1, _asn_ctx), + .tag2el = asn_MAP_Test_structure_1_tag2el_1, + .tag2el_count = 4, /* Count of tags in the map */ + 0, 0, 0, /* Optional elements (not needed) */ + -1, /* First extension addition */ +}; +asn_TYPE_descriptor_t asn_DEF_Test_structure_1 = { + "Test-structure-1", + "Test-structure-1", + &asn_OP_SEQUENCE, + asn_DEF_Test_structure_1_tags_1, + sizeof(asn_DEF_Test_structure_1_tags_1) + /sizeof(asn_DEF_Test_structure_1_tags_1[0]), /* 1 */ + asn_DEF_Test_structure_1_tags_1, /* Same as above */ + sizeof(asn_DEF_Test_structure_1_tags_1) + /sizeof(asn_DEF_Test_structure_1_tags_1[0]), /* 1 */ + { 0, 0, SEQUENCE_constraint }, + asn_MBR_Test_structure_1_1, + 4, /* Elements count */ + &asn_SPC_Test_structure_1_specs_1 /* Additional specs */ +}; + + +/*** <<< INCLUDES [Choice-1] >>> ***/ + +#include +#include +#include +#include + +/*** <<< DEPS [Choice-1] >>> ***/ + +typedef enum Choice_1_PR { + Choice_1_PR_NOTHING, /* No components present */ + Choice_1_PR_and, + Choice_1_PR_or, + Choice_1_PR_not, + Choice_1_PR_other +} Choice_1_PR; + +/*** <<< FWD-DECLS [Choice-1] >>> ***/ + +struct Choice_1; + +/*** <<< TYPE-DECLS [Choice-1] >>> ***/ + +typedef struct Choice_1 { + Choice_1_PR present; + union Choice_1_u { + struct Choice_1 *And; + struct Or { + A_SET_OF(struct Choice_1) list; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; + } Or; + struct Choice_1 *Not; + INTEGER_t other; + } choice; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; +} Choice_1_t; + +/*** <<< FUNC-DECLS [Choice-1] >>> ***/ + +extern asn_TYPE_descriptor_t asn_DEF_Choice_1; +extern asn_CHOICE_specifics_t asn_SPC_Choice_1_specs_1; +extern asn_TYPE_member_t asn_MBR_Choice_1_1[4]; + +/*** <<< POST-INCLUDE [Choice-1] >>> ***/ + +#include "Choice-1.h" + +/*** <<< STAT-DEFS [Choice-1] >>> ***/ + +static asn_TYPE_member_t asn_MBR_or_3[] = { + { ATF_POINTER, 0, 0, + .tag = -1 /* Ambiguous tag (CHOICE?) */, + .tag_mode = 0, + .type = &asn_DEF_Choice_1, + .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_or_tags_3[] = { + (ASN_TAG_CLASS_CONTEXT | (2 << 2)), + (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)) +}; +static asn_SET_OF_specifics_t asn_SPC_or_specs_3 = { + sizeof(struct Or), + offsetof(struct Or, _asn_ctx), + 2, /* XER encoding is XMLValueList */ +}; +static /* Use -fall-defs-global to expose */ +asn_TYPE_descriptor_t asn_DEF_or_3 = { + "or", + "or", + &asn_OP_SET_OF, + asn_DEF_or_tags_3, + sizeof(asn_DEF_or_tags_3) + /sizeof(asn_DEF_or_tags_3[0]) - 1, /* 1 */ + asn_DEF_or_tags_3, /* Same as above */ + sizeof(asn_DEF_or_tags_3) + /sizeof(asn_DEF_or_tags_3[0]), /* 2 */ + { 0, 0, SET_OF_constraint }, + asn_MBR_or_3, + 1, /* Single element */ + &asn_SPC_or_specs_3 /* Additional specs */ +}; + +asn_TYPE_member_t asn_MBR_Choice_1_1[] = { + { ATF_POINTER, 0, offsetof(struct Choice_1, choice.And), + .tag = (ASN_TAG_CLASS_CONTEXT | (1 << 2)), + .tag_mode = +1, /* EXPLICIT tag at current level */ + .type = &asn_DEF_Choice_1, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "and" + }, + { ATF_NOFLAGS, 0, offsetof(struct Choice_1, choice.Or), + .tag = (ASN_TAG_CLASS_CONTEXT | (2 << 2)), + .tag_mode = 0, + .type = &asn_DEF_or_3, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "or" + }, + { ATF_POINTER, 0, offsetof(struct Choice_1, choice.Not), + .tag = (ASN_TAG_CLASS_CONTEXT | (3 << 2)), + .tag_mode = +1, /* EXPLICIT tag at current level */ + .type = &asn_DEF_Choice_1, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "not" + }, + { ATF_NOFLAGS, 0, offsetof(struct Choice_1, choice.other), + .tag = (ASN_TAG_CLASS_CONTEXT | (4 << 2)), + .tag_mode = +1, /* EXPLICIT tag at current level */ + .type = &asn_DEF_INTEGER, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "other" + }, +}; +static const asn_TYPE_tag2member_t asn_MAP_Choice_1_tag2el_1[] = { + { (ASN_TAG_CLASS_CONTEXT | (1 << 2)), 0, 0, 0 }, /* and */ + { (ASN_TAG_CLASS_CONTEXT | (2 << 2)), 1, 0, 0 }, /* or */ + { (ASN_TAG_CLASS_CONTEXT | (3 << 2)), 2, 0, 0 }, /* not */ + { (ASN_TAG_CLASS_CONTEXT | (4 << 2)), 3, 0, 0 } /* other */ +}; +asn_CHOICE_specifics_t asn_SPC_Choice_1_specs_1 = { + sizeof(struct Choice_1), + offsetof(struct Choice_1, _asn_ctx), + offsetof(struct Choice_1, present), + sizeof(((struct Choice_1 *)0)->present), + .tag2el = asn_MAP_Choice_1_tag2el_1, + .tag2el_count = 4, /* Count of tags in the map */ + 0, 0, + .first_extension = -1 /* Extensions start */ +}; +asn_TYPE_descriptor_t asn_DEF_Choice_1 = { + "Choice-1", + "Choice-1", + &asn_OP_CHOICE, + 0, /* No effective tags (pointer) */ + 0, /* No effective tags (count) */ + 0, /* No tags (pointer) */ + 0, /* No tags (count) */ + { 0, 0, CHOICE_constraint }, + asn_MBR_Choice_1_1, + 4, /* Elements count */ + &asn_SPC_Choice_1_specs_1 /* Additional specs */ +}; + + +/*** <<< INCLUDES [Test-structure-2] >>> ***/ + +#include + +/*** <<< DEPS [Test-structure-2] >>> ***/ + + +/* + * Method of determining the components presence + */ +typedef enum Test_structure_2_PR { + Test_structure_2_PR_m1, /* Member m1 is present */ +} Test_structure_2_PR; + +/*** <<< FWD-DECLS [Test-structure-2] >>> ***/ + +struct Test_structure_3; + +/*** <<< TYPE-DECLS [Test-structure-2] >>> ***/ + +typedef struct Test_structure_2 { + struct Test_structure_3 *m1; /* OPTIONAL */ + + /* Presence bitmask: ASN_SET_ISPRESENT(pTest_structure_2, Test_structure_2_PR_x) */ + unsigned int _presence_map + [((1+(8*sizeof(unsigned int))-1)/(8*sizeof(unsigned int)))]; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; +} Test_structure_2_t; + +/*** <<< FUNC-DECLS [Test-structure-2] >>> ***/ + +extern asn_TYPE_descriptor_t asn_DEF_Test_structure_2; +extern asn_SET_specifics_t asn_SPC_Test_structure_2_specs_1; +extern asn_TYPE_member_t asn_MBR_Test_structure_2_1[1]; + +/*** <<< POST-INCLUDE [Test-structure-2] >>> ***/ + +#include "Test-structure-3.h" + +/*** <<< STAT-DEFS [Test-structure-2] >>> ***/ + +asn_TYPE_member_t asn_MBR_Test_structure_2_1[] = { + { ATF_POINTER, 1, offsetof(struct Test_structure_2, m1), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), + .tag_mode = 0, + .type = &asn_DEF_Test_structure_3, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "m1" + }, +}; +static const ber_tlv_tag_t asn_DEF_Test_structure_2_tags_1[] = { + (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)) +}; +static const asn_TYPE_tag2member_t asn_MAP_Test_structure_2_tag2el_1[] = { + { (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), 0, 0, 0 } /* m1 */ +}; +static const uint8_t asn_MAP_Test_structure_2_mmap_1[(1 + (8 * sizeof(unsigned int)) - 1) / 8] = { + (0 << 7) +}; +asn_SET_specifics_t asn_SPC_Test_structure_2_specs_1 = { + sizeof(struct Test_structure_2), + offsetof(struct Test_structure_2, _asn_ctx), + offsetof(struct Test_structure_2, _presence_map), + .tag2el = asn_MAP_Test_structure_2_tag2el_1, + .tag2el_count = 1, /* Count of tags in the map */ + asn_MAP_Test_structure_2_tag2el_1, /* Same as above */ + 1, /* Count of tags in the CXER map */ + 0, /* Whether extensible */ + (const unsigned int *)asn_MAP_Test_structure_2_mmap_1 /* Mandatory elements map */ +}; +asn_TYPE_descriptor_t asn_DEF_Test_structure_2 = { + "Test-structure-2", + "Test-structure-2", + &asn_OP_SET, + asn_DEF_Test_structure_2_tags_1, + sizeof(asn_DEF_Test_structure_2_tags_1) + /sizeof(asn_DEF_Test_structure_2_tags_1[0]), /* 1 */ + asn_DEF_Test_structure_2_tags_1, /* Same as above */ + sizeof(asn_DEF_Test_structure_2_tags_1) + /sizeof(asn_DEF_Test_structure_2_tags_1[0]), /* 1 */ + { 0, 0, SET_constraint }, + asn_MBR_Test_structure_2_1, + 1, /* Elements count */ + &asn_SPC_Test_structure_2_specs_1 /* Additional specs */ +}; + + +/*** <<< INCLUDES [Test-structure-3] >>> ***/ + +#include + +/*** <<< DEPS [Test-structure-3] >>> ***/ + + +/* + * Method of determining the components presence + */ +typedef enum Test_structure_3_PR { + Test_structure_3_PR_m1, /* Member m1 is present */ +} Test_structure_3_PR; + +/*** <<< FWD-DECLS [Test-structure-3] >>> ***/ + +struct Test_structure_2; + +/*** <<< TYPE-DECLS [Test-structure-3] >>> ***/ + +typedef struct Test_structure_3 { + struct Test_structure_2 *m1; /* OPTIONAL */ + + /* Presence bitmask: ASN_SET_ISPRESENT(pTest_structure_3, Test_structure_3_PR_x) */ + unsigned int _presence_map + [((1+(8*sizeof(unsigned int))-1)/(8*sizeof(unsigned int)))]; + + /* Context for parsing across buffer boundaries */ + asn_struct_ctx_t _asn_ctx; +} Test_structure_3_t; + +/*** <<< FUNC-DECLS [Test-structure-3] >>> ***/ + +extern asn_TYPE_descriptor_t asn_DEF_Test_structure_3; +extern asn_SET_specifics_t asn_SPC_Test_structure_3_specs_1; +extern asn_TYPE_member_t asn_MBR_Test_structure_3_1[1]; + +/*** <<< POST-INCLUDE [Test-structure-3] >>> ***/ + +#include "Test-structure-2.h" + +/*** <<< STAT-DEFS [Test-structure-3] >>> ***/ + +asn_TYPE_member_t asn_MBR_Test_structure_3_1[] = { + { ATF_POINTER, 1, offsetof(struct Test_structure_3, m1), + .tag = (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), + .tag_mode = 0, + .type = &asn_DEF_Test_structure_2, + .type_selector = 0, + { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, + 0, 0, /* No default value */ + .name = "m1" + }, +}; +static const ber_tlv_tag_t asn_DEF_Test_structure_3_tags_1[] = { + (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)) +}; +static const asn_TYPE_tag2member_t asn_MAP_Test_structure_3_tag2el_1[] = { + { (ASN_TAG_CLASS_UNIVERSAL | (17 << 2)), 0, 0, 0 } /* m1 */ +}; +static const uint8_t asn_MAP_Test_structure_3_mmap_1[(1 + (8 * sizeof(unsigned int)) - 1) / 8] = { + (0 << 7) +}; +asn_SET_specifics_t asn_SPC_Test_structure_3_specs_1 = { + sizeof(struct Test_structure_3), + offsetof(struct Test_structure_3, _asn_ctx), + offsetof(struct Test_structure_3, _presence_map), + .tag2el = asn_MAP_Test_structure_3_tag2el_1, + .tag2el_count = 1, /* Count of tags in the map */ + asn_MAP_Test_structure_3_tag2el_1, /* Same as above */ + 1, /* Count of tags in the CXER map */ + 0, /* Whether extensible */ + (const unsigned int *)asn_MAP_Test_structure_3_mmap_1 /* Mandatory elements map */ +}; +asn_TYPE_descriptor_t asn_DEF_Test_structure_3 = { + "Test-structure-3", + "Test-structure-3", + &asn_OP_SET, + asn_DEF_Test_structure_3_tags_1, + sizeof(asn_DEF_Test_structure_3_tags_1) + /sizeof(asn_DEF_Test_structure_3_tags_1[0]), /* 1 */ + asn_DEF_Test_structure_3_tags_1, /* Same as above */ + sizeof(asn_DEF_Test_structure_3_tags_1) + /sizeof(asn_DEF_Test_structure_3_tags_1[0]), /* 1 */ + { 0, 0, SET_constraint }, + asn_MBR_Test_structure_3_1, + 1, /* Elements count */ + &asn_SPC_Test_structure_3_specs_1 /* Additional specs */ +}; +