LibreOffice
LibreOffice 24.2 SDK C/C++ API Reference
mathconf.h
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  * Licensed to the Apache Software Foundation (ASF) under one or more
12  * contributor license agreements. See the NOTICE file distributed
13  * with this work for additional information regarding copyright
14  * ownership. The ASF licenses this file to you under the Apache
15  * License, Version 2.0 (the "License"); you may not use this file
16  * except in compliance with the License. You may obtain a copy of
17  * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 
20 /*
21  * This file is part of LibreOffice published API.
22  */
23 
24 #ifndef INCLUDED_SAL_MATHCONF_H
25 #define INCLUDED_SAL_MATHCONF_H
26 
27 #include "osl/endian.h"
28 
29 #if defined __sun
30 #include <ieeefp.h>
31 #endif /* __sun */
32 
33 #if defined(__cplusplus) && ( defined(__GXX_EXPERIMENTAL_CXX0X__) || __cplusplus >= 201103L )
34 #include <cmath>
35 #endif
36 
37 #if defined(IOS)
38 #if defined(__cplusplus)
39 #include <cmath>
40 #else
41 #include <math.h>
42 #endif
43 #endif
44 
45 #if defined __cplusplus
46 extern "C" {
47 #endif /* __cplusplus */
48 
49 
50 /* Generally, the C standard guarantees that at program startup, "trapping or
51  stopping (if supported) is disabled on all [floating-point] exceptions"
52  (F.7.3/1 of the August 3, 1998 draft of C99), and that during program
53  execution, "a programmer can safely assume default modes (or be unaware of
54  them)" (7.6/2, footnote 161 of the August 3, 1998 draft of C99). Reportedly,
55  on Windows there are printer drivers that switch on exceptions. To avoid
56  problems, the SAL_MATH_FPEXCEPTIONS_OFF macro can be used to explicitly
57  switch off exceptions (on Windows).
58  */
59 #if defined(_WIN32)
60 #define SAL_MATH_FPEXCEPTIONS_OFF() _control87( _MCW_EM, _MCW_EM )
61 #else /* WNT */
62 #define SAL_MATH_FPEXCEPTIONS_OFF()
63 #endif /* WNT */
64 
65 
66 /* SAL_MATH_FINITE(d): test double d on INFINITY, NaN et al. */
67 #if !defined __sun && !defined ANDROID \
68  && defined(__cplusplus) \
69  && ( defined(__GXX_EXPERIMENTAL_CXX0X__) \
70  || __cplusplus >= 201103L \
71  || defined(IOS) )
72 #define SAL_MATH_FINITE(d) std::isfinite(d)
73 #elif defined __APPLE__ && !(defined __i386__ || defined __x86_64__)
74 #define SAL_MATH_FINITE(d) isfinite(d)
75 #elif defined(_WIN32)
76 #define SAL_MATH_FINITE(d) _finite(d)
77 #elif defined(ANDROID) || defined LINUX || defined UNX
78 #define SAL_MATH_FINITE(d) finite(d)
79 #else /* WNT, LINUX, UNX */
80 #error "SAL_MATH_FINITE not defined"
81 #endif /* WNT, LINUX, UNX */
82 
83 
84 /* This needs to be fixed for non--IEEE-754 platforms: */
85 #if 1 /* IEEE 754 supported */
86 #if defined OSL_BIGENDIAN
87 
88 /* IEEE 754 double structures for BigEndian */
89 union sal_math_Double
90 {
91  struct
92  {
93  unsigned sign : 1;
94  unsigned exponent :11;
95  unsigned fraction_hi :20;
96  unsigned fraction_lo :32;
97  } inf_parts;
98  struct
99  {
100  unsigned sign : 1;
101  unsigned exponent :11;
102  unsigned qnan_bit : 1;
103  unsigned bits :19;
104  unsigned fraction_lo :32;
105  } nan_parts;
106  struct
107  {
108  unsigned msw :32;
109  unsigned lsw :32;
110  } w32_parts;
111  struct
112  {
113  sal_uInt64 sign : 1;
114  sal_uInt64 exponent :11;
115  sal_uInt64 fraction :52;
116  } parts;
117  sal_uInt64 intrep;
118  double value;
119 };
120 
121 #elif defined OSL_LITENDIAN
122 
123 /* IEEE 754 double structures for LittleEndian */
124 union sal_math_Double
125 {
126  struct {
127  unsigned fraction_lo :32;
128  unsigned fraction_hi :20;
129  unsigned exponent :11;
130  unsigned sign : 1;
131  } inf_parts;
132  struct {
133  unsigned fraction_lo :32;
134  unsigned bits :19;
135  unsigned qnan_bit : 1;
136  unsigned exponent :11;
137  unsigned sign : 1;
138  } nan_parts;
139  struct
140  {
141  unsigned lsw :32;
142  unsigned msw :32;
143  } w32_parts;
144  struct
145  {
146  sal_uInt64 fraction :52;
147  sal_uInt64 exponent :11;
148  sal_uInt64 sign : 1;
149  } parts;
150  sal_uInt64 intrep;
151  double value;
152 };
153 
154 #else /* OSL_BIGENDIAN, OSL_LITENDIAN */
155 
156 #error "neither OSL_BIGENDIAN nor OSL_LITENDIAN"
157 
158 #endif /* OSL_BIGENDIAN, OSL_LITENDIAN */
159 #else /* IEEE 754 supported */
160 
161 #error "don't know how to handle IEEE 754"
162 
163 #endif /* IEEE 754 supported */
164 
165 
166 #if defined __cplusplus
167 }
168 #endif /* __cplusplus */
169 
170 #endif /* INCLUDED_SAL_MATHCONF_H */
171 
172 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */