X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?p=sim%2Fe2-interface.git;a=blobdiff_plain;f=e2sim%2Fprevious%2Fe2apv1sim%2Fricsim%2Fsrc%2FASN1%2Fasn%2Fper%2Finteger.hpp;fp=e2sim%2Fprevious%2Fe2apv1sim%2Fricsim%2Fsrc%2FASN1%2Fasn%2Fper%2Finteger.hpp;h=0000000000000000000000000000000000000000;hp=7bb93c21729a9af615a0fcd9c44ddf7cb868fb70;hb=f86662b5b6481f27e18313a36355871f3a947193;hpb=a9f02a2b5886990fd81e64f7c218c5d4844f18a3 diff --git a/e2sim/previous/e2apv1sim/ricsim/src/ASN1/asn/per/integer.hpp b/e2sim/previous/e2apv1sim/ricsim/src/ASN1/asn/per/integer.hpp deleted file mode 100755 index 7bb93c2..0000000 --- a/e2sim/previous/e2apv1sim/ricsim/src/ASN1/asn/per/integer.hpp +++ /dev/null @@ -1,154 +0,0 @@ -#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/elements.hpp" -#include "asn/per/common.hpp" -#include "asn/per/binary_integer.hpp" -#include "asn/per/whole_number.hpp" - -namespace asn { -namespace per { - -template -struct Integer; - -template -struct Integer > -{ - static void inline run(IE const& ie, EncoderCtx& ctx) - { - if(IE::constraint_t::is_extended(ie.get())) - { - ctx.refErrorCtx().valueRangeError(static_cast(ie.get())); - return; - } - ConstrainedWholeNumber::run(ctx, ie.get()); - } - static void inline run(IE& ie, DecoderCtx& ctx) - { - ie.set(ConstrainedWholeNumber::run(ctx)); - } -}; - -template -struct Integer > -{ - //X.691 12.1 - static void inline run(IE const& ie, EncoderCtx& ctx) - { - if (!IE::constraint_t::is_extended(ie.get())) - { - Tools::bit_accessor::put(0, 1, ctx.refBuffer()); - //X.691 12.2 - ConstrainedWholeNumber::run(ctx, ie.get()); - } - else - { - Tools::bit_accessor::put(1, 1, ctx.refBuffer()); - //X.691 12.2.4, 12.2.6, 10.8s - TwosComplementBinaryInteger::run(ie, ctx); - } - } - static void inline run(IE& ie, DecoderCtx& ctx) - { - - u8 ext = Tools::bit_accessor::get(1, ctx.refBuffer()); - if (ext) - TwosComplementBinaryInteger::run(ie, ctx); - else - ie.set(ConstrainedWholeNumber::run(ctx)); - } -}; - -// (X.691 10.7) -template -struct Integer > -{ - static void inline run(IE const& ie, EncoderCtx& ctx) - { - if(IE::constraint_t::is_extended(ie.get())) - { - ctx.refErrorCtx().valueRangeError(static_cast(ie.get())); - return; - } - NonnegativeBinaryInteger::run(ie.get() - IE::constraint_t::lower_bound, ctx); - } - static void inline run(IE& ie, DecoderCtx& ctx) - { - typename IE::value_type val = 0; - NonnegativeBinaryInteger::run(val, ctx, false); - ie.set(IE::constraint_t::lower_bound + val); - } -}; - -template -struct Integer > -{ - static void inline run(IE const& ie, EncoderCtx& ctx) - { - if (!IE::constraint_t::is_extended(ie.get())) - { - Tools::bit_accessor::put(0, 1, ctx.refBuffer()); - NonnegativeBinaryInteger::run(ie.get() - IE::constraint_t::lower_bound, ctx); - } - else - { - Tools::bit_accessor::put(1, 1, ctx.refBuffer()); - TwosComplementBinaryInteger::run(ie, ctx); - } - } - static void inline run(IE& ie, DecoderCtx& ctx) - { - u8 ext = Tools::bit_accessor::get(1, ctx.refBuffer()); - - if (ext) - TwosComplementBinaryInteger::run(ie, ctx); - else - { - typename IE::value_type val = 0; - NonnegativeBinaryInteger::run(val, ctx, false); - ie.set(val + IE::constraint_t::lower_bound); - } - } -}; - -/*************************************************************************************** -* Encoding of an unconstrained whole number (X.691 10.8) -***************************************************************************************/ - -template -struct Integer > -{ - static void inline run(IE const& ie, EncoderCtx& ctx) - { - TwosComplementBinaryInteger::run(ie, ctx); - } - static void inline run(IE& ie, DecoderCtx& ctx) - { - TwosComplementBinaryInteger::run(ie, ctx); - } -}; - -} //namespace per -} //namespace asn -