jbarnette-johnson 1.0.0.200806240111 → 1.0.0.200807291507
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/MANIFEST +1 -0
- data/Rakefile +3 -10
- data/bin/johnson +2 -1
- data/ext/spidermonkey/context.c +3 -4
- data/ext/spidermonkey/context.h +1 -1
- data/ext/spidermonkey/conversions.c +39 -33
- data/ext/spidermonkey/debugger.c +5 -5
- data/ext/spidermonkey/immutable_node.c.erb +11 -11
- data/ext/spidermonkey/jroot.h +4 -4
- data/ext/spidermonkey/js_land_proxy.c +9 -8
- data/ext/spidermonkey/ruby_land_proxy.c +5 -4
- data/ext/spidermonkey/runtime.c +1 -1
- data/johnson.gemspec +36 -0
- data/lib/hoe.rb +0 -7
- data/lib/johnson/cli/options.rb +10 -4
- data/lib/johnson/spidermonkey/runtime.rb +2 -2
- data/lib/johnson/version.rb +4 -2
- data/lib/johnson.rb +1 -0
- data/test/johnson/runtime_test.rb +11 -0
- data/test/johnson/spidermonkey/ruby_land_proxy_test.rb +6 -0
- data/vendor/spidermonkey/.cvsignore +9 -0
- data/vendor/spidermonkey/Makefile.in +462 -0
- data/vendor/spidermonkey/Makefile.ref +364 -0
- data/vendor/spidermonkey/README.html +820 -0
- data/vendor/spidermonkey/SpiderMonkey.rsp +12 -0
- data/vendor/spidermonkey/Y.js +19 -0
- data/vendor/spidermonkey/build.mk +43 -0
- data/vendor/spidermonkey/config/AIX4.1.mk +65 -0
- data/vendor/spidermonkey/config/AIX4.2.mk +64 -0
- data/vendor/spidermonkey/config/AIX4.3.mk +65 -0
- data/vendor/spidermonkey/config/Darwin.mk +83 -0
- data/vendor/spidermonkey/config/Darwin1.3.mk +81 -0
- data/vendor/spidermonkey/config/Darwin1.4.mk +41 -0
- data/vendor/spidermonkey/config/Darwin5.2.mk +81 -0
- data/vendor/spidermonkey/config/Darwin5.3.mk +81 -0
- data/vendor/spidermonkey/config/HP-UXB.10.10.mk +77 -0
- data/vendor/spidermonkey/config/HP-UXB.10.20.mk +77 -0
- data/vendor/spidermonkey/config/HP-UXB.11.00.mk +80 -0
- data/vendor/spidermonkey/config/IRIX.mk +87 -0
- data/vendor/spidermonkey/config/IRIX5.3.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.1.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.2.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.3.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.5.mk +44 -0
- data/vendor/spidermonkey/config/Linux_All.mk +103 -0
- data/vendor/spidermonkey/config/Mac_OS10.0.mk +82 -0
- data/vendor/spidermonkey/config/OSF1V4.0.mk +72 -0
- data/vendor/spidermonkey/config/OSF1V5.0.mk +69 -0
- data/vendor/spidermonkey/config/SunOS4.1.4.mk +101 -0
- data/vendor/spidermonkey/config/SunOS5.10.mk +50 -0
- data/vendor/spidermonkey/config/SunOS5.3.mk +91 -0
- data/vendor/spidermonkey/config/SunOS5.4.mk +92 -0
- data/vendor/spidermonkey/config/SunOS5.5.1.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.5.mk +87 -0
- data/vendor/spidermonkey/config/SunOS5.6.mk +89 -0
- data/vendor/spidermonkey/config/SunOS5.7.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.8.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.9.mk +44 -0
- data/vendor/spidermonkey/config/WINNT4.0.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.0.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.1.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.2.mk +117 -0
- data/vendor/spidermonkey/config/WINNT6.0.mk +117 -0
- data/vendor/spidermonkey/config/dgux.mk +64 -0
- data/vendor/spidermonkey/config.mk +192 -0
- data/vendor/spidermonkey/editline/Makefile.ref +144 -0
- data/vendor/spidermonkey/editline/README +83 -0
- data/vendor/spidermonkey/editline/editline.3 +175 -0
- data/vendor/spidermonkey/editline/editline.c +1369 -0
- data/vendor/spidermonkey/editline/editline.h +135 -0
- data/vendor/spidermonkey/editline/sysunix.c +182 -0
- data/vendor/spidermonkey/editline/unix.h +82 -0
- data/vendor/spidermonkey/fdlibm/.cvsignore +7 -0
- data/vendor/spidermonkey/fdlibm/Makefile.in +127 -0
- data/vendor/spidermonkey/fdlibm/Makefile.ref +192 -0
- data/vendor/spidermonkey/fdlibm/e_acos.c +147 -0
- data/vendor/spidermonkey/fdlibm/e_acosh.c +105 -0
- data/vendor/spidermonkey/fdlibm/e_asin.c +156 -0
- data/vendor/spidermonkey/fdlibm/e_atan2.c +165 -0
- data/vendor/spidermonkey/fdlibm/e_atanh.c +110 -0
- data/vendor/spidermonkey/fdlibm/e_cosh.c +133 -0
- data/vendor/spidermonkey/fdlibm/e_exp.c +202 -0
- data/vendor/spidermonkey/fdlibm/e_fmod.c +184 -0
- data/vendor/spidermonkey/fdlibm/e_gamma.c +71 -0
- data/vendor/spidermonkey/fdlibm/e_gamma_r.c +70 -0
- data/vendor/spidermonkey/fdlibm/e_hypot.c +173 -0
- data/vendor/spidermonkey/fdlibm/e_j0.c +524 -0
- data/vendor/spidermonkey/fdlibm/e_j1.c +523 -0
- data/vendor/spidermonkey/fdlibm/e_jn.c +315 -0
- data/vendor/spidermonkey/fdlibm/e_lgamma.c +71 -0
- data/vendor/spidermonkey/fdlibm/e_lgamma_r.c +347 -0
- data/vendor/spidermonkey/fdlibm/e_log.c +184 -0
- data/vendor/spidermonkey/fdlibm/e_log10.c +134 -0
- data/vendor/spidermonkey/fdlibm/e_pow.c +386 -0
- data/vendor/spidermonkey/fdlibm/e_rem_pio2.c +222 -0
- data/vendor/spidermonkey/fdlibm/e_remainder.c +120 -0
- data/vendor/spidermonkey/fdlibm/e_scalb.c +89 -0
- data/vendor/spidermonkey/fdlibm/e_sinh.c +122 -0
- data/vendor/spidermonkey/fdlibm/e_sqrt.c +497 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.h +273 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.mak +1453 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.mdp +0 -0
- data/vendor/spidermonkey/fdlibm/k_cos.c +135 -0
- data/vendor/spidermonkey/fdlibm/k_rem_pio2.c +354 -0
- data/vendor/spidermonkey/fdlibm/k_sin.c +114 -0
- data/vendor/spidermonkey/fdlibm/k_standard.c +785 -0
- data/vendor/spidermonkey/fdlibm/k_tan.c +170 -0
- data/vendor/spidermonkey/fdlibm/s_asinh.c +101 -0
- data/vendor/spidermonkey/fdlibm/s_atan.c +175 -0
- data/vendor/spidermonkey/fdlibm/s_cbrt.c +133 -0
- data/vendor/spidermonkey/fdlibm/s_ceil.c +120 -0
- data/vendor/spidermonkey/fdlibm/s_copysign.c +72 -0
- data/vendor/spidermonkey/fdlibm/s_cos.c +118 -0
- data/vendor/spidermonkey/fdlibm/s_erf.c +356 -0
- data/vendor/spidermonkey/fdlibm/s_expm1.c +267 -0
- data/vendor/spidermonkey/fdlibm/s_fabs.c +70 -0
- data/vendor/spidermonkey/fdlibm/s_finite.c +71 -0
- data/vendor/spidermonkey/fdlibm/s_floor.c +121 -0
- data/vendor/spidermonkey/fdlibm/s_frexp.c +99 -0
- data/vendor/spidermonkey/fdlibm/s_ilogb.c +85 -0
- data/vendor/spidermonkey/fdlibm/s_isnan.c +74 -0
- data/vendor/spidermonkey/fdlibm/s_ldexp.c +66 -0
- data/vendor/spidermonkey/fdlibm/s_lib_version.c +73 -0
- data/vendor/spidermonkey/fdlibm/s_log1p.c +211 -0
- data/vendor/spidermonkey/fdlibm/s_logb.c +79 -0
- data/vendor/spidermonkey/fdlibm/s_matherr.c +64 -0
- data/vendor/spidermonkey/fdlibm/s_modf.c +132 -0
- data/vendor/spidermonkey/fdlibm/s_nextafter.c +124 -0
- data/vendor/spidermonkey/fdlibm/s_rint.c +131 -0
- data/vendor/spidermonkey/fdlibm/s_scalbn.c +107 -0
- data/vendor/spidermonkey/fdlibm/s_signgam.c +40 -0
- data/vendor/spidermonkey/fdlibm/s_significand.c +68 -0
- data/vendor/spidermonkey/fdlibm/s_sin.c +118 -0
- data/vendor/spidermonkey/fdlibm/s_tan.c +112 -0
- data/vendor/spidermonkey/fdlibm/s_tanh.c +122 -0
- data/vendor/spidermonkey/fdlibm/w_acos.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_acosh.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_asin.c +80 -0
- data/vendor/spidermonkey/fdlibm/w_atan2.c +79 -0
- data/vendor/spidermonkey/fdlibm/w_atanh.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_cosh.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_exp.c +88 -0
- data/vendor/spidermonkey/fdlibm/w_fmod.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_gamma.c +85 -0
- data/vendor/spidermonkey/fdlibm/w_gamma_r.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_hypot.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_j0.c +105 -0
- data/vendor/spidermonkey/fdlibm/w_j1.c +106 -0
- data/vendor/spidermonkey/fdlibm/w_jn.c +128 -0
- data/vendor/spidermonkey/fdlibm/w_lgamma.c +85 -0
- data/vendor/spidermonkey/fdlibm/w_lgamma_r.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_log.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_log10.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_pow.c +99 -0
- data/vendor/spidermonkey/fdlibm/w_remainder.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_scalb.c +95 -0
- data/vendor/spidermonkey/fdlibm/w_sinh.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_sqrt.c +77 -0
- data/vendor/spidermonkey/javascript-trace.d +73 -0
- data/vendor/spidermonkey/js.c +3951 -0
- data/vendor/spidermonkey/js.mak +4438 -0
- data/vendor/spidermonkey/js.mdp +0 -0
- data/vendor/spidermonkey/js.msg +307 -0
- data/vendor/spidermonkey/js.pkg +2 -0
- data/vendor/spidermonkey/js3240.rc +79 -0
- data/vendor/spidermonkey/jsOS240.def +654 -0
- data/vendor/spidermonkey/jsapi.c +5836 -0
- data/vendor/spidermonkey/jsapi.h +2624 -0
- data/vendor/spidermonkey/jsarena.c +450 -0
- data/vendor/spidermonkey/jsarena.h +318 -0
- data/vendor/spidermonkey/jsarray.c +2988 -0
- data/vendor/spidermonkey/jsarray.h +124 -0
- data/vendor/spidermonkey/jsatom.c +1045 -0
- data/vendor/spidermonkey/jsatom.h +442 -0
- data/vendor/spidermonkey/jsbit.h +253 -0
- data/vendor/spidermonkey/jsbool.c +176 -0
- data/vendor/spidermonkey/jsbool.h +73 -0
- data/vendor/spidermonkey/jsclist.h +139 -0
- data/vendor/spidermonkey/jscntxt.c +1348 -0
- data/vendor/spidermonkey/jscntxt.h +1120 -0
- data/vendor/spidermonkey/jscompat.h +57 -0
- data/vendor/spidermonkey/jsconfig.h +248 -0
- data/vendor/spidermonkey/jsconfig.mk +181 -0
- data/vendor/spidermonkey/jscpucfg.c +383 -0
- data/vendor/spidermonkey/jscpucfg.h +212 -0
- data/vendor/spidermonkey/jsdate.c +2398 -0
- data/vendor/spidermonkey/jsdate.h +124 -0
- data/vendor/spidermonkey/jsdbgapi.c +1799 -0
- data/vendor/spidermonkey/jsdbgapi.h +464 -0
- data/vendor/spidermonkey/jsdhash.c +868 -0
- data/vendor/spidermonkey/jsdhash.h +592 -0
- data/vendor/spidermonkey/jsdtoa.c +3167 -0
- data/vendor/spidermonkey/jsdtoa.h +130 -0
- data/vendor/spidermonkey/jsdtracef.c +317 -0
- data/vendor/spidermonkey/jsdtracef.h +77 -0
- data/vendor/spidermonkey/jsemit.c +6909 -0
- data/vendor/spidermonkey/jsemit.h +741 -0
- data/vendor/spidermonkey/jsexn.c +1371 -0
- data/vendor/spidermonkey/jsexn.h +96 -0
- data/vendor/spidermonkey/jsfile.c +2736 -0
- data/vendor/spidermonkey/jsfile.h +56 -0
- data/vendor/spidermonkey/jsfile.msg +90 -0
- data/vendor/spidermonkey/jsfun.c +2634 -0
- data/vendor/spidermonkey/jsfun.h +254 -0
- data/vendor/spidermonkey/jsgc.c +3554 -0
- data/vendor/spidermonkey/jsgc.h +403 -0
- data/vendor/spidermonkey/jshash.c +476 -0
- data/vendor/spidermonkey/jshash.h +151 -0
- data/vendor/spidermonkey/jsify.pl +485 -0
- data/vendor/spidermonkey/jsinterp.c +6981 -0
- data/vendor/spidermonkey/jsinterp.h +521 -0
- data/vendor/spidermonkey/jsinvoke.c +43 -0
- data/vendor/spidermonkey/jsiter.c +1067 -0
- data/vendor/spidermonkey/jsiter.h +122 -0
- data/vendor/spidermonkey/jskeyword.tbl +124 -0
- data/vendor/spidermonkey/jskwgen.c +460 -0
- data/vendor/spidermonkey/jslibmath.h +266 -0
- data/vendor/spidermonkey/jslock.c +1309 -0
- data/vendor/spidermonkey/jslock.h +313 -0
- data/vendor/spidermonkey/jslocko.asm +60 -0
- data/vendor/spidermonkey/jslog2.c +94 -0
- data/vendor/spidermonkey/jslong.c +264 -0
- data/vendor/spidermonkey/jslong.h +412 -0
- data/vendor/spidermonkey/jsmath.c +568 -0
- data/vendor/spidermonkey/jsmath.h +57 -0
- data/vendor/spidermonkey/jsnum.c +1228 -0
- data/vendor/spidermonkey/jsnum.h +283 -0
- data/vendor/spidermonkey/jsobj.c +5266 -0
- data/vendor/spidermonkey/jsobj.h +709 -0
- data/vendor/spidermonkey/jsopcode.c +5245 -0
- data/vendor/spidermonkey/jsopcode.h +394 -0
- data/vendor/spidermonkey/jsopcode.tbl +523 -0
- data/vendor/spidermonkey/jsotypes.h +202 -0
- data/vendor/spidermonkey/jsparse.c +6680 -0
- data/vendor/spidermonkey/jsparse.h +511 -0
- data/vendor/spidermonkey/jsprf.c +1262 -0
- data/vendor/spidermonkey/jsprf.h +150 -0
- data/vendor/spidermonkey/jsproto.tbl +128 -0
- data/vendor/spidermonkey/jsprvtd.h +267 -0
- data/vendor/spidermonkey/jspubtd.h +744 -0
- data/vendor/spidermonkey/jsregexp.c +4352 -0
- data/vendor/spidermonkey/jsregexp.h +183 -0
- data/vendor/spidermonkey/jsreops.tbl +145 -0
- data/vendor/spidermonkey/jsscan.c +2003 -0
- data/vendor/spidermonkey/jsscan.h +387 -0
- data/vendor/spidermonkey/jsscope.c +1948 -0
- data/vendor/spidermonkey/jsscope.h +418 -0
- data/vendor/spidermonkey/jsscript.c +1832 -0
- data/vendor/spidermonkey/jsscript.h +287 -0
- data/vendor/spidermonkey/jsshell.msg +50 -0
- data/vendor/spidermonkey/jsstddef.h +83 -0
- data/vendor/spidermonkey/jsstr.c +5004 -0
- data/vendor/spidermonkey/jsstr.h +641 -0
- data/vendor/spidermonkey/jstypes.h +475 -0
- data/vendor/spidermonkey/jsutil.c +345 -0
- data/vendor/spidermonkey/jsutil.h +157 -0
- data/vendor/spidermonkey/jsxdrapi.c +800 -0
- data/vendor/spidermonkey/jsxdrapi.h +218 -0
- data/vendor/spidermonkey/jsxml.c +8471 -0
- data/vendor/spidermonkey/jsxml.h +349 -0
- data/vendor/spidermonkey/lock_SunOS.s +119 -0
- data/vendor/spidermonkey/perfect.js +39 -0
- data/vendor/spidermonkey/plify_jsdhash.sed +36 -0
- data/vendor/spidermonkey/prmjtime.c +846 -0
- data/vendor/spidermonkey/prmjtime.h +103 -0
- data/vendor/spidermonkey/resource.h +15 -0
- data/vendor/spidermonkey/rules.mk +197 -0
- data/vendor/spidermonkey/win32.order +384 -0
- metadata +4 -3
@@ -0,0 +1,184 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_fmod.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*/
|
51
|
+
|
52
|
+
/*
|
53
|
+
* __ieee754_fmod(x,y)
|
54
|
+
* Return x mod y in exact arithmetic
|
55
|
+
* Method: shift and subtract
|
56
|
+
*/
|
57
|
+
|
58
|
+
#include "fdlibm.h"
|
59
|
+
|
60
|
+
#ifdef __STDC__
|
61
|
+
static const double one = 1.0, Zero[] = {0.0, -0.0,};
|
62
|
+
#else
|
63
|
+
static double one = 1.0, Zero[] = {0.0, -0.0,};
|
64
|
+
#endif
|
65
|
+
|
66
|
+
#ifdef __STDC__
|
67
|
+
double __ieee754_fmod(double x, double y)
|
68
|
+
#else
|
69
|
+
double __ieee754_fmod(x,y)
|
70
|
+
double x,y ;
|
71
|
+
#endif
|
72
|
+
{
|
73
|
+
fd_twoints ux, uy;
|
74
|
+
int n,hx,hy,hz,ix,iy,sx,i;
|
75
|
+
unsigned lx,ly,lz;
|
76
|
+
|
77
|
+
ux.d = x; uy.d = y;
|
78
|
+
hx = __HI(ux); /* high word of x */
|
79
|
+
lx = __LO(ux); /* low word of x */
|
80
|
+
hy = __HI(uy); /* high word of y */
|
81
|
+
ly = __LO(uy); /* low word of y */
|
82
|
+
sx = hx&0x80000000; /* sign of x */
|
83
|
+
hx ^=sx; /* |x| */
|
84
|
+
hy &= 0x7fffffff; /* |y| */
|
85
|
+
|
86
|
+
/* purge off exception values */
|
87
|
+
if((hy|ly)==0||(hx>=0x7ff00000)|| /* y=0,or x not finite */
|
88
|
+
((hy|((ly|-(int)ly)>>31))>0x7ff00000)) /* or y is NaN */
|
89
|
+
return (x*y)/(x*y);
|
90
|
+
if(hx<=hy) {
|
91
|
+
if((hx<hy)||(lx<ly)) return x; /* |x|<|y| return x */
|
92
|
+
if(lx==ly)
|
93
|
+
return Zero[(unsigned)sx>>31]; /* |x|=|y| return x*0*/
|
94
|
+
}
|
95
|
+
|
96
|
+
/* determine ix = ilogb(x) */
|
97
|
+
if(hx<0x00100000) { /* subnormal x */
|
98
|
+
if(hx==0) {
|
99
|
+
for (ix = -1043, i=lx; i>0; i<<=1) ix -=1;
|
100
|
+
} else {
|
101
|
+
for (ix = -1022,i=(hx<<11); i>0; i<<=1) ix -=1;
|
102
|
+
}
|
103
|
+
} else ix = (hx>>20)-1023;
|
104
|
+
|
105
|
+
/* determine iy = ilogb(y) */
|
106
|
+
if(hy<0x00100000) { /* subnormal y */
|
107
|
+
if(hy==0) {
|
108
|
+
for (iy = -1043, i=ly; i>0; i<<=1) iy -=1;
|
109
|
+
} else {
|
110
|
+
for (iy = -1022,i=(hy<<11); i>0; i<<=1) iy -=1;
|
111
|
+
}
|
112
|
+
} else iy = (hy>>20)-1023;
|
113
|
+
|
114
|
+
/* set up {hx,lx}, {hy,ly} and align y to x */
|
115
|
+
if(ix >= -1022)
|
116
|
+
hx = 0x00100000|(0x000fffff&hx);
|
117
|
+
else { /* subnormal x, shift x to normal */
|
118
|
+
n = -1022-ix;
|
119
|
+
if(n<=31) {
|
120
|
+
hx = (hx<<n)|(lx>>(32-n));
|
121
|
+
lx <<= n;
|
122
|
+
} else {
|
123
|
+
hx = lx<<(n-32);
|
124
|
+
lx = 0;
|
125
|
+
}
|
126
|
+
}
|
127
|
+
if(iy >= -1022)
|
128
|
+
hy = 0x00100000|(0x000fffff&hy);
|
129
|
+
else { /* subnormal y, shift y to normal */
|
130
|
+
n = -1022-iy;
|
131
|
+
if(n<=31) {
|
132
|
+
hy = (hy<<n)|(ly>>(32-n));
|
133
|
+
ly <<= n;
|
134
|
+
} else {
|
135
|
+
hy = ly<<(n-32);
|
136
|
+
ly = 0;
|
137
|
+
}
|
138
|
+
}
|
139
|
+
|
140
|
+
/* fix point fmod */
|
141
|
+
n = ix - iy;
|
142
|
+
while(n--) {
|
143
|
+
hz=hx-hy;lz=lx-ly; if(lx<ly) hz -= 1;
|
144
|
+
if(hz<0){hx = hx+hx+(lx>>31); lx = lx+lx;}
|
145
|
+
else {
|
146
|
+
if((hz|lz)==0) /* return sign(x)*0 */
|
147
|
+
return Zero[(unsigned)sx>>31];
|
148
|
+
hx = hz+hz+(lz>>31); lx = lz+lz;
|
149
|
+
}
|
150
|
+
}
|
151
|
+
hz=hx-hy;lz=lx-ly; if(lx<ly) hz -= 1;
|
152
|
+
if(hz>=0) {hx=hz;lx=lz;}
|
153
|
+
|
154
|
+
/* convert back to floating value and restore the sign */
|
155
|
+
if((hx|lx)==0) /* return sign(x)*0 */
|
156
|
+
return Zero[(unsigned)sx>>31];
|
157
|
+
while(hx<0x00100000) { /* normalize x */
|
158
|
+
hx = hx+hx+(lx>>31); lx = lx+lx;
|
159
|
+
iy -= 1;
|
160
|
+
}
|
161
|
+
if(iy>= -1022) { /* normalize output */
|
162
|
+
hx = ((hx-0x00100000)|((iy+1023)<<20));
|
163
|
+
ux.d = x;
|
164
|
+
__HI(ux) = hx|sx;
|
165
|
+
__LO(ux) = lx;
|
166
|
+
x = ux.d;
|
167
|
+
} else { /* subnormal output */
|
168
|
+
n = -1022 - iy;
|
169
|
+
if(n<=20) {
|
170
|
+
lx = (lx>>n)|((unsigned)hx<<(32-n));
|
171
|
+
hx >>= n;
|
172
|
+
} else if (n<=31) {
|
173
|
+
lx = (hx<<(32-n))|(lx>>n); hx = sx;
|
174
|
+
} else {
|
175
|
+
lx = hx>>(n-32); hx = sx;
|
176
|
+
}
|
177
|
+
ux.d = x;
|
178
|
+
__HI(ux) = hx|sx;
|
179
|
+
__LO(ux) = lx;
|
180
|
+
x = ux.d;
|
181
|
+
x *= one; /* create necessary signal */
|
182
|
+
}
|
183
|
+
return x; /* exact output */
|
184
|
+
}
|
@@ -0,0 +1,71 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_gamma.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*
|
51
|
+
*/
|
52
|
+
|
53
|
+
/* __ieee754_gamma(x)
|
54
|
+
* Return the logarithm of the Gamma function of x.
|
55
|
+
*
|
56
|
+
* Method: call __ieee754_gamma_r
|
57
|
+
*/
|
58
|
+
|
59
|
+
#include "fdlibm.h"
|
60
|
+
|
61
|
+
extern int signgam;
|
62
|
+
|
63
|
+
#ifdef __STDC__
|
64
|
+
double __ieee754_gamma(double x)
|
65
|
+
#else
|
66
|
+
double __ieee754_gamma(x)
|
67
|
+
double x;
|
68
|
+
#endif
|
69
|
+
{
|
70
|
+
return __ieee754_gamma_r(x,&signgam);
|
71
|
+
}
|
@@ -0,0 +1,70 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_gamma_r.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*
|
51
|
+
*/
|
52
|
+
|
53
|
+
/* __ieee754_gamma_r(x, signgamp)
|
54
|
+
* Reentrant version of the logarithm of the Gamma function
|
55
|
+
* with user provide pointer for the sign of Gamma(x).
|
56
|
+
*
|
57
|
+
* Method: See __ieee754_lgamma_r
|
58
|
+
*/
|
59
|
+
|
60
|
+
#include "fdlibm.h"
|
61
|
+
|
62
|
+
#ifdef __STDC__
|
63
|
+
double __ieee754_gamma_r(double x, int *signgamp)
|
64
|
+
#else
|
65
|
+
double __ieee754_gamma_r(x,signgamp)
|
66
|
+
double x; int *signgamp;
|
67
|
+
#endif
|
68
|
+
{
|
69
|
+
return __ieee754_lgamma_r(x,signgamp);
|
70
|
+
}
|
@@ -0,0 +1,173 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_hypot.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*/
|
51
|
+
|
52
|
+
/* __ieee754_hypot(x,y)
|
53
|
+
*
|
54
|
+
* Method :
|
55
|
+
* If (assume round-to-nearest) z=x*x+y*y
|
56
|
+
* has error less than sqrt(2)/2 ulp, than
|
57
|
+
* sqrt(z) has error less than 1 ulp (exercise).
|
58
|
+
*
|
59
|
+
* So, compute sqrt(x*x+y*y) with some care as
|
60
|
+
* follows to get the error below 1 ulp:
|
61
|
+
*
|
62
|
+
* Assume x>y>0;
|
63
|
+
* (if possible, set rounding to round-to-nearest)
|
64
|
+
* 1. if x > 2y use
|
65
|
+
* x1*x1+(y*y+(x2*(x+x1))) for x*x+y*y
|
66
|
+
* where x1 = x with lower 32 bits cleared, x2 = x-x1; else
|
67
|
+
* 2. if x <= 2y use
|
68
|
+
* t1*y1+((x-y)*(x-y)+(t1*y2+t2*y))
|
69
|
+
* where t1 = 2x with lower 32 bits cleared, t2 = 2x-t1,
|
70
|
+
* y1= y with lower 32 bits chopped, y2 = y-y1.
|
71
|
+
*
|
72
|
+
* NOTE: scaling may be necessary if some argument is too
|
73
|
+
* large or too tiny
|
74
|
+
*
|
75
|
+
* Special cases:
|
76
|
+
* hypot(x,y) is INF if x or y is +INF or -INF; else
|
77
|
+
* hypot(x,y) is NAN if x or y is NAN.
|
78
|
+
*
|
79
|
+
* Accuracy:
|
80
|
+
* hypot(x,y) returns sqrt(x^2+y^2) with error less
|
81
|
+
* than 1 ulps (units in the last place)
|
82
|
+
*/
|
83
|
+
|
84
|
+
#include "fdlibm.h"
|
85
|
+
|
86
|
+
#ifdef __STDC__
|
87
|
+
double __ieee754_hypot(double x, double y)
|
88
|
+
#else
|
89
|
+
double __ieee754_hypot(x,y)
|
90
|
+
double x, y;
|
91
|
+
#endif
|
92
|
+
{
|
93
|
+
fd_twoints ux, uy;
|
94
|
+
double a=x,b=y,t1,t2,y1,y2,w;
|
95
|
+
int j,k,ha,hb;
|
96
|
+
|
97
|
+
ux.d = x; uy.d = y;
|
98
|
+
ha = __HI(ux)&0x7fffffff; /* high word of x */
|
99
|
+
hb = __HI(uy)&0x7fffffff; /* high word of y */
|
100
|
+
if(hb > ha) {a=y;b=x;j=ha; ha=hb;hb=j;} else {a=x;b=y;}
|
101
|
+
ux.d = a; uy.d = b;
|
102
|
+
__HI(ux) = ha; /* a <- |a| */
|
103
|
+
__HI(uy) = hb; /* b <- |b| */
|
104
|
+
a = ux.d; b = uy.d;
|
105
|
+
if((ha-hb)>0x3c00000) {return a+b;} /* x/y > 2**60 */
|
106
|
+
k=0;
|
107
|
+
if(ha > 0x5f300000) { /* a>2**500 */
|
108
|
+
if(ha >= 0x7ff00000) { /* Inf or NaN */
|
109
|
+
w = a+b; /* for sNaN */
|
110
|
+
ux.d = a; uy.d = b;
|
111
|
+
if(((ha&0xfffff)|__LO(ux))==0) w = a;
|
112
|
+
if(((hb^0x7ff00000)|__LO(uy))==0) w = b;
|
113
|
+
return w;
|
114
|
+
}
|
115
|
+
/* scale a and b by 2**-600 */
|
116
|
+
ha -= 0x25800000; hb -= 0x25800000; k += 600;
|
117
|
+
ux.d = a; uy.d = b;
|
118
|
+
__HI(ux) = ha;
|
119
|
+
__HI(uy) = hb;
|
120
|
+
a = ux.d; b = uy.d;
|
121
|
+
}
|
122
|
+
if(hb < 0x20b00000) { /* b < 2**-500 */
|
123
|
+
if(hb <= 0x000fffff) { /* subnormal b or 0 */
|
124
|
+
uy.d = b;
|
125
|
+
if((hb|(__LO(uy)))==0) return a;
|
126
|
+
t1=0;
|
127
|
+
ux.d = t1;
|
128
|
+
__HI(ux) = 0x7fd00000; /* t1=2^1022 */
|
129
|
+
t1 = ux.d;
|
130
|
+
b *= t1;
|
131
|
+
a *= t1;
|
132
|
+
k -= 1022;
|
133
|
+
} else { /* scale a and b by 2^600 */
|
134
|
+
ha += 0x25800000; /* a *= 2^600 */
|
135
|
+
hb += 0x25800000; /* b *= 2^600 */
|
136
|
+
k -= 600;
|
137
|
+
ux.d = a; uy.d = b;
|
138
|
+
__HI(ux) = ha;
|
139
|
+
__HI(uy) = hb;
|
140
|
+
a = ux.d; b = uy.d;
|
141
|
+
}
|
142
|
+
}
|
143
|
+
/* medium size a and b */
|
144
|
+
w = a-b;
|
145
|
+
if (w>b) {
|
146
|
+
t1 = 0;
|
147
|
+
ux.d = t1;
|
148
|
+
__HI(ux) = ha;
|
149
|
+
t1 = ux.d;
|
150
|
+
t2 = a-t1;
|
151
|
+
w = fd_sqrt(t1*t1-(b*(-b)-t2*(a+t1)));
|
152
|
+
} else {
|
153
|
+
a = a+a;
|
154
|
+
y1 = 0;
|
155
|
+
ux.d = y1;
|
156
|
+
__HI(ux) = hb;
|
157
|
+
y1 = ux.d;
|
158
|
+
y2 = b - y1;
|
159
|
+
t1 = 0;
|
160
|
+
ux.d = t1;
|
161
|
+
__HI(ux) = ha+0x00100000;
|
162
|
+
t1 = ux.d;
|
163
|
+
t2 = a - t1;
|
164
|
+
w = fd_sqrt(t1*y1-(w*(-w)-(t1*y2+t2*b)));
|
165
|
+
}
|
166
|
+
if(k!=0) {
|
167
|
+
t1 = 1.0;
|
168
|
+
ux.d = t1;
|
169
|
+
__HI(ux) += (k<<20);
|
170
|
+
t1 = ux.d;
|
171
|
+
return t1*w;
|
172
|
+
} else return w;
|
173
|
+
}
|