Initial commit of the 'release' directory (splash screen/icon
[blender.git] / release / plugins / include / floatpatch.h
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. The Blender
10  * Foundation also sells licenses for use in proprietary software under
11  * the Blender License.  See http://www.blender.org/BL/ for information
12  * about this.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software Foundation,
21  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  *
23  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
24  * All rights reserved.
25  *
26  * The Original Code is: all of this file.
27  *
28  * Contributor(s): none yet.
29  *
30  * ***** END GPL/BL DUAL LICENSE BLOCK *****
31  */
32
33 #ifndef FLOATPATCH_H
34 #define FLOATPATCH_H
35
36 /* floating point libs differ at systems... with these defines it comilies at all! */
37
38 #ifdef MIPS1
39 #else
40
41 #define fabsf(a)        fabs((double)(a))
42
43 #define facos           acosf
44 #define acosf(a)        acos((double)(a))
45
46 #define fasin           asinf
47 #define asinf(a)        asin((double)(a))
48
49 #define fatan           atanf
50 #define atanf(a)        atan((double)(a))
51
52 #define fatan2                  atan2f
53 #define atan2f(a, b)    atan2((double)(a), (double)(b))
54
55 #define fmodf(a, b)             fmod((double)(a), (double)(b))
56
57 #define fcos            cosf
58 #define cosf(a)         cos((double)(a))
59
60 #define fsin            sinf
61 #define sinf(a)         sin((double)(a))
62
63 #define ftan            tanf
64 #define tanf(a)         tan((double)(a))
65
66 #define fexp            expf
67 #define expf(a)         exp((double)(a))
68
69 #define flog            logf
70 #define logf(a)         log((double)(a))
71
72 #define flog10          log10f
73 #define log10f(a)       log10((double)(a))
74
75 #define fsqrt           sqrtf
76 #define sqrtf(a)        sqrt((double)(a))
77
78 #define fceil           ceilf
79 #define ceilf(a)        ceil((double)(a))
80
81 #define ffloor          floorf
82 #define floorf(a)       floor((double)(a))
83
84 #define fpow            powf
85 #define powf(a, b)      pow((double)(a), (double)(b))
86
87 /* #endif  */
88
89 #endif
90
91 #endif /* FLOATPATCH_H */
92