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,744 @@
|
|
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
|
+
* Netscape Communications Corporation.
|
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
|
+
#ifndef jspubtd_h___
|
41
|
+
#define jspubtd_h___
|
42
|
+
/*
|
43
|
+
* JS public API typedefs.
|
44
|
+
*/
|
45
|
+
#include "jstypes.h"
|
46
|
+
#include "jscompat.h"
|
47
|
+
|
48
|
+
JS_BEGIN_EXTERN_C
|
49
|
+
|
50
|
+
/* Scalar typedefs. */
|
51
|
+
typedef uint16 jschar;
|
52
|
+
typedef int32 jsint;
|
53
|
+
typedef uint32 jsuint;
|
54
|
+
typedef float64 jsdouble;
|
55
|
+
typedef jsword jsval;
|
56
|
+
typedef jsword jsid;
|
57
|
+
typedef int32 jsrefcount; /* PRInt32 if JS_THREADSAFE, see jslock.h */
|
58
|
+
|
59
|
+
/*
|
60
|
+
* Run-time version enumeration. See jsconfig.h for compile-time counterparts
|
61
|
+
* to these values that may be selected by the JS_VERSION macro, and tested by
|
62
|
+
* #if expressions.
|
63
|
+
*/
|
64
|
+
typedef enum JSVersion {
|
65
|
+
JSVERSION_1_0 = 100,
|
66
|
+
JSVERSION_1_1 = 110,
|
67
|
+
JSVERSION_1_2 = 120,
|
68
|
+
JSVERSION_1_3 = 130,
|
69
|
+
JSVERSION_1_4 = 140,
|
70
|
+
JSVERSION_ECMA_3 = 148,
|
71
|
+
JSVERSION_1_5 = 150,
|
72
|
+
JSVERSION_1_6 = 160,
|
73
|
+
JSVERSION_1_7 = 170,
|
74
|
+
JSVERSION_1_8 = 180,
|
75
|
+
JSVERSION_DEFAULT = 0,
|
76
|
+
JSVERSION_UNKNOWN = -1,
|
77
|
+
JSVERSION_LATEST = JSVERSION_1_8
|
78
|
+
} JSVersion;
|
79
|
+
|
80
|
+
#define JSVERSION_IS_ECMA(version) \
|
81
|
+
((version) == JSVERSION_DEFAULT || (version) >= JSVERSION_1_3)
|
82
|
+
|
83
|
+
/* Result of typeof operator enumeration. */
|
84
|
+
typedef enum JSType {
|
85
|
+
JSTYPE_VOID, /* undefined */
|
86
|
+
JSTYPE_OBJECT, /* object */
|
87
|
+
JSTYPE_FUNCTION, /* function */
|
88
|
+
JSTYPE_STRING, /* string */
|
89
|
+
JSTYPE_NUMBER, /* number */
|
90
|
+
JSTYPE_BOOLEAN, /* boolean */
|
91
|
+
JSTYPE_NULL, /* null */
|
92
|
+
JSTYPE_XML, /* xml object */
|
93
|
+
JSTYPE_LIMIT
|
94
|
+
} JSType;
|
95
|
+
|
96
|
+
/* Dense index into cached prototypes and class atoms for standard objects. */
|
97
|
+
typedef enum JSProtoKey {
|
98
|
+
#define JS_PROTO(name,code,init) JSProto_##name = code,
|
99
|
+
#include "jsproto.tbl"
|
100
|
+
#undef JS_PROTO
|
101
|
+
JSProto_LIMIT
|
102
|
+
} JSProtoKey;
|
103
|
+
|
104
|
+
/* JSObjectOps.checkAccess mode enumeration. */
|
105
|
+
typedef enum JSAccessMode {
|
106
|
+
JSACC_PROTO = 0, /* XXXbe redundant w.r.t. id */
|
107
|
+
JSACC_PARENT = 1, /* XXXbe redundant w.r.t. id */
|
108
|
+
JSACC_IMPORT = 2, /* import foo.bar */
|
109
|
+
JSACC_WATCH = 3, /* a watchpoint on object foo for id 'bar' */
|
110
|
+
JSACC_READ = 4, /* a "get" of foo.bar */
|
111
|
+
JSACC_WRITE = 8, /* a "set" of foo.bar = baz */
|
112
|
+
JSACC_LIMIT
|
113
|
+
} JSAccessMode;
|
114
|
+
|
115
|
+
#define JSACC_TYPEMASK (JSACC_WRITE - 1)
|
116
|
+
|
117
|
+
/*
|
118
|
+
* This enum type is used to control the behavior of a JSObject property
|
119
|
+
* iterator function that has type JSNewEnumerate.
|
120
|
+
*/
|
121
|
+
typedef enum JSIterateOp {
|
122
|
+
JSENUMERATE_INIT, /* Create new iterator state */
|
123
|
+
JSENUMERATE_NEXT, /* Iterate once */
|
124
|
+
JSENUMERATE_DESTROY /* Destroy iterator state */
|
125
|
+
} JSIterateOp;
|
126
|
+
|
127
|
+
/* Struct typedefs. */
|
128
|
+
typedef struct JSClass JSClass;
|
129
|
+
typedef struct JSExtendedClass JSExtendedClass;
|
130
|
+
typedef struct JSConstDoubleSpec JSConstDoubleSpec;
|
131
|
+
typedef struct JSContext JSContext;
|
132
|
+
typedef struct JSErrorReport JSErrorReport;
|
133
|
+
typedef struct JSFunction JSFunction;
|
134
|
+
typedef struct JSFunctionSpec JSFunctionSpec;
|
135
|
+
typedef struct JSTracer JSTracer;
|
136
|
+
typedef struct JSIdArray JSIdArray;
|
137
|
+
typedef struct JSProperty JSProperty;
|
138
|
+
typedef struct JSPropertySpec JSPropertySpec;
|
139
|
+
typedef struct JSObject JSObject;
|
140
|
+
typedef struct JSObjectMap JSObjectMap;
|
141
|
+
typedef struct JSObjectOps JSObjectOps;
|
142
|
+
typedef struct JSXMLObjectOps JSXMLObjectOps;
|
143
|
+
typedef struct JSRuntime JSRuntime;
|
144
|
+
typedef struct JSRuntime JSTaskState; /* XXX deprecated name */
|
145
|
+
typedef struct JSScript JSScript;
|
146
|
+
typedef struct JSStackFrame JSStackFrame;
|
147
|
+
typedef struct JSString JSString;
|
148
|
+
typedef struct JSXDRState JSXDRState;
|
149
|
+
typedef struct JSExceptionState JSExceptionState;
|
150
|
+
typedef struct JSLocaleCallbacks JSLocaleCallbacks;
|
151
|
+
|
152
|
+
/* JSClass (and JSObjectOps where appropriate) function pointer typedefs. */
|
153
|
+
|
154
|
+
/*
|
155
|
+
* Add, delete, get or set a property named by id in obj. Note the jsval id
|
156
|
+
* type -- id may be a string (Unicode property identifier) or an int (element
|
157
|
+
* index). The *vp out parameter, on success, is the new property value after
|
158
|
+
* an add, get, or set. After a successful delete, *vp is JSVAL_FALSE iff
|
159
|
+
* obj[id] can't be deleted (because it's permanent).
|
160
|
+
*/
|
161
|
+
typedef JSBool
|
162
|
+
(* JS_DLL_CALLBACK JSPropertyOp)(JSContext *cx, JSObject *obj, jsval id,
|
163
|
+
jsval *vp);
|
164
|
+
|
165
|
+
/*
|
166
|
+
* This function type is used for callbacks that enumerate the properties of
|
167
|
+
* a JSObject. The behavior depends on the value of enum_op:
|
168
|
+
*
|
169
|
+
* JSENUMERATE_INIT
|
170
|
+
* A new, opaque iterator state should be allocated and stored in *statep.
|
171
|
+
* (You can use PRIVATE_TO_JSVAL() to tag the pointer to be stored).
|
172
|
+
*
|
173
|
+
* The number of properties that will be enumerated should be returned as
|
174
|
+
* an integer jsval in *idp, if idp is non-null, and provided the number of
|
175
|
+
* enumerable properties is known. If idp is non-null and the number of
|
176
|
+
* enumerable properties can't be computed in advance, *idp should be set
|
177
|
+
* to JSVAL_ZERO.
|
178
|
+
*
|
179
|
+
* JSENUMERATE_NEXT
|
180
|
+
* A previously allocated opaque iterator state is passed in via statep.
|
181
|
+
* Return the next jsid in the iteration using *idp. The opaque iterator
|
182
|
+
* state pointed at by statep is destroyed and *statep is set to JSVAL_NULL
|
183
|
+
* if there are no properties left to enumerate.
|
184
|
+
*
|
185
|
+
* JSENUMERATE_DESTROY
|
186
|
+
* Destroy the opaque iterator state previously allocated in *statep by a
|
187
|
+
* call to this function when enum_op was JSENUMERATE_INIT.
|
188
|
+
*
|
189
|
+
* The return value is used to indicate success, with a value of JS_FALSE
|
190
|
+
* indicating failure.
|
191
|
+
*/
|
192
|
+
typedef JSBool
|
193
|
+
(* JS_DLL_CALLBACK JSNewEnumerateOp)(JSContext *cx, JSObject *obj,
|
194
|
+
JSIterateOp enum_op,
|
195
|
+
jsval *statep, jsid *idp);
|
196
|
+
|
197
|
+
/*
|
198
|
+
* The old-style JSClass.enumerate op should define all lazy properties not
|
199
|
+
* yet reflected in obj.
|
200
|
+
*/
|
201
|
+
typedef JSBool
|
202
|
+
(* JS_DLL_CALLBACK JSEnumerateOp)(JSContext *cx, JSObject *obj);
|
203
|
+
|
204
|
+
/*
|
205
|
+
* Resolve a lazy property named by id in obj by defining it directly in obj.
|
206
|
+
* Lazy properties are those reflected from some peer native property space
|
207
|
+
* (e.g., the DOM attributes for a given node reflected as obj) on demand.
|
208
|
+
*
|
209
|
+
* JS looks for a property in an object, and if not found, tries to resolve
|
210
|
+
* the given id. If resolve succeeds, the engine looks again in case resolve
|
211
|
+
* defined obj[id]. If no such property exists directly in obj, the process
|
212
|
+
* is repeated with obj's prototype, etc.
|
213
|
+
*
|
214
|
+
* NB: JSNewResolveOp provides a cheaper way to resolve lazy properties.
|
215
|
+
*/
|
216
|
+
typedef JSBool
|
217
|
+
(* JS_DLL_CALLBACK JSResolveOp)(JSContext *cx, JSObject *obj, jsval id);
|
218
|
+
|
219
|
+
/*
|
220
|
+
* Like JSResolveOp, but flags provide contextual information as follows:
|
221
|
+
*
|
222
|
+
* JSRESOLVE_QUALIFIED a qualified property id: obj.id or obj[id], not id
|
223
|
+
* JSRESOLVE_ASSIGNING obj[id] is on the left-hand side of an assignment
|
224
|
+
* JSRESOLVE_DETECTING 'if (o.p)...' or similar detection opcode sequence
|
225
|
+
* JSRESOLVE_DECLARING var, const, or function prolog declaration opcode
|
226
|
+
* JSRESOLVE_CLASSNAME class name used when constructing
|
227
|
+
*
|
228
|
+
* The *objp out parameter, on success, should be null to indicate that id
|
229
|
+
* was not resolved; and non-null, referring to obj or one of its prototypes,
|
230
|
+
* if id was resolved.
|
231
|
+
*
|
232
|
+
* This hook instead of JSResolveOp is called via the JSClass.resolve member
|
233
|
+
* if JSCLASS_NEW_RESOLVE is set in JSClass.flags.
|
234
|
+
*
|
235
|
+
* Setting JSCLASS_NEW_RESOLVE and JSCLASS_NEW_RESOLVE_GETS_START further
|
236
|
+
* extends this hook by passing in the starting object on the prototype chain
|
237
|
+
* via *objp. Thus a resolve hook implementation may define the property id
|
238
|
+
* being resolved in the object in which the id was first sought, rather than
|
239
|
+
* in a prototype object whose class led to the resolve hook being called.
|
240
|
+
*
|
241
|
+
* When using JSCLASS_NEW_RESOLVE_GETS_START, the resolve hook must therefore
|
242
|
+
* null *objp to signify "not resolved". With only JSCLASS_NEW_RESOLVE and no
|
243
|
+
* JSCLASS_NEW_RESOLVE_GETS_START, the hook can assume *objp is null on entry.
|
244
|
+
* This is not good practice, but enough existing hook implementations count
|
245
|
+
* on it that we can't break compatibility by passing the starting object in
|
246
|
+
* *objp without a new JSClass flag.
|
247
|
+
*/
|
248
|
+
typedef JSBool
|
249
|
+
(* JS_DLL_CALLBACK JSNewResolveOp)(JSContext *cx, JSObject *obj, jsval id,
|
250
|
+
uintN flags, JSObject **objp);
|
251
|
+
|
252
|
+
/*
|
253
|
+
* Convert obj to the given type, returning true with the resulting value in
|
254
|
+
* *vp on success, and returning false on error or exception.
|
255
|
+
*/
|
256
|
+
typedef JSBool
|
257
|
+
(* JS_DLL_CALLBACK JSConvertOp)(JSContext *cx, JSObject *obj, JSType type,
|
258
|
+
jsval *vp);
|
259
|
+
|
260
|
+
/*
|
261
|
+
* Finalize obj, which the garbage collector has determined to be unreachable
|
262
|
+
* from other live objects or from GC roots. Obviously, finalizers must never
|
263
|
+
* store a reference to obj.
|
264
|
+
*/
|
265
|
+
typedef void
|
266
|
+
(* JS_DLL_CALLBACK JSFinalizeOp)(JSContext *cx, JSObject *obj);
|
267
|
+
|
268
|
+
/*
|
269
|
+
* Used by JS_AddExternalStringFinalizer and JS_RemoveExternalStringFinalizer
|
270
|
+
* to extend and reduce the set of string types finalized by the GC.
|
271
|
+
*/
|
272
|
+
typedef void
|
273
|
+
(* JS_DLL_CALLBACK JSStringFinalizeOp)(JSContext *cx, JSString *str);
|
274
|
+
|
275
|
+
/*
|
276
|
+
* The signature for JSClass.getObjectOps, used by JS_NewObject's internals
|
277
|
+
* to discover the set of high-level object operations to use for new objects
|
278
|
+
* of the given class. All native objects have a JSClass, which is stored as
|
279
|
+
* a private (int-tagged) pointer in obj slots. In contrast, all native and
|
280
|
+
* host objects have a JSObjectMap at obj->map, which may be shared among a
|
281
|
+
* number of objects, and which contains the JSObjectOps *ops pointer used to
|
282
|
+
* dispatch object operations from API calls.
|
283
|
+
*
|
284
|
+
* Thus JSClass (which pre-dates JSObjectOps in the API) provides a low-level
|
285
|
+
* interface to class-specific code and data, while JSObjectOps allows for a
|
286
|
+
* higher level of operation, which does not use the object's class except to
|
287
|
+
* find the class's JSObjectOps struct, by calling clasp->getObjectOps, and to
|
288
|
+
* finalize the object.
|
289
|
+
*
|
290
|
+
* If this seems backwards, that's because it is! API compatibility requires
|
291
|
+
* a JSClass *clasp parameter to JS_NewObject, etc. Most host objects do not
|
292
|
+
* need to implement the larger JSObjectOps, and can share the common JSScope
|
293
|
+
* code and data used by the native (js_ObjectOps, see jsobj.c) ops.
|
294
|
+
*
|
295
|
+
* Further extension to preserve API compatibility: if this function returns
|
296
|
+
* a pointer to JSXMLObjectOps.base, not to JSObjectOps, then the engine calls
|
297
|
+
* extended hooks needed for E4X.
|
298
|
+
*/
|
299
|
+
typedef JSObjectOps *
|
300
|
+
(* JS_DLL_CALLBACK JSGetObjectOps)(JSContext *cx, JSClass *clasp);
|
301
|
+
|
302
|
+
/*
|
303
|
+
* JSClass.checkAccess type: check whether obj[id] may be accessed per mode,
|
304
|
+
* returning false on error/exception, true on success with obj[id]'s last-got
|
305
|
+
* value in *vp, and its attributes in *attrsp. As for JSPropertyOp above, id
|
306
|
+
* is either a string or an int jsval.
|
307
|
+
*
|
308
|
+
* See JSCheckAccessIdOp, below, for the JSObjectOps counterpart, which takes
|
309
|
+
* a jsid (a tagged int or aligned, unique identifier pointer) rather than a
|
310
|
+
* jsval. The native js_ObjectOps.checkAccess simply forwards to the object's
|
311
|
+
* clasp->checkAccess, so that both JSClass and JSObjectOps implementors may
|
312
|
+
* specialize access checks.
|
313
|
+
*/
|
314
|
+
typedef JSBool
|
315
|
+
(* JS_DLL_CALLBACK JSCheckAccessOp)(JSContext *cx, JSObject *obj, jsval id,
|
316
|
+
JSAccessMode mode, jsval *vp);
|
317
|
+
|
318
|
+
/*
|
319
|
+
* Encode or decode an object, given an XDR state record representing external
|
320
|
+
* data. See jsxdrapi.h.
|
321
|
+
*/
|
322
|
+
typedef JSBool
|
323
|
+
(* JS_DLL_CALLBACK JSXDRObjectOp)(JSXDRState *xdr, JSObject **objp);
|
324
|
+
|
325
|
+
/*
|
326
|
+
* Check whether v is an instance of obj. Return false on error or exception,
|
327
|
+
* true on success with JS_TRUE in *bp if v is an instance of obj, JS_FALSE in
|
328
|
+
* *bp otherwise.
|
329
|
+
*/
|
330
|
+
typedef JSBool
|
331
|
+
(* JS_DLL_CALLBACK JSHasInstanceOp)(JSContext *cx, JSObject *obj, jsval v,
|
332
|
+
JSBool *bp);
|
333
|
+
|
334
|
+
/*
|
335
|
+
* Deprecated function type for JSClass.mark. All new code should define
|
336
|
+
* JSTraceOp instead to ensure the traversal of traceable things stored in
|
337
|
+
* the native structures.
|
338
|
+
*/
|
339
|
+
typedef uint32
|
340
|
+
(* JS_DLL_CALLBACK JSMarkOp)(JSContext *cx, JSObject *obj, void *arg);
|
341
|
+
|
342
|
+
/*
|
343
|
+
* Function type for trace operation of the class called to enumerate all
|
344
|
+
* traceable things reachable from obj's private data structure. For each such
|
345
|
+
* thing, a trace implementation must call
|
346
|
+
*
|
347
|
+
* JS_CallTracer(trc, thing, kind);
|
348
|
+
*
|
349
|
+
* or one of its convenience macros as described in jsapi.h.
|
350
|
+
*
|
351
|
+
* JSTraceOp implementation can assume that no other threads mutates object
|
352
|
+
* state. It must not change state of the object or corresponding native
|
353
|
+
* structures. The only exception for this rule is the case when the embedding
|
354
|
+
* needs a tight integration with GC. In that case the embedding can check if
|
355
|
+
* the traversal is a part of the marking phase through calling
|
356
|
+
* JS_IsGCMarkingTracer and apply a special code like emptying caches or
|
357
|
+
* marking its native structures.
|
358
|
+
*
|
359
|
+
* To define the tracer for a JSClass, the implementation must add
|
360
|
+
* JSCLASS_MARK_IS_TRACE to class flags and use JS_CLASS_TRACE(method)
|
361
|
+
* macro below to convert JSTraceOp to JSMarkOp when initializing or
|
362
|
+
* assigning JSClass.mark field.
|
363
|
+
*/
|
364
|
+
typedef void
|
365
|
+
(* JS_DLL_CALLBACK JSTraceOp)(JSTracer *trc, JSObject *obj);
|
366
|
+
|
367
|
+
#if defined __GNUC__ && __GNUC__ >= 4 && !defined __cplusplus
|
368
|
+
# define JS_CLASS_TRACE(method) \
|
369
|
+
(__builtin_types_compatible_p(JSTraceOp, __typeof(&(method))) \
|
370
|
+
? (JSMarkOp)(method) \
|
371
|
+
: js_WrongTypeForClassTracer)
|
372
|
+
|
373
|
+
extern JSMarkOp js_WrongTypeForClassTracer;
|
374
|
+
|
375
|
+
#else
|
376
|
+
# define JS_CLASS_TRACE(method) ((JSMarkOp)(method))
|
377
|
+
#endif
|
378
|
+
|
379
|
+
/*
|
380
|
+
* Tracer callback, called for each traceable thing directly refrenced by a
|
381
|
+
* particular object or runtime structure. It is the callback responsibility
|
382
|
+
* to ensure the traversal of the full object graph via calling eventually
|
383
|
+
* JS_TraceChildren on the passed thing. In this case the callback must be
|
384
|
+
* prepared to deal with cycles in the traversal graph.
|
385
|
+
*
|
386
|
+
* kind argument is one of JSTRACE_OBJECT, JSTRACE_DOUBLE, JSTRACE_STRING or
|
387
|
+
* a tag denoting internal implementation-specific traversal kind. In the
|
388
|
+
* latter case the only operations on thing that the callback can do is to call
|
389
|
+
* JS_TraceChildren or DEBUG-only JS_PrintTraceThingInfo.
|
390
|
+
*/
|
391
|
+
typedef void
|
392
|
+
(* JS_DLL_CALLBACK JSTraceCallback)(JSTracer *trc, void *thing, uint32 kind);
|
393
|
+
|
394
|
+
/*
|
395
|
+
* DEBUG only callback that JSTraceOp implementation can provide to return
|
396
|
+
* a string describing the reference traced with JS_CallTracer.
|
397
|
+
*/
|
398
|
+
#ifdef DEBUG
|
399
|
+
typedef void
|
400
|
+
(* JS_DLL_CALLBACK JSTraceNamePrinter)(JSTracer *trc, char *buf,
|
401
|
+
size_t bufsize);
|
402
|
+
#endif
|
403
|
+
|
404
|
+
/*
|
405
|
+
* The optional JSClass.reserveSlots hook allows a class to make computed
|
406
|
+
* per-instance object slots reservations, in addition to or instead of using
|
407
|
+
* JSCLASS_HAS_RESERVED_SLOTS(n) in the JSClass.flags initializer to reserve
|
408
|
+
* a constant-per-class number of slots. Implementations of this hook should
|
409
|
+
* return the number of slots to reserve, not including any reserved by using
|
410
|
+
* JSCLASS_HAS_RESERVED_SLOTS(n) in JSClass.flags.
|
411
|
+
*
|
412
|
+
* NB: called with obj locked by the JSObjectOps-specific mutual exclusion
|
413
|
+
* mechanism appropriate for obj, so don't nest other operations that might
|
414
|
+
* also lock obj.
|
415
|
+
*/
|
416
|
+
typedef uint32
|
417
|
+
(* JS_DLL_CALLBACK JSReserveSlotsOp)(JSContext *cx, JSObject *obj);
|
418
|
+
|
419
|
+
/* JSObjectOps function pointer typedefs. */
|
420
|
+
|
421
|
+
/*
|
422
|
+
* Create a new subclass of JSObjectMap (see jsobj.h), with the nrefs and ops
|
423
|
+
* members initialized from the same-named parameters, and with the nslots and
|
424
|
+
* freeslot members initialized according to ops and clasp. Return null on
|
425
|
+
* error, non-null on success.
|
426
|
+
*
|
427
|
+
* JSObjectMaps are reference-counted by generic code in the engine. Usually,
|
428
|
+
* the nrefs parameter to JSObjectOps.newObjectMap will be 1, to count the ref
|
429
|
+
* returned to the caller on success. After a successful construction, some
|
430
|
+
* number of js_HoldObjectMap and js_DropObjectMap calls ensue. When nrefs
|
431
|
+
* reaches 0 due to a js_DropObjectMap call, JSObjectOps.destroyObjectMap will
|
432
|
+
* be called to dispose of the map.
|
433
|
+
*/
|
434
|
+
typedef JSObjectMap *
|
435
|
+
(* JS_DLL_CALLBACK JSNewObjectMapOp)(JSContext *cx, jsrefcount nrefs,
|
436
|
+
JSObjectOps *ops, JSClass *clasp,
|
437
|
+
JSObject *obj);
|
438
|
+
|
439
|
+
/*
|
440
|
+
* Generic type for an infallible JSObjectMap operation, used currently by
|
441
|
+
* JSObjectOps.destroyObjectMap.
|
442
|
+
*/
|
443
|
+
typedef void
|
444
|
+
(* JS_DLL_CALLBACK JSObjectMapOp)(JSContext *cx, JSObjectMap *map);
|
445
|
+
|
446
|
+
/*
|
447
|
+
* Look for id in obj and its prototype chain, returning false on error or
|
448
|
+
* exception, true on success. On success, return null in *propp if id was
|
449
|
+
* not found. If id was found, return the first object searching from obj
|
450
|
+
* along its prototype chain in which id names a direct property in *objp, and
|
451
|
+
* return a non-null, opaque property pointer in *propp.
|
452
|
+
*
|
453
|
+
* If JSLookupPropOp succeeds and returns with *propp non-null, that pointer
|
454
|
+
* may be passed as the prop parameter to a JSAttributesOp, as a short-cut
|
455
|
+
* that bypasses id re-lookup. In any case, a non-null *propp result after a
|
456
|
+
* successful lookup must be dropped via JSObjectOps.dropProperty.
|
457
|
+
*
|
458
|
+
* NB: successful return with non-null *propp means the implementation may
|
459
|
+
* have locked *objp and added a reference count associated with *propp, so
|
460
|
+
* callers should not risk deadlock by nesting or interleaving other lookups
|
461
|
+
* or any obj-bearing ops before dropping *propp.
|
462
|
+
*/
|
463
|
+
typedef JSBool
|
464
|
+
(* JS_DLL_CALLBACK JSLookupPropOp)(JSContext *cx, JSObject *obj, jsid id,
|
465
|
+
JSObject **objp, JSProperty **propp);
|
466
|
+
|
467
|
+
/*
|
468
|
+
* Define obj[id], a direct property of obj named id, having the given initial
|
469
|
+
* value, with the specified getter, setter, and attributes. If the propp out
|
470
|
+
* param is non-null, *propp on successful return contains an opaque property
|
471
|
+
* pointer usable as a speedup hint with JSAttributesOp. But note that propp
|
472
|
+
* may be null, indicating that the caller is not interested in recovering an
|
473
|
+
* opaque pointer to the newly-defined property.
|
474
|
+
*
|
475
|
+
* If propp is non-null and JSDefinePropOp succeeds, its caller must be sure
|
476
|
+
* to drop *propp using JSObjectOps.dropProperty in short order, just as with
|
477
|
+
* JSLookupPropOp.
|
478
|
+
*/
|
479
|
+
typedef JSBool
|
480
|
+
(* JS_DLL_CALLBACK JSDefinePropOp)(JSContext *cx, JSObject *obj,
|
481
|
+
jsid id, jsval value,
|
482
|
+
JSPropertyOp getter, JSPropertyOp setter,
|
483
|
+
uintN attrs, JSProperty **propp);
|
484
|
+
|
485
|
+
/*
|
486
|
+
* Get, set, or delete obj[id], returning false on error or exception, true
|
487
|
+
* on success. If getting or setting, the new value is returned in *vp on
|
488
|
+
* success. If deleting without error, *vp will be JSVAL_FALSE if obj[id] is
|
489
|
+
* permanent, and JSVAL_TRUE if id named a direct property of obj that was in
|
490
|
+
* fact deleted, or if id names no direct property of obj (id could name a
|
491
|
+
* prototype property, or no property in obj or its prototype chain).
|
492
|
+
*/
|
493
|
+
typedef JSBool
|
494
|
+
(* JS_DLL_CALLBACK JSPropertyIdOp)(JSContext *cx, JSObject *obj, jsid id,
|
495
|
+
jsval *vp);
|
496
|
+
|
497
|
+
/*
|
498
|
+
* Get or set attributes of the property obj[id]. Return false on error or
|
499
|
+
* exception, true with current attributes in *attrsp. If prop is non-null,
|
500
|
+
* it must come from the *propp out parameter of a prior JSDefinePropOp or
|
501
|
+
* JSLookupPropOp call.
|
502
|
+
*/
|
503
|
+
typedef JSBool
|
504
|
+
(* JS_DLL_CALLBACK JSAttributesOp)(JSContext *cx, JSObject *obj, jsid id,
|
505
|
+
JSProperty *prop, uintN *attrsp);
|
506
|
+
|
507
|
+
/*
|
508
|
+
* JSObjectOps.checkAccess type: check whether obj[id] may be accessed per
|
509
|
+
* mode, returning false on error/exception, true on success with obj[id]'s
|
510
|
+
* last-got value in *vp, and its attributes in *attrsp.
|
511
|
+
*/
|
512
|
+
typedef JSBool
|
513
|
+
(* JS_DLL_CALLBACK JSCheckAccessIdOp)(JSContext *cx, JSObject *obj, jsid id,
|
514
|
+
JSAccessMode mode, jsval *vp,
|
515
|
+
uintN *attrsp);
|
516
|
+
|
517
|
+
/*
|
518
|
+
* A generic type for functions mapping an object to another object, or null
|
519
|
+
* if an error or exception was thrown on cx. Used by JSObjectOps.thisObject
|
520
|
+
* at present.
|
521
|
+
*/
|
522
|
+
typedef JSObject *
|
523
|
+
(* JS_DLL_CALLBACK JSObjectOp)(JSContext *cx, JSObject *obj);
|
524
|
+
|
525
|
+
/*
|
526
|
+
* Hook that creates an iterator object for a given object. Returns the
|
527
|
+
* iterator object or null if an error or exception was thrown on cx.
|
528
|
+
*/
|
529
|
+
typedef JSObject *
|
530
|
+
(* JS_DLL_CALLBACK JSIteratorOp)(JSContext *cx, JSObject *obj,
|
531
|
+
JSBool keysonly);
|
532
|
+
|
533
|
+
/*
|
534
|
+
* A generic type for functions taking a context, object, and property, with
|
535
|
+
* no return value. Used by JSObjectOps.dropProperty currently (see above,
|
536
|
+
* JSDefinePropOp and JSLookupPropOp, for the object-locking protocol in which
|
537
|
+
* dropProperty participates).
|
538
|
+
*/
|
539
|
+
typedef void
|
540
|
+
(* JS_DLL_CALLBACK JSPropertyRefOp)(JSContext *cx, JSObject *obj,
|
541
|
+
JSProperty *prop);
|
542
|
+
|
543
|
+
/*
|
544
|
+
* Function pointer type for JSObjectOps.setProto and JSObjectOps.setParent.
|
545
|
+
* These hooks must check for cycles without deadlocking, and otherwise take
|
546
|
+
* special steps. See jsobj.c and jsgc.c for details.
|
547
|
+
*/
|
548
|
+
typedef JSBool
|
549
|
+
(* JS_DLL_CALLBACK JSSetObjectSlotOp)(JSContext *cx, JSObject *obj,
|
550
|
+
uint32 slot, JSObject *pobj);
|
551
|
+
|
552
|
+
/*
|
553
|
+
* Get and set a required slot, one that should already have been allocated.
|
554
|
+
* These operations are infallible, so required slots must be pre-allocated,
|
555
|
+
* or implementations must suppress out-of-memory errors. The native ops
|
556
|
+
* (js_ObjectOps, see jsobj.c) access slots reserved by including a call to
|
557
|
+
* the JSCLASS_HAS_RESERVED_SLOTS(n) macro in the JSClass.flags initializer.
|
558
|
+
*
|
559
|
+
* NB: the slot parameter is a zero-based index into obj slots, unlike the
|
560
|
+
* index parameter to the JS_GetReservedSlot and JS_SetReservedSlot API entry
|
561
|
+
* points, which is a zero-based index into the JSCLASS_RESERVED_SLOTS(clasp)
|
562
|
+
* reserved slots that come after the initial well-known slots: proto, parent,
|
563
|
+
* class, and optionally, the private data slot.
|
564
|
+
*/
|
565
|
+
typedef jsval
|
566
|
+
(* JS_DLL_CALLBACK JSGetRequiredSlotOp)(JSContext *cx, JSObject *obj,
|
567
|
+
uint32 slot);
|
568
|
+
|
569
|
+
typedef JSBool
|
570
|
+
(* JS_DLL_CALLBACK JSSetRequiredSlotOp)(JSContext *cx, JSObject *obj,
|
571
|
+
uint32 slot, jsval v);
|
572
|
+
|
573
|
+
typedef JSObject *
|
574
|
+
(* JS_DLL_CALLBACK JSGetMethodOp)(JSContext *cx, JSObject *obj, jsid id,
|
575
|
+
jsval *vp);
|
576
|
+
|
577
|
+
typedef JSBool
|
578
|
+
(* JS_DLL_CALLBACK JSSetMethodOp)(JSContext *cx, JSObject *obj, jsid id,
|
579
|
+
jsval *vp);
|
580
|
+
|
581
|
+
typedef JSBool
|
582
|
+
(* JS_DLL_CALLBACK JSEnumerateValuesOp)(JSContext *cx, JSObject *obj,
|
583
|
+
JSIterateOp enum_op,
|
584
|
+
jsval *statep, jsid *idp, jsval *vp);
|
585
|
+
|
586
|
+
typedef JSBool
|
587
|
+
(* JS_DLL_CALLBACK JSEqualityOp)(JSContext *cx, JSObject *obj, jsval v,
|
588
|
+
JSBool *bp);
|
589
|
+
|
590
|
+
typedef JSBool
|
591
|
+
(* JS_DLL_CALLBACK JSConcatenateOp)(JSContext *cx, JSObject *obj, jsval v,
|
592
|
+
jsval *vp);
|
593
|
+
|
594
|
+
/* Typedef for native functions called by the JS VM. */
|
595
|
+
|
596
|
+
typedef JSBool
|
597
|
+
(* JS_DLL_CALLBACK JSNative)(JSContext *cx, JSObject *obj, uintN argc,
|
598
|
+
jsval *argv, jsval *rval);
|
599
|
+
|
600
|
+
/* See jsapi.h, the JS_CALLEE, JS_THIS, etc. macros. */
|
601
|
+
typedef JSBool
|
602
|
+
(* JS_DLL_CALLBACK JSFastNative)(JSContext *cx, uintN argc, jsval *vp);
|
603
|
+
|
604
|
+
/* Callbacks and their arguments. */
|
605
|
+
|
606
|
+
typedef enum JSContextOp {
|
607
|
+
JSCONTEXT_NEW,
|
608
|
+
JSCONTEXT_DESTROY
|
609
|
+
} JSContextOp;
|
610
|
+
|
611
|
+
/*
|
612
|
+
* The possible values for contextOp when the runtime calls the callback are:
|
613
|
+
* JSCONTEXT_NEW JS_NewContext successfully created a new JSContext
|
614
|
+
* instance. The callback can initialize the instance as
|
615
|
+
* required. If the callback returns false, the instance
|
616
|
+
* will be destroyed and JS_NewContext returns null. In
|
617
|
+
* this case the callback is not called again.
|
618
|
+
* JSCONTEXT_DESTROY One of JS_DestroyContext* methods is called. The
|
619
|
+
* callback may perform its own cleanup and must always
|
620
|
+
* return true.
|
621
|
+
* Any other value For future compatibility the callback must do nothing
|
622
|
+
* and return true in this case.
|
623
|
+
*/
|
624
|
+
typedef JSBool
|
625
|
+
(* JS_DLL_CALLBACK JSContextCallback)(JSContext *cx, uintN contextOp);
|
626
|
+
|
627
|
+
typedef enum JSGCStatus {
|
628
|
+
JSGC_BEGIN,
|
629
|
+
JSGC_END,
|
630
|
+
JSGC_MARK_END,
|
631
|
+
JSGC_FINALIZE_END
|
632
|
+
} JSGCStatus;
|
633
|
+
|
634
|
+
typedef JSBool
|
635
|
+
(* JS_DLL_CALLBACK JSGCCallback)(JSContext *cx, JSGCStatus status);
|
636
|
+
|
637
|
+
/*
|
638
|
+
* Generic trace operation that calls JS_CallTracer on each traceable thing
|
639
|
+
* stored in data.
|
640
|
+
*/
|
641
|
+
typedef void
|
642
|
+
(* JS_DLL_CALLBACK JSTraceDataOp)(JSTracer *trc, void *data);
|
643
|
+
|
644
|
+
typedef JSBool
|
645
|
+
(* JS_DLL_CALLBACK JSOperationCallback)(JSContext *cx);
|
646
|
+
|
647
|
+
/*
|
648
|
+
* Deprecated form of JSOperationCallback.
|
649
|
+
*/
|
650
|
+
typedef JSBool
|
651
|
+
(* JS_DLL_CALLBACK JSBranchCallback)(JSContext *cx, JSScript *script);
|
652
|
+
|
653
|
+
typedef void
|
654
|
+
(* JS_DLL_CALLBACK JSErrorReporter)(JSContext *cx, const char *message,
|
655
|
+
JSErrorReport *report);
|
656
|
+
|
657
|
+
/*
|
658
|
+
* Possible exception types. These types are part of a JSErrorFormatString
|
659
|
+
* structure. They define which error to throw in case of a runtime error.
|
660
|
+
* JSEXN_NONE marks an unthrowable error.
|
661
|
+
*/
|
662
|
+
typedef enum JSExnType {
|
663
|
+
JSEXN_NONE = -1,
|
664
|
+
JSEXN_ERR,
|
665
|
+
JSEXN_INTERNALERR,
|
666
|
+
JSEXN_EVALERR,
|
667
|
+
JSEXN_RANGEERR,
|
668
|
+
JSEXN_REFERENCEERR,
|
669
|
+
JSEXN_SYNTAXERR,
|
670
|
+
JSEXN_TYPEERR,
|
671
|
+
JSEXN_URIERR,
|
672
|
+
JSEXN_LIMIT
|
673
|
+
} JSExnType;
|
674
|
+
|
675
|
+
typedef struct JSErrorFormatString {
|
676
|
+
/* The error format string (UTF-8 if js_CStringsAreUTF8). */
|
677
|
+
const char *format;
|
678
|
+
|
679
|
+
/* The number of arguments to expand in the formatted error message. */
|
680
|
+
uint16 argCount;
|
681
|
+
|
682
|
+
/* One of the JSExnType constants above. */
|
683
|
+
int16 exnType;
|
684
|
+
} JSErrorFormatString;
|
685
|
+
|
686
|
+
typedef const JSErrorFormatString *
|
687
|
+
(* JS_DLL_CALLBACK JSErrorCallback)(void *userRef, const char *locale,
|
688
|
+
const uintN errorNumber);
|
689
|
+
|
690
|
+
#ifdef va_start
|
691
|
+
#define JS_ARGUMENT_FORMATTER_DEFINED 1
|
692
|
+
|
693
|
+
typedef JSBool
|
694
|
+
(* JS_DLL_CALLBACK JSArgumentFormatter)(JSContext *cx, const char *format,
|
695
|
+
JSBool fromJS, jsval **vpp,
|
696
|
+
va_list *app);
|
697
|
+
#endif
|
698
|
+
|
699
|
+
typedef JSBool
|
700
|
+
(* JS_DLL_CALLBACK JSLocaleToUpperCase)(JSContext *cx, JSString *src,
|
701
|
+
jsval *rval);
|
702
|
+
|
703
|
+
typedef JSBool
|
704
|
+
(* JS_DLL_CALLBACK JSLocaleToLowerCase)(JSContext *cx, JSString *src,
|
705
|
+
jsval *rval);
|
706
|
+
|
707
|
+
typedef JSBool
|
708
|
+
(* JS_DLL_CALLBACK JSLocaleCompare)(JSContext *cx,
|
709
|
+
JSString *src1, JSString *src2,
|
710
|
+
jsval *rval);
|
711
|
+
|
712
|
+
typedef JSBool
|
713
|
+
(* JS_DLL_CALLBACK JSLocaleToUnicode)(JSContext *cx, char *src, jsval *rval);
|
714
|
+
|
715
|
+
/*
|
716
|
+
* Security protocol types.
|
717
|
+
*/
|
718
|
+
typedef struct JSPrincipals JSPrincipals;
|
719
|
+
|
720
|
+
/*
|
721
|
+
* XDR-encode or -decode a principals instance, based on whether xdr->mode is
|
722
|
+
* JSXDR_ENCODE, in which case *principalsp should be encoded; or JSXDR_DECODE,
|
723
|
+
* in which case implementations must return a held (via JSPRINCIPALS_HOLD),
|
724
|
+
* non-null *principalsp out parameter. Return true on success, false on any
|
725
|
+
* error, which the implementation must have reported.
|
726
|
+
*/
|
727
|
+
typedef JSBool
|
728
|
+
(* JS_DLL_CALLBACK JSPrincipalsTranscoder)(JSXDRState *xdr,
|
729
|
+
JSPrincipals **principalsp);
|
730
|
+
|
731
|
+
/*
|
732
|
+
* Return a weak reference to the principals associated with obj, possibly via
|
733
|
+
* the immutable parent chain leading from obj to a top-level container (e.g.,
|
734
|
+
* a window object in the DOM level 0). If there are no principals associated
|
735
|
+
* with obj, return null. Therefore null does not mean an error was reported;
|
736
|
+
* in no event should an error be reported or an exception be thrown by this
|
737
|
+
* callback's implementation.
|
738
|
+
*/
|
739
|
+
typedef JSPrincipals *
|
740
|
+
(* JS_DLL_CALLBACK JSObjectPrincipalsFinder)(JSContext *cx, JSObject *obj);
|
741
|
+
|
742
|
+
JS_END_EXTERN_C
|
743
|
+
|
744
|
+
#endif /* jspubtd_h___ */
|