1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2024-06-24 22:13:15 +00:00
gnss-sdr/src/core/libs/supl/asn-supl/FormatIndicator.c
Carles Fernandez 4d0d263280
Make the software package compliant with the REUSE Specification v3.0 (see https://reuse.software/spec/)
Update license headers to SPDX format (see https://spdx.org/)
Add license to all files
Add CI job in GitHub Actions to ensure compliance
2020-02-08 01:20:02 +01:00

183 lines
6.1 KiB
C

/*
* SPDX-FileCopyrightText: (c) 2003, 2004 Lev Walkin <vlm@lionet.info>. All rights reserved.
* SPDX-License-Identifier: BSD-1-Clause
* Generated by asn1c-0.9.22 (http://lionet.info/asn1c)
* From ASN.1 module "SUPL-INIT"
* found in "../supl-init.asn"
*/
#include "FormatIndicator.h"
int FormatIndicator_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb,
void *app_key)
{
/* Replace with underlying type checker */
td->check_constraints = asn_DEF_ENUMERATED.check_constraints;
return td->check_constraints(td, sptr, ctfailcb, app_key);
}
/*
* This type is implemented using ENUMERATED,
* so here we adjust the DEF accordingly.
*/
static void FormatIndicator_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
{
td->free_struct = asn_DEF_ENUMERATED.free_struct;
td->print_struct = asn_DEF_ENUMERATED.print_struct;
td->ber_decoder = asn_DEF_ENUMERATED.ber_decoder;
td->der_encoder = asn_DEF_ENUMERATED.der_encoder;
td->xer_decoder = asn_DEF_ENUMERATED.xer_decoder;
td->xer_encoder = asn_DEF_ENUMERATED.xer_encoder;
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined
* explicitly
*/
}
void FormatIndicator_free(asn_TYPE_descriptor_t *td, void *struct_ptr,
int contents_only)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
td->free_struct(td, struct_ptr, contents_only);
}
int FormatIndicator_print(asn_TYPE_descriptor_t *td, const void *struct_ptr,
int ilevel, asn_app_consume_bytes_f *cb,
void *app_key)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->print_struct(td, struct_ptr, ilevel, cb, app_key);
}
asn_dec_rval_t FormatIndicator_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td,
void **structure, const void *bufptr,
size_t size, int tag_mode)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->ber_decoder(opt_codec_ctx, td, structure, bufptr, size,
tag_mode);
}
asn_enc_rval_t FormatIndicator_encode_der(asn_TYPE_descriptor_t *td,
void *structure, int tag_mode,
ber_tlv_tag_t tag,
asn_app_consume_bytes_f *cb,
void *app_key)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->der_encoder(td, structure, tag_mode, tag, cb, app_key);
}
asn_dec_rval_t FormatIndicator_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td,
void **structure,
const char *opt_mname,
const void *bufptr, size_t size)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->xer_decoder(opt_codec_ctx, td, structure, opt_mname, bufptr,
size);
}
asn_enc_rval_t FormatIndicator_encode_xer(asn_TYPE_descriptor_t *td,
void *structure, int ilevel,
enum xer_encoder_flags_e flags,
asn_app_consume_bytes_f *cb,
void *app_key)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->xer_encoder(td, structure, ilevel, flags, cb, app_key);
}
asn_dec_rval_t FormatIndicator_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td,
asn_per_constraints_t *constraints,
void **structure,
asn_per_data_t *per_data)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->uper_decoder(opt_codec_ctx, td, constraints, structure,
per_data);
}
asn_enc_rval_t FormatIndicator_encode_uper(asn_TYPE_descriptor_t *td,
asn_per_constraints_t *constraints,
void *structure,
asn_per_outp_t *per_out)
{
FormatIndicator_1_inherit_TYPE_descriptor(td);
return td->uper_encoder(td, constraints, structure, per_out);
}
static asn_per_constraints_t ASN_PER_TYPE_FORMAT_INDICATOR_CONSTR_1 = {
{APC_CONSTRAINED | APC_EXTENSIBLE, 3, 3, 0, 7} /* (0..7,...) */,
{APC_UNCONSTRAINED, -1, -1, 0, 0},
0,
0 /* No PER value map */
};
static asn_INTEGER_enum_map_t asn_MAP_FormatIndicator_value2enum_1[] = {
{0, 11, "logicalName"},
{1, 13, "e-mailAddress"},
{2, 6, "msisdn"},
{3, 3, "url"},
{4, 6, "sipUrl"},
{5, 3, "min"},
{6, 3, "mdn"},
{7, 17, "imsPublicIdentity"}
/* This list is extensible */
};
static unsigned int asn_MAP_FormatIndicator_enum2value_1[] = {
1, /* e-mailAddress(1) */
7, /* imsPublicIdentity(7) */
0, /* logicalName(0) */
6, /* mdn(6) */
5, /* min(5) */
2, /* msisdn(2) */
4, /* sipUrl(4) */
3 /* url(3) */
/* This list is extensible */
};
static asn_INTEGER_specifics_t asn_SPC_FormatIndicator_specs_1 = {
asn_MAP_FormatIndicator_value2enum_1, /* "tag" => N; sorted by tag */
asn_MAP_FormatIndicator_enum2value_1, /* N => "tag"; sorted by N */
8, /* Number of elements in the maps */
9, /* Extensions before this member */
1, /* Strict enumeration */
0, /* Native long size */
0};
static ber_tlv_tag_t asn_DEF_FormatIndicator_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))};
asn_TYPE_descriptor_t asn_DEF_FormatIndicator = {
"FormatIndicator",
"FormatIndicator",
FormatIndicator_free,
FormatIndicator_print,
FormatIndicator_constraint,
FormatIndicator_decode_ber,
FormatIndicator_encode_der,
FormatIndicator_decode_xer,
FormatIndicator_encode_xer,
FormatIndicator_decode_uper,
FormatIndicator_encode_uper,
0, /* Use generic outmost tag fetcher */
asn_DEF_FormatIndicator_tags_1,
sizeof(asn_DEF_FormatIndicator_tags_1) /
sizeof(asn_DEF_FormatIndicator_tags_1[0]), /* 1 */
asn_DEF_FormatIndicator_tags_1, /* Same as above */
sizeof(asn_DEF_FormatIndicator_tags_1) /
sizeof(asn_DEF_FormatIndicator_tags_1[0]), /* 1 */
&ASN_PER_TYPE_FORMAT_INDICATOR_CONSTR_1,
0,
0, /* Defined elsewhere */
&asn_SPC_FormatIndicator_specs_1 /* Additional specs */
};