X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?p=sim%2Fe2-interface.git;a=blobdiff_plain;f=e2sim%2Fe2apv1sim%2Fricsim%2Fsrc%2FASN1%2Fasn%2Fper%2Fsequence_of.hpp;fp=e2sim%2Fe2apv1sim%2Fricsim%2Fsrc%2FASN1%2Fasn%2Fper%2Fsequence_of.hpp;h=d4e21a96d17292d805b12f6326ec78625b6039a6;hp=0000000000000000000000000000000000000000;hb=3ebf932d23dcbec9ed19f4a51f9d00a0a54f5124;hpb=6896318f2b4ff01b4a88b16019c3dc93b0b693f5 diff --git a/e2sim/e2apv1sim/ricsim/src/ASN1/asn/per/sequence_of.hpp b/e2sim/e2apv1sim/ricsim/src/ASN1/asn/per/sequence_of.hpp new file mode 100755 index 0000000..d4e21a9 --- /dev/null +++ b/e2sim/e2apv1sim/ricsim/src/ASN1/asn/per/sequence_of.hpp @@ -0,0 +1,156 @@ +#pragma once +/****************************************************************************** +* +* Copyright (c) 2019 AT&T Intellectual Property. +* Copyright (c) 2018-2019 Nokia. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +* +******************************************************************************/ + +// Standard Includes: ANSI C/C++, MSA, and Third-Party Libraries + +// Local Includes: Application specific classes, functions, and libraries +#include "asn/per/common.hpp" + +namespace asn { +namespace per { + +template +struct SequenceOf; + +//19.6 Default +template +struct SequenceOfNoExt +{ + static void inline run(IE const& ie, EncoderCtx& ctx) + { + LengthDeterminant::run(ctx, ie.size()); + } + static void inline run(IE& ie, DecoderCtx& ctx) + { + size_t len = LengthDeterminant::run(ctx, false); + for (size_t i = 0; i < len; ++i) + { + u8* data = ctx.refAllocator().alloc_bytes(sizeof(typename IE::value_type)); + if (data) + { + typename IE::value_type * v = new (data) typename IE::value_type; + v->clear(); + ie.push_back(*v); + } + else + { + ctx.refErrorCtx().allocatorNoMem(0, sizeof(typename IE::value_type)); + break; + } + } + } +}; + +//16.6 +template +struct SequenceOfNoExt> +{ + static void inline run(IE const& ie, EncoderCtx& ctx) {/*do nothing*/ } + static void inline run(IE& ie, DecoderCtx& ctx) + { + for (size_t i = 0; i < IE::constraint_t::upper_bound; ++i) + { + u8* data = ctx.refAllocator().alloc_bytes(sizeof(typename IE::value_type)); + if (data) + { + typename IE::value_type * v = new (data) typename IE::value_type; + v->clear(); + ie.push_back(*v); + } + else + { + ctx.refErrorCtx().allocatorNoMem(0, sizeof(typename IE::value_type)); + break; + } + } + } +}; + +/**************************************************/ + +//19.4 Extension present +template +struct SequenceOf > +{ + static void inline run(IE const& ie, EncoderCtx& ctx) + { + if (ie.size() <= IE::constraint_t::upper_bound && ie.size() >= IE::constraint_t::lower_bound) + { + Tools::bit_accessor::put(0, 1, ctx.refBuffer()); + SequenceOfNoExt::run(ie, ctx); + } + else + { + Tools::bit_accessor::put(1, 1, ctx.refBuffer()); + LengthDeterminant::run(ctx, ie.size()); + } + } + static void inline run(IE& ie, DecoderCtx& ctx) + { + u8 ext = Tools::bit_accessor::get(1, ctx.refBuffer()); + if (ext) + { + size_t len = LengthDeterminant::run(ctx, true); + for (size_t i = 0; i < len; ++i) + { + u8* data = ctx.refAllocator().alloc_bytes(sizeof(typename IE::value_type)); + if (data) + { + typename IE::value_type * v = new (data) typename IE::value_type; + //v->clear(); + ie.push_back(*v); + } + else + { + ctx.refErrorCtx().allocatorNoMem(0, sizeof(typename IE::value_type)); + break; + } + } + } + else + SequenceOfNoExt::run(ie, ctx); + } +}; + +//19.5-6 No extension +template +struct SequenceOf > +{ + static void inline run(IE const& ie, EncoderCtx& ctx) + { + if (IE::constraint_t::lower_bound >= 0 && ie.size() < size_t(IE::constraint_t::lower_bound)) + { + ctx.refErrorCtx().sizeRangeError(ie.size(), size_t(IE::constraint_t::lower_bound)); + } + else + { + SequenceOfNoExt::run(ie, ctx); + } + } + static void inline run(IE& ie, DecoderCtx& ctx) + { + SequenceOfNoExt::run(ie, ctx); + } +}; + +} //namespace per +} //namespace asn