Branch data Line data Source code
1 : : /* 2 : : * ----------------- BEGIN LICENSE BLOCK --------------------------------- 3 : : * 4 : : * Copyright (C) 2018-2020 Intel Corporation 5 : : * 6 : : * SPDX-License-Identifier: MIT 7 : : * 8 : : * ----------------- END LICENSE BLOCK ----------------------------------- 9 : : */ 10 : : 11 : : /** 12 : : * Generated file 13 : : * @file 14 : : * 15 : : * Generator Version : 11.0.0-1997 16 : : */ 17 : : 18 : : #pragma once 19 : : 20 : : #include <cmath> 21 : : #include <limits> 22 : : #include "ad/physics/Angle.hpp" 23 : : #include "spdlog/fmt/ostr.h" 24 : : #include "spdlog/spdlog.h" 25 : : 26 : : /*! 27 : : * \brief check if the given Angle is within valid input range 28 : : * 29 : : * \param[in] input the Angle as an input value 30 : : * \param[in] logErrors enables error logging 31 : : * 32 : : * \returns \c true if Angle is considered to be within the specified input range 33 : : * 34 : : * \note the specified input range is defined by 35 : : * std::numeric_limits<::ad::physics::Angle>::lowest() <= \c input <= 36 : : * std::numeric_limits<::ad::physics::Angle>::max() 37 : : * -6.283185308 <= \c input <= 6.283185308 38 : : */ 39 : 20 : inline bool withinValidInputRange(::ad::physics::Angle const &input, bool const logErrors = true) 40 : : { 41 : : // check for generic numeric limits of the type 42 [ + - + - ]: 38 : bool inValidInputRange = input.isValid() && (std::numeric_limits<::ad::physics::Angle>::lowest() <= input) 43 [ + + + - : 38 : && (input <= std::numeric_limits<::ad::physics::Angle>::max()); + - ] 44 [ + + + - ]: 20 : if (!inValidInputRange && logErrors) 45 : : { 46 [ + - ]: 2 : spdlog::error("withinValidInputRange(::ad::physics::Angle)>> {} out of numerical limits [{}, {}]", 47 : : input, 48 : 2 : std::numeric_limits<::ad::physics::Angle>::lowest(), 49 : 4 : std::numeric_limits<::ad::physics::Angle>::max()); // LCOV_EXCL_BR_LINE 50 : : } 51 : : // check for individual input range 52 [ + + ]: 20 : if (inValidInputRange) 53 : : { 54 [ + - + + : 18 : inValidInputRange = (::ad::physics::Angle(-6.283185308) <= input) && (input <= ::ad::physics::Angle(6.283185308)); + - + + ] 55 [ + + + - ]: 18 : if (!inValidInputRange && logErrors) 56 : : { 57 [ + - ]: 9 : spdlog::error("withinValidInputRange(::ad::physics::Angle)>> {} out of valid input range [{}, {}]", 58 : : input, 59 : 9 : ::ad::physics::Angle(-6.283185308), 60 : 18 : ::ad::physics::Angle(6.283185308)); // LCOV_EXCL_BR_LINE 61 : : } 62 : : } 63 : 20 : return inValidInputRange; 64 : : }