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.
Files changed (269) hide show
  1. data/MANIFEST +1 -0
  2. data/Rakefile +3 -10
  3. data/bin/johnson +2 -1
  4. data/ext/spidermonkey/context.c +3 -4
  5. data/ext/spidermonkey/context.h +1 -1
  6. data/ext/spidermonkey/conversions.c +39 -33
  7. data/ext/spidermonkey/debugger.c +5 -5
  8. data/ext/spidermonkey/immutable_node.c.erb +11 -11
  9. data/ext/spidermonkey/jroot.h +4 -4
  10. data/ext/spidermonkey/js_land_proxy.c +9 -8
  11. data/ext/spidermonkey/ruby_land_proxy.c +5 -4
  12. data/ext/spidermonkey/runtime.c +1 -1
  13. data/johnson.gemspec +36 -0
  14. data/lib/hoe.rb +0 -7
  15. data/lib/johnson/cli/options.rb +10 -4
  16. data/lib/johnson/spidermonkey/runtime.rb +2 -2
  17. data/lib/johnson/version.rb +4 -2
  18. data/lib/johnson.rb +1 -0
  19. data/test/johnson/runtime_test.rb +11 -0
  20. data/test/johnson/spidermonkey/ruby_land_proxy_test.rb +6 -0
  21. data/vendor/spidermonkey/.cvsignore +9 -0
  22. data/vendor/spidermonkey/Makefile.in +462 -0
  23. data/vendor/spidermonkey/Makefile.ref +364 -0
  24. data/vendor/spidermonkey/README.html +820 -0
  25. data/vendor/spidermonkey/SpiderMonkey.rsp +12 -0
  26. data/vendor/spidermonkey/Y.js +19 -0
  27. data/vendor/spidermonkey/build.mk +43 -0
  28. data/vendor/spidermonkey/config/AIX4.1.mk +65 -0
  29. data/vendor/spidermonkey/config/AIX4.2.mk +64 -0
  30. data/vendor/spidermonkey/config/AIX4.3.mk +65 -0
  31. data/vendor/spidermonkey/config/Darwin.mk +83 -0
  32. data/vendor/spidermonkey/config/Darwin1.3.mk +81 -0
  33. data/vendor/spidermonkey/config/Darwin1.4.mk +41 -0
  34. data/vendor/spidermonkey/config/Darwin5.2.mk +81 -0
  35. data/vendor/spidermonkey/config/Darwin5.3.mk +81 -0
  36. data/vendor/spidermonkey/config/HP-UXB.10.10.mk +77 -0
  37. data/vendor/spidermonkey/config/HP-UXB.10.20.mk +77 -0
  38. data/vendor/spidermonkey/config/HP-UXB.11.00.mk +80 -0
  39. data/vendor/spidermonkey/config/IRIX.mk +87 -0
  40. data/vendor/spidermonkey/config/IRIX5.3.mk +44 -0
  41. data/vendor/spidermonkey/config/IRIX6.1.mk +44 -0
  42. data/vendor/spidermonkey/config/IRIX6.2.mk +44 -0
  43. data/vendor/spidermonkey/config/IRIX6.3.mk +44 -0
  44. data/vendor/spidermonkey/config/IRIX6.5.mk +44 -0
  45. data/vendor/spidermonkey/config/Linux_All.mk +103 -0
  46. data/vendor/spidermonkey/config/Mac_OS10.0.mk +82 -0
  47. data/vendor/spidermonkey/config/OSF1V4.0.mk +72 -0
  48. data/vendor/spidermonkey/config/OSF1V5.0.mk +69 -0
  49. data/vendor/spidermonkey/config/SunOS4.1.4.mk +101 -0
  50. data/vendor/spidermonkey/config/SunOS5.10.mk +50 -0
  51. data/vendor/spidermonkey/config/SunOS5.3.mk +91 -0
  52. data/vendor/spidermonkey/config/SunOS5.4.mk +92 -0
  53. data/vendor/spidermonkey/config/SunOS5.5.1.mk +44 -0
  54. data/vendor/spidermonkey/config/SunOS5.5.mk +87 -0
  55. data/vendor/spidermonkey/config/SunOS5.6.mk +89 -0
  56. data/vendor/spidermonkey/config/SunOS5.7.mk +44 -0
  57. data/vendor/spidermonkey/config/SunOS5.8.mk +44 -0
  58. data/vendor/spidermonkey/config/SunOS5.9.mk +44 -0
  59. data/vendor/spidermonkey/config/WINNT4.0.mk +117 -0
  60. data/vendor/spidermonkey/config/WINNT5.0.mk +117 -0
  61. data/vendor/spidermonkey/config/WINNT5.1.mk +117 -0
  62. data/vendor/spidermonkey/config/WINNT5.2.mk +117 -0
  63. data/vendor/spidermonkey/config/WINNT6.0.mk +117 -0
  64. data/vendor/spidermonkey/config/dgux.mk +64 -0
  65. data/vendor/spidermonkey/config.mk +192 -0
  66. data/vendor/spidermonkey/editline/Makefile.ref +144 -0
  67. data/vendor/spidermonkey/editline/README +83 -0
  68. data/vendor/spidermonkey/editline/editline.3 +175 -0
  69. data/vendor/spidermonkey/editline/editline.c +1369 -0
  70. data/vendor/spidermonkey/editline/editline.h +135 -0
  71. data/vendor/spidermonkey/editline/sysunix.c +182 -0
  72. data/vendor/spidermonkey/editline/unix.h +82 -0
  73. data/vendor/spidermonkey/fdlibm/.cvsignore +7 -0
  74. data/vendor/spidermonkey/fdlibm/Makefile.in +127 -0
  75. data/vendor/spidermonkey/fdlibm/Makefile.ref +192 -0
  76. data/vendor/spidermonkey/fdlibm/e_acos.c +147 -0
  77. data/vendor/spidermonkey/fdlibm/e_acosh.c +105 -0
  78. data/vendor/spidermonkey/fdlibm/e_asin.c +156 -0
  79. data/vendor/spidermonkey/fdlibm/e_atan2.c +165 -0
  80. data/vendor/spidermonkey/fdlibm/e_atanh.c +110 -0
  81. data/vendor/spidermonkey/fdlibm/e_cosh.c +133 -0
  82. data/vendor/spidermonkey/fdlibm/e_exp.c +202 -0
  83. data/vendor/spidermonkey/fdlibm/e_fmod.c +184 -0
  84. data/vendor/spidermonkey/fdlibm/e_gamma.c +71 -0
  85. data/vendor/spidermonkey/fdlibm/e_gamma_r.c +70 -0
  86. data/vendor/spidermonkey/fdlibm/e_hypot.c +173 -0
  87. data/vendor/spidermonkey/fdlibm/e_j0.c +524 -0
  88. data/vendor/spidermonkey/fdlibm/e_j1.c +523 -0
  89. data/vendor/spidermonkey/fdlibm/e_jn.c +315 -0
  90. data/vendor/spidermonkey/fdlibm/e_lgamma.c +71 -0
  91. data/vendor/spidermonkey/fdlibm/e_lgamma_r.c +347 -0
  92. data/vendor/spidermonkey/fdlibm/e_log.c +184 -0
  93. data/vendor/spidermonkey/fdlibm/e_log10.c +134 -0
  94. data/vendor/spidermonkey/fdlibm/e_pow.c +386 -0
  95. data/vendor/spidermonkey/fdlibm/e_rem_pio2.c +222 -0
  96. data/vendor/spidermonkey/fdlibm/e_remainder.c +120 -0
  97. data/vendor/spidermonkey/fdlibm/e_scalb.c +89 -0
  98. data/vendor/spidermonkey/fdlibm/e_sinh.c +122 -0
  99. data/vendor/spidermonkey/fdlibm/e_sqrt.c +497 -0
  100. data/vendor/spidermonkey/fdlibm/fdlibm.h +273 -0
  101. data/vendor/spidermonkey/fdlibm/fdlibm.mak +1453 -0
  102. data/vendor/spidermonkey/fdlibm/fdlibm.mdp +0 -0
  103. data/vendor/spidermonkey/fdlibm/k_cos.c +135 -0
  104. data/vendor/spidermonkey/fdlibm/k_rem_pio2.c +354 -0
  105. data/vendor/spidermonkey/fdlibm/k_sin.c +114 -0
  106. data/vendor/spidermonkey/fdlibm/k_standard.c +785 -0
  107. data/vendor/spidermonkey/fdlibm/k_tan.c +170 -0
  108. data/vendor/spidermonkey/fdlibm/s_asinh.c +101 -0
  109. data/vendor/spidermonkey/fdlibm/s_atan.c +175 -0
  110. data/vendor/spidermonkey/fdlibm/s_cbrt.c +133 -0
  111. data/vendor/spidermonkey/fdlibm/s_ceil.c +120 -0
  112. data/vendor/spidermonkey/fdlibm/s_copysign.c +72 -0
  113. data/vendor/spidermonkey/fdlibm/s_cos.c +118 -0
  114. data/vendor/spidermonkey/fdlibm/s_erf.c +356 -0
  115. data/vendor/spidermonkey/fdlibm/s_expm1.c +267 -0
  116. data/vendor/spidermonkey/fdlibm/s_fabs.c +70 -0
  117. data/vendor/spidermonkey/fdlibm/s_finite.c +71 -0
  118. data/vendor/spidermonkey/fdlibm/s_floor.c +121 -0
  119. data/vendor/spidermonkey/fdlibm/s_frexp.c +99 -0
  120. data/vendor/spidermonkey/fdlibm/s_ilogb.c +85 -0
  121. data/vendor/spidermonkey/fdlibm/s_isnan.c +74 -0
  122. data/vendor/spidermonkey/fdlibm/s_ldexp.c +66 -0
  123. data/vendor/spidermonkey/fdlibm/s_lib_version.c +73 -0
  124. data/vendor/spidermonkey/fdlibm/s_log1p.c +211 -0
  125. data/vendor/spidermonkey/fdlibm/s_logb.c +79 -0
  126. data/vendor/spidermonkey/fdlibm/s_matherr.c +64 -0
  127. data/vendor/spidermonkey/fdlibm/s_modf.c +132 -0
  128. data/vendor/spidermonkey/fdlibm/s_nextafter.c +124 -0
  129. data/vendor/spidermonkey/fdlibm/s_rint.c +131 -0
  130. data/vendor/spidermonkey/fdlibm/s_scalbn.c +107 -0
  131. data/vendor/spidermonkey/fdlibm/s_signgam.c +40 -0
  132. data/vendor/spidermonkey/fdlibm/s_significand.c +68 -0
  133. data/vendor/spidermonkey/fdlibm/s_sin.c +118 -0
  134. data/vendor/spidermonkey/fdlibm/s_tan.c +112 -0
  135. data/vendor/spidermonkey/fdlibm/s_tanh.c +122 -0
  136. data/vendor/spidermonkey/fdlibm/w_acos.c +78 -0
  137. data/vendor/spidermonkey/fdlibm/w_acosh.c +78 -0
  138. data/vendor/spidermonkey/fdlibm/w_asin.c +80 -0
  139. data/vendor/spidermonkey/fdlibm/w_atan2.c +79 -0
  140. data/vendor/spidermonkey/fdlibm/w_atanh.c +81 -0
  141. data/vendor/spidermonkey/fdlibm/w_cosh.c +77 -0
  142. data/vendor/spidermonkey/fdlibm/w_exp.c +88 -0
  143. data/vendor/spidermonkey/fdlibm/w_fmod.c +78 -0
  144. data/vendor/spidermonkey/fdlibm/w_gamma.c +85 -0
  145. data/vendor/spidermonkey/fdlibm/w_gamma_r.c +81 -0
  146. data/vendor/spidermonkey/fdlibm/w_hypot.c +78 -0
  147. data/vendor/spidermonkey/fdlibm/w_j0.c +105 -0
  148. data/vendor/spidermonkey/fdlibm/w_j1.c +106 -0
  149. data/vendor/spidermonkey/fdlibm/w_jn.c +128 -0
  150. data/vendor/spidermonkey/fdlibm/w_lgamma.c +85 -0
  151. data/vendor/spidermonkey/fdlibm/w_lgamma_r.c +81 -0
  152. data/vendor/spidermonkey/fdlibm/w_log.c +78 -0
  153. data/vendor/spidermonkey/fdlibm/w_log10.c +81 -0
  154. data/vendor/spidermonkey/fdlibm/w_pow.c +99 -0
  155. data/vendor/spidermonkey/fdlibm/w_remainder.c +77 -0
  156. data/vendor/spidermonkey/fdlibm/w_scalb.c +95 -0
  157. data/vendor/spidermonkey/fdlibm/w_sinh.c +77 -0
  158. data/vendor/spidermonkey/fdlibm/w_sqrt.c +77 -0
  159. data/vendor/spidermonkey/javascript-trace.d +73 -0
  160. data/vendor/spidermonkey/js.c +3951 -0
  161. data/vendor/spidermonkey/js.mak +4438 -0
  162. data/vendor/spidermonkey/js.mdp +0 -0
  163. data/vendor/spidermonkey/js.msg +307 -0
  164. data/vendor/spidermonkey/js.pkg +2 -0
  165. data/vendor/spidermonkey/js3240.rc +79 -0
  166. data/vendor/spidermonkey/jsOS240.def +654 -0
  167. data/vendor/spidermonkey/jsapi.c +5836 -0
  168. data/vendor/spidermonkey/jsapi.h +2624 -0
  169. data/vendor/spidermonkey/jsarena.c +450 -0
  170. data/vendor/spidermonkey/jsarena.h +318 -0
  171. data/vendor/spidermonkey/jsarray.c +2988 -0
  172. data/vendor/spidermonkey/jsarray.h +124 -0
  173. data/vendor/spidermonkey/jsatom.c +1045 -0
  174. data/vendor/spidermonkey/jsatom.h +442 -0
  175. data/vendor/spidermonkey/jsbit.h +253 -0
  176. data/vendor/spidermonkey/jsbool.c +176 -0
  177. data/vendor/spidermonkey/jsbool.h +73 -0
  178. data/vendor/spidermonkey/jsclist.h +139 -0
  179. data/vendor/spidermonkey/jscntxt.c +1348 -0
  180. data/vendor/spidermonkey/jscntxt.h +1120 -0
  181. data/vendor/spidermonkey/jscompat.h +57 -0
  182. data/vendor/spidermonkey/jsconfig.h +248 -0
  183. data/vendor/spidermonkey/jsconfig.mk +181 -0
  184. data/vendor/spidermonkey/jscpucfg.c +383 -0
  185. data/vendor/spidermonkey/jscpucfg.h +212 -0
  186. data/vendor/spidermonkey/jsdate.c +2398 -0
  187. data/vendor/spidermonkey/jsdate.h +124 -0
  188. data/vendor/spidermonkey/jsdbgapi.c +1799 -0
  189. data/vendor/spidermonkey/jsdbgapi.h +464 -0
  190. data/vendor/spidermonkey/jsdhash.c +868 -0
  191. data/vendor/spidermonkey/jsdhash.h +592 -0
  192. data/vendor/spidermonkey/jsdtoa.c +3167 -0
  193. data/vendor/spidermonkey/jsdtoa.h +130 -0
  194. data/vendor/spidermonkey/jsdtracef.c +317 -0
  195. data/vendor/spidermonkey/jsdtracef.h +77 -0
  196. data/vendor/spidermonkey/jsemit.c +6909 -0
  197. data/vendor/spidermonkey/jsemit.h +741 -0
  198. data/vendor/spidermonkey/jsexn.c +1371 -0
  199. data/vendor/spidermonkey/jsexn.h +96 -0
  200. data/vendor/spidermonkey/jsfile.c +2736 -0
  201. data/vendor/spidermonkey/jsfile.h +56 -0
  202. data/vendor/spidermonkey/jsfile.msg +90 -0
  203. data/vendor/spidermonkey/jsfun.c +2634 -0
  204. data/vendor/spidermonkey/jsfun.h +254 -0
  205. data/vendor/spidermonkey/jsgc.c +3554 -0
  206. data/vendor/spidermonkey/jsgc.h +403 -0
  207. data/vendor/spidermonkey/jshash.c +476 -0
  208. data/vendor/spidermonkey/jshash.h +151 -0
  209. data/vendor/spidermonkey/jsify.pl +485 -0
  210. data/vendor/spidermonkey/jsinterp.c +6981 -0
  211. data/vendor/spidermonkey/jsinterp.h +521 -0
  212. data/vendor/spidermonkey/jsinvoke.c +43 -0
  213. data/vendor/spidermonkey/jsiter.c +1067 -0
  214. data/vendor/spidermonkey/jsiter.h +122 -0
  215. data/vendor/spidermonkey/jskeyword.tbl +124 -0
  216. data/vendor/spidermonkey/jskwgen.c +460 -0
  217. data/vendor/spidermonkey/jslibmath.h +266 -0
  218. data/vendor/spidermonkey/jslock.c +1309 -0
  219. data/vendor/spidermonkey/jslock.h +313 -0
  220. data/vendor/spidermonkey/jslocko.asm +60 -0
  221. data/vendor/spidermonkey/jslog2.c +94 -0
  222. data/vendor/spidermonkey/jslong.c +264 -0
  223. data/vendor/spidermonkey/jslong.h +412 -0
  224. data/vendor/spidermonkey/jsmath.c +568 -0
  225. data/vendor/spidermonkey/jsmath.h +57 -0
  226. data/vendor/spidermonkey/jsnum.c +1228 -0
  227. data/vendor/spidermonkey/jsnum.h +283 -0
  228. data/vendor/spidermonkey/jsobj.c +5266 -0
  229. data/vendor/spidermonkey/jsobj.h +709 -0
  230. data/vendor/spidermonkey/jsopcode.c +5245 -0
  231. data/vendor/spidermonkey/jsopcode.h +394 -0
  232. data/vendor/spidermonkey/jsopcode.tbl +523 -0
  233. data/vendor/spidermonkey/jsotypes.h +202 -0
  234. data/vendor/spidermonkey/jsparse.c +6680 -0
  235. data/vendor/spidermonkey/jsparse.h +511 -0
  236. data/vendor/spidermonkey/jsprf.c +1262 -0
  237. data/vendor/spidermonkey/jsprf.h +150 -0
  238. data/vendor/spidermonkey/jsproto.tbl +128 -0
  239. data/vendor/spidermonkey/jsprvtd.h +267 -0
  240. data/vendor/spidermonkey/jspubtd.h +744 -0
  241. data/vendor/spidermonkey/jsregexp.c +4352 -0
  242. data/vendor/spidermonkey/jsregexp.h +183 -0
  243. data/vendor/spidermonkey/jsreops.tbl +145 -0
  244. data/vendor/spidermonkey/jsscan.c +2003 -0
  245. data/vendor/spidermonkey/jsscan.h +387 -0
  246. data/vendor/spidermonkey/jsscope.c +1948 -0
  247. data/vendor/spidermonkey/jsscope.h +418 -0
  248. data/vendor/spidermonkey/jsscript.c +1832 -0
  249. data/vendor/spidermonkey/jsscript.h +287 -0
  250. data/vendor/spidermonkey/jsshell.msg +50 -0
  251. data/vendor/spidermonkey/jsstddef.h +83 -0
  252. data/vendor/spidermonkey/jsstr.c +5004 -0
  253. data/vendor/spidermonkey/jsstr.h +641 -0
  254. data/vendor/spidermonkey/jstypes.h +475 -0
  255. data/vendor/spidermonkey/jsutil.c +345 -0
  256. data/vendor/spidermonkey/jsutil.h +157 -0
  257. data/vendor/spidermonkey/jsxdrapi.c +800 -0
  258. data/vendor/spidermonkey/jsxdrapi.h +218 -0
  259. data/vendor/spidermonkey/jsxml.c +8471 -0
  260. data/vendor/spidermonkey/jsxml.h +349 -0
  261. data/vendor/spidermonkey/lock_SunOS.s +119 -0
  262. data/vendor/spidermonkey/perfect.js +39 -0
  263. data/vendor/spidermonkey/plify_jsdhash.sed +36 -0
  264. data/vendor/spidermonkey/prmjtime.c +846 -0
  265. data/vendor/spidermonkey/prmjtime.h +103 -0
  266. data/vendor/spidermonkey/resource.h +15 -0
  267. data/vendor/spidermonkey/rules.mk +197 -0
  268. data/vendor/spidermonkey/win32.order +384 -0
  269. 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___ */