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,192 @@
|
|
1
|
+
# -*- Mode: makefile -*-
|
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
|
+
#
|
41
|
+
# @(#)Makefile 1.4 95/01/18
|
42
|
+
#
|
43
|
+
# ====================================================
|
44
|
+
# Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
45
|
+
#
|
46
|
+
# Developed at SunSoft, a Sun Microsystems, Inc. business.
|
47
|
+
# Permission to use, copy, modify, and distribute this
|
48
|
+
# software is freely granted, provided that this notice
|
49
|
+
# is preserved.
|
50
|
+
# ====================================================
|
51
|
+
#
|
52
|
+
#
|
53
|
+
|
54
|
+
#
|
55
|
+
# There are two options in making libm at fdlibm compile time:
|
56
|
+
# _IEEE_LIBM --- IEEE libm; smaller, and somewhat faster
|
57
|
+
# _MULTI_LIBM --- Support multi-standard at runtime by
|
58
|
+
# imposing wrapper functions defined in
|
59
|
+
# fdlibm.h:
|
60
|
+
# _IEEE_MODE -- IEEE
|
61
|
+
# _XOPEN_MODE -- X/OPEN
|
62
|
+
# _POSIX_MODE -- POSIX/ANSI
|
63
|
+
# _SVID3_MODE -- SVID
|
64
|
+
#
|
65
|
+
# Here is how to set up CFLAGS to create the desired libm at
|
66
|
+
# compile time:
|
67
|
+
#
|
68
|
+
# CFLAGS = -D_IEEE_LIBM ... IEEE libm (recommended)
|
69
|
+
# CFLAGS = -D_SVID3_MODE ... Multi-standard supported
|
70
|
+
# libm with SVID as the
|
71
|
+
# default standard
|
72
|
+
# CFLAGS = -D_XOPEN_MODE ... Multi-standard supported
|
73
|
+
# libm with XOPEN as the
|
74
|
+
# default standard
|
75
|
+
# CFLAGS = -D_POSIX_MODE ... Multi-standard supported
|
76
|
+
# libm with POSIX as the
|
77
|
+
# default standard
|
78
|
+
# CFLAGS = ... Multi-standard supported
|
79
|
+
# libm with IEEE as the
|
80
|
+
# default standard
|
81
|
+
#
|
82
|
+
# NOTE: if scalb's second arguement is an int, then one must
|
83
|
+
# define _SCALB_INT in CFLAGS. The default prototype of scalb
|
84
|
+
# is double scalb(double, double)
|
85
|
+
#
|
86
|
+
|
87
|
+
DEPTH = ..
|
88
|
+
|
89
|
+
include $(DEPTH)/config.mk
|
90
|
+
|
91
|
+
#
|
92
|
+
# Default IEEE libm
|
93
|
+
#
|
94
|
+
CFLAGS += -DXP_UNIX $(OPTIMIZER) $(OS_CFLAGS) $(DEFINES) $(INCLUDES) \
|
95
|
+
-DJSFILE $(XCFLAGS) -D_IEEE_LIBM
|
96
|
+
|
97
|
+
# Need for jstypes.h and friends
|
98
|
+
INCLUDES += -I..
|
99
|
+
INCLUDES += -I../$(OBJDIR)
|
100
|
+
|
101
|
+
#CC = cc
|
102
|
+
|
103
|
+
INCFILES = fdlibm.h
|
104
|
+
.INIT: $(INCFILES)
|
105
|
+
.KEEP_STATE:
|
106
|
+
FDLIBM_CFILES = \
|
107
|
+
k_standard.c k_rem_pio2.c \
|
108
|
+
k_cos.c k_sin.c k_tan.c \
|
109
|
+
e_acos.c e_acosh.c e_asin.c e_atan2.c \
|
110
|
+
e_atanh.c e_cosh.c e_exp.c e_fmod.c \
|
111
|
+
e_gamma.c e_gamma_r.c e_hypot.c e_j0.c \
|
112
|
+
e_j1.c e_jn.c e_lgamma.c e_lgamma_r.c \
|
113
|
+
e_log.c e_log10.c e_pow.c e_rem_pio2.c e_remainder.c \
|
114
|
+
e_scalb.c e_sinh.c e_sqrt.c \
|
115
|
+
w_acos.c w_acosh.c w_asin.c w_atan2.c \
|
116
|
+
w_atanh.c w_cosh.c w_exp.c w_fmod.c \
|
117
|
+
w_gamma.c w_gamma_r.c w_hypot.c w_j0.c \
|
118
|
+
w_j1.c w_jn.c w_lgamma.c w_lgamma_r.c \
|
119
|
+
w_log.c w_log10.c w_pow.c w_remainder.c \
|
120
|
+
w_scalb.c w_sinh.c w_sqrt.c \
|
121
|
+
s_asinh.c s_atan.c s_cbrt.c s_ceil.c s_copysign.c \
|
122
|
+
s_cos.c s_erf.c s_expm1.c s_fabs.c s_finite.c s_floor.c \
|
123
|
+
s_frexp.c s_ilogb.c s_isnan.c s_ldexp.c s_lib_version.c \
|
124
|
+
s_log1p.c s_logb.c s_matherr.c s_modf.c s_nextafter.c \
|
125
|
+
s_rint.c s_scalbn.c s_signgam.c s_significand.c s_sin.c \
|
126
|
+
s_tan.c s_tanh.c
|
127
|
+
|
128
|
+
ifdef USE_MSVC
|
129
|
+
FDLIBM_OBJS = $(addprefix $(OBJDIR)/, $(FDLIBM_CFILES:.c=.obj))
|
130
|
+
else
|
131
|
+
FDLIBM_OBJS = $(addprefix $(OBJDIR)/, $(FDLIBM_CFILES:.c=.o))
|
132
|
+
endif
|
133
|
+
|
134
|
+
ifdef USE_MSVC
|
135
|
+
LIBRARY = $(OBJDIR)/fdlibm.lib
|
136
|
+
else
|
137
|
+
LIBRARY = $(OBJDIR)/libfdm.a
|
138
|
+
endif
|
139
|
+
|
140
|
+
define MAKE_OBJDIR
|
141
|
+
if test ! -d $(@D); then rm -rf $(@D); mkdir -p $(@D); fi
|
142
|
+
endef
|
143
|
+
|
144
|
+
all: $(LIBRARY)
|
145
|
+
|
146
|
+
export:
|
147
|
+
|
148
|
+
$(OBJDIR)/%: %.c
|
149
|
+
@$(MAKE_OBJDIR)
|
150
|
+
$(CC) -o $@ $(CFLAGS) $*.c $(LDFLAGS)
|
151
|
+
|
152
|
+
$(OBJDIR)/%.o: %.c
|
153
|
+
@$(MAKE_OBJDIR)
|
154
|
+
$(CC) -o $@ -c $(CFLAGS) $*.c
|
155
|
+
|
156
|
+
$(OBJDIR)/%.o: %.s
|
157
|
+
@$(MAKE_OBJDIR)
|
158
|
+
$(AS) -o $@ $(ASFLAGS) $*.s
|
159
|
+
|
160
|
+
# windows only
|
161
|
+
$(OBJDIR)/%.obj: %.c
|
162
|
+
@$(MAKE_OBJDIR)
|
163
|
+
$(CC) -Fo$(OBJDIR)/ -c $(CFLAGS) $*.c
|
164
|
+
|
165
|
+
ifeq ($(OS_ARCH),OS2)
|
166
|
+
$(LIBRARY): $(FDLIBM_OBJS)
|
167
|
+
$(AR) $@ $? $(AR_OS2_SUFFIX)
|
168
|
+
$(RANLIB) $@
|
169
|
+
else
|
170
|
+
ifdef USE_MSVC
|
171
|
+
$(LIBRARY): $(FDLIBM_OBJS)
|
172
|
+
lib.exe /out:"$@" $?
|
173
|
+
else
|
174
|
+
$(LIBRARY): $(FDLIBM_OBJS)
|
175
|
+
$(AR) rv $@ $?
|
176
|
+
$(RANLIB) $@
|
177
|
+
endif
|
178
|
+
endif
|
179
|
+
|
180
|
+
libfdm.a : $(FDLIBM_OBJS)
|
181
|
+
$(AR) cru $(OBJDIR)/libfdm.a $(FDLIBM_OBJS)
|
182
|
+
$(RANLIB) $(OBJDIR)/libfdm.a
|
183
|
+
|
184
|
+
clean:
|
185
|
+
rm -rf $(FDLIBM_OBJS)
|
186
|
+
|
187
|
+
clobber:
|
188
|
+
rm -rf $(FDLIBM_OBJS) $(LIBRARY) $(DEPENDENCIES)
|
189
|
+
|
190
|
+
SUFFIXES: .i
|
191
|
+
%.i: %.c
|
192
|
+
$(CC) -C -E $(CFLAGS) $< > $*.i
|
@@ -0,0 +1,147 @@
|
|
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_acos.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_acos(x)
|
53
|
+
* Method :
|
54
|
+
* acos(x) = pi/2 - asin(x)
|
55
|
+
* acos(-x) = pi/2 + asin(x)
|
56
|
+
* For |x|<=0.5
|
57
|
+
* acos(x) = pi/2 - (x + x*x^2*R(x^2)) (see asin.c)
|
58
|
+
* For x>0.5
|
59
|
+
* acos(x) = pi/2 - (pi/2 - 2asin(sqrt((1-x)/2)))
|
60
|
+
* = 2asin(sqrt((1-x)/2))
|
61
|
+
* = 2s + 2s*z*R(z) ...z=(1-x)/2, s=sqrt(z)
|
62
|
+
* = 2f + (2c + 2s*z*R(z))
|
63
|
+
* where f=hi part of s, and c = (z-f*f)/(s+f) is the correction term
|
64
|
+
* for f so that f+c ~ sqrt(z).
|
65
|
+
* For x<-0.5
|
66
|
+
* acos(x) = pi - 2asin(sqrt((1-|x|)/2))
|
67
|
+
* = pi - 0.5*(s+s*z*R(z)), where z=(1-|x|)/2,s=sqrt(z)
|
68
|
+
*
|
69
|
+
* Special cases:
|
70
|
+
* if x is NaN, return x itself;
|
71
|
+
* if |x|>1, return NaN with invalid signal.
|
72
|
+
*
|
73
|
+
* Function needed: sqrt
|
74
|
+
*/
|
75
|
+
|
76
|
+
#include "fdlibm.h"
|
77
|
+
|
78
|
+
#ifdef __STDC__
|
79
|
+
static const double
|
80
|
+
#else
|
81
|
+
static double
|
82
|
+
#endif
|
83
|
+
one= 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */
|
84
|
+
pi = 3.14159265358979311600e+00, /* 0x400921FB, 0x54442D18 */
|
85
|
+
pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */
|
86
|
+
pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */
|
87
|
+
pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */
|
88
|
+
pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */
|
89
|
+
pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */
|
90
|
+
pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */
|
91
|
+
pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */
|
92
|
+
pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */
|
93
|
+
qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */
|
94
|
+
qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */
|
95
|
+
qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */
|
96
|
+
qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */
|
97
|
+
|
98
|
+
#ifdef __STDC__
|
99
|
+
double __ieee754_acos(double x)
|
100
|
+
#else
|
101
|
+
double __ieee754_acos(x)
|
102
|
+
double x;
|
103
|
+
#endif
|
104
|
+
{
|
105
|
+
fd_twoints u;
|
106
|
+
double df;
|
107
|
+
double z,p,q,r,w,s,c;
|
108
|
+
int hx,ix;
|
109
|
+
u.d = x;
|
110
|
+
hx = __HI(u);
|
111
|
+
ix = hx&0x7fffffff;
|
112
|
+
if(ix>=0x3ff00000) { /* |x| >= 1 */
|
113
|
+
if(((ix-0x3ff00000)|__LO(u))==0) { /* |x|==1 */
|
114
|
+
if(hx>0) return 0.0; /* acos(1) = 0 */
|
115
|
+
else return pi+2.0*pio2_lo; /* acos(-1)= pi */
|
116
|
+
}
|
117
|
+
return (x-x)/(x-x); /* acos(|x|>1) is NaN */
|
118
|
+
}
|
119
|
+
if(ix<0x3fe00000) { /* |x| < 0.5 */
|
120
|
+
if(ix<=0x3c600000) return pio2_hi+pio2_lo;/*if|x|<2**-57*/
|
121
|
+
z = x*x;
|
122
|
+
p = z*(pS0+z*(pS1+z*(pS2+z*(pS3+z*(pS4+z*pS5)))));
|
123
|
+
q = one+z*(qS1+z*(qS2+z*(qS3+z*qS4)));
|
124
|
+
r = p/q;
|
125
|
+
return pio2_hi - (x - (pio2_lo-x*r));
|
126
|
+
} else if (hx<0) { /* x < -0.5 */
|
127
|
+
z = (one+x)*0.5;
|
128
|
+
p = z*(pS0+z*(pS1+z*(pS2+z*(pS3+z*(pS4+z*pS5)))));
|
129
|
+
q = one+z*(qS1+z*(qS2+z*(qS3+z*qS4)));
|
130
|
+
s = fd_sqrt(z);
|
131
|
+
r = p/q;
|
132
|
+
w = r*s-pio2_lo;
|
133
|
+
return pi - 2.0*(s+w);
|
134
|
+
} else { /* x > 0.5 */
|
135
|
+
z = (one-x)*0.5;
|
136
|
+
s = fd_sqrt(z);
|
137
|
+
u.d = s;
|
138
|
+
__LO(u) = 0;
|
139
|
+
df = u.d;
|
140
|
+
c = (z-df*df)/(s+df);
|
141
|
+
p = z*(pS0+z*(pS1+z*(pS2+z*(pS3+z*(pS4+z*pS5)))));
|
142
|
+
q = one+z*(qS1+z*(qS2+z*(qS3+z*qS4)));
|
143
|
+
r = p/q;
|
144
|
+
w = r*s+c;
|
145
|
+
return 2.0*(df+w);
|
146
|
+
}
|
147
|
+
}
|
@@ -0,0 +1,105 @@
|
|
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_acosh.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_acosh(x)
|
54
|
+
* Method :
|
55
|
+
* Based on
|
56
|
+
* acosh(x) = log [ x + sqrt(x*x-1) ]
|
57
|
+
* we have
|
58
|
+
* acosh(x) := log(x)+ln2, if x is large; else
|
59
|
+
* acosh(x) := log(2x-1/(sqrt(x*x-1)+x)) if x>2; else
|
60
|
+
* acosh(x) := log1p(t+sqrt(2.0*t+t*t)); where t=x-1.
|
61
|
+
*
|
62
|
+
* Special cases:
|
63
|
+
* acosh(x) is NaN with signal if x<1.
|
64
|
+
* acosh(NaN) is NaN without signal.
|
65
|
+
*/
|
66
|
+
|
67
|
+
#include "fdlibm.h"
|
68
|
+
|
69
|
+
#ifdef __STDC__
|
70
|
+
static const double
|
71
|
+
#else
|
72
|
+
static double
|
73
|
+
#endif
|
74
|
+
one = 1.0,
|
75
|
+
ln2 = 6.93147180559945286227e-01; /* 0x3FE62E42, 0xFEFA39EF */
|
76
|
+
|
77
|
+
#ifdef __STDC__
|
78
|
+
double __ieee754_acosh(double x)
|
79
|
+
#else
|
80
|
+
double __ieee754_acosh(x)
|
81
|
+
double x;
|
82
|
+
#endif
|
83
|
+
{
|
84
|
+
fd_twoints u;
|
85
|
+
double t;
|
86
|
+
int hx;
|
87
|
+
u.d = x;
|
88
|
+
hx = __HI(u);
|
89
|
+
if(hx<0x3ff00000) { /* x < 1 */
|
90
|
+
return (x-x)/(x-x);
|
91
|
+
} else if(hx >=0x41b00000) { /* x > 2**28 */
|
92
|
+
if(hx >=0x7ff00000) { /* x is inf of NaN */
|
93
|
+
return x+x;
|
94
|
+
} else
|
95
|
+
return __ieee754_log(x)+ln2; /* acosh(huge)=log(2x) */
|
96
|
+
} else if(((hx-0x3ff00000)|__LO(u))==0) {
|
97
|
+
return 0.0; /* acosh(1) = 0 */
|
98
|
+
} else if (hx > 0x40000000) { /* 2**28 > x > 2 */
|
99
|
+
t=x*x;
|
100
|
+
return __ieee754_log(2.0*x-one/(x+fd_sqrt(t-one)));
|
101
|
+
} else { /* 1<x<2 */
|
102
|
+
t = x-one;
|
103
|
+
return fd_log1p(t+fd_sqrt(2.0*t+t*t));
|
104
|
+
}
|
105
|
+
}
|
@@ -0,0 +1,156 @@
|
|
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_asin.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_asin(x)
|
53
|
+
* Method :
|
54
|
+
* Since asin(x) = x + x^3/6 + x^5*3/40 + x^7*15/336 + ...
|
55
|
+
* we approximate asin(x) on [0,0.5] by
|
56
|
+
* asin(x) = x + x*x^2*R(x^2)
|
57
|
+
* where
|
58
|
+
* R(x^2) is a rational approximation of (asin(x)-x)/x^3
|
59
|
+
* and its remez error is bounded by
|
60
|
+
* |(asin(x)-x)/x^3 - R(x^2)| < 2^(-58.75)
|
61
|
+
*
|
62
|
+
* For x in [0.5,1]
|
63
|
+
* asin(x) = pi/2-2*asin(sqrt((1-x)/2))
|
64
|
+
* Let y = (1-x), z = y/2, s := sqrt(z), and pio2_hi+pio2_lo=pi/2;
|
65
|
+
* then for x>0.98
|
66
|
+
* asin(x) = pi/2 - 2*(s+s*z*R(z))
|
67
|
+
* = pio2_hi - (2*(s+s*z*R(z)) - pio2_lo)
|
68
|
+
* For x<=0.98, let pio4_hi = pio2_hi/2, then
|
69
|
+
* f = hi part of s;
|
70
|
+
* c = sqrt(z) - f = (z-f*f)/(s+f) ...f+c=sqrt(z)
|
71
|
+
* and
|
72
|
+
* asin(x) = pi/2 - 2*(s+s*z*R(z))
|
73
|
+
* = pio4_hi+(pio4-2s)-(2s*z*R(z)-pio2_lo)
|
74
|
+
* = pio4_hi+(pio4-2f)-(2s*z*R(z)-(pio2_lo+2c))
|
75
|
+
*
|
76
|
+
* Special cases:
|
77
|
+
* if x is NaN, return x itself;
|
78
|
+
* if |x|>1, return NaN with invalid signal.
|
79
|
+
*
|
80
|
+
*/
|
81
|
+
|
82
|
+
|
83
|
+
#include "fdlibm.h"
|
84
|
+
|
85
|
+
#ifdef __STDC__
|
86
|
+
static const double
|
87
|
+
#else
|
88
|
+
static double
|
89
|
+
#endif
|
90
|
+
one = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */
|
91
|
+
really_big = 1.000e+300,
|
92
|
+
pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */
|
93
|
+
pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */
|
94
|
+
pio4_hi = 7.85398163397448278999e-01, /* 0x3FE921FB, 0x54442D18 */
|
95
|
+
/* coefficient for R(x^2) */
|
96
|
+
pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */
|
97
|
+
pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */
|
98
|
+
pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */
|
99
|
+
pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */
|
100
|
+
pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */
|
101
|
+
pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */
|
102
|
+
qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */
|
103
|
+
qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */
|
104
|
+
qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */
|
105
|
+
qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */
|
106
|
+
|
107
|
+
#ifdef __STDC__
|
108
|
+
double __ieee754_asin(double x)
|
109
|
+
#else
|
110
|
+
double __ieee754_asin(x)
|
111
|
+
double x;
|
112
|
+
#endif
|
113
|
+
{
|
114
|
+
fd_twoints u;
|
115
|
+
double w,t,p,q,c,r,s;
|
116
|
+
int hx,ix;
|
117
|
+
u.d = x;
|
118
|
+
hx = __HI(u);
|
119
|
+
x = u.d;
|
120
|
+
ix = hx&0x7fffffff;
|
121
|
+
if(ix>= 0x3ff00000) { /* |x|>= 1 */
|
122
|
+
if(((ix-0x3ff00000)|__LO(u))==0)
|
123
|
+
/* asin(1)=+-pi/2 with inexact */
|
124
|
+
return x*pio2_hi+x*pio2_lo;
|
125
|
+
return (x-x)/(x-x); /* asin(|x|>1) is NaN */
|
126
|
+
} else if (ix<0x3fe00000) { /* |x|<0.5 */
|
127
|
+
if(ix<0x3e400000) { /* if |x| < 2**-27 */
|
128
|
+
if(really_big+x>one) return x;/* return x with inexact if x!=0*/
|
129
|
+
} else
|
130
|
+
t = x*x;
|
131
|
+
p = t*(pS0+t*(pS1+t*(pS2+t*(pS3+t*(pS4+t*pS5)))));
|
132
|
+
q = one+t*(qS1+t*(qS2+t*(qS3+t*qS4)));
|
133
|
+
w = p/q;
|
134
|
+
return x+x*w;
|
135
|
+
}
|
136
|
+
/* 1> |x|>= 0.5 */
|
137
|
+
w = one-fd_fabs(x);
|
138
|
+
t = w*0.5;
|
139
|
+
p = t*(pS0+t*(pS1+t*(pS2+t*(pS3+t*(pS4+t*pS5)))));
|
140
|
+
q = one+t*(qS1+t*(qS2+t*(qS3+t*qS4)));
|
141
|
+
s = fd_sqrt(t);
|
142
|
+
if(ix>=0x3FEF3333) { /* if |x| > 0.975 */
|
143
|
+
w = p/q;
|
144
|
+
t = pio2_hi-(2.0*(s+s*w)-pio2_lo);
|
145
|
+
} else {
|
146
|
+
u.d = s;
|
147
|
+
__LO(u) = 0;
|
148
|
+
w = u.d;
|
149
|
+
c = (t-w*w)/(s+w);
|
150
|
+
r = p/q;
|
151
|
+
p = 2.0*s*r-(pio2_lo-2.0*c);
|
152
|
+
q = pio4_hi-2.0*w;
|
153
|
+
t = pio4_hi-(p-q);
|
154
|
+
}
|
155
|
+
if(hx>0) return t; else return -t;
|
156
|
+
}
|