annotate dmdscript_tango/dmath.d @ 3:8363a4bf6a8f

rename package: dmdscript to dmdscript_tango
author saaadel
date Sun, 24 Jan 2010 18:33:05 +0200
parents 55c2951c07be
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
1
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
2 /* Digital Mars DMDScript source code.
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
3 * Copyright (c) 2000-2002 by Chromium Communications
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
4 * D version Copyright (c) 2004-2005 by Digital Mars
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
5 * All Rights Reserved
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
6 * written by Walter Bright
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
7 * www.digitalmars.com
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
8 * Use at your own risk. There is no warranty, express or implied.
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
9 * License for redistribution is by the GNU General Public License in gpl.txt.
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
10 *
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
11 * A binary, non-exclusive license for commercial use can be
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
12 * purchased from www.digitalmars.com/dscript/buy.html.
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
13 *
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
14 * DMDScript is implemented in the D Programming Language,
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
15 * www.digitalmars.com/d/
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
16 *
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
17 * For a C++ implementation of DMDScript, including COM support,
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
18 * see www.digitalmars.com/dscript/cppscript.html.
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
19 */
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
20
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
21
3
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
22 module dmdscript_tango.dmath;
0
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
23
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
24 import std.math;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
25 import std.random;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
26
3
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
27 import dmdscript_tango.script;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
28 import dmdscript_tango.value;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
29 import dmdscript_tango.dobject;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
30 import dmdscript_tango.dnative;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
31 import dmdscript_tango.threadcontext;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
32 import dmdscript_tango.text;
8363a4bf6a8f rename package: dmdscript to dmdscript_tango
saaadel
parents: 0
diff changeset
33 import dmdscript_tango.property;
0
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
34
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
35 d_number math_helper(Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
36 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
37 Value *v;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
38
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
39 v = arglist.length ? &arglist[0] : &vundefined;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
40 return v.toNumber();
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
41 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
42
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
43 void* Dmath_abs(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
44 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
45 // ECMA 15.8.2.1
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
46 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
47
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
48 result = fabs(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
49 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
50 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
51 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
52
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
53 void* Dmath_acos(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
54 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
55 // ECMA 15.8.2.2
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
56 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
57
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
58 result = acos(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
59 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
60 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
61 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
62
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
63 void* Dmath_asin(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
64 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
65 // ECMA 15.8.2.3
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
66 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
67
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
68 result = asin(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
69 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
70 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
71 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
72
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
73 void* Dmath_atan(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
74 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
75 // ECMA 15.8.2.4
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
76 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
77
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
78 result = atan(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
79 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
80 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
81 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
82
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
83 void* Dmath_atan2(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
84 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
85 // ECMA 15.8.2.5
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
86 d_number n1;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
87 Value *v2;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
88 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
89
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
90 n1 = math_helper(arglist);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
91 v2 = (arglist.length >= 2) ? &arglist[1] : &vundefined;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
92 result = atan2(n1, v2.toNumber());
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
93 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
94 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
95 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
96
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
97 void* Dmath_ceil(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
98 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
99 // ECMA 15.8.2.6
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
100 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
101
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
102 result = ceil(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
103 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
104 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
105 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
106
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
107 void* Dmath_cos(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
108 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
109 // ECMA 15.8.2.7
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
110 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
111
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
112 result = cos(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
113 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
114 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
115 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
116
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
117 void* Dmath_exp(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
118 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
119 // ECMA 15.8.2.8
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
120 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
121
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
122 result = std.math.exp(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
123 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
124 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
125 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
126
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
127 void* Dmath_floor(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
128 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
129 // ECMA 15.8.2.9
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
130 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
131
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
132 result = std.math.floor(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
133 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
134 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
135 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
136
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
137 void* Dmath_log(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
138 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
139 // ECMA 15.8.2.10
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
140 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
141
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
142 result = log(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
143 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
144 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
145 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
146
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
147 void* Dmath_max(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
148 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
149 // ECMA v3 15.8.2.11
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
150 d_number n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
151 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
152 uint a;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
153
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
154 result = -d_number.infinity;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
155 foreach (Value v; arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
156 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
157 n = v.toNumber();
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
158 if (isnan(n))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
159 { result = d_number.nan;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
160 break;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
161 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
162 if (result == n)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
163 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
164 // if n is +0 and result is -0, pick n
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
165 if (n == 0 && !signbit(n))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
166 result = n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
167 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
168 else if (n > result)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
169 result = n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
170 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
171 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
172 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
173 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
174
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
175 void* Dmath_min(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
176 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
177 // ECMA v3 15.8.2.12
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
178 d_number n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
179 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
180 uint a;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
181
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
182 result = d_number.infinity;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
183 foreach (Value v; arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
184 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
185 n = v.toNumber();
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
186 if (isnan(n))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
187 { result = d_number.nan;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
188 break;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
189 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
190 if (result == n)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
191 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
192 // if n is -0 and result is +0, pick n
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
193 if (n == 0 && signbit(n))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
194 result = n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
195 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
196 else if (n < result)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
197 result = n;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
198 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
199 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
200 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
201 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
202
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
203 void* Dmath_pow(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
204 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
205 // ECMA 15.8.2.13
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
206 d_number n1;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
207 Value *v2;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
208 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
209
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
210 n1 = math_helper(arglist);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
211 v2 = (arglist.length >= 2) ? &arglist[1] : &vundefined;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
212 result = pow(n1, v2.toNumber());
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
213 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
214 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
215 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
216
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
217 void* Dmath_random(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
218 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
219 // ECMA 15.8.2.14
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
220 // 0.0 <= result < 1.0
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
221 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
222
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
223 ulong x;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
224
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
225 // Only want 53 bits of precision
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
226 x = (cast(ulong)std.random.rand() << 32) + std.random.rand();
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
227 //PRINTF("x = x%016llx\n",x);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
228 x &= 0xFFFFFFFFFFFFF800L;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
229 result = x * (1 / (0x100000000L * cast(double)0x100000000L))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
230 + (1 / (0x200000000L * cast(double)0x100000000L));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
231
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
232 // Experiments on linux show that this will never be exactly
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
233 // 1.0, so is the assert() worth it?
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
234 assert(result >= 0 && result < 1.0);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
235 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
236 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
237 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
238
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
239 void* Dmath_round(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
240 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
241 // ECMA 15.8.2.15
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
242 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
243
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
244 result = math_helper(arglist);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
245 if (!isnan(result))
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
246 result = copysign(std.math.floor(result + .5), result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
247 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
248 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
249 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
250
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
251 void* Dmath_sin(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
252 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
253 // ECMA 15.8.2.16
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
254 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
255
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
256 result = sin(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
257 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
258 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
259 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
260
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
261 void* Dmath_sqrt(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
262 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
263 // ECMA 15.8.2.17
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
264 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
265
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
266 result = sqrt(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
267 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
268 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
269 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
270
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
271 void* Dmath_tan(Dobject pthis, CallContext *cc, Dobject othis, Value* ret, Value[] arglist)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
272 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
273 // ECMA 15.8.2.18
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
274 d_number result;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
275
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
276 result = tan(math_helper(arglist));
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
277 ret.putVnumber(result);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
278 return null;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
279 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
280
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
281 /* ===================== Dmath ==================== */
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
282
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
283 class Dmath : Dobject
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
284 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
285 this(ThreadContext *tc)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
286 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
287 super(tc.Dobject_prototype);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
288
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
289 //writef("Dmath::Dmath(%x)\n", this);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
290 uint attributes = DontEnum | DontDelete | ReadOnly;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
291
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
292 struct MathConst
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
293 { d_string *name;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
294 d_number value;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
295 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
296
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
297 static MathConst table[] =
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
298 [
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
299 { &TEXT_E, std.math.E },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
300 { &TEXT_LN10, std.math.LN10 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
301 { &TEXT_LN2, std.math.LN2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
302 { &TEXT_LOG2E, std.math.LOG2E },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
303 { &TEXT_LOG10E, std.math.LOG10E },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
304 { &TEXT_PI, std.math.PI },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
305 { &TEXT_SQRT1_2, std.math.SQRT1_2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
306 { &TEXT_SQRT2, std.math.SQRT2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
307 ];
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
308
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
309 for (size_t u = 0; u < table.length; u++)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
310 { Value *v;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
311
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
312 v = Put(*table[u].name, table[u].value, attributes);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
313 //writef("Put(%s,%.5g) = %x\n", *table[u].name, table[u].value, v);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
314 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
315
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
316 classname = TEXT_Math;
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
317
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
318 static NativeFunctionData nfd[] =
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
319 [
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
320 { &TEXT_abs, &Dmath_abs, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
321 { &TEXT_acos, &Dmath_acos, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
322 { &TEXT_asin, &Dmath_asin, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
323 { &TEXT_atan, &Dmath_atan, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
324 { &TEXT_atan2, &Dmath_atan2, 2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
325 { &TEXT_ceil, &Dmath_ceil, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
326 { &TEXT_cos, &Dmath_cos, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
327 { &TEXT_exp, &Dmath_exp, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
328 { &TEXT_floor, &Dmath_floor, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
329 { &TEXT_log, &Dmath_log, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
330 { &TEXT_max, &Dmath_max, 2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
331 { &TEXT_min, &Dmath_min, 2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
332 { &TEXT_pow, &Dmath_pow, 2 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
333 { &TEXT_random, &Dmath_random, 0 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
334 { &TEXT_round, &Dmath_round, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
335 { &TEXT_sin, &Dmath_sin, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
336 { &TEXT_sqrt, &Dmath_sqrt, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
337 { &TEXT_tan, &Dmath_tan, 1 },
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
338 ];
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
339
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
340 DnativeFunction.init(this, nfd, attributes);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
341 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
342
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
343 static void init(ThreadContext *tc)
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
344 {
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
345 tc.Dmath_object = new Dmath(tc);
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
346 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
347 }
55c2951c07be initial, files origin, premoved tree
saaadel
parents:
diff changeset
348