Initial version of asn1c
[com/asn1c.git] / tests / tests-asn1c-compiler / 106-param-constr-OK.asn1.-P
diff --git a/tests/tests-asn1c-compiler/106-param-constr-OK.asn1.-P b/tests/tests-asn1c-compiler/106-param-constr-OK.asn1.-P
new file mode 100644 (file)
index 0000000..fe41bed
--- /dev/null
@@ -0,0 +1,235 @@
+
+/*** <<< INCLUDES [Narrow] >>> ***/
+
+#include <NativeInteger.h>
+#include <constr_SEQUENCE.h>
+
+/*** <<< TYPE-DECLS [Narrow] >>> ***/
+
+typedef struct Narrow_15P0 {
+       long    *narrow1;       /* DEFAULT 3 */
+       long     narrow2;
+       long    *narrow3;       /* OPTIONAL */
+       
+       /* Context for parsing across buffer boundaries */
+       asn_struct_ctx_t _asn_ctx;
+} Narrow_15P0_t;
+
+/*** <<< FUNC-DECLS [Narrow] >>> ***/
+
+extern asn_TYPE_descriptor_t asn_DEF_Narrow_15P0;
+extern asn_SEQUENCE_specifics_t asn_SPC_Narrow_15P0_specs_1;
+extern asn_TYPE_member_t asn_MBR_Narrow_15P0_1[3];
+
+/*** <<< CODE [Narrow] >>> ***/
+
+static int
+memb_narrow1_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 >= 1 && value <= 5)) {
+               /* 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_narrow2_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 >= 2 && value <= 5)) {
+               /* 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_narrow3_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 >= 3 && value <= 5)) {
+               /* Constraint check succeeded */
+               return 0;
+       } else {
+               ASN__CTFAIL(app_key, td, sptr,
+                       "%s: constraint failed (%s:%d)",
+                       td->name, __FILE__, __LINE__);
+               return -1;
+       }
+}
+
+
+/*** <<< STAT-DEFS [Narrow] >>> ***/
+
+static int asn_DFL_2_cmp_3(const void *sptr) {
+       const long *st = sptr;
+       
+       if(!st) {
+               return -1; /* No value is not a default value */
+       }
+       
+       /* Test default value 3 */
+       return (*st != 3);
+}
+static int asn_DFL_2_set_3(void **sptr) {
+       long *st = *sptr;
+       
+       if(!st) {
+               st = (*sptr = CALLOC(1, sizeof(*st)));
+               if(!st) return -1;
+       }
+       
+       /* Install default value 3 */
+       *st = 3;
+       return 0;
+}
+asn_TYPE_member_t asn_MBR_Narrow_15P0_1[] = {
+       { ATF_POINTER, 1, offsetof(struct Narrow_15P0, narrow1),
+               .tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)),
+               .tag_mode = 0,
+               .type = &asn_DEF_NativeInteger,
+               .type_selector = 0,
+               { .oer_constraints = 0, .per_constraints = 0, .general_constraints =  memb_narrow1_constraint_1 },
+               .default_value_cmp = &asn_DFL_2_cmp_3,  /* Compare DEFAULT 3 */
+               .default_value_set = &asn_DFL_2_set_3,  /* Set DEFAULT 3 */
+               .name = "narrow1"
+               },
+       { ATF_NOFLAGS, 0, offsetof(struct Narrow_15P0, narrow2),
+               .tag = (ASN_TAG_CLASS_CONTEXT | (0 << 2)),
+               .tag_mode = +1, /* EXPLICIT tag at current level */
+               .type = &asn_DEF_NativeInteger,
+               .type_selector = 0,
+               { .oer_constraints = 0, .per_constraints = 0, .general_constraints =  memb_narrow2_constraint_1 },
+               0, 0, /* No default value */
+               .name = "narrow2"
+               },
+       { ATF_POINTER, 1, offsetof(struct Narrow_15P0, narrow3),
+               .tag = (ASN_TAG_CLASS_CONTEXT | (1 << 2)),
+               .tag_mode = +1, /* EXPLICIT tag at current level */
+               .type = &asn_DEF_NativeInteger,
+               .type_selector = 0,
+               { .oer_constraints = 0, .per_constraints = 0, .general_constraints =  memb_narrow3_constraint_1 },
+               0, 0, /* No default value */
+               .name = "narrow3"
+               },
+};
+static const ber_tlv_tag_t asn_DEF_Narrow_15P0_tags_1[] = {
+       (ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
+};
+static const asn_TYPE_tag2member_t asn_MAP_Narrow_15P0_tag2el_1[] = {
+    { (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 0, 0, 0 }, /* narrow1 */
+    { (ASN_TAG_CLASS_CONTEXT | (0 << 2)), 1, 0, 0 }, /* narrow2 */
+    { (ASN_TAG_CLASS_CONTEXT | (1 << 2)), 2, 0, 0 } /* narrow3 */
+};
+asn_SEQUENCE_specifics_t asn_SPC_Narrow_15P0_specs_1 = {
+       sizeof(struct Narrow_15P0),
+       offsetof(struct Narrow_15P0, _asn_ctx),
+       .tag2el = asn_MAP_Narrow_15P0_tag2el_1,
+       .tag2el_count = 3,      /* Count of tags in the map */
+       0, 0, 0,        /* Optional elements (not needed) */
+       -1,     /* First extension addition */
+};
+asn_TYPE_descriptor_t asn_DEF_Narrow_15P0 = {
+       "Narrow",
+       "Narrow",
+       &asn_OP_SEQUENCE,
+       asn_DEF_Narrow_15P0_tags_1,
+       sizeof(asn_DEF_Narrow_15P0_tags_1)
+               /sizeof(asn_DEF_Narrow_15P0_tags_1[0]), /* 1 */
+       asn_DEF_Narrow_15P0_tags_1,     /* Same as above */
+       sizeof(asn_DEF_Narrow_15P0_tags_1)
+               /sizeof(asn_DEF_Narrow_15P0_tags_1[0]), /* 1 */
+       { 0, 0, SEQUENCE_constraint },
+       asn_MBR_Narrow_15P0_1,
+       3,      /* Elements count */
+       &asn_SPC_Narrow_15P0_specs_1    /* Additional specs */
+};
+
+
+/*** <<< INCLUDES [NarrowInteger] >>> ***/
+
+#include "Narrow.h"
+
+/*** <<< TYPE-DECLS [NarrowInteger] >>> ***/
+
+typedef Narrow_15P0_t   NarrowInteger_t;
+
+/*** <<< FUNC-DECLS [NarrowInteger] >>> ***/
+
+extern asn_TYPE_descriptor_t asn_DEF_NarrowInteger;
+asn_struct_free_f NarrowInteger_free;
+asn_struct_print_f NarrowInteger_print;
+asn_constr_check_f NarrowInteger_constraint;
+ber_type_decoder_f NarrowInteger_decode_ber;
+der_type_encoder_f NarrowInteger_encode_der;
+xer_type_decoder_f NarrowInteger_decode_xer;
+xer_type_encoder_f NarrowInteger_encode_xer;
+
+/*** <<< CODE [NarrowInteger] >>> ***/
+
+/*
+ * This type is implemented using Narrow_15P0,
+ * so here we adjust the DEF accordingly.
+ */
+
+/*** <<< STAT-DEFS [NarrowInteger] >>> ***/
+
+static const ber_tlv_tag_t asn_DEF_NarrowInteger_tags_1[] = {
+       (ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
+};
+asn_TYPE_descriptor_t asn_DEF_NarrowInteger = {
+       "NarrowInteger",
+       "NarrowInteger",
+       &asn_OP_SEQUENCE,
+       asn_DEF_NarrowInteger_tags_1,
+       sizeof(asn_DEF_NarrowInteger_tags_1)
+               /sizeof(asn_DEF_NarrowInteger_tags_1[0]), /* 1 */
+       asn_DEF_NarrowInteger_tags_1,   /* Same as above */
+       sizeof(asn_DEF_NarrowInteger_tags_1)
+               /sizeof(asn_DEF_NarrowInteger_tags_1[0]), /* 1 */
+       { 0, 0, SEQUENCE_constraint },
+       asn_MBR_Narrow_15P0_1,
+       3,      /* Elements count */
+       &asn_SPC_Narrow_15P0_specs_1    /* Additional specs */
+};
+