LCOV - code coverage report
Current view: top level - nix/store/14c6s4xzhy14i2b05s00rjns2j93gzz4-gcc-13.2.0/include/c++/13.2.0/bits - std_abs.h (source / functions) Hit Total Coverage
Test: coverage.info.cleaned Lines: 2 2 100.0 %
Date: 1980-01-01 00:00:00 Functions: 1 1 100.0 %
Branches: 0 0 -

           Branch data     Line data    Source code
       1                 :            : // -*- C++ -*- C library enhancements header.
       2                 :            : 
       3                 :            : // Copyright (C) 2016-2023 Free Software Foundation, Inc.
       4                 :            : //
       5                 :            : // This file is part of the GNU ISO C++ Library.  This library is free
       6                 :            : // software; you can redistribute it and/or modify it under the
       7                 :            : // terms of the GNU General Public License as published by the
       8                 :            : // Free Software Foundation; either version 3, or (at your option)
       9                 :            : // any later version.
      10                 :            : 
      11                 :            : // This library is distributed in the hope that it will be useful,
      12                 :            : // but WITHOUT ANY WARRANTY; without even the implied warranty of
      13                 :            : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      14                 :            : // GNU General Public License for more details.
      15                 :            : 
      16                 :            : // Under Section 7 of GPL version 3, you are granted additional
      17                 :            : // permissions described in the GCC Runtime Library Exception, version
      18                 :            : // 3.1, as published by the Free Software Foundation.
      19                 :            : 
      20                 :            : // You should have received a copy of the GNU General Public License and
      21                 :            : // a copy of the GCC Runtime Library Exception along with this program;
      22                 :            : // see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
      23                 :            : // <http://www.gnu.org/licenses/>.
      24                 :            : 
      25                 :            : /** @file include/bits/std_abs.h
      26                 :            :  *  This is an internal header file, included by other library headers.
      27                 :            :  *  Do not attempt to use it directly. @headername{cmath, cstdlib}
      28                 :            :  */
      29                 :            : 
      30                 :            : #ifndef _GLIBCXX_BITS_STD_ABS_H
      31                 :            : #define _GLIBCXX_BITS_STD_ABS_H
      32                 :            : 
      33                 :            : #pragma GCC system_header
      34                 :            : 
      35                 :            : #include <bits/c++config.h>
      36                 :            : 
      37                 :            : #define _GLIBCXX_INCLUDE_NEXT_C_HEADERS
      38                 :            : #include_next <stdlib.h>
      39                 :            : #ifdef __CORRECT_ISO_CPP_MATH_H_PROTO
      40                 :            : # include_next <math.h>
      41                 :            : #endif
      42                 :            : #undef _GLIBCXX_INCLUDE_NEXT_C_HEADERS
      43                 :            : 
      44                 :            : #undef abs
      45                 :            : 
      46                 :            : extern "C++"
      47                 :            : {
      48                 :            : namespace std _GLIBCXX_VISIBILITY(default)
      49                 :            : {
      50                 :            : _GLIBCXX_BEGIN_NAMESPACE_VERSION
      51                 :            : 
      52                 :            :   using ::abs;
      53                 :            : 
      54                 :            : #ifndef __CORRECT_ISO_CPP_STDLIB_H_PROTO
      55                 :            :   inline long
      56                 :            :   abs(long __i) { return __builtin_labs(__i); }
      57                 :            : #endif
      58                 :            : 
      59                 :            : #ifdef _GLIBCXX_USE_LONG_LONG
      60                 :            :   inline long long
      61                 :            :   abs(long long __x) { return __builtin_llabs (__x); }
      62                 :            : #endif
      63                 :            : 
      64                 :            : // _GLIBCXX_RESOLVE_LIB_DEFECTS
      65                 :            : // 2192. Validity and return type of std::abs(0u) is unclear
      66                 :            : // 2294. <cstdlib> should declare abs(double)
      67                 :            : // 2735. std::abs(short), std::abs(signed char) and others should return int
      68                 :            : 
      69                 :            : #ifndef __CORRECT_ISO_CPP_MATH_H_PROTO
      70                 :            :   inline _GLIBCXX_CONSTEXPR double
      71                 :        153 :   abs(double __x)
      72                 :        153 :   { return __builtin_fabs(__x); }
      73                 :            : 
      74                 :            :   inline _GLIBCXX_CONSTEXPR float
      75                 :            :   abs(float __x)
      76                 :            :   { return __builtin_fabsf(__x); }
      77                 :            : 
      78                 :            :   inline _GLIBCXX_CONSTEXPR long double
      79                 :            :   abs(long double __x)
      80                 :            :   { return __builtin_fabsl(__x); }
      81                 :            : #endif
      82                 :            : 
      83                 :            : #if defined(__GLIBCXX_TYPE_INT_N_0)
      84                 :            :   __extension__ inline _GLIBCXX_CONSTEXPR __GLIBCXX_TYPE_INT_N_0
      85                 :            :   abs(__GLIBCXX_TYPE_INT_N_0 __x) { return __x >= 0 ? __x : -__x; }
      86                 :            : #endif
      87                 :            : #if defined(__GLIBCXX_TYPE_INT_N_1)
      88                 :            :   __extension__ inline _GLIBCXX_CONSTEXPR __GLIBCXX_TYPE_INT_N_1
      89                 :            :   abs(__GLIBCXX_TYPE_INT_N_1 __x) { return __x >= 0 ? __x : -__x; }
      90                 :            : #endif
      91                 :            : #if defined(__GLIBCXX_TYPE_INT_N_2)
      92                 :            :   __extension__ inline _GLIBCXX_CONSTEXPR __GLIBCXX_TYPE_INT_N_2
      93                 :            :   abs(__GLIBCXX_TYPE_INT_N_2 __x) { return __x >= 0 ? __x : -__x; }
      94                 :            : #endif
      95                 :            : #if defined(__GLIBCXX_TYPE_INT_N_3)
      96                 :            :   __extension__ inline _GLIBCXX_CONSTEXPR __GLIBCXX_TYPE_INT_N_3
      97                 :            :   abs(__GLIBCXX_TYPE_INT_N_3 __x) { return __x >= 0 ? __x : -__x; }
      98                 :            : #endif
      99                 :            : 
     100                 :            : #if defined(__STDCPP_FLOAT16_T__) && defined(_GLIBCXX_FLOAT_IS_IEEE_BINARY32)
     101                 :            :   constexpr _Float16
     102                 :            :   abs(_Float16 __x)
     103                 :            :   { return _Float16(__builtin_fabsf(__x)); }
     104                 :            : #endif
     105                 :            : 
     106                 :            : #if defined(__STDCPP_FLOAT32_T__) && defined(_GLIBCXX_FLOAT_IS_IEEE_BINARY32)
     107                 :            :   constexpr _Float32
     108                 :            :   abs(_Float32 __x)
     109                 :            :   { return __builtin_fabsf(__x); }
     110                 :            : #endif
     111                 :            : 
     112                 :            : #if defined(__STDCPP_FLOAT64_T__) && defined(_GLIBCXX_DOUBLE_IS_IEEE_BINARY64)
     113                 :            :   constexpr _Float64
     114                 :            :   abs(_Float64 __x)
     115                 :            :   { return __builtin_fabs(__x); }
     116                 :            : #endif
     117                 :            : 
     118                 :            : #if defined(__STDCPP_FLOAT128_T__) && defined(_GLIBCXX_LDOUBLE_IS_IEEE_BINARY128)
     119                 :            :   constexpr _Float128
     120                 :            :   abs(_Float128 __x)
     121                 :            :   { return __builtin_fabsl(__x); }
     122                 :            : #elif defined(__STDCPP_FLOAT128_T__) && defined(_GLIBCXX_HAVE_FLOAT128_MATH)
     123                 :            :   constexpr _Float128
     124                 :            :   abs(_Float128 __x)
     125                 :            :   { return __builtin_fabsf128(__x); }
     126                 :            : #endif
     127                 :            : 
     128                 :            : #if defined(__STDCPP_BFLOAT16_T__) && defined(_GLIBCXX_FLOAT_IS_IEEE_BINARY32)
     129                 :            :   constexpr __gnu_cxx::__bfloat16_t
     130                 :            :   abs(__gnu_cxx::__bfloat16_t __x)
     131                 :            :   { return __gnu_cxx::__bfloat16_t(__builtin_fabsf(__x)); }
     132                 :            : #endif
     133                 :            : 
     134                 :            : #if !defined(__STRICT_ANSI__) && defined(_GLIBCXX_USE_FLOAT128)
     135                 :            :   __extension__ inline _GLIBCXX_CONSTEXPR
     136                 :            :   __float128
     137                 :            :   abs(__float128 __x)
     138                 :            :   {
     139                 :            : #if defined(_GLIBCXX_LDOUBLE_IS_IEEE_BINARY128)
     140                 :            :     return __builtin_fabsl(__x);
     141                 :            : #elif defined(_GLIBCXX_HAVE_FLOAT128_MATH)
     142                 :            :     return __builtin_fabsf128(__x);
     143                 :            : #else
     144                 :            :     // Assume that __builtin_signbit works for __float128.
     145                 :            :     return __builtin_signbit(__x) ? -__x : __x;
     146                 :            : #endif
     147                 :            :   }
     148                 :            : #endif
     149                 :            : 
     150                 :            : _GLIBCXX_END_NAMESPACE_VERSION
     151                 :            : } // namespace
     152                 :            : } // extern "C++"
     153                 :            : 
     154                 :            : #endif // _GLIBCXX_BITS_STD_ABS_H

Generated by: LCOV version 1.0