diff options
Diffstat (limited to 'files/ja/mozilla/projects/spidermonkey')
45 files changed, 15503 insertions, 0 deletions
diff --git a/files/ja/mozilla/projects/spidermonkey/build_documentation/index.html b/files/ja/mozilla/projects/spidermonkey/build_documentation/index.html new file mode 100644 index 0000000000..dd5a4146c2 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/build_documentation/index.html @@ -0,0 +1,290 @@ +--- +title: SpiderMonkey のビルド +slug: Mozilla/Projects/SpiderMonkey/Build_Documentation +tags: + - Build documentation + - Guide + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Build_Documentation +--- +<div>{{SpiderMonkeySidebar("General")}}</div> + +<h2 id="SpiderMonkey_のビルド">SpiderMonkey のビルド</h2> + +<p>この文書は SpiderMonkey の最新版をソースコードからビルドする方法を解説します。</p> + +<p><strong>ビルドを始める前に、必要なツールがインストールされていることを確認してください</strong>。<a href="/En/Developer_Guide/Build_Instructions/Linux_Prerequisites" title="en/Linux_Build_Prerequisites">Linux</a>, <a href="/En/Developer_Guide/Build_Instructions/Windows_Prerequisites" title="en/Windows_Build_Prerequisites">Windows</a>, <a href="/En/Developer_Guide/Build_Instructions/Mac_OS_X_Prerequisites" title="en/Mac_OS_X_Build_Prerequisites">Mac</a>, <a href="/En/Developer_Guide/Build_Instructions" title="en/Build_Documentation">その他の環境</a> での準備は、それぞれのドキュメントをごらんください。28 より古いバージョンのビルドをする際は、<a href="/ja/docs/Mozilla/Projects/NSPR">NSPR</a> が追加で必要となります。</p> + +<p style="margin: 0px 0px 1.7em; padding: 0px;">また <a class="internal" href="/En/SpiderMonkey/Getting_SpiderMonkey_source_code#Getting_the_latest_SpiderMonkey_source_code" title="En/SpiderMonkey/Getting SpiderMonkey source code#Getting the latest SpiderMonkey source code">SpiderMonkey 最新版のソースコード</a> も必要です。</p> + +<h3 id="非開発者向け_(最適化)_ビルド">非開発者向け (最適化) ビルド</h3> + +<p>実運用用のために SpiderMonkey をインストールする場合、またはパフォーマンスベンチマークを実行する場合は、これらの手順を使用してください (SpiderMonkey を C++ アプリケーションのライブラリとして使用したい場合、または SpiderMonkey 自体の改善に取り組んでいる場合は、代わりに下記のように開発者/デバッグビルドを行ってください)。</p> + +<pre class="eval line-numbers language-html">cd js/src +autoconf2.13 + +# この名前は、バージョン管理システムで無視させるために "_OPT.OBJ" で終わる必要があります。 +mkdir build_OPT.OBJ +cd build_OPT.OBJ +../configure +# Windows では "mozmake" を使います。 +make +</pre> + +<p>これについてのいくつかのメモ:</p> + +<ul> + <li> + <p>最も一般的なビルドの問題は依存関係の問題です。<a href="/ja/docs/Mozilla/Developer_Guide/Build_Documentation#Getting_started">プラットフォーム用のビルド前提条件ページ</a>を見てください。</p> + </li> + <li> + <p>SpiderMonkey はソースディレクトリでの構築をサポートしていません。上記のように、別のビルドディレクトリに設定してビルドする必要があります。</p> + </li> + <li> + <p>はい、autoconf バージョン 2.13 が本当に必要です。 それ以降のバージョンは動作しません (ただし、システムの autoconf としてインストールしないでください。これも機能しません。そのバージョンは非常に古いため、お勧めできません)。</p> + </li> +</ul> + +<div class="note"> +<p><strong>メモ</strong>: Mac を使用していて、次のようなエラーが表示される場合</p> + +<p>"<code>checking whether the C compiler (gcc-4.2 ) works... no<br> + configure: error: installation or configuration problem: C compiler cannot create executables.</code>"</p> + +<p>次のように設定してみてください。</p> + +<pre><code>CC=clang CXX=clang++ ../configure</code></pre> + +<p>baldrdash がコンパイルに失敗する可能性もあります。</p> + +<pre class="line-numbers language-html"><code class="language-html">/usr/local/Cellar/llvm/7.0.1/lib/clang/7.0.1/include/inttypes.h:30:15: fatal error: 'inttypes.h' file not found + +/usr/local/Cellar/llvm/7.0.1/lib/clang/7.0.1/include/inttypes.h:30:15: fatal error: 'inttypes.h' file not found, err: true</code></pre> + +<p>これは Mohave 以降、ヘッダーが /usr/include にインストールされなくなったためです。コマンドラインツール -> 新機能の下の<a href="https://developer.apple.com/documentation/xcode_release_notes/xcode_10_release_notes">リリースノート</a>を参照してください。</p> + +<p>リリースノートには、この互換性パッケージは近い将来提供されなくなると記載されているので、macOS 上のビルドシステムは SDK のヘッダを探すように適合させる必要があるでしょう。<br> + <br> + それまでは、次のことが役に立ちます。</p> + +<pre><code>open /Library/Developer/CommandLineTools/Packages/macOS_SDK_headers_for_macOS_10.14.pk +</code></pre> +</div> + +<p>これにより <code>build-release/dist/bin</code> ディレクトリに <code>js</code> という実行可能ファイルが構築されます。ヘルプページを表示する <code>dist/bin/js --help</code> でテストできます。これで、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell">シェルを実行して試す</a>準備が整いました。</p> + +<p>Mac、Linux、または UNIX では、追加のコマンド <code>make install</code> を使用してシステムに SpiderMonkey をインストールできます。これは共有ライブラリを <code>/usr/local/lib</code> に、C ヘッダファイルを <code>usr/local/include</code> に、そして <code>js</code> 実行ファイルを <code>/usr/local/bin</code> にインストールします。</p> + +<h3 id="開発者向け(デバッグ用)ビルド">開発者向け(デバッグ用)ビルド</h3> + +<p>SpiderMonkey 自身の開発やデバッグを目的とする場合、日々のデバッグにはデバッグビルドを、パフォーマンステストには最適化ビルドを、それぞれ別のディレクトリで行うことになります。デバッグビルドを行うには、上記の手順に加えて以下の 3 ステップを行います:</p> + +<pre class="eval">cd js/src +autoconf-2.13 + +# This name should end with "_DBG.OBJ" to make the version control system ignore it. +mkdir build_DBG.OBJ +cd build_DBG.OBJ +../configure --enable-debug --disable-optimize +# Use "mozmake" on Windows +make +</pre> + +<p><code>JS_GC_ZEAL</code> オプションをつけてビルドすると、zealous ガベージコレクションが有効になります。これはメモリリークに代表されるメモリ関連のデバッグを行う時に有用です。詳細は <a class="internal" href="/SpiderMonkey/JSAPI_Reference/JS_SetGCZeal" title="En/SpiderMonkey/JSAPI Reference/JS SetGCZeal"><code>JS_SetGCZeal()</code></a> をご覧ください。</p> + +<p>この他のビルドオプションについては、上記で作成したビルドディレクトリ内で次のコマンドを実行してください:</p> + +<pre class="eval">../configure --help +</pre> + +<h4 id="コンパイルデータベースの生成">コンパイルデータベースの生成</h4> + +<p>一部のツール (IDE、静的アナライザー、リファクタリングツールなど) は、ソフトウェアを構築するために必要なすべての要素の説明を含む <code><a href="https://clang.llvm.org/docs/JSONCompilationDatabase.html">compile_commands.json</a></code> というファイルを使用するため、ツールは構築システムも理解する必要はありません。</p> + +<p>SpiderMonkey 設定スクリプトを使用して <code>compile_commands.json</code> を生成するには、次のように CompileDB バックエンドを有効にします。</p> + +<pre class="syntaxbox"> ../configure <options> --enable-build-backends=CompileDB,RecursiveMake +</pre> + +<p>(RecursiveMake はあなたもビルドできるようになりたいと思うのでそこにあります!)</p> + +<h3 id="Building" name="Building">Windows でのビルド</h3> + +<div class="note"> +<p>バージョン 28 以降、<strong>スレッドセーフビルドがデフォルト</strong>となり、すべての POSIX プラットフォームでそのまま使用できるはずです。したがって、次の手順は Windows を使用している場合、または古いバージョンの SpiderMonkey をコンパイルしている場合にのみ関係があります。</p> +</div> + +<p>The <a href="https://wiki.mozilla.org/MozillaBuild">MozillaBuild</a> batch file you used to open your shell (e.g. <code>start-shell-msvc2013.bat</code> or <code>start-shell-msvc2013-x64.bat</code>) determines whether the compiler toolchain will target 32-bit or 64-bit builds. To create a 64-bit build, note that you must configure with <code>--target=x86_64-pc-mingw32 --host=x86_64-pc-mingw32</code>.</p> + +<p>Since the POSIX NSPR emulation is not available for Windows, a working version of NSPR must be available to your build. <strong>The easiest option is to configure with <code>--enable-nspr-build.</code></strong><code> </code>This configure option builds the in-tree version of NSPR which is probably what you want; <span style="line-height: normal;"><span style="line-height: normal;">because SpiderMonkey uses newer NSPR symbols, the NSPR that ships with your operating system probably does not work.</span></span></p> + +<p>If <code>--enable-nspr-build</code> does not work, explicitly tell <code>configure</code> where to find NSPR using the <code>--with-nspr-cflags</code> and <code>--with-nspr-libs</code> configure options. For example, assuming your local NSPR has been installed to <code>C:/mozilla-build/msys/local</code>:</p> + +<pre><span style="line-height: normal;"><code><span style="line-height: normal;"><code><code>./configure<code> --with-nspr-cflags="-IC:/mozilla-build/msys/local/include" \ + --with-nspr-libs="<span style="line-height: normal;"><code><span style="line-height: normal;"><code><code><code>C:/mozilla-build/msys/local</code></code></code></span></code></span>/lib/libnspr4.a \ + <span style="line-height: normal;"><code><span style="line-height: normal;"><code><code><code>C:/mozilla-build/msys/local</code></code></code></span></code></span>/lib/libplds4.a \ + <span style="line-height: normal;"><code><span style="line-height: normal;"><code><code><code>C:/mozilla-build/msys/local</code></code></code></span></code></span>/lib/libplc4.a"</code> +</code></code></span></code></span></pre> + +<p>If you get symbol loading or dynamic library errors, you can force the correct NSPR to load with:</p> + +<pre class="line-numbers language-html"><code class="language-html">PATH="$PATH;C:/mozilla-build/msys/local/lib/" ./js</code></pre> + +<h2 id="Specifying_installation_directories">Specifying installation directories</h2> + +<p><code>make install</code> puts files in the following directories by default. You can override this by passing options to the <code>configure</code> script:</p> + +<table class="standard-table"> + <tbody> + <tr> + <th>What it is</th> + <th>Where it gets put</th> + <th><code>configure</code> option</th> + </tr> + <tr> + <td>executables, shell scripts</td> + <td><code>/usr/local/bin</code></td> + <td><code>--bindir</code></td> + </tr> + <tr> + <td>libraries, data</td> + <td><code>/usr/local/lib</code></td> + <td><code>--libdir</code></td> + </tr> + <tr> + <td>architecture-independent data</td> + <td><code>/usr/local/share</code></td> + <td><code>--sharedir</code></td> + </tr> + <tr> + <td>C header files</td> + <td><code>/usr/local/include</code></td> + <td><code>--includedir</code></td> + </tr> + </tbody> +</table> + +<p>For convenience, you can pass the <code>configure</code> script an option of the form <code>--prefix=<PREFIXDIR></code>, which substitutes <code><PREFIXDIR></code> for <code>/usr/local</code> in all the settings above, in one step. This is usually the least troublesome thing to do, as it preserves the typical arrangement of <code>lib</code>, <code>bin</code>, and the rest.</p> + +<div class="note"><strong>Note:</strong> All directories you pass to <code>configure</code> are recorded in the generated makefile, so you don't need to specify them again until you re-run <code>configure</code>.</div> + +<h2 id="Building_SpiderMonkey_as_a_static_library">Building SpiderMonkey as a static library</h2> + +<p>By default, SpiderMonkey builds as a shared library. However, you can build SpiderMonkey as a static library by specifying the <code>--disable-shared-js</code> flag when you run <code>configure</code>.</p> + +<h2 id="Specifying_compilers_and_compiler_flags">Specifying compilers and compiler flags</h2> + +<p>If you want to use a compiler other than the one the <code>configure</code> script chooses for you by default, you can set the <code>CXX</code> variable in the environment when you run <code>configure</code>. This will save the values you specify in the generated makefile, so once you've set it, you don't need to do so again until you re-run <code>configure</code>.</p> + +<p>If you'd like to pass certain flags to the compiler, you can set the <code>CXXFLAGS</code> environment variable when you run <code>configure</code>. For example, if you're using the GNU toolchain, the following will pass the <code>-g3</code> flag to the compiler, causing it to emit debug information about macros. Then you can use those macros in <code>gdb</code> commands:</p> + +<pre class="eval line-numbers language-html"><code class="language-html">$ CXXFLAGS=-g3 $SRC/configure +... +checking whether the C++ compiler (c++ -g3 ) works... yes +... +$</code></pre> + +<h2 id="Cross-compiling_options">Cross-compiling options</h2> + +<p>For cross-compiling you will need a cross-compiling compiler. That tends to be easier with clang as clang has cross-compiling support built in. You may need other libraries though. For example on debian linux you'll need the following to cross compile from x86_64 to x86.</p> + +<pre class="syntaxbox">apt install clang libstdc++-8-dev-i386-cross binutils-i686-gnu zlib1g-dev:i386</pre> + +<p>You'll also need rust, in addition to having normal rust set up you'll need to add another target to your existing rust toolchain (don't add a new toolchain spidermonkey will use only one toolchain and use it for both host and target code:</p> + +<pre class="syntaxbox">rustup target add i686-unknown-linux-gnu</pre> + +<p>To build a 32-bit version on a 64-bit Linux system, you can use the following:</p> + +<pre class="eval line-numbers language-html"><code class="language-html">PKG_CONFIG_LIBDIR=/usr/lib/pkgconfig CC="gcc -m32 -mfpmath=sse -msse -msse2" CXX="g++ -m32 -mfpmath=sse -msse -msse2" AR=ar \ +$SRC/configure --target=i686-pc-linux</code></pre> + +<p>Or for clang.</p> + +<pre class="syntaxbox">$SRC/configure --target=i686-pc-linux-gnu</pre> + +<p>To build a 32-bit arm version on a 64-bit Linux system, that runs in the arm simulator, you can use the following:</p> + +<pre class="line-numbers language-html"><code class="language-html"> AR=ar CC="gcc -m32 -mfpmath=sse -msse -msse2" CXX="g++ -m32 -mfpmath=sse -msse -msse2" \ + $SRC/configure --target=i686-pc-linux --enable-simulator=arm</code></pre> + +<p>To build a 32-bit version on a 64-bit Mac system (the target version is specific to your OS/X SDK), you can use the following:</p> + +<pre class="syntaxbox">$SRC/configure --target=i386-apple-darwin16.7.0 # Choose the appropriate SDK version for your version of OS/X</pre> + +<p>To build a 64-bit version on a 32-bit Mac system (e.g. Mac OS X 10.5), you can use the following:</p> + +<pre class="eval line-numbers language-html"><code class="language-html">AR=ar CC="gcc -m64" CXX="g++ -m64" ../configure --target=x86_64-apple-darwin10.0.0</code></pre> + +<p>To build a 64-bit Windows version, you can use the following:</p> + +<pre class="eval line-numbers language-html"><code class="language-html">$SRC/configure --host=x86_64-pc-mingw32 --target=x86_64-pc-mingw32</code></pre> + +<div class="note"><strong>Note:</strong> You must have started your MozillaBuild shell with the proper -x64.bat script in order for the 64-bit compilers to be in your PATH.</div> + +<p>Whatever compiler and flags you pass to <code>configure</code> are recorded in the generated makefile, so you don't need to specify them again until you re-run <code>configure</code>.</p> + +<h2 id="Building_your_application">Building your application</h2> + +<p>While "How to build your complete application" is clearly out of scope for this document, here are some tips that will help get you on your way:</p> + +<ul> + <li>The SpiderMonkey developers frequently and deliberately change the JSAPI ABI. You cannot use headers built for one version/configuration of JSAPI to create object files which will be linked against another.</li> + <li>Support for JS_THREADSAFE was recently removed, and threadsafe builds are now enabled by default.</li> + <li>The <code>js-config</code> script, described below, is the recommended way to determine correct include paths, required libraries, etc. for your embedding to use during compilation. We highly recommend calling the <code>js-config</code> script from your embedding's makefile to set your CFLAGS, LDFLAGS, and so forth.</li> + <li>To install SpiderMonkey somewhere other than the default, you must use the <code>configure</code> <code>--prefix</code> option, as described above. Failure to do so may break your <code>js-config.h</code> header or <code>js-config</code> script.</li> + <li>Some features detected by the <code>configure</code> script do not work for cross-compilation.</li> +</ul> + +<h3 id="Using_the_js-config_script">Using the js-config script</h3> + +<p>In addition to the SpiderMonkey libraries, header files, and shell, the SpiderMonkey build also produces a shell script named <code>js-config</code> which other build systems can use to find out how to compile code using the SpiderMonkey APIs, and how to link with the SpiderMonkey libraries.</p> + +<div class="note"><strong>Note:</strong> In SpiderMonkey 1.8.5, the js-config script is not generated properly on many platforms. If the instructions below do not work, you can try this <a href="https://developer.mozilla.org/en/SpiderMonkey/1.8.5#js-config" title="https://developer.mozilla.org/en/SpiderMonkey/1.8.5#js-config">workaround</a>.</div> + +<p>When invoked with the <code>--cflags</code> option, <code>js-config</code> prints the flags that you should pass to the C compiler when compiling files that use the SpiderMonkey API. These flags ensure the compiler will find the SpiderMonkey header files.</p> + +<pre class="eval line-numbers language-html"><code class="language-html">$ ./js-config --cflags # Example output: -I/usr/local/include/js -I/usr/include/nspr</code></pre> + +<p>When invoked with the <code>--libs</code> option, <code>js-config</code> prints the flags that you should pass to the C compiler when linking an executable or shared library that uses SpiderMonkey. These flags ensure the compiler will find the SpiderMonkey libraries, along with any libraries that SpiderMonkey itself depends upon (like NSPR).</p> + +<pre class="eval line-numbers language-html"><code class="language-html">$ ./js-config --libs # Example output: -L/usr/local/lib -lmozjs -L/usr/lib -lplds4 -lplc4 -lnspr4 -lpthread -ldl -ldl -lm -lm -ldl</code></pre> + +<h2 id="Test" name="Test">Testing SpiderMonkey</h2> + +<ul> + <li> + <p>Run <code>${BUILDDIR}/dist/bin/js </code><code>Y.js</code> and check if appropriate output is printed. (It should say: <code>5! is 120</code>.)</p> + </li> + <li> + <p>Run the main test suite by running <code>./tests/jstests.py ${BUILDDIR}/dist/bin/js</code></p> + </li> + <li> + <p>Run JIT-specific tests by running: <code>./jit-test/jit_test.py ${BUILDDIR}/dist/bin/js</code></p> + </li> +</ul> + +<h2 id="Building_SpiderMonkey_1.8_or_earlier">Building SpiderMonkey 1.8 or earlier</h2> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">Use these instructions to build SpiderMonkey from an official source release or from the old CVS repository. To build the latest SpiderMonkey sources from Mercurial, see <a href="https://developer.mozilla.org/ja/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation$edit#Building_SpiderMonkey_tip" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;">Building SpiderMonkey </a>above.</p> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;"><a href="https://developer.mozilla.org/en/SpiderMonkey" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="en/SpiderMonkey">SpiderMonkey</a> is easy to build from source if you have the usual Mozilla build prerequisites installed. Before you begin, make sure you have right build tools for your computer: <a href="https://developer.mozilla.org/en/Developer_Guide/Build_Instructions/Linux_Prerequisites" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="en/Linux_Build_Prerequisites">Linux</a>, <a href="https://developer.mozilla.org/en/Developer_Guide/Build_Instructions/Windows_Prerequisites" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="en/Windows_Build_Prerequisites">Windows</a>, <a href="https://developer.mozilla.org/en/Developer_Guide/Build_Instructions/Mac_OS_X_Prerequisites" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="en/Mac_OS_X_Build_Prerequisites">Mac</a>, <a href="https://developer.mozilla.org/en/Developer_Guide/Build_Instructions" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="en/Build_Documentation">others</a>.</p> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">First, download a SpiderMonkey source distribution, such as <a class="external external-icon" href="http://ftp.mozilla.org/pub/mozilla.org/js/js-1.8.0-rc1.tar.gz" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;">SpiderMonkey 1.8 Release Candidate 1</a>.</p> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">To build, use these commands:</p> + +<pre class="eval line-numbers language-html" style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 15px; padding-right: 15px; padding-bottom: 15px; padding-left: 15px; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-top-style: dotted; border-right-style: dotted; border-bottom-style: dotted; border-left-style: dotted; background-clip: initial; background-color: rgb(246, 246, 242); font: normal normal normal 100%/normal 'Courier New', 'Andale Mono', monospace;"><code class="language-html">tar xvzf js-1.8.0-rc1.tar.gz +cd js/src +make -f Makefile.ref</code></pre> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">This builds a debug version of SpiderMonkey. All build files are created in a subdirectory named depending on your system (for example,<code style="font: normal normal normal 100%/normal 'Courier New', 'Andale Mono', monospace; color: inherit; font-weight: inherit;">Linux_All_DBG.OBJ</code> if you are on Linux). To install this build on your system, see <a class="external external-icon" href="http://ebixio.com/blog/2010/07/31/how-to-install-libjs-spidermonkey/" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="http://ebixio.com/blog/2010/07/31/how-to-install-libjs-spidermonkey/">SpiderMonkey installation instructions</a>.</p> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">To build an optimized (non-debug) version of SpiderMonkey:</p> + +<pre class="eval line-numbers language-html" style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 15px; padding-right: 15px; padding-bottom: 15px; padding-left: 15px; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-top-style: dotted; border-right-style: dotted; border-bottom-style: dotted; border-left-style: dotted; background-clip: initial; background-color: rgb(246, 246, 242); font: normal normal normal 100%/normal 'Courier New', 'Andale Mono', monospace;"><code class="language-html">make BUILD_OPT=1 -f Makefile.ref</code></pre> + +<p style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px;">To build a <a href="https://developer.mozilla.org/en/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE" style="text-decoration: none; color: rgb(51, 102, 153) !important; cursor: default;" title="JS_THREADSAFE">thread-safe</a> version of SpiderMonkey:</p> + +<pre class="eval line-numbers language-html" style="margin-top: 0px; margin-right: 0px; margin-bottom: 1.286em; margin-left: 0px; padding-top: 15px; padding-right: 15px; padding-bottom: 15px; padding-left: 15px; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-top-style: dotted; border-right-style: dotted; border-bottom-style: dotted; border-left-style: dotted; background-clip: initial; background-color: rgb(246, 246, 242); font: normal normal normal 100%/normal 'Courier New', 'Andale Mono', monospace;"><code class="language-html">make JS_DIST=/full/path/to/directory/containing/nspr JS_THREADSAFE=1 -f Makefile.ref</code></pre> diff --git a/files/ja/mozilla/projects/spidermonkey/bytecodes/index.html b/files/ja/mozilla/projects/spidermonkey/bytecodes/index.html new file mode 100644 index 0000000000..a9ddaeee75 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/bytecodes/index.html @@ -0,0 +1,30 @@ +--- +title: バイトコード +slug: Mozilla/Projects/SpiderMonkey/Bytecodes +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Internals/Bytecodes +--- +<div>{{SpiderMonkeySidebar("Internals")}}</div> + +<h2 id="バックグラウンド">バックグラウンド</h2> + +<p>SpiderMonkey バイトコードは、JavaScript エンジンで使用される標準形式のコード表現です。JavaScript フロントエンドは、ソーステキストから AST を構築してから、その AST から JSScript データ構造の一部としてスタックベースのバイトコードを生成します。バイトコードは、JSScript データ構造にも含まれているアトムとオブジェクトを (通常は配列インデックスで) 参照できます。</p> + +<p>エンジン内では、すべてのバイトコードはスタックフレーム内で実行されます。グローバル (最上位) コードでも eval コードでもスタックフレームが関連付けられています。スタック上のフレームには、いくつかの異なるカテゴリの JavaScript 値 (タグ付き値形式) 用のスペースがあります。単一の JavaScript 値のスペースは「スロット」と呼ばれ、カテゴリは次のとおりです。</p> + +<ul> + <li>引数スロット: 現在のフレームに渡される実際の引数を保持します</li> + <li>ローカルスロット: 現在のコードで使用されているローカル変数を保持します</li> + <li>式スロット: スタック上で式を計算するために必要な一時スペースを保持します。たとえば、<code>(a + b) + c</code> では、a をプッシュしてから b をプッシュして add をプッシュし、さらに c をプッシュから add のようにします。これには、最大2つの式スロットの深さが必要です</li> +</ul> + +<p><code>this</code> のような値と呼び出し先/戻り値を保持する、専用の機能のために予約されているいくつかのスロットもあります。</p> + +<p>式スタックにプッシュされた最新の値に対応する "Top of Stack" (TOS) が常にあります。すべてのバイトコードは、この場所に関して暗黙的に機能します。</p> + +<h2 id="バイトコードリスト">バイトコードリスト</h2> + +<p>すべてのオペコードには、実行全体のスタック効果を表すために [-popcount, +pushcount] という注釈が付けられています。</p> + +<p>バイトコードのリストは <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Internals/Bytecode">SpiderMonkey の内部: バイトコードの説明ページ</a>に移動しました。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/creating_javascript_jstest_reftests/index.html b/files/ja/mozilla/projects/spidermonkey/creating_javascript_jstest_reftests/index.html new file mode 100644 index 0000000000..5a438b7932 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/creating_javascript_jstest_reftests/index.html @@ -0,0 +1,9 @@ +--- +title: JavaScript jstest reftests を作成する +slug: Mozilla/Projects/SpiderMonkey/Creating_JavaScript_jstest_reftests +tags: + - Junk + - NeedsUpdate +translation_of: Mozilla/Projects/SpiderMonkey/Creating_JavaScript_jstest_reftests +--- +<p>このページにはすぐにコンテンツが表示されます。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/creating_javascript_tests/index.html b/files/ja/mozilla/projects/spidermonkey/creating_javascript_tests/index.html new file mode 100644 index 0000000000..d093c38e42 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/creating_javascript_tests/index.html @@ -0,0 +1,77 @@ +--- +title: JavaScript のテストを作成する +slug: Mozilla/Projects/SpiderMonkey/Creating_JavaScript_tests +translation_of: Mozilla/Projects/SpiderMonkey/Creating_JavaScript_tests +--- +<div>{{SpiderMonkeySidebar("Tests")}}</div> + +<div class="summary"> +<p>主に 2 つの SpiderMonkey テストスイート: <strong>jstests</strong> (in js/src/tests) と <strong>jit-tests</strong> (in js/src/jit-test) があります。詳細については、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Running_Automated_JavaScript_Tests">自動 JavaScript テストの実行</a>を参照してください。</p> +</div> + +<p>新しいテストはどのテストスイートに属しますか?</p> + +<ol> + <li><strong>jit-tests</strong> は JIT の実装をテストすることを目的としています。正当性や機能性をテストするテストのみをこれらのスイートに追加してください。</li> + <li><strong>jstests</strong> is intended for tests of language-visible functionality. Please put tests of functionality into jstests even if related tests are in jit-tests, since jstests are closer to (and more easily converted to) <a href="https://github.com/tc39/test262/blob/master/README.md">test262</a> tests. (In fact, the test262 test suite is run as part of jstests.)</li> +</ol> + +<p>Practical differences between the two test suites:</p> + +<ol> +</ol> + +<p><strong>jstest</strong></p> + +<ol> + <li><strong>New jstest files </strong>should be put the code in the appropriate subdirectory of js/src/tests/non262/, or, under some scenarios, contributed directly to the <a href="https://github.com/tc39/test262/blob/master/README.md">test262 repository</a>.</li> + <li>jstests run in both the shell and the browser (although you can specify that the test should be run in only one of the two locations).</li> + <li>jstests automatically load js/src/tests/shell.js before they run, which creates a ton of functions.</li> + <li>Read more advice on jstests <a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Creating_JavaScript_tests/jsreftests">here</a>.</li> +</ol> + +<p><strong>jit-test</strong></p> + +<ol> + <li><strong>New jit-test files </strong>should be put in js/src/jit-test/tests/basic or one of the other appropriate subdirectories of jit-test/tests. </li> + <li>jit-tests run only in the shell.</li> + <li>jit-tests do not load extra test functionality automatically.</li> +</ol> + +<h2 id="Creating_the_test_case_file" name="Creating_the_test_case_file">新しいテストファイルを書く</h2> + +<p>Have a look at the existing files and follow what they do. All tests, in both suite, can use the <em>assertEq</em> function.</p> + +<p><strong>assertEq(v1, v2[, message])</strong></p> + +<p style="margin-left: 40px;">Check that v1 and v2 are the same value. If they're not, throw an exception (which will cause the test to fail).</p> + +<p>If you are writing a jstests, additional testing functionality is provided for you in shell.js files. You can read about them <a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Running_Automated_JavaScript_Tests">here</a>.</p> + +<h3 id="Performance_testing" name="Performance_testing">Performance testing and general advice</h3> + +<p><strong>Do not</strong> attempt to test the performance of engine features in the test suite. </p> + +<p>Please keep in mind that the JavaScript test suite is run on a wide variety of wildly varying hardware plaforms, from phones all the way up to servers. Even tests that check for polynomial time complexity will start to fail in a few years when they have sped up enough to run faster than the granularity of the OS scheduler or when run on platforms with higher latencies than your development workstation. These tests will also show up as infrequent oranges on our heavily loaded test machines, lowering the value of our test suite for everyone. Just don't do it, it's never worth it.</p> + +<p><strong>Do not</strong> add performance tests to the test suite.</p> + +<p>It is not generally even possible to tell if the speed of any particular feature is going to be important in the real world without running a real-world benchmark. It is <em>very</em> hard to write a good real-world benchmark. For this reason, the best place to find out if a change is performance sensitive is on arewefastyet.com.</p> + +<p><strong>Focus on writing fast, light tests that cover a single feature. There is basically no cost to adding a new test, so add as many feature tests as needed to cover each feature orthogonally. Remember that whenever a test fails, someone -- probably you -- is going to have to figure out what went wrong.</strong></p> + +<h3 id="Testing_your_test">Testing your test</h3> + +<p>Run your new test locally before checking it in (or posting it for review). Nobody likes patches that include failing tests!</p> + +<p>See<a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Running_Automated_JavaScript_Tests"> Running Automated Javascript Tests</a> for instructions on how to run jstests or jit-tests.</p> + +<p>It's also a good sanity check to run each new test against an unpatched shell or browser. The test should fail if it's working properly.</p> + +<h3 id="Checking_in_completed_tests" name="Checking_in_completed_tests">Checking in completed tests</h3> + +<p>Tests are usually reviewed and pushed just like any other code change. Just include the test in your patch.</p> + +<p><strong>Security-sensitive tests should <strong>not</strong> be committed</strong> until the corresponding bug has been made public. Instead, ask a SpiderMonkey peer how to proceed.</p> + +<p>It is OK under certain circumstances to push new tests to certain repositories without a code review. Don't do this unless you know what you're doing. Ask a SpiderMonkey peer for details.</p> diff --git a/files/ja/mozilla/projects/spidermonkey/foss/index.html b/files/ja/mozilla/projects/spidermonkey/foss/index.html new file mode 100644 index 0000000000..70ad9afcb6 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/foss/index.html @@ -0,0 +1,97 @@ +--- +title: FOSS +slug: Mozilla/Projects/SpiderMonkey/FOSS +tags: + - Guide + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/FOSS +--- +<div>{{SpiderMonkeySidebar}}</div> + +<p>自身の SpiderMonkey ベースのオープンソースプロジェクトを追加してください (必要ならばカテゴリを追加してください) !</p> + +<h2 id="ラッパーバインディング">ラッパー/バインディング</h2> + +<h3 id="C">C++</h3> + +<ul> + <li><a href="https://github.com/cocos2d/cocos2d-js">Cocos2d-JS</a> - Cocos2d-JS は SpiderMonkey を組み込んだクロスプラットフォームのゲームエンジンで、Web とネイティブプラットフォームの両方に同じ API を提供します。<a href="http://www.cocos2d-x.org/wiki/Getting_Started_Cocos2d-js">Getting started here</a>.</li> + <li><a class="external" href="http://flusspferd.org/" title="http://flusspferd.org/">Flusspferd</a> - (新しい) C++ バインディング</li> + <li><a href="http://code.google.com/p/libjspp/" title="http://code.google.com/p/libjspp/">libjspp</a> - SpiderMonkey を拡張して埋め込むための C++ テンプレートベースのライブラリ。SpiderMonkey 1.8.5 以降で動作します。</li> + <li style="text-align: left;"><a class="external" href="http://spiderape.sourceforge.net/" title="http://spiderape.sourceforge.net/">Spiderape</a> - SpiderMonkey の最も古い C++ バインディング</li> + <li><a class="external text" href="http://www.trixul.com/" rel="nofollow" title="http://www.trixul.com/">TriXUL</a> - <a class="external text" href="http://trixul.cvs.sourceforge.net/trixul/trixul/layout/jsengine" rel="nofollow" title="http://trixul.cvs.sourceforge.net/trixul/trixul/layout/jsengine">(TriXUL CVS)</a> - Trixul XML ベースの GUI ツールキットは、SpiderMonkey を組み込み、JavaScript を使用してその GUI の背後にロジックを実装し、JavaScript から C++ オブジェクトへの呼び出しをサポートします。</li> +</ul> + +<h3 id="Rust">Rust</h3> + +<ul> + <li><a class="external" href="https://crates.io/crates/mozjs" title="http://live.gnome.org/Gjs">mozjs</a> - <a href="https://servo.org/">Servo</a> で使用されている Rust バインディング</li> +</ul> + +<h3 id="GNOME">GNOME</h3> + +<ul> + <li><a class="external" href="http://live.gnome.org/Gjs" title="http://live.gnome.org/Gjs">gjs</a> - GNOME への JavaScript バインディング(概して、GObject のイントロスペクションメカニズムを使用している任意のライブラリへの)</li> +</ul> + +<h3 id="Objective_Caml">Objective Caml</h3> + +<ul> + <li><a class="external" href="http://alain.frisch.fr/soft.html#spider" title="http://alain.frisch.fr/soft.html#spider">http://alain.frisch.fr/soft.html#spider</a> - OCaml アプリケーションに SpiderMonkey を埋め込むためのバインディング</li> +</ul> + +<h3 id="Perl">Perl</h3> + +<ul> + <li><a class="external" href="http://jspl.msg.mx/" title="http://jspl.msg.mx/">http://jspl.msg.mx/</a> - SpiderMonkey と Perl を相互に埋め込むためのバインディング。JavaScript から CPAN モジュールを使用できるようにする JS シェルが含まれています。</li> +</ul> + +<h3 id="Python">Python</h3> + +<ul> + <li><a class="external" href="http://pypi.python.org/pypi/python-spidermonkey" title="http://pypi.python.org/pypi/python-spidermonkey">http://pypi.python.org/pypi/python-spidermonkey</a></li> +</ul> + +<h3 id="wxWidgets">wxWidgets</h3> + +<ul> + <li><a class="external" href="http://gluescript.sourceforge.net/" title="http://gluescript.sourceforge.net/">GLUEscript</a> (formerly <a class="external" href="http://www.wxjavascript.net/" title="http://www.wxjavascript.net/">wxJavaScript</a>)</li> +</ul> + +<h3 id="Code_generators">Code generators</h3> + +<ul> + <li><a class="external" href="http://jsapigen.sourceforge.net" title="http://jsapigen.sourceforge.net/">jsapigen</a> - C アプリケーションに SpiderMonkey を埋め込むためのバインディングを生成する</li> +</ul> + +<h2 id="拡張機能">拡張機能</h2> + +<ul> + <li> + <p><a class="external" href="http://code.google.com/p/jslibs/" title="http://code.google.com/p/jslibs/">http://code.google.com/p/jslibs/</a> - <a class="external" href="http://en.wikipedia.org/wiki/Zlib" title="Zlib">zlib</a>, <a class="external" href="http://en.wikipedia.org/wiki/SQLite" title="SQLite">SQLite</a>, <a class="mw-redirect external" href="http://en.wikipedia.org/wiki/NSPR" title="NSPR">NSPR</a>, <a class="external" href="http://en.wikipedia.org/wiki/Open_Dynamics_Engine" title="Open Dynamics Engine">ode</a>, <a class="external" href="http://en.wikipedia.org/wiki/Libpng" title="Libpng">libpng</a>, <a class="external" href="http://en.wikipedia.org/wiki/Libjpeg" title="Libjpeg">libjpeg</a>, <a class="external" href="http://en.wikipedia.org/wiki/Libffi" title="Libffi">libffi</a>, (...) SpiderMonkey 用のライブラリ</p> + </li> + <li> + <p><a class="external" href="http://www.jsdb.org/" title="http://www.jsdb.org/">http://www.jsdb.org/</a> - ファイル、ネットワーク、データベース、圧縮、メールなどのネイティブオブジェクトを含む JS シェル</p> + </li> + <li> + <p><a class="external" href="http://code.google.com/p/gpsee/" title="http://code.google.com/p/gpsee/"><u>http://code.google.com/p/gpsee/</u></a> - SpiderMonkey 用の commonJS プラットフォーム、母国語モジュールの相互運用方法、モジュールなど。既存の埋め込みを補完するように設計された GPSEE は、サンプルの簡単な埋め込み、スクリプトホスト、および Mozilla の JS シェルの拡張バージョンを同梱しています。バンドルされているモジュールには、ByteArray、ByteString、CGI、POSIX Signals、FFI などのサポートが含まれています。</p> + </li> + <li> + <p><a class="external" href="http://javalikescript.free.fr/" title="http://javalikescript.free.fr/">http://javalikescript.free.fr/</a> - 拡張可能なツーリングフレームワークを提供することを目的とした汎用 JavaScript プラットフォーム</p> + </li> + <li> + <p><a href="http://www.synchro.net/" title="http://www.synchro.net/">http://www.synchro.net/</a> - telnet/SSH 掲示板システム (BBS) とインターネットサーバ (HTTP/SMTP/FTP)。JavaScript で記述された追加のインターネットサービス(IRC、IMAP、Gopher など)。</p> + </li> + <li> + <p><a href="https://github.com/mindbit/libjssql/wiki" title="https://github.com/mindbit/libjssql/wiki">https://github.com/mindbit/libjssql/wiki</a> - JDBC にできるだけ似せた、JavaScript 用の汎用 SQL API を提供することを目的としたライブラリ</p> + </li> +</ul> + +<h2 id="その他">その他</h2> + +<ul> + <li><a class="external" href="http://groups.google.com/group/serverjs" title="http://groups.google.com/group/serverjs">ServerJS</a>, 細分化されたサーバサイドの Javascript の世界に対する標準化の取り組み</li> + <li><a class="external" href="http://play0ad.com/" title="http://wildfiregames.com/0ad/">0 A.D.</a>, JavaScript スクリプトを使った歴史的な RTS ゲーム</li> + <li><a class="external" href="http://soubok.googlepages.com/javascript" title="http://soubok.googlepages.com/javascript">http://soubok.googlepages.com/javascript</a></li> + <li><a class="external text" href="http://malzilla.sourceforge.net/" rel="nofollow" title="http://malzilla.sourceforge.net/">Malzilla</a> - SpiderMonkey を使用して、Web ページ上の JavaScript を難読化して<a href="https://ja.wikipedia.org/wiki/%E3%83%9E%E3%83%AB%E3%82%A6%E3%82%A7%E3%82%A2">マルウェア</a>を除去するためのツール</li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/getting_spidermonkey_source_code/index.html b/files/ja/mozilla/projects/spidermonkey/getting_spidermonkey_source_code/index.html new file mode 100644 index 0000000000..3296d837dc --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/getting_spidermonkey_source_code/index.html @@ -0,0 +1,90 @@ +--- +title: SpiderMonkeyソースコードの取得 +slug: Mozilla/Projects/SpiderMonkey/Getting_SpiderMonkey_source_code +tags: + - Guide + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Getting_SpiderMonkey_source_code +--- +<div>{{SpiderMonkeySidebar}}</div> + +<p>SpiderMonkey のソースコードは gzip 形式でも直接 Mercurial リポジトリからも入手できます。</p> + +<h2 id="gzip_で圧縮された_SpiderMonkey_のソースコードのダウンロード">gzip で圧縮された SpiderMonkey のソースコードのダウンロード</h2> + +<p>gzip で圧縮された SpiderMonkey のソースコードを次の URL からダウンロードできます:</p> + +<pre><span class="plain"><a href="http://ftp.mozilla.org/pub/mozilla.org/js/" title="http://ftp.mozilla.org/pub/mozilla.org/js/">http://ftp.mozilla.org/pub/mozilla.org/js/</a></span> +</pre> + +<p>コマンドラインから SpiderMonkey ソースコード ver24.2 をダウンロードして展開する例です:</p> + +<pre>mkdir mozilla +cd mozilla +wget <a href="http://ftp.mozilla.org/pub/mozilla.org/js/mozjs-24.2.0.tar.bz2">http://ftp.mozilla.org/pub/mozilla.org/js/mozjs-24.2.0.tar.bz2</a> +tar xjf mozjs-24.2.0.tar.bz2 +</pre> + +<p>These commands should work on most platforms including Windows, as long as on Windows you are using the <a href="/En/Developer_Guide/Build_Instructions/Windows_Prerequisites#mozillabuild" title="https://developer.mozilla.org/en/Windows_Build_Prerequisites#mozillabuild">MozillaBuild</a> bash shell.</p> + +<h2 id="Getting_the_latest_SpiderMonkey_source_code" name="Getting_the_latest_SpiderMonkey_source_code">Mercurial から最新の SpiderMonkey ソースコードを入手する</h2> + +<p>The <a href="/en/Mercurial" title="en/Mercurial">Mercurial</a> repository at <a class="external" href="http://hg.mozilla.org/mozilla-central/" title="http://hg.mozilla.org/mozilla-central/">http://hg.mozilla.org/mozilla-central/</a> hosts the latest SpiderMonkey sources. Mercurial is also known as hg.</p> + +<p>The following command line downloads the entire Mozilla repository, including the full change history and a lot of Gecko and Firefox source code that isn't part of SpiderMonkey. It also changes to the SpiderMonkey directory (js/src).</p> + +<pre class="eval">hg clone <span class="nowiki">http://hg.mozilla.org/mozilla-central/</span> +cd js/src +</pre> + +<p>To avoid getting the full change history, click the <code>zip</code> or <code>gz</code> links at <a class="external" href="http://hg.mozilla.org/index.cgi/mozilla-central/file/tip" title="http://hg.mozilla.org/index.cgi/mozilla-central/file/tip">http://hg.mozilla.org/index.cgi/mozilla-central/file/tip</a>. This fetches a snapshot of the current Mozilla tree.</p> + +<p>If you have problems with the instructions above, you can read the full details of using Mercurial to get Mozilla code <a href="https://developer.mozilla.org/en-US/docs/Developer_Guide/Source_Code/Mercurial" title="https://developer.mozilla.org/en-US/docs/Developer_Guide/Source_Code/Mercurial">here</a>. That page also contains links to several bundles, which can be useful if you have a poor network connection.</p> + +<h2 id="Getting_the_latest_SpiderMonkey_source_code" name="Getting_the_latest_SpiderMonkey_source_code">Git で最新の SpiderMonkey のソースコードを取得する</h2> + +<p>The following command line downloads the entire Mozilla repository, including the full change history and a lot of Gecko and Firefox source code that isn't part of SpiderMonkey. It also changes to the SpiderMonkey directory (js/src).</p> + +<pre class="eval">git clone https://github.com/mozilla/gecko-dev.git +cd gecko-dev/js/src +</pre> + +<p>If you want a faster (about 5 times as of January 2015) download, try doing a shallow clone (no version control history).</p> + +<pre class="eval">git clone --depth 1 https://github.com/mozilla/gecko-dev.git +</pre> + +<p>If you have any problems check the <a href="https://wiki.mozilla.org/Github" title="https://wiki.mozilla.org/Github">https://wiki.mozilla.org/Github</a> page.</p> + +<h2 id="Getting_older_SpiderMonkey_sources_from_CVS" name="Getting_older_SpiderMonkey_sources_from_CVS">CVS から古い SpiderMonkey ソースを入手する</h2> + +<div class="note"><strong>Note:</strong> You will need to explicitly fetch the JavaScript shell sources even if you currently build another Mozilla project, as there are files specific to the shell that are not normally found in a Mozilla source tree.</div> + +<p>Just like when you're fetching any other Mozilla project from CVS, you need to log into the CVS server first. To do this, <code>cd</code> into the base directory you'd like to check out the code into, then enter the following command at your command line:</p> + +<pre>cvs -d :pserver:anonymous@cvs-mirror.mozilla.org:/cvsroot login +</pre> + +<p>When prompted, enter the password <code>anonymous</code>.</p> + +<p>Once you've logged in, <code>cd</code> into the root of your CVS tree and enter the following command:</p> + +<pre>cvs -d :pserver:anonymous@cvs-mirror.mozilla.org:/cvsroot co -l mozilla/js/src mozilla/js/src/config mozilla/js/src/editline mozilla/js/src/fdlibm +</pre> + +<p>This checks out all the files needed in order to build the JavaScript shell.</p> + +<p>If you also want the regression tests, add this command:</p> + +<pre>cvs -d :pserver:anonymous@cvs-mirror.mozilla.org:/cvsroot co mozilla/js/tests +</pre> + +<h2 id="Getting_older_branch_versions_of_SpiderMonkey" name="Getting_older_branch_versions_of_SpiderMonkey">SpiderMonkey の古いブランチバージョンを入手する</h2> + +<p>If you want to experiment with a specific branch's version of SpiderMonkey, you need to check out js/src from branch but check out <code>editline</code> and <code>config</code> from trunk:</p> + +<pre>cvs -d :pserver:anonymous@cvs-mirror.mozilla.org:/cvsroot co -l -r <em><var>BRANCH_NAME</var></em> mozilla/js/src mozilla/js/src/fdlibm +cvs -d :pserver:anonymous@cvs-mirror.mozilla.org:/cvsroot co -l mozilla/js/src/config mozilla/js/src/editline +</pre> + +<p>Change <code><em>BRANCH_NAME</em></code> to the name of the branch you want to check out. You can use a JavaScript branch name (e.g. <code>JS_1_7_ALPHA_BRANCH</code>) or a Mozilla branch name (e.g. <code>MOZILLA_1_8_BRANCH</code>).</p> diff --git a/files/ja/mozilla/projects/spidermonkey/hacking_tips/index.html b/files/ja/mozilla/projects/spidermonkey/hacking_tips/index.html new file mode 100644 index 0000000000..933d9d64a4 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/hacking_tips/index.html @@ -0,0 +1,654 @@ +--- +title: ハッキングのヒント +slug: Mozilla/Projects/SpiderMonkey/Hacking_Tips +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Hacking_Tips +--- +<div>{{SpiderMonkeySidebar("Getting_started")}}</div> + +<p>このページには、SpiderMonkey に関連する問題の調査に役立つヒントがいくつか掲載されています。ここに記載されているヒントはすべて、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey">SpiderMonkey のビルドドキュメント</a>の最後に取得された JavaScript シェルを扱っています。2つの部分に分かれており、1つはデバッグに関するセクション、もう1つはドラフト最適化に関するセクションです。これらのヒントの多くは、JS シェルのデバッグビルドにのみ適用されます。それらはリリースビルドでは機能しません。</p> + +<h2 id="デバッグのヒント">デバッグのヒント</h2> + +<h3 id="ヘルプの入手_(JS_シェルから)">ヘルプの入手 (JS シェルから)</h3> + +<p><strong>help</strong> 関数を使用して、シェルのすべてのプリミティブ関数のリストを記述します。いくつかの関数は 'os' オブジェクトの下に移動されているので、<strong>help(os)</strong> はその "namespace" のメンバーだけを簡単に助けます。</p> + +<h3 id="関数のバイトコードを取得する_(JSシェルから)">関数のバイトコードを取得する (JSシェルから)</h3> + +<p>シェルには、関数のバイトコードをソースノートとともにダンプするための小さな関数 <strong>dis</strong> があります。引数がなければ、呼び出し元のバイトコードをダンプします。</p> + +<pre class="eval"><code>js> function f () { + return 1; +} +js> <strong>dis(</strong>f<strong>)</strong>; +flags: +loc op +----- -- +main: +00000: one +00001: return +00002: stop + +Source notes: + ofs line pc delta desc args +---- ---- ----- ------ -------- ------ + 0: 1 0 [ 0] newline + 1: 2 0 [ 0] colspan 2 + 3: 2 2 [ 2] colspan 9 + +</code></pre> + +<h3 id="関数のバイトコードを取得する_(gdbから)">関数のバイトコードを取得する (gdbから)</h3> + +<p><em>jsopcode.cpp</em> では、<strong>js::DisassembleAtPC</strong> という名前の関数が使用されています。PC はスクリプトのバイトコードを出力できます。<strong>js::DumpScript</strong> などのこの関数のいくつかの変種はデバッグに便利です。</p> + +<h3 id="JS_スタックのプリント_(gdbから)">JS スタックのプリント (gdbから)</h3> + +<p>jsobj.cppでは、<strong>js::DumpBacktrace</strong> という名前の関数が、JS スタックのバックトレース à la gdb を出力します。バックトレースには次の順序で、スタックの深さ、インタープリタフレームポインタ (<em>js/src/vm/Stack.h</em>、<strong>StackFrame</strong> クラスを参照) または IonMonkeyでコンパイルした場合は (nil)、コールロケーションのファイルと行番号、およびカッコの下に実行された JSScript ポインタと jsbytecode ポインタ (pc) が含まれます。</p> + +<pre class="eval"><code>$ gdb --args js +[…] +(gdb) b js::ReportOverRecursed +(gdb) r +js> function f(i) { + if (i % 2) f(i + 1); + else f(i + 3); +} +js> f(0) + +Breakpoint 1, js::ReportOverRecursed (maybecx=0xfdca70) at /home/nicolas/mozilla/ionmonkey/js/src/jscntxt.cpp:495 +495 if (maybecx) +(gdb) call <strong>js::DumpBacktrace(</strong>maybecx<strong>)</strong> +#0 (nil) typein:2 (0x7fffef1231c0 @ 0) +#1 (nil) typein:2 (0x7fffef1231c0 @ 24) +#2 (nil) typein:3 (0x7fffef1231c0 @ 47) +#3 (nil) typein:2 (0x7fffef1231c0 @ 24) +#4 (nil) typein:3 (0x7fffef1231c0 @ 47) +[…] +#25157 0x7fffefbbc250 typein:2 (0x7fffef1231c0 @ 24) +#25158 0x7fffefbbc1c8 typein:3 (0x7fffef1231c0 @ 47) +#25159 0x7fffefbbc140 typein:2 (0x7fffef1231c0 @ 24) +#25160 0x7fffefbbc0b8 typein:3 (0x7fffef1231c0 @ 47) +#25161 0x7fffefbbc030 typein:5 (0x7fffef123280 @ 9) + +</code></pre> + +<p>Note, you can do the exact same exercise above using <code>lldb</code> (necessary on OSX after Apple removed <code>gdb</code>) by running <code>lldb -f js</code> then following the remaining steps.</p> + +<p>Since SpiderMonkey 48, we have a gdb unwinder. This unwinder is able to read the frames created by the JIT, and to display the frames which are after these JIT frames.</p> + +<pre><code>$ gdb --args out/dist/bin/js ./foo.js +[…] +SpiderMonkey unwinder is disabled by default, to enable it type: + enable unwinder .* SpiderMonkey +(gdb) b js::math_cos +(gdb) run +[…] +#0 js::math_cos (cx=0x14f2640, argc=1, vp=0x7fffffff6a88) at js/src/jsmath.cpp:338 +338 CallArgs args = CallArgsFromVp(argc, vp); +(gdb) enable unwinder .* SpiderMonkey +(gdb) backtrace 10 +#0 0x0000000000f89979 in js::math_cos(JSContext*, unsigned int, JS::Value*) (cx=0x14f2640, argc=1, vp=0x7fffffff6a88) at js/src/jsmath.cpp:338 +#1 0x0000000000ca9c6e in js::CallJSNative(JSContext*, bool (*)(JSContext*, unsigned int, JS::Value*), JS::CallArgs const&) (cx=0x14f2640, native=0xf89960 , args=...) at js/src/jscntxtinlines.h:235 +#2 0x0000000000c87625 in js::Invoke(JSContext*, JS::CallArgs const&, js::MaybeConstruct) (cx=0x14f2640, args=..., construct=js::NO_CONSTRUCT) at js/src/vm/Interpreter.cpp:476 +#3 0x000000000069bdcf in js::jit::DoCallFallback(JSContext*, js::jit::BaselineFrame*, js::jit::ICCall_Fallback*, uint32_t, JS::Value*, JS::MutableHandleValue) (cx=0x14f2640, frame=0x7fffffff6ad8, stub_=0x1798838, argc=1, vp=0x7fffffff6a88, res=JSVAL_VOID) at js/src/jit/BaselineIC.cpp:6113 +#4 0x00007ffff7f41395 in </code><<JitFrame_Exit>><code> () +#5 0x00007ffff7f42223 in </code><<JitFrame_BaselineStub>><code> () +#6 0x00007ffff7f4423d in </code><<JitFrame_BaselineJS>><code> () +#7 0x00007ffff7f4222e in </code><<JitFrame_BaselineStub>><code> () +#8 0x00007ffff7f4326a in </code><<JitFrame_BaselineJS>><code> () +#9 0x00007ffff7f38d5f in </code><<JitFrame_Entry>><code> () +#10 0x00000000006a86de in EnterBaseline(JSContext*, js::jit::EnterJitData&) (cx=0x14f2640, data=...) at js/src/jit/BaselineJIT.cpp:150 +</code></pre> + +<p>Note, when you enable the unwinder, the current version of gdb (7.10.1) does not flush the backtrace. Therefore, the JIT frames do not appear until you settle on the next breakpoint. To work-around this issue you can use the recording feature of <code>gdb</code>, to step one instruction, and settle back to where you came from with the following set of <code>gdb</code> commands:</p> + +<pre><code>(gdb) record full +(gdb) si +(gdb) record goto 0 +(gdb) record stop +</code></pre> + +<p>If you have a core file, you can use the gdb unwinder the same way, or do everything from the command line as follow:</p> + +<pre><code>$ gdb -ex 'enable unwinder .* SpiderMonkey' -ex 'bt 0' -ex 'thread apply all backtrace' -ex 'quit' out/dist/bin/js corefile +</code></pre> + +<p>The gdb unwinder is supposed to be loaded by <code>dist/bin/js-gdb.py</code> and load python scripts which are located in <code>js/src/gdb/mozilla</code> under gdb. If gdb does not load the unwinder by default, you can force it to, by using the <code>source</code> command with the <code>js-gdb.py</code> file.</p> + +<h3 id="生成されたコードにブレークポイントを設定する_(gdb_x86_x86-64_arm_から)">生成されたコードにブレークポイントを設定する (gdb, x86 / x86-64, arm から)</h3> + +<p>To set a breakpoint the generated code of a specific JSScript compiled with IonMonkey. Set a breakpoint on the instruction you are interested in. If you have no precise idea which function you are looking at, you can set a breakpoint on the <strong>js::ion::CodeGenerator::visitStart</strong> function. Optionally, a condition on the <strong>ins->id()</strong> of the LIR instruction can be added to select precisely the instruction you are looking for. Once the breakpoint is on <strong>CodeGenerator</strong> function of the LIR instruction, add a command to generate a static breakpoint in the generated code.</p> + +<pre class="eval"><code>$ gdb --args js +[…] +(gdb) b js::ion::CodeGenerator::visitStart +(gdb) command +>call masm.breakpoint() +>continue +>end +(gdb) r +js> function f(a, b) { return a + b; } +js> for (var i = 0; i < 100000; i++) f(i, i + 1); + +Breakpoint 1, js::ion::CodeGenerator::visitStart (this=0x101ed20, lir=0x10234e0) + at /home/nicolas/mozilla/ionmonkey/js/src/ion/CodeGenerator.cpp:609 +609 } + +Program received signal SIGTRAP, Trace/breakpoint trap. +0x00007ffff7fb165a in ?? () +(gdb) + +</code></pre> + +<p>Once you hit the generated breakpoint, you can replace it by a gdb breakpoint to make it conditional, the procedure is to first replace the generated breakpoint by a nop instruction, and to set a breakpoint at the address of the nop.</p> + +<pre class="eval"><code>(gdb) x /5i $pc - 1 + 0x7ffff7fb1659: int3 +=> 0x7ffff7fb165a: mov 0x28(%rsp),%rax + 0x7ffff7fb165f: mov %eax,%ecx + 0x7ffff7fb1661: mov 0x30(%rsp),%rdx + 0x7ffff7fb1666: mov %edx,%ebx + +(gdb) # replace the int3 by a nop +(gdb) set *(unsigned char *) ($pc - 1) = 0x90 +(gdb) x /1i $pc - 1 + 0x7ffff7fb1659: nop + +(gdb) # set a breakpoint at the previous location +(gdb) b *0x7ffff7fb1659 +Breakpoint 2 at 0x7ffff7fb1659 +</code> +</pre> + +<h3 id="イオン生成アセンブリコードのプリント_(gdb_から)">イオン生成アセンブリコードのプリント (gdb から)</h3> + +<p>If you want to look at the assembly code generated by IonMonkey, you can follow this procedure:</p> + +<ul> + <li>Place a breakpoint at CodeGenerator.cpp on the CodeGenerator::link method.</li> + <li>Step next a few times, so that the "code" variable gets generated</li> + <li>Print code->code_, which is the address of the code</li> + <li>Disassembly code read at this address (using x/Ni address, where N is the number of instructions you would like to see)</li> +</ul> + +<p>Here is an example. It might be simpler to use the CodeGenerator::link lineno instead of the full qualified name to put the breakpoint. Let's say that the line number of this function is 4780, for instance:</p> + +<pre>(gdb) b CodeGenerator.cpp:4780 +Breakpoint 1 at 0x84cade0: file /home/code/mozilla-central/js/src/ion/CodeGenerator.cpp, line 4780. +(gdb) r +Starting program: /home/code/mozilla-central/js/src/32-release/js -f /home/code/jaeger.js +[Thread debugging using libthread_db enabled] +Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1". +[New Thread 0xf7903b40 (LWP 12563)] +[New Thread 0xf6bdeb40 (LWP 12564)] +Run#0 + +Breakpoint 1, js::ion::CodeGenerator::link (this=0x86badf8) + at /home/code/mozilla-central/js/src/ion/CodeGenerator.cpp:4780 +4780 { +(gdb) n +4781 JSContext *cx = GetIonContext()->cx; +(gdb) n +4783 Linker linker(masm); +(gdb) n +4784 IonCode *code = linker.newCode(cx, JSC::ION_CODE); +(gdb) n +4785 if (!code) +(gdb) p code->code_ +$1 = (uint8_t *) 0xf7fd25a8 "\201", <incomplete sequence \354\200> +(gdb) x/2i 0xf7fd25a8 + 0xf7fd25a8: sub $0x80,%esp + 0xf7fd25ae: mov 0x94(%esp),%ecx + +</pre> + +<p>On arm, the compiled JS code will always be ARM machine code, whereas spidermonkey itself is frequently Thumb2. Since there isn't debug info for the jitted code, you will need to tell gdb that you are looking at ARM code:</p> + +<pre>(gdb) set arm force-mode arm +</pre> + +<p>Or you can wrap the x command in your own command:</p> + +<pre>def xi + set arm force-mode arm + eval "x/%di %d", $arg0, $arg1 + set arm force-mode auto +end + +</pre> + +<h3 id="Printing_asm.jswasm_generated_assembly_code_(from_gdb)">Printing asm.js/wasm generated assembly code (from gdb)</h3> + +<ul> + <li> + <p>Set a breakpoint on <code>js::wasm::Instance::callExport</code> (defined in <code>WasmInstance.cpp</code> as of November 18th 2016). This will trigger for *any* asm.js/wasm call, so you should find a way to set this breakpoint for the only generated codes you want to look at.</p> + </li> + <li> + <p>Run the program.</p> + </li> + <li> + <p>Do <code>next</code> in gdb until you reach the definition of the <code>funcPtr</code>:</p> + </li> +</ul> + +<pre>// Call the per-exported-function trampoline created by GenerateEntry. │ +auto funcPtr = JS_DATA_TO_FUNC_PTR(ExportFuncPtr, codeBase() + func.entryOffset()); │ +if (!CALL_GENERATED_2(funcPtr, exportArgs.begin(), &tlsData_)) │ + return false; </pre> + +<ul> + <li><code>After it's set, x/64i funcPtr</code> will show you the trampoline code. There should be a call to an address at some point ; that's what we're targeting. Copy that address.</li> +</ul> + +<pre><code> 0x7ffff7ff6000: push %r15 + 0x7ffff7ff6002: push %r14 + 0x7ffff7ff6004: push %r13 + 0x7ffff7ff6006: push %r12 + 0x7ffff7ff6008: push %rbp + 0x7ffff7ff6009: push %rbx + 0x7ffff7ff600a: movabs $0xea4f80,%r10 + 0x7ffff7ff6014: mov 0x178(%r10),%r10 + 0x7ffff7ff601b: mov %rsp,0x40(%r10) + 0x7ffff7ff601f: mov (%rsi),%r15 + 0x7ffff7ff6022: mov %rdi,%r10 + 0x7ffff7ff6025: push %r10 + 0x7ffff7ff6027: test $0xf,%spl + 0x7ffff7ff602b: je 0x7ffff7ff6032 + 0x7ffff7ff6031: int3 + 0x7ffff7ff6032: callq 0x7ffff7ff5000 <------ right here</code></pre> + +<ul> + <li><code>x/64i address</code> (in this case: <code>x/64i 0x7ffff7ff6032</code>).</li> + <li>If you want to put a breakpoint at the function's entry, you can do: <code>b *address </code>(for instance here, <code>b* 0x7ffff7ff6032</code>). Then you can display the instructions around pc with<code> x/20i $pc, </code>and execute instruction by instruction with<code> stepi.</code></li> +</ul> + +<h3 id="Finding_the_script_of_Ion_generated_assembly_(from_gdb)">Finding the script of Ion generated assembly (from gdb)</h3> + +<p>When facing a bug in which you are in the middle of IonMonkey generated code, first thing to note, is that gdb's backtrace is not reliable, because the generated code does not keep a frame pointer. To figure it out you have to read the stack to infer the IonMonkey frame.</p> + +<pre><code>(gdb) </code>x /64a $sp +[…] +0x7fffffff9838: 0x7ffff7fad2da 0x141 +0x7fffffff9848: 0x7fffef134d40 0x2 +[…] +(gdb) p (*(JSFunction**) 0x7fffffff9848)->u.i.script_->lineno +$1 = 1 +(gdb) p (*(JSFunction**) 0x7fffffff9848)->u.i.script_->filename +$2 = 0xff92d1 "typein" +</pre> + +<p>The stack is order as defined in js/src/ion/IonFrames-x86-shared.h, it is composed of the return address, a descriptor (a small value), the JSFunction (if it is even) or a JSScript (if the it is odd, remove it to dereference the pointer) and the frame ends with the number of actual arguments (a small value too). If you want to know at which LIR the code is failing at, the <strong>js::ion::CodeGenerator::generateBody</strong> function can be intrumented to dump the LIR <strong>id</strong> before each instruction.</p> + +<pre><code>for (; iter != current->end(); iter++) { + IonSpew(IonSpew_Codegen, "instruction %s", iter->opName()); + […] + + masm.store16(Imm32(iter->id()), Address(StackPointer, -8)); // added + if (!iter->accept(this)) + return false; +</code> +<code> […] +</code><code>}</code></pre> + +<p><code>This modification will add an instruction which abuse the stack pointer </code>to store an immediate value (the LIR id) to a location which would never be generated by any sane compiler. Thus when dumping the assembly under gdb, this kind of instructions would be easily noticeable.</p> + +<h3 id="Viewing_the_MIRGraph_of_IonOdin_compilations_(from_gdb)">Viewing the MIRGraph of Ion/Odin compilations (from gdb)</h3> + +<p>With gdb instrumentation, we can call <a href="https://github.com/sstangl/iongraph">iongraph</a> program within gdb when the execution is stopped. This instrumentation adds an <strong><code>iongraph</code></strong> command when provided with an instance of a <strong><code>MIRGenerator*</code></strong>, will call <code>iongraph</code>, <code>graphviz</code> and your prefered png viewer to display the MIR graph at the precise time of the execution. To find <strong><code>MIRGenetator*</code></strong> instances, is best is to look up into the stack for <code>OptimizeMIR</code>, or <code>CodeGenerator::generateBody</code>. <strong><code>OptimizeMIR</code></strong> function has a <strong><code>mir</code></strong> argument, and the <strong><code>CodeGenerator::generateBody</code></strong> function has a member <strong><code>this->gen</code></strong>.</p> + +<pre><code>(gdb) bt</code> +#0 0x00000000007eaad4 in js::InlineList<js::jit::MBasicBlock>::begin() const (this=0x33dbbc0) at …/js/src/jit/InlineList.h:280 +#1 0x00000000007cb845 in js::jit::MIRGraph::begin() (this=0x33dbbc0) at …/js/src/jit/MIRGraph.h:787 +#2 0x0000000000837d25 in js::jit::BuildPhiReverseMapping(js::jit::MIRGraph&) (graph=...) at …/js/src/jit/IonAnalysis.cpp:2436 +#3 0x000000000083317f in js::jit::OptimizeMIR(js::jit::MIRGenerator*) (mir=0x33dbdf0) at …/js/src/jit/Ion.cpp:1570 +… +(gdb) frame 3 +#3 0x000000000083317f in js::jit::OptimizeMIR(js::jit::MIRGenerator*) (mir=0x33dbdf0) at …/js/src/jit/Ion.cpp:1570 +<code>(gdb) iongraph mir</code> + function 0 (asm.js compilation): success; 1 passes<code>.</code> +<code>/* open your png viewer with the result of iongraph */</code></pre> + +<p>This gdb instrumentation is supposed to work with debug builds, or with optimized build compiled with <code>--enable-jitspew</code> configure flag. External programs such as <code>iongraph</code>, <code>dot</code>, and your png viewer are search into the <code>PATH</code>, otherwise custom one can either be configured with environment variables (<code>GDB_IONGRAPH</code>, <code>GDB_DOT</code>, <code>GDB_PNGVIEWER</code>) before starting gdb, or with gdb parameters (<code>set iongraph-bin <path></code>, <code>set dot-bin <path></code>, <code>set pngviewer-bin <path></code>) within gdb.</p> + +<p>Enabling GDB instrumentation may require launching a JS shell executable that shares a directory with a file name "js-gdb.py". If js/src/js does not provide the "iongraph" command, try js/src/shell/js. GDB may complain that ~/.gdbinit requires modification to authorize user scripts, and if so will print out directions.</p> + +<h3 id="Break_on_valgrind_errors">Break on valgrind errors</h3> + +<p>Sometimes, a bug can be reproduced under valgrind but hardly under gdb. One way to investigate is to let valgrind start gdb for you, the other way documented here is to let valgrind act as a gdb server which can be manipulated from the gdb remote.</p> + +<pre><code>$ valgrind --smc-check=all-non-file</code> --vex-iropt-register-updates=allregs-at-mem-access <code>--vgdb-error=0 ./js …</code></pre> + +<p>This command will tell you how to start gdb as a remote. Be aware that functions which are usually dumping some output will do it in the shell where valgrind is started and not in the shell where gdb is started. Thus functions such as <strong>js::DumpBacktrace</strong>, when called from gdb, will print their output in the shell containing valgrind.</p> + +<h3 id="Adding_spew_for_Compilations_Bailouts_Invalidations_(from_gdb)">Adding spew for Compilations & Bailouts & Invalidations (from gdb)</h3> + +<p>If you are in rr, and forgot to record with the spew enabled with IONFLAGS or because this is an optimized build, then you can add similar spew with extra breakpoints within gdb. gdb has the ability to set breakpoints with commands, but a simpler / friendlier version is to use <strong>dprintf</strong>, with a location, and followed by printf-like arguments.</p> + +<pre>(gdb) dprintf js::jit::IonBuilder::IonBuilder, "Compiling %s:%d:%d-%d\n", info->script_->scriptSource()->filename_.mTuple.mFirstA, info->script_->lineno_, info->script_->sourceStart_, info->script_->sourceEnd_ +Dprintf 1 at 0x7fb4f6a104eb: file /home/nicolas/mozilla/contrib-push/js/src/jit/IonBuilder.cpp, line 159. +(gdb) cond 1 inliningDepth == 0 +(gdb) dprintf js::jit::BailoutIonToBaseline, "Bailout from %s:%d:%d-%d\n", iter.script()->scriptSource()->filename_.mTuple.mFirstA, iter.script()->lineno_, iter.script()->sourceStart_, iter.script()->sourceEnd_ +Dprintf 2 at 0x7fb4f6fe43dc: js::jit::BailoutIonToBaseline. (2 locations) +(gdb) dprintf Ion.cpp:3196, "Invalidate %s:%d:%d-%d\n", co->script_->scriptSource()->filename_.mTuple.mFirstA, co->script_->lineno_, co->script_->sourceStart_, co->script_->sourceEnd_ +Dprintf 3 at 0x7fb4f6a0b62a: file /home/nicolas/mozilla/contrib-push/js/src/jit/Ion.cpp, line 3196. +<code>(gdb) continue</code> +Compiling self-hosted:650:20470-21501 +Bailout from self-hosted:20:403-500 +Invalidate self-hosted:20:403-500 +</pre> + +<p>Note: the line 3196, listed above, corresponds to the location of the <a href="http://searchfox.org/mozilla-central/rev/f6c298b36db67a7109079c0dd7755f329c1d58e2/js/src/jit/Ion.cpp#3196">Jit spew inside jit::Invalidate function</a>.</p> + +<h2 id="ハッキングのヒント">ハッキングのヒント</h2> + +<h3 id="Benchmarking_(shell)">Benchmarking (shell)</h3> + +<p><a href="http://arewefastyet.com">AreWeFastYet.com</a> display the benchmark results of the JavaScript shell, and browser for B2G. These benchmarks are publicly recognized benchmarks suggested by other companies and are used as a metric to evaluate how fast JavaScript engines. This tool is maintained by the JavaScript Team, to find regressions and to compare SpiderMonkey with other JavaScript engines when possible. To run these benchmarks localy, you can clone <a href="https://github.com/haytjes/arewefastyet.git">AreWeFastYet sources</a> and look inside the <em>benchmarks</em> directory to run individual benchmarks with your JS shell.</p> + +<h3 id="Using_the_Gecko_Profiler_(browser_xpcshell)">Using the Gecko Profiler (browser / xpcshell)</h3> + +<p>see the section dedicated to <a href="/en-US/docs/Performance/Profiling_with_the_Built-in_Profiler" title="/en-US/docs/Performance/Profiling_with_the_Built-in_Profiler">profiling with the gecko profiler</a>. This method of profiling has the advantage of mixing the JavaScript stack with the C++ stack, which is useful to analyze library function issues. One tip is to start looking at a script with an inverted JS stack to locate the most expensive JS function, then to focus on the frame of this JS function, and to remove the inverted stack and look at C++ part of this function to determine from where the cost is coming from.</p> + +<h3 id="Using_the_JIT_Inspector_(browser)">Using the JIT Inspector (browser)</h3> + +<p>Install the <a href="https://addons.mozilla.org/en-US/firefox/addon/jit-inspector/" title="https://addons.mozilla.org/en-US/firefox/addon/jit-inspector/">JIT Inspector</a> addon in your browser. This addon provides estimated cost of IonMonkey , the Baseline compiler, and the interpreter. In addition it provides a clean way to analyze if instructions are inferred as being monomorphic or polymorphic in addition to the number of time each category of type has been observed.</p> + +<h3 id="Using_the_TraceLogger_(JS_shell_browser)">Using the TraceLogger (JS shell / browser)</h3> + +<p>Create graphs showing time spent in which engine and which function like <a href="https://raw.githubusercontent.com/h4writer/tracelogger/master/screenshot.png" title="http://alasal.be/ionmonkey/index.php?subject=octane-richards-82d28bdf9317">this</a>.</p> + +<p>Whenever running a testcase the file "tl-data.json" and several "tl-*" files get created in the "/tmp" directory. (Per proces a "tl-data-*PID*.json" file and per thread a "tl-tree.*PID*.*ID*.tl", "tl-event.*PID*.*ID*.tl" and "tl-dict.*PID*.*ID*.json" file). These files contain all information to create a tracelogger graph. On <a href="https://github.com/h4writer/tracelogger">https://github.com/h4writer/tracelogger</a> you can find the instructions to create the graph (Tools V2 > 1. Creating a tracelogging graph).</p> + +<p>Note 1: when you are doing this from "file:///" you will probably get a security warning in the console. This is because firefox doesn't allow loading files from the harddisk using httprequest, even when the file loading the file is on the harddisk. There are two solutions. One is to create a localhost server and serving the files there. The simplest way to do this is to run <code>python -m SimpleHTTPServer</code> from within the above directory. The other being disable this check in "about:config", by temporarily switching "security.fileuri.strict_origin_policy" to false</p> + +<p>Note 2: The files can be very big and take a long time to load in the browser. Therefore it might be good to reduce the logged file. This will remove entries that took only a minor time (=entries that will only show up with les than 1px). This can be done with the reduce.py script in <a href="https://github.com/haytjes/tracelogger/tree/master/tools_v2" title="https://github.com/haytjes/tracelogger">https://github.com/haytjes/tracelogger/tree/master/tools_v2</a>. You need to download "engine.js", "reduce.py", "reduce.js", "reduce-tree.js" and "reduce-corrections.js". Running this tool is a matter of running "python reduce.py JS_SHELL /tmp/tl-data.json tl-reduced". Where JS_SHELL is a real shell.</p> + +<h3 id="Using_callgrind_(JS_shell)">Using callgrind (JS shell)</h3> + +<p>As SpiderMonkey just-in-time compiler are rewriting the executed program, valgrind should be informed from the command line by adding <strong>--smc-check=all-non-file</strong>.</p> + +<pre class="eval"><code>$ valgrind --tool=callgrind --callgrind-out-file=bench.clg \ + --smc-check=all-non-file</code> --vex-iropt-register-updates=allregs-at-mem-access<code> ./js ./run.js +</code></pre> + +<p>The output file can then be use with <strong>kcachegrind</strong> which provides a graphical view of the call graph.</p> + +<h3 id="Using_IonMonkey_spew_(JS_shell)">Using IonMonkey spew (JS shell)</h3> + +<p>IonMonkey spew is extremely verbose (not as much as the INFER spew), but you can filter it to focus on the list of compiled scripts or channels, IonMonkey spew channels can be selected with the IONFLAGS environment variable, and compilation spew can be filtered with IONFILTER.</p> + +<p>IONFLAGS contains the names of each channel separated by commas. The <strong>logs</strong> channel produces 2 files in <em>/tmp/</em>, one (<em>/tmp/ion.json</em>) made to be used with <a class="external text" href="https://github.com/sstangl/iongraph" rel="nofollow">iongraph</a> (made by Sean Stangl) and another one (<em>/tmp/ion.cfg</em>) made to be used with <a class="external text" href="http://java.net/projects/c1visualizer/" rel="nofollow">c1visualizer</a>. These tools will show the MIR & LIR steps done by IonMonkey during the compilation. If you would like to use <a class="external text" href="https://github.com/sstangl/iongraph" rel="nofollow" style="line-height: 1.572;">iongraph</a>, you must install <a href="http://www.graphviz.org/Download..php" title="http://www.graphviz.org/Download..php">Graphviz</a>.</p> + +<p>Compilation logs and spew can be filtered with the IONFILTER environment variable which contains locations as output in other spew channels. Multiple locations can be separated with comma as a separator of locations.</p> + +<pre class="eval"><code>$ IONFILTER=pdfjs.js:16934 IONFLAGS=logs,scripts,osi,bailouts ./js --ion-offthread-compile=off ./run.js 2>&1 | less</code></pre> + +<p>The <strong>bailouts</strong> channel is likely to be the first thing you should focus on, because this means that something does not stay in IonMonkey and fallback to the interpreter. This channel output locations (as returned by the<strong> id()</strong> function of both instructions) of the latest MIR and the latest LIR phases. These locations should correspond to phases of the <strong>logs</strong> and a filter can be used to remove uninteresting functions.</p> + +<h3 id="Using_the_ARM_simulator">Using the ARM simulator</h3> + +<p>The ARM simulator can be used to test the ARM JIT backend on x86/x64 hardware. An ARM simulator build is an x86 shell (or browser) with the ARM JIT backend. Instead of entering JIT code, it runs it in a simulator (interpreter) for ARM code. To use the simulator, compile an x86 shell (32-bit, x64 doesn't work as we use a different Value format there), and pass --enable-arm-simulator to configure. For instance, on a 64-bit Linux host you can use the following configure command to get an ARM simulator build:</p> + +<pre class="line-numbers language-html"><code class="language-html">AR=ar CC="gcc -m32" CXX="g++ -m32" ../configure --target=i686-pc-linux --enable-debug --disable-optimize --enable-threadsafe --enable-simulator=arm</code></pre> + +<p>Or on OS X:</p> + +<pre> $ AR=ar CC="clang -m32" CXX="clang++ -m32" ../configure --target=i686-apple-darwin10.0.0 --enable-debug --disable-optimize --enable-threadsafe --enable-arm-simulator</pre> + +<p>An --enable-debug --enable-optimize build is recommended if you want to run jit-tests or jstests.</p> + +<h4 id="Use_the_VIXL_Debugger_in_the_simulator_(arm64)">Use the VIXL Debugger in the simulator (arm64)</h4> + +<p>Set a breakpoint (see the comments above about <code>masm.breakpoint()</code>) and run with the environment variable <code>USE_DEBUGGER=1</code>. This will then drop you into a simple debugger provided with VIXL, the ARM simulator technology used for arm64 simulation.</p> + +<h4 id="Use_the_Simulator_Debugger_for_arm32">Use the Simulator Debugger for arm32</h4> + +<p>The same instructions for arm64 in the preceeding section apply, but the environment variable differs: Use <code>ARM_SIM_DEBUGGER=1</code>.</p> + +<h4 id="Building_the_browser_with_the_ARM_simulator">Building the browser with the ARM simulator</h4> + +<p>You can also build the entire browser with the ARM simulator backend, for instance to reproduce browser-only JS failures on ARM. Make sure to build a browser for x86 (32-bits) and add this option to your mozconfig file:</p> + +<pre>ac_add_options --enable-arm-simulator +</pre> + +<p>If you are under an Ubuntu or Debian 64-bits distribution and you want to build a 32-bits browser, it might be hard to find the relevant 32-bits dependencies. You can use <a href="https://github.com/padenot/fx-32-on-64.sh">padenot's scripts</a> which will magically setup a chrooted 32-bits environment and do All The Things (c) for you (you just need to modify the mozconfig file).</p> + +<h3 id="Using_rr_on_a_test">Using rr on a test</h3> + +<p>Get the command line for your test run using -s:</p> + +<pre>./jit_test.py -s $JS_SHELL saved-stacks/async.js</pre> + +<p>Insert 'rr' before the shell invocation:</p> + +<pre><code>rr $JS_SHELL -f $JS_SRC/jit-test/lib/prolog.js --js-cache $JS_SRC/jit-test/.js-cache -e "const platform='linux2'; const libdir='$JS_SRC/jit-test/lib/'; const scriptdir='$JS_SRC/jit-test/tests/saved-stacks/'" -f $JS_SRC/jit-test/tests/saved-stacks/async.js</code></pre> + +<p>(note that the above is an example; simply setting JS_SHELL and JS_SRC will not work). Or if this is an intermittent, run it in a loop capturing an rr log for every one until it fails:</p> + +<pre><code>n=1; while rr ...same.as.above...; do echo passed $n; n=$(( $n + 1 )); done</code></pre> + +<p>Wait until it hits a failure. Now you can run <code>rr replay</code> to replay that last (failed) run under gdb.</p> + +<h4 id="rr_with_reftest">rr with reftest</h4> + +<p>To break on the write of a differing pixel:</p> + +<ol> + <li>Find the X/Y of a pixel that differs</li> + <li>Use 'run Z' where Z is the mark in the log for TEST-START. For example in '[rr 28496 607198]REFTEST TEST-START | file:///home/bgirard/mozilla-central/tree/image/test/reftest/bmp/bmpsuite/b/wrapper.html?badpalettesize.bmp' Z would be 607198.</li> + <li>break 'mozilla::dom::CanvasRenderingContext2D::DrawWindow(nsGlobalWindow&, double, double, double, double, nsAString_internal const&, unsigned int, mozilla::ErrorResult&)'</li> + <li>cont</li> + <li>break 'PresShell::RenderDocument(nsRect const&, unsigned int, unsigned int, gfxContext*)'</li> + <li>set print object on</li> + <li>set $x = <YOUR X VALUE></li> + <li>set $y = <YOUR Y VALUE></li> + <li>print &((cairo_image_surface_t*)aThebesContext->mDT.mRawPtr->mSurface).data[$y * ((cairo_image_surface_t*)aThebesContext->mDT.mRawPtr->mSurface).stride + $x * ((cairo_image_surface_t*)aThebesContext->mDT.mRawPtr->mSurface).depth / 8]</li> + <li> + <p>watch *(char*)<ADDRESS OF PREVIOUS COMMAND> (NOTE: If you set a watch on the previous expression gdb will watch the expression and run out of watchpoint)</p> + </li> +</ol> + +<h4 id="rr_with_emacs">rr with emacs</h4> + +<p>Within emacs, do <code>M-x gud-gdb</code> and replace the command line with <code>rr replay</code>. When gdb comes up, enter</p> + +<pre><code>set annot 1</code></pre> + +<p>to get it to emit file location information so that emacs will pop up the corresponding source. Note that if you <code>reverse-continue</code> over a SIGSEGV and you're using the standard .gdbinit that sets a catchpoint for that signal, you'll get an additional stop at the catchpoint. Just <code>reverse-continue</code> again to continue to your breakpoints or whatever.</p> + +<h3 id="Hack_Replacing_one_instruction">[Hack] Replacing one instruction</h3> + +<p>To replace one specific instruction, you can use in visit function of each instruction the JSScript <strong>filename</strong> in <strong>lineno</strong> fields as well as the <strong>id()</strong> of the LIR / MIR instructions. The JSScript can be obtained from <strong>info().script()</strong>.</p> + +<pre class="eval"><code>bool +CodeGeneratorX86Shared::visitGuardShape(LGuardShape *guard) +{ + if (info().script()->lineno == 16934 && guard->id() == 522) { + [… another impl only for this one …] + return true; + } + [… old impl …] +</code></pre> + +<h3 id="Hack_Spewing_all_compiled_code">[Hack] Spewing all compiled code</h3> + +<p>I usually just add this to the apropriate executableCopy.</p> + +<pre><span class="quote"> if (getenv("INST_DUMP")) { + char buf[4096]; + sprintf(buf, "gdb /proc/%d/exe %d -batch -ex 'set pagination off' -ex 'set arm force-mode arm' -ex 'x/%di %p' -ex 'set arm force-mode auto'", getpid(), getpid(), m_buffer.size() / 4, buffer); + system(buf); + }</span> + +</pre> + +<p>If you aren't running on arm, you should omit the -ex 'set arm force-mode arm' and -ex 'set arm force-mode auto'. And you should change the size()/4 to be something more apropriate for your architecture.</p> + +<h3 id="Benchmarking_with_sub-milliseconds_(JS_shell)">Benchmarking with sub-milliseconds (JS shell)</h3> + +<p>In the shell we have 2 simple ways to benchmark a script, we can either use the <strong>-b</strong> shell option (<strong>--print-timing</strong>) which will evaluate a script given on the command line without any need to instrument the benchmark and print an extra line showing the run-time of the script. The other way is to wrap the section that you want to measure with the <strong>dateNow()</strong> function call which returns the number of milliseconds, with a decimal part for sub-milliseconds.</p> + +<pre class="eval">js> dateNow() - dateNow() +-0.0009765625<code> +</code></pre> + +<h3 id="Benchmarking_with_sub-milliseconds_(browser)">Benchmarking with sub-milliseconds (browser)</h3> + +<p>In a simillar way as <strong>dateNow()</strong> in the JS shell, you can use <strong>performance.now()</strong> in the JavaScript code of a page.</p> + +<h3 id="Dumping_the_JavaScript_heap">Dumping the JavaScript heap</h3> + +<p>From the shell, you can call the dumpHeap before Firefox function to dump out all GC things (reachable and unreachable) that are present in the heap. By default the function writes to stdout, but a filename can be specified as an argument.</p> + +<p>Example output might look as follows:</p> + +<pre class="eval"><code>0x1234abcd B global object +</code>========== +# zone 0x56789123 +# compartment http://gmail.com [in zone 0x56789123] +# compartment http://gmail.com/iframe [in zone 0x56789123] +# arena<code> allockind=3 size=64 +0x1234abcd B object +> 0x1234abcd B prop1 +> 0xabcd1234 W prop2 +0xabcd1234 W object +> 0xdeadbeef B prop3 +# arena allockind=5 size=72 +0xdeadbeef W object +> 0xabcd1234 W prop4 </code></pre> + +<p>The output is textual. The first section of the file contains a list of roots, one per line. Each root has the form "0xabcd1234 <color> <description>", where <color> is the color of the given GC thing (B for black, G for gray, W for white) and <description> is a string. The list of roots ends with a line containing "==========".</p> + +<p>After the roots come a series of zones. A zone starts with several "comment lines" that start with hashes. The first comment declares the zone. It is followed by lines listing each compartment within the zone. After all the compartments come arenas, which is where the GC things are actually stored. Each arena is followed by all the GC things in the arena. A GC thing starts with a line giving its address, its color, and the thing kind (object, function, whatever). After this come a list of addresses that the GC thing points to, each one starting with ">".</p> + +<p>It's also possible to dump the JavaScript heap from C++ code (or from gdb) using the js::DumpHeap function. It is part of jsfriendapi.h and it is available in release builds.</p> + +<h3 id="Inspecting_MIR_objects_within_a_debugger">Inspecting MIR objects within a debugger</h3> + +<p>For MIRGraph, MBasicBlock, and MDefinition and its subclasses (MInstruction, MConstant, etc.), call the dump member function.</p> + +<pre> (gdb) call graph->dump() + + (gdb) call block->dump() + + (gdb) call def->dump() + +</pre> + +<h3 id="Benchmarking_without_a_Phone">Benchmarking without a Phone</h3> + +<p>If you do not have a mobile device or prefer to test on your desktop first, you will need to downgrade your computer such as it is able to run programs as fast as-if they were running on a phone.</p> + +<p>On Linux, you can manage the resources available to one program by using cgroup, and to do you can install <strong>libcgroup</strong> which provides some convenient tools such as <strong>cgexec</strong> to wrap the program that you want to benchmark.</p> + +<p>The following list of commands is used to create 3 control groups. The top-level control group is just to group the <strong>mask</strong> and the <strong>negate-mask</strong>. The <strong>mask</strong> control group is used to run the program that we want to benchmark. The <strong>negate-mask</strong> control group is used to reserve resources which might be used by the other program if not reserved.</p> + +<pre> $ sudo cgcreate -a nicolas:users -t nicolas:users -g cpuset,cpu,memory:/benchmarks + $ cgcreate -a nicolas:users -t nicolas:users -g cpuset,cpu,memory:/benchmarks/mask + $ cgcreate -a nicolas:users -t nicolas:users -g cpuset,cpu,memory:/benchmarks/negate-mask +</pre> + +<p>Then we restrict programs of these groups to the first core of the CPU. This is a list of cpu, which means that we can allocate 2 cores by doing <strong>0-1</strong> instead of <strong>0</strong>.</p> + +<pre> $ cgset -r cpuset.cpus=0 /benchmarks + $ cgset -r cpuset.cpus=0 /benchmarks/mask + $ cgset -r cpuset.cpus=0 /benchmarks/negate-mask +</pre> + +<p>Then we restrict programs of these groups to the first memory node. Most of the time you will only have one, otherwise you should read what is the best setting to set here. If this is not set, you will have some error when you will try to write a pid in <strong>/sys/fs/cgroup/cpuset/benchmarks/mask/tasks</strong> while running <strong>cgexec</strong>.</p> + +<pre> $ cgset -r cpuset.mems=0 /benchmarks + $ cgset -r cpuset.mems=0 /benchmarks/mask + $ cgset -r cpuset.mems=0 /benchmarks/negate-mask +</pre> + +<p>Then we limit the performance of the CPU, as a proportion such as the result approximately correspond to what you might have if you were running on a phone. For example an Unagi is approximately 40 times slower than my computer. So I allocate <strong>1/40</strong> for the mask, and <strong>39/40</strong> for the negate-mask.</p> + +<pre> $ cgset -r cpu.shares=1 /benchmarks/mask + $ cgset -r cpu.shares=39 /benchmarks/negate-mask +</pre> + +<p>Then we limit the memory available, to what would be available on the phone. For example an Unagi you want to limit this to 512 MB. As there is no swap, on this device, we set the <strong>memsw</strong> (Memory+Swap) to the same value.</p> + +<pre> $ cgset -r memory.limit_in_bytes=$((512*1024*1024)) /benchmarks/mask + $ cgset -r memory.memsw.limit_in_bytes=$((512*1024*1024)) /benchmarks/mask +</pre> + +<p>And finally, we run the program that we want to benchmark after the one which is consuming resources. In case of the JS Shell we might also want to set the amount of memory available to change the GC settings as if we were running on a Firefox OS device.</p> + +<pre> $ cgexec -g 'cpuset,cpu,memory:/benchmarks/negate-mask' yes > /dev/null & + $ cgexec -g 'cpuset,cpu,memory:/benchmarks/mask' ./js --available-memory=512 ./run.js +</pre> + +<h3 id="How_to_debug_oomTest()_failures">How to debug oomTest() failures</h3> + +<p>The oomTest() function executes a piece of code many times, simulating an OOM failure at each successive allocation it makes. It's designed to highlight incorrect OOM handling and this may show up as a crash or assertion failure at some later point.</p> + +<p>When debugging such a crash the most useful thing is to locate the last simulated alloction failure, as it's usually this that has caused the subsequent crash.</p> + +<p>My workflow for doing this is as follows:</p> + +<ol> + <li>Build a version of the engine with <code>--enable-debug</code> and <code>--enable-oom-breakpoint</code> configure flags.</li> + <li>Set the environment variable <code>OOM_VERBOSE=1</code> and reproduce the failure. This will print an allocation count at each simulated failure. Note the count of the last allocation.</li> + <li>Run the engine under a debugger and set a breakpoint on the function <code>js_failedAllocBreakpoint</code>.</li> + <li>Run the program and continue the necessary number of times until you reach the final allocation. + <ul> + <li>e.g. in lldb, if the allocation failure number shown is 1500, run `continue -i 1498` (subtracted 2 because we've already hit it once and don't want to skip the last). Drop "-i" for gdb.</li> + </ul> + </li> + <li>Dump a backtrace. This should show you the point at which the OOM is incorrectly handled, which will be a few frames up from the breakpoint.</li> +</ol> + +<p>Note: if you are on linux it may be simpler to use rr.</p> + +<p>Some guidelines for handling OOM that lead to failures when they are not followed:</p> + +<ol> + <li>Check for allocation failure! + <ul> + <li>Fallible allocations should always must be checked and handled, at a minimum by returning a status indicating failure to the caller.</li> + </ul> + </li> + <li>Report OOM to the context if you have one + <ul> + <li>If a function has a <code>JSContext*</code> argument, usually it should call <code>js::ReportOutOfMemory(cx)</code> on allocation failure to report this to the context.</li> + </ul> + </li> + <li>Sometimes it's OK to ignore OOM + <ul> + <li>For example if you are performing a speculative optimisation you might abandon it and continue anyway. But in this case you may have to call cx->recoverFromOutOfMemory() if something further down the stack has already reported the failure.</li> + </ul> + </li> +</ol> + +<h3 id="Debugging_GC_markingrooting">Debugging GC marking/rooting</h3> + +<p>The <strong>js::debug</strong> namespace contains some functions that are useful for watching mark bits for an individual JSObject* (or any Cell*). <strong>js/src/gc/Heap.h</strong> contains a comment describing an example usage. Reproduced here:</p> + +<pre>// Sample usage from gdb: +// +// (gdb) p $word = js::debug::GetMarkWordAddress(obj) +// $1 = (uintptr_t *) 0x7fa56d5fe360 +// (gdb) p/x $mask = js::debug::GetMarkMask(obj, js::gc::GRAY) +// $2 = 0x200000000 +// (gdb) watch *$word +// Hardware watchpoint 7: *$word +// (gdb) cond 7 *$word & $mask +// (gdb) cont +// +// Note that this is *not* a watchpoint on a single bit. It is a watchpoint on +// the whole word, which will trigger whenever the word changes and the +// selected bit is set after the change. +// +// So if the bit changing is the desired one, this is exactly what you want. +// But if a different bit changes (either set or cleared), you may still stop +// execution if the $mask bit happened to already be set. gdb does not expose +// enough information to restrict the watchpoint to just a single bit. +</pre> + +<p>Most of the time, you will want <strong>js::gc::BLACK</strong> (or you can just use 0) for the 2nd param to <strong>js::debug::GetMarkMask</strong>.</p> diff --git a/files/ja/mozilla/projects/spidermonkey/how_to_embed_the_javascript_engine/index.html b/files/ja/mozilla/projects/spidermonkey/how_to_embed_the_javascript_engine/index.html new file mode 100644 index 0000000000..7b623d6cbd --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/how_to_embed_the_javascript_engine/index.html @@ -0,0 +1,474 @@ +--- +title: JavaScript エンジンを埋め込む方法 +slug: Mozilla/Projects/SpiderMonkey/How_to_embed_the_JavaScript_engine +tags: + - Embedding Mozilla + - JavaScript + - SpiderMonkey + - チュートリアル +translation_of: Mozilla/Projects/SpiderMonkey/How_to_embed_the_JavaScript_engine +--- +<div>{{SpiderMonkeySidebar("General")}}</div> + +<p>特により良いコードの例として <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide" title="En/SpiderMonkey/JSAPI_User_Guide">JSAPI User Guide</a> も参照して下さい。</p> + +<h2 id="A_Bare_Bones_Tutorial" name="A_Bare_Bones_Tutorial">チュートリアル要点</h2> + +<h3 id="Hello_World_サンプル組み込みアプリケーション">Hello World サンプル組み込みアプリケーション</h3> + +<p>次のコードは、SpiderMonkey を埋め込んで単純な JavaScript スクリプトを実行する方法を示す非常に単純なアプリケーションです。下のコードのサンプルをビルドして実行するための手順を参照してください。</p> + +<p>コードは SpiderMonkey のバージョンごとに異なりますので、SpiderMonkey の正しいバージョンを選択してください。</p> + +<h4 id="SpiderMonkey_24">SpiderMonkey 24</h4> + +<pre class="brush: cpp line-numbers language-cpp"><code class="language-cpp"><span class="comment token">// following code might be needed in some case</span> +<span class="comment token">// #define __STDC_LIMIT_MACROS</span> +<span class="comment token">// #include <stdint.h></span> +#include <span class="string token">"jsapi.h"</span> + +<span class="comment token">/* The class of the global object. */</span> +static JSClass global_class <span class="operator token">=</span> <span class="punctuation token">{</span> + <span class="string token">"global"</span><span class="punctuation token">,</span> + JSCLASS_GLOBAL_FLAGS<span class="punctuation token">,</span> + JS_PropertyStub<span class="punctuation token">,</span> + JS_DeletePropertyStub<span class="punctuation token">,</span> + JS_PropertyStub<span class="punctuation token">,</span> + JS_StrictPropertyStub<span class="punctuation token">,</span> + JS_EnumerateStub<span class="punctuation token">,</span> + JS_ResolveStub<span class="punctuation token">,</span> + JS_ConvertStub<span class="punctuation token">,</span> +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +int <span class="function token">main</span><span class="punctuation token">(</span>int argc<span class="punctuation token">,</span> const char <span class="operator token">*</span>argv<span class="punctuation token">[</span><span class="punctuation token">]</span><span class="punctuation token">)</span> +<span class="punctuation token">{</span> + JSRuntime <span class="operator token">*</span>rt <span class="operator token">=</span> <span class="function token">JS_NewRuntime</span><span class="punctuation token">(</span><span class="number token">8</span>L <span class="operator token">*</span> <span class="number token">1024</span> <span class="operator token">*</span> <span class="number token">1024</span><span class="punctuation token">,</span> JS_USE_HELPER_THREADS<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>rt<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JSContext <span class="operator token">*</span>cx <span class="operator token">=</span> <span class="function token">JS_NewContext</span><span class="punctuation token">(</span>rt<span class="punctuation token">,</span> <span class="number token">8192</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>cx<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for our various stack objects (JSAutoRequest, RootedObject), so they all go</span> + <span class="comment token">// out of scope before we JS_DestroyContext.</span> + + JSAutoRequest <span class="function token">ar</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// In practice, you would want to exit this any</span> + <span class="comment token">// time you're spinning the event loop</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedObject <span class="function token">global</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="function token">JS_NewGlobalObject</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="operator token">&</span>global_class<span class="punctuation token">,</span> nullptr<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>global<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedValue <span class="function token">rval</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for JSAutoCompartment</span> + JSAutoCompartment <span class="function token">ac</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_InitStandardClasses</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + + const char <span class="operator token">*</span>script <span class="operator token">=</span> <span class="string token">"'hello'+'world, it is '+new Date()"</span><span class="punctuation token">;</span> + const char <span class="operator token">*</span>filename <span class="operator token">=</span> <span class="string token">"noname"</span><span class="punctuation token">;</span> + int lineno <span class="operator token">=</span> <span class="number token">1</span><span class="punctuation token">;</span> + bool ok <span class="operator token">=</span> <span class="function token">JS_EvaluateScript</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">,</span> script<span class="punctuation token">,</span> <span class="function token">strlen</span><span class="punctuation token">(</span>script<span class="punctuation token">)</span><span class="punctuation token">,</span> filename<span class="punctuation token">,</span> lineno<span class="punctuation token">,</span> rval<span class="punctuation token">.</span><span class="function token">address</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>ok<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + JSString <span class="operator token">*</span>str <span class="operator token">=</span> rval<span class="punctuation token">.</span><span class="function token">toString</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">printf</span><span class="punctuation token">(</span><span class="string token">"%s\n"</span><span class="punctuation token">,</span> <span class="function token">JS_EncodeString</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> str<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + <span class="function token">JS_DestroyContext</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_DestroyRuntime</span><span class="punctuation token">(</span>rt<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_ShutDown</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> +<span class="punctuation token">}</span></code></pre> + +<h4 id="SpiderMonkey_31">SpiderMonkey 31</h4> + +<pre class="brush: cpp line-numbers language-cpp"><code class="language-cpp"><span class="comment token">// following code might be needed in some case</span> +<span class="comment token">// #define __STDC_LIMIT_MACROS</span> +<span class="comment token">// #include <stdint.h></span> +#include <span class="string token">"jsapi.h"</span> + +<span class="comment token">/* The class of the global object. */</span> +static JSClass global_class <span class="operator token">=</span> <span class="punctuation token">{</span> + <span class="string token">"global"</span><span class="punctuation token">,</span> + JSCLASS_GLOBAL_FLAGS<span class="punctuation token">,</span> + JS_PropertyStub<span class="punctuation token">,</span> + JS_DeletePropertyStub<span class="punctuation token">,</span> + JS_PropertyStub<span class="punctuation token">,</span> + JS_StrictPropertyStub<span class="punctuation token">,</span> + JS_EnumerateStub<span class="punctuation token">,</span> + JS_ResolveStub<span class="punctuation token">,</span> + JS_ConvertStub<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + JS_GlobalObjectTraceHook +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +int <span class="function token">main</span><span class="punctuation token">(</span>int argc<span class="punctuation token">,</span> const char <span class="operator token">*</span>argv<span class="punctuation token">[</span><span class="punctuation token">]</span><span class="punctuation token">)</span> +<span class="punctuation token">{</span> + <span class="function token">JS_Init</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + + JSRuntime <span class="operator token">*</span>rt <span class="operator token">=</span> <span class="function token">JS_NewRuntime</span><span class="punctuation token">(</span><span class="number token">8</span>L <span class="operator token">*</span> <span class="number token">1024</span> <span class="operator token">*</span> <span class="number token">1024</span><span class="punctuation token">,</span> JS_USE_HELPER_THREADS<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>rt<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JSContext <span class="operator token">*</span>cx <span class="operator token">=</span> <span class="function token">JS_NewContext</span><span class="punctuation token">(</span>rt<span class="punctuation token">,</span> <span class="number token">8192</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>cx<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for our various stack objects (JSAutoRequest, RootedObject), so they all go</span> + <span class="comment token">// out of scope before we JS_DestroyContext.</span> + + JSAutoRequest <span class="function token">ar</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// In practice, you would want to exit this any</span> + <span class="comment token">// time you're spinning the event loop</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedObject <span class="function token">global</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="function token">JS_NewGlobalObject</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="operator token">&</span>global_class<span class="punctuation token">,</span> nullptr<span class="punctuation token">,</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span>FireOnNewGlobalHook<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>global<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedValue <span class="function token">rval</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for JSAutoCompartment</span> + JSAutoCompartment <span class="function token">ac</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_InitStandardClasses</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + + const char <span class="operator token">*</span>script <span class="operator token">=</span> <span class="string token">"'hello'+'world, it is '+new Date()"</span><span class="punctuation token">;</span> + const char <span class="operator token">*</span>filename <span class="operator token">=</span> <span class="string token">"noname"</span><span class="punctuation token">;</span> + int lineno <span class="operator token">=</span> <span class="number token">1</span><span class="punctuation token">;</span> + bool ok <span class="operator token">=</span> <span class="function token">JS_EvaluateScript</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">,</span> script<span class="punctuation token">,</span> <span class="function token">strlen</span><span class="punctuation token">(</span>script<span class="punctuation token">)</span><span class="punctuation token">,</span> filename<span class="punctuation token">,</span> lineno<span class="punctuation token">,</span> <span class="operator token">&</span>rval<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>ok<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + JSString <span class="operator token">*</span>str <span class="operator token">=</span> rval<span class="punctuation token">.</span><span class="function token">toString</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">printf</span><span class="punctuation token">(</span><span class="string token">"%s\n"</span><span class="punctuation token">,</span> <span class="function token">JS_EncodeString</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> str<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + <span class="function token">JS_DestroyContext</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_DestroyRuntime</span><span class="punctuation token">(</span>rt<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_ShutDown</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> +<span class="punctuation token">}</span></code></pre> + +<h4 id="SpiderMonkey_38">SpiderMonkey 38</h4> + +<pre class="brush: cpp line-numbers language-cpp"><code class="language-cpp"><span class="comment token">// following code might be needed in some case</span> +<span class="comment token">// #define __STDC_LIMIT_MACROS</span> +<span class="comment token">// #include <stdint.h></span> +#include <span class="string token">"jsapi.h"</span> + +<span class="comment token">/* The class of the global object. */</span> +static JSClass global_class <span class="operator token">=</span> <span class="punctuation token">{</span> + <span class="string token">"global"</span><span class="punctuation token">,</span> + JSCLASS_GLOBAL_FLAGS<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + JS_GlobalObjectTraceHook +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +int <span class="function token">main</span><span class="punctuation token">(</span>int argc<span class="punctuation token">,</span> const char <span class="operator token">*</span>argv<span class="punctuation token">[</span><span class="punctuation token">]</span><span class="punctuation token">)</span> +<span class="punctuation token">{</span> + <span class="function token">JS_Init</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + + JSRuntime <span class="operator token">*</span>rt <span class="operator token">=</span> <span class="function token">JS_NewRuntime</span><span class="punctuation token">(</span><span class="number token">8</span>L <span class="operator token">*</span> <span class="number token">1024</span> <span class="operator token">*</span> <span class="number token">1024</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>rt<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JSContext <span class="operator token">*</span>cx <span class="operator token">=</span> <span class="function token">JS_NewContext</span><span class="punctuation token">(</span>rt<span class="punctuation token">,</span> <span class="number token">8192</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>cx<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for our various stack objects (JSAutoRequest, RootedObject), so they all go</span> + <span class="comment token">// out of scope before we JS_DestroyContext.</span> + + JSAutoRequest <span class="function token">ar</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// In practice, you would want to exit this any</span> + <span class="comment token">// time you're spinning the event loop</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedObject <span class="function token">global</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="function token">JS_NewGlobalObject</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="operator token">&</span>global_class<span class="punctuation token">,</span> nullptr<span class="punctuation token">,</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span>FireOnNewGlobalHook<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>global<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedValue <span class="function token">rval</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for JSAutoCompartment</span> + JSAutoCompartment <span class="function token">ac</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_InitStandardClasses</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + + const char <span class="operator token">*</span>script <span class="operator token">=</span> <span class="string token">"'hello'+'world, it is '+new Date()"</span><span class="punctuation token">;</span> + const char <span class="operator token">*</span>filename <span class="operator token">=</span> <span class="string token">"noname"</span><span class="punctuation token">;</span> + int lineno <span class="operator token">=</span> <span class="number token">1</span><span class="punctuation token">;</span> + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>CompileOptions <span class="function token">opts</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + opts<span class="punctuation token">.</span><span class="function token">setFileAndLine</span><span class="punctuation token">(</span>filename<span class="punctuation token">,</span> lineno<span class="punctuation token">)</span><span class="punctuation token">;</span> + bool ok <span class="operator token">=</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span><span class="function token">Evaluate</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">,</span> opts<span class="punctuation token">,</span> script<span class="punctuation token">,</span> <span class="function token">strlen</span><span class="punctuation token">(</span>script<span class="punctuation token">)</span><span class="punctuation token">,</span> <span class="operator token">&</span>rval<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>ok<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + JSString <span class="operator token">*</span>str <span class="operator token">=</span> rval<span class="punctuation token">.</span><span class="function token">toString</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">printf</span><span class="punctuation token">(</span><span class="string token">"%s\n"</span><span class="punctuation token">,</span> <span class="function token">JS_EncodeString</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> str<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + <span class="function token">JS_DestroyContext</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_DestroyRuntime</span><span class="punctuation token">(</span>rt<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_ShutDown</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> +<span class="punctuation token">}</span></code></pre> + +<h4 id="SpiderMonkey_45">SpiderMonkey 45</h4> + +<pre class="brush: cpp line-numbers language-cpp"><code class="language-cpp"><span class="comment token">// following code might be needed in some case</span> +<span class="comment token">// #define __STDC_LIMIT_MACROS</span> +<span class="comment token">// #include <stdint.h></span> +#include <span class="string token">"jsapi.h"</span> +#include <span class="string token">"js/Initialization.h"</span> + +<span class="comment token">/* The class of the global object. */</span> +static JSClass global_class <span class="operator token">=</span> <span class="punctuation token">{</span> + <span class="string token">"global"</span><span class="punctuation token">,</span> + JSCLASS_GLOBAL_FLAGS<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + JS_GlobalObjectTraceHook +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +int <span class="function token">main</span><span class="punctuation token">(</span>int argc<span class="punctuation token">,</span> const char <span class="operator token">*</span>argv<span class="punctuation token">[</span><span class="punctuation token">]</span><span class="punctuation token">)</span> +<span class="punctuation token">{</span> + <span class="function token">JS_Init</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + + JSRuntime <span class="operator token">*</span>rt <span class="operator token">=</span> <span class="function token">JS_NewRuntime</span><span class="punctuation token">(</span><span class="number token">8</span>L <span class="operator token">*</span> <span class="number token">1024</span> <span class="operator token">*</span> <span class="number token">1024</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>rt<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JSContext <span class="operator token">*</span>cx <span class="operator token">=</span> <span class="function token">JS_NewContext</span><span class="punctuation token">(</span>rt<span class="punctuation token">,</span> <span class="number token">8192</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>cx<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for our various stack objects (JSAutoRequest, RootedObject), so they all go</span> + <span class="comment token">// out of scope before we JS_DestroyContext.</span> + + JSAutoRequest <span class="function token">ar</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// In practice, you would want to exit this any</span> + <span class="comment token">// time you're spinning the event loop</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedObject <span class="function token">global</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="function token">JS_NewGlobalObject</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="operator token">&</span>global_class<span class="punctuation token">,</span> nullptr<span class="punctuation token">,</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span>FireOnNewGlobalHook<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>global<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedValue <span class="function token">rval</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for JSAutoCompartment</span> + JSAutoCompartment <span class="function token">ac</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_InitStandardClasses</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + + const char <span class="operator token">*</span>script <span class="operator token">=</span> <span class="string token">"'hello'+'world, it is '+new Date()"</span><span class="punctuation token">;</span> + const char <span class="operator token">*</span>filename <span class="operator token">=</span> <span class="string token">"noname"</span><span class="punctuation token">;</span> + int lineno <span class="operator token">=</span> <span class="number token">1</span><span class="punctuation token">;</span> + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>CompileOptions <span class="function token">opts</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + opts<span class="punctuation token">.</span><span class="function token">setFileAndLine</span><span class="punctuation token">(</span>filename<span class="punctuation token">,</span> lineno<span class="punctuation token">)</span><span class="punctuation token">;</span> + bool ok <span class="operator token">=</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span><span class="function token">Evaluate</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> opts<span class="punctuation token">,</span> script<span class="punctuation token">,</span> <span class="function token">strlen</span><span class="punctuation token">(</span>script<span class="punctuation token">)</span><span class="punctuation token">,</span> <span class="operator token">&</span>rval<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>ok<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + JSString <span class="operator token">*</span>str <span class="operator token">=</span> rval<span class="punctuation token">.</span><span class="function token">toString</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">printf</span><span class="punctuation token">(</span><span class="string token">"%s\n"</span><span class="punctuation token">,</span> <span class="function token">JS_EncodeString</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> str<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + <span class="function token">JS_DestroyContext</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_DestroyRuntime</span><span class="punctuation token">(</span>rt<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_ShutDown</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> +<span class="punctuation token">}</span></code></pre> + +<h4 id="SpiderMonkey_52">SpiderMonkey 52</h4> + +<pre class="brush: cpp line-numbers language-cpp"><code class="language-cpp">#include <span class="string token">"jsapi.h"</span> +#include <span class="string token">"js/Initialization.h"</span> + +static JSClassOps global_ops <span class="operator token">=</span> <span class="punctuation token">{</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + nullptr<span class="punctuation token">,</span> + JS_GlobalObjectTraceHook +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +<span class="comment token">/* The class of the global object. */</span> +static JSClass global_class <span class="operator token">=</span> <span class="punctuation token">{</span> + <span class="string token">"global"</span><span class="punctuation token">,</span> + JSCLASS_GLOBAL_FLAGS<span class="punctuation token">,</span> + <span class="operator token">&</span>global_ops +<span class="punctuation token">}</span><span class="punctuation token">;</span> + +int <span class="function token">main</span><span class="punctuation token">(</span>int argc<span class="punctuation token">,</span> const char <span class="operator token">*</span>argv<span class="punctuation token">[</span><span class="punctuation token">]</span><span class="punctuation token">)</span> +<span class="punctuation token">{</span> + <span class="function token">JS_Init</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + + JSContext <span class="operator token">*</span>cx <span class="operator token">=</span> <span class="function token">JS_NewContext</span><span class="punctuation token">(</span><span class="number token">8</span>L <span class="operator token">*</span> <span class="number token">1024</span> <span class="operator token">*</span> <span class="number token">1024</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>cx<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>JS<span class="punctuation token">:</span><span class="punctuation token">:</span><span class="function token">InitSelfHostedCode</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for our various stack objects (JSAutoRequest, RootedObject), so they all go</span> + <span class="comment token">// out of scope before we JS_DestroyContext.</span> + + JSAutoRequest <span class="function token">ar</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// In practice, you would want to exit this any</span> + <span class="comment token">// time you're spinning the event loop</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>CompartmentOptions options<span class="punctuation token">;</span> + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedObject <span class="function token">global</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="function token">JS_NewGlobalObject</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> <span class="operator token">&</span>global_class<span class="punctuation token">,</span> nullptr<span class="punctuation token">,</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span>FireOnNewGlobalHook<span class="punctuation token">,</span> options<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>global<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>RootedValue <span class="function token">rval</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + + <span class="punctuation token">{</span> <span class="comment token">// Scope for JSAutoCompartment</span> + JSAutoCompartment <span class="function token">ac</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_InitStandardClasses</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> global<span class="punctuation token">)</span><span class="punctuation token">;</span> + + const char <span class="operator token">*</span>script <span class="operator token">=</span> <span class="string token">"'hello'+'world, it is '+new Date()"</span><span class="punctuation token">;</span> + const char <span class="operator token">*</span>filename <span class="operator token">=</span> <span class="string token">"noname"</span><span class="punctuation token">;</span> + int lineno <span class="operator token">=</span> <span class="number token">1</span><span class="punctuation token">;</span> + JS<span class="punctuation token">:</span><span class="punctuation token">:</span>CompileOptions <span class="function token">opts</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + opts<span class="punctuation token">.</span><span class="function token">setFileAndLine</span><span class="punctuation token">(</span>filename<span class="punctuation token">,</span> lineno<span class="punctuation token">)</span><span class="punctuation token">;</span> + bool ok <span class="operator token">=</span> JS<span class="punctuation token">:</span><span class="punctuation token">:</span><span class="function token">Evaluate</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> opts<span class="punctuation token">,</span> script<span class="punctuation token">,</span> <span class="function token">strlen</span><span class="punctuation token">(</span>script<span class="punctuation token">)</span><span class="punctuation token">,</span> <span class="operator token">&</span>rval<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">if</span> <span class="punctuation token">(</span><span class="operator token">!</span>ok<span class="punctuation token">)</span> + <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + JSString <span class="operator token">*</span>str <span class="operator token">=</span> rval<span class="punctuation token">.</span><span class="function token">toString</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">printf</span><span class="punctuation token">(</span><span class="string token">"%s\n"</span><span class="punctuation token">,</span> <span class="function token">JS_EncodeString</span><span class="punctuation token">(</span>cx<span class="punctuation token">,</span> str<span class="punctuation token">)</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="punctuation token">}</span> + + <span class="function token">JS_DestroyContext</span><span class="punctuation token">(</span>cx<span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="function token">JS_ShutDown</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> + <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> +<span class="punctuation token">}</span></code></pre> + +<h3 id="Hello_Worldの例のビルドと実行">Hello Worldの例のビルドと実行</h3> + +<div> +<p>ビルドコマンドラインは OS とツールに依存します。Mac と Linux のコマンドラインのサンプルを次に示します (<code><objdir></code> は SpiderMonkey がビルドされたディレクトリです)。</p> + +<pre class="line-numbers language-html"><code class="language-html"># </code>SpiderMonkey のデバッグビルドを使用している場合は、以下のコマンドに加えて -DDEBUG が必要です。<code class="language-html"> +# </code>SpiderMonkey 31 以外のバージョンを使用している場合は、-lmozjs-XX を自分のバージョンに変更してください。<code class="language-html"> + +[Mac] +clang++ -std=c++11 -I<span class="tag token"><span class="tag token"><span class="punctuation token"><</span>objdir</span><span class="punctuation token">></span></span>/dist/include -L<span class="tag token"><span class="tag token"><span class="punctuation token"><</span>objdir</span><span class="punctuation token">></span></span>/dist/lib helloworld.cpp -o helloworld -lmozjs-31 -lz +[Linux] +g++ -std=c++11 -I<span class="tag token"><span class="tag token"><span class="punctuation token"><</span>objdir</span><span class="punctuation token">></span></span>/dist/include -L<span class="tag token"><span class="tag token"><span class="punctuation token"><</span>objdir</span><span class="punctuation token">></span></span>/dist/lib helloworld.cpp -o helloworld -lmozjs-31 -lz -lpthread -ldl</code></pre> + +<p><code>"helloworld, it is TIME"</code> と表示されます (ここでは TIME が現在の時刻です)。</p> + +<ol> + <li>Make sure the build computer has the prerequisites for building SpiderMonkey: <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Linux_Prerequisites" title="Linux Prerequisites">Linux</a>, <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Windows_Prerequisites" title="Windows build prerequisites">Windows</a>, <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Mac_OS_X_Prerequisites" title="Mac OS X Build Prerequisites">Mac OS X</a>, <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions" title="Build Instructions">others</a>. For Windows, the following steps will assume that you have installed the <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Developer_guide/Build_Instructions/Windows_Prerequisites" title="MozillaBuild">MozillaBuild</a> package.</li> + <li>Get the SpiderMonkey source code. You can <a href="http://ftp.mozilla.org/pub/mozilla.org/js/" title="http://ftp.mozilla.org/pub/mozilla.org/js/">download a source archive</a> or use Mercurial (hg) to <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/Getting_SpiderMonkey_source_code#Getting_the_latest_SpiderMonkey_source_code" title="Getting the latest SpiderMonkey source code">pull the SpiderMonkey repository</a>. On Windows, do not install the SpiderMonkey source code under the MSYS root directory (which is usually c:\mozilla-build\msys). Instead use something like c:\mozjs-31.2.0</li> + <li>Compile SpiderMonkey using the build instructions at <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation" title="Build Documentation">SpiderMonkey Build Documentation</a>. By default this will build a SpiderMonkey shared library that you will link into your application in a later step.</li> + <li>Copy the code example above into a text editor and save the file as helloworld.cpp in the SpiderMonkey js\src directory. To get a copy of the code sample without line numbers, hover over the sample near the top until buttons appear. Then click the view source button, and copy the code from the window that appears.</li> + <li>Compile the helloworld application and link to the SpiderMonkey library.</li> + <li>Run the helloworld executable at the command line: + <pre class="line-numbers language-html"><code class="language-html">./helloworld</code></pre> + </li> +</ol> +</div> + +<h3 id="JavaScript_から_C_関数の呼び出し方">JavaScript から C 関数の呼び出し方</h3> + +<p><code>doit</code> という名前のC関数について言及します。これは呼び出されるときに少なくとも二つの実際のパラメータを使います。(もし呼びだし元がより少ないパラメータを使う場合、JSエンジンは無くなった一つの変数に対して未定義の変数が渡される事を確認すべきです):</p> + +<pre class="eval">#define DOIT_MINARGS 2 + +static JSBool +doit(JSContext *cx, unsigned argc, jsval *vp) +{ +<span id="the-code"><a class="d external" href="http://mxr.mozilla.org/mozilla-central/ident?i=jsval"> jsval</a> *<a class="d external" href="http://mxr.mozilla.org/mozilla-central/ident?i=argv">argv</a> = <a class="d external" href="http://mxr.mozilla.org/mozilla-central/ident?i=JS_ARGV">JS_ARGV</a>(<a class="d external" href="http://mxr.mozilla.org/mozilla-central/ident?i=cx">cx</a>, <a class="d external" href="http://mxr.mozilla.org/mozilla-central/ident?i=vp">vp</a>);</span> + /* + * Look in argv for argc actual parameters, set *rval to return a + * value to the caller. + */ + ... +} +</pre> + +<p>そして、以下のようにコーディングし、JSに渡します:</p> + +<pre class="eval">ok = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_DefineFunction" title="en/SpiderMonkey/JSAPI_Reference/JS_DefineFunction">JS_DefineFunction</a>(cx, global, "doit", doit, DOIT_MINARGS, 0); +</pre> + +<p>または、ネイティブな関数群として定義するならば、おそらくそれらをテーブルの中に置き、関数テーブルとして定義するでしょう:</p> + +<pre class="eval">static <a href="/En/SpiderMonkey/JSAPI_Reference/JSFunctionSpec" title="En/SpiderMonkey/JSAPI_Reference/JSFunctionSpec">JSFunctionSpec</a> my_functions[] = { + {"doit", doit, DOIT_MINARGS, 0, 0}, + etc... + {0,0,0,0,0}, +}; +</pre> + +<p>(最終的に、すべてのNULL 関数はテーブルを終端します)そして、以下のようにします:</p> + +<pre class="eval">ok = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_DefineFunctions" title="en/SpiderMonkey/JSAPI_Reference/JS_DefineFunctions">JS_DefineFunctions</a>(cx, global, my_functions); +</pre> + +<h3 id="C_から_JavaScript_の関数の呼び出し方">C から JavaScript の関数の呼び出し方</h3> + +<p>クリックイベントを最上位の UI から座標 (x,y) の UI 要素に焦点をあてます:</p> + +<pre class="eval">JSObject *target, *event; +jsval argv[1], rval; + +/* + * Find event target and make event object to represent this click. + * Pass cx to NewEventObject so JS_NewObject can be called. + */ +target = FindEventTargetAt(cx, global, x, y); +event = NewEventObject(cx, "click", x, y); +argv[0] = <a href="/en/SpiderMonkey/JSAPI_Reference/OBJECT_TO_JSVAL" title="en/SpiderMonkey/JSAPI_Reference/OBJECT_TO_JSVAL">OBJECT_TO_JSVAL</a>(event); + +/* To emulate the DOM, you might want to try "onclick" too. */ +ok = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName" title="en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName">JS_CallFunctionName</a>(cx, target, "onClick", 1, argv, &rval); + +/* Now test rval to see whether we should cancel the event. */ +if (<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_BOOLEAN" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_BOOLEAN">JSVAL_IS_BOOLEAN</a>(rval) && !<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_BOOLEAN" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_BOOLEAN">JSVAL_TO_BOOLEAN</a>(rval)) + CancelEvent(event); +</pre> + +<p>繰り返しますが、ここではエラーチェックは無視しています。(関数呼び出し後の 戻り値 !ok のテストような)、いくつかのCのイベント管理処理やハンドラーが偽値を返したときのイベントをキャンセルする場合のDOMの伝統的なやり方を適切にエミュレートするために疑似コードを用いています。</p> + +<div class="originaldocinfo"> +<h2 id="Original_Document_Information" name="Original_Document_Information">Original Document Information</h2> + +<ul> + <li>Author: Brendan Eich</li> + <li>Last Updated Date: 21 February, 2000</li> +</ul> +</div> diff --git a/files/ja/mozilla/projects/spidermonkey/index.html b/files/ja/mozilla/projects/spidermonkey/index.html new file mode 100644 index 0000000000..e285c49690 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/index.html @@ -0,0 +1,102 @@ +--- +title: SpiderMonkey +slug: Mozilla/Projects/SpiderMonkey +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey +--- +<div>{{SpiderMonkeySidebar}}</div> + +<p class="summary"><strong>SpiderMonkey</strong> は 、C / C++ で書かれた <a href="/ja/docs/Web/JavaScript">JavaScript</a> エンジンです。Firefoxを含む、Mozillaの複数の製品で使用されており、MPL2 ライセンスの下で利用できます。</p> + +<p>独立したソースコードリリースは、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases">リリースページ</a>にあります。</p> + +<div class="topicpage-table"> +<div class="section"> +<h2 id="ガイド">ガイド</h2> + +<h3 id="ビルド">ビルド</h3> + +<dl> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation">SpiderMonkey のビルド手順</a></dt> + <dd>SpiderMonkey をビルドしてテストスイートを実行する方法について。</dd> +</dl> + +<h3 id="SpiderMonkey_の利用">SpiderMonkey の利用</h3> + +<dl> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell">JavaScript シェルの手引き</a></dt> + <dd>JavaScript シェルの取得、構築、利用方法について。</dd> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide">JSAPI ユーザガイド</a></dt> + <dd>このガイドでは、SpiderMonkey の概要と、あなたのアプリケーションを JavaScript 対応にするため、アプリケーションから組み込んだエンジンを呼び出す方法について説明します。</dd> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Cookbook">JSAPI クックブック</a></dt> + <dd>よく使われる JavaScript の式や文の JSAPI 表現を解説します。</dd> + <dt><a href="/ja/docs/SpiderMonkey/GC_Rooting_Guide">GC ルーティングガイド</a></dt> + <dd>SpiderMonkey の世代別 GC に対応したコードの書き方を解説します。</dd> + <dt><a href="/ja/docs/How_to_embed_the_JavaScript_engine">JavaScript エンジンの埋め込み方</a></dt> + <dd>SpiderMonkey の埋め込み方の古い解説です。</dd> +</dl> + +<h2 id="SpiderMonkey_のハック">SpiderMonkey のハック</h2> + +<dl> + <dt><a href="https://wiki.mozilla.org/JavaScript:New_to_SpiderMonkey">SpiderMonkey 入門</a></dt> + <dd>SpiderMonkey をハックするためのガイド。</dd> + <dt><a href="/ja/docs/SpiderMonkey/Setting_up_CDT_to_work_on_SpiderMonkey">SpiderMonkey 開発のための CDT 設定</a></dt> + <dd>SpiderMonkey を開発するための Eclipse 設定手順を解説します。</dd> + <dt><a href="http://blog.cdleary.com/2011/11/contributing-to-spidermonkey/">SpiderMonkey に貢献するには</a></dt> + <dd>4 分弱のスライドキャストです。</dd> +</dl> + +<dl> + <dt><a href="/ja/docs/SpiderMonkey/Running_Automated_JavaScript_Tests">JavaScript テストの自動実行</a></dt> + <dd>JavaScript テストスイートの自動実行方法について解説します。</dd> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Creating_JavaScript_tests">JavaScript のテストを作成する</a></dt> + <dd>JavaScript テストスイートに対するテストの追加方法を解説します。</dd> +</dl> +</div> + +<div class="section"> +<h2 id="リファレンス">リファレンス</h2> + +<dl> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference">JSAPI レファレンス</a></dt> + <dd>SpiderMonkey の API レファレンスです。</dd> + <dt><a href="/ja/docs/SpiderMonkey/JS_Debugger_API_Reference">JS Debugger API レファレンス</a></dt> + <dd>Gecko 8.0 {{GeckoRelease("8.0")}} と同時にリリースされた SpiderMonkey 1.8.6 で導入された、<code>Debugger</code> オブジェクトの API について解説します。</dd> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Internals/Bytecode">バイトコードの解説</a></dt> + <dd>SpiderMonkey が利用するバイトコードのリストです。</dd> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Parser_API">Parser API</a></dt> + <dd>SpiderMonkey の持つ構文解析器と、JavaScript API からの利用方法を解説しています。</dd> +</dl> + +<h2 id="TIPS、トリック、哲学">TIPS、トリック、哲学</h2> + +<dl> + <dt><a href="/ja/docs/SpiderMonkey/Future_directions">今後の方針</a></dt> + <dd>機能、設計、コーディングにおける今後の方針を述べています。</dd> + <dt><a href="/ja/docs/SpiderMonkey/Internals">SpiderMonkey の内部構造</a></dt> + <dd>設計の概要と、ファイル単位での実装の解説です。</dd> + <dt><a href="/ja/docs/SpiderMonkey/Bytecodes">バイトコードのレファレンス</a></dt> + <dd>SpiderMonkey の使用するバイトコードのレファレンスです。</dd> + <dt><a href="/ja/docs/SpiderMonkey/Internals/Garbage_collection">SpiderMonkey の内部構造: GC</a></dt> + <dd>GC の内部構造を解説します。</dd> + <dt><a href="/ja/docs/SpiderMonkey/Hacking_Tips">SpiderMonkey の内部構造: ハックのための TIPS </a></dt> + <dd>SpiderMonkey をハックするために有用なツールと TIPS がまとめられています。</dd> +</dl> + +<h2 id="関連項目">関連項目</h2> + +<ul> + <li><a href="/ja/docs/Web/JavaScript">JavaScript</a></li> + <li><a href="/ja/docs/SpiderMonkey/FOSS">SpiderMonkey を利用した FOSS プロジェクト</a></li> +</ul> + +<h2 id="リリースノート">リリースノート</h2> + +<dl> + <dt><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases">SpiderMonkey リリースノート</a></dt> + <dd>現在のリリースと、次にあげる過去のリリースに対するリリースノートがまとめられています:<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/52">52</a>, <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/45">45</a>, <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/38">38</a>, <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/31">31</a>, <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/24">24</a>, <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/17">17</a></dd> +</dl> +</div> +</div> diff --git a/files/ja/mozilla/projects/spidermonkey/index/index.html b/files/ja/mozilla/projects/spidermonkey/index/index.html new file mode 100644 index 0000000000..f59feeeb07 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/index/index.html @@ -0,0 +1,10 @@ +--- +title: Index +slug: Mozilla/Projects/SpiderMonkey/Index +tags: + - Index + - MDN Meta + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Index +--- +<p>{{Index("/ja/docs/Mozilla/Projects/SpiderMonkey")}}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/internals/bytecode/index.html b/files/ja/mozilla/projects/spidermonkey/internals/bytecode/index.html new file mode 100644 index 0000000000..f4e65a7748 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/internals/bytecode/index.html @@ -0,0 +1,6855 @@ +--- +title: バイトコードの説明 +slug: Mozilla/Projects/SpiderMonkey/Internals/Bytecode +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Internals/Bytecode +--- +<div>{{SpiderMonkeySidebar("Internals")}}</div> + +<h2 id="バイトコード一覧">バイトコード一覧</h2> + +<p>この文書は <a href="http://dxr.mozilla.org/mozilla-central/source/js/src/vm/make_opcode_doc.py">make_opcode_doc.py</a> によって <a href="http://dxr.mozilla.org/mozilla-central/source/js/src/vm/Opcodes.h">Opcodes.h</a> から自動的に生成されます。</p> + +<h3 id="ステートメント">ステートメント</h3> + +<h4 id="Jumps">Jumps</h4> + +<dl> + <dt id="JSOP_AND">JSOP_AND [-1, +1] (JUMP, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>69 (0x45)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>cond</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>cond</code></td> + </tr> + </tbody> + </table> + + <p>スタックの先頭の値をブール値に変換し、結果が <code>false</code> の場合、現在のバイトコードから 32-bit のオフセットにジャンプします。</p> + </dd> + <dt id="JSOP_GOTO">JSOP_GOTO [-0, +0] (JUMP)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>6 (0x06)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>現在のバイトコードから 32-bit のオフセットにジャンプします。</p> + </dd> + <dt id="JSOP_IFEQ">JSOP_IFEQ [-1, +0] (JUMP, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>7 (0x07)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>cond</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, converts it into a boolean, if the result is <code>false</code>, jumps to a 32-bit offset from the current bytecode.</p> + + <p>The idea is that a sequence like <code>JSOP_ZERO</code>; <code>JSOP_ZERO</code>; <code>JSOP_EQ</code>; <code>JSOP_IFEQ</code>; <code>JSOP_RETURN</code>; reads like a nice linear sequence that will execute the return.</p> + </dd> + <dt id="JSOP_IFNE">JSOP_IFNE [-1, +0] (JUMP, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>8 (0x08)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>cond</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, converts it into a boolean, if the result is <code>true</code>, jumps to a 32-bit offset from the current bytecode.</p> + </dd> + <dt id="JSOP_LABEL">JSOP_LABEL [-0, +0] (CODE_OFFSET)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>106 (0x6a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This opcode precedes every labeled statement. It's a no-op.</p> + + <p><code>offset</code> is the offset to the next instruction after this statement, the one <code>break LABEL;</code> would jump to. IonMonkey uses this.</p> + </dd> + <dt id="JSOP_LOOPENTRY">JSOP_LOOPENTRY [-0, +0] (LOOPENTRY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>227 (0xe3)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t icIndex, uint8_t BITFIELD</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>6</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This opcode is the target of the entry jump for some loop. The uint8 argument is a bitfield. The lower 7 bits of the argument indicate the loop depth. This value starts at 1 and is just a hint: deeply nested loops all have the same value. The upper bit is set if Ion should be able to OSR at this point, which is true unless there is non-loop state on the stack. See <code>JSOP_JUMPTARGET</code> for the icIndex argument.</p> + </dd> + <dt id="JSOP_LOOPHEAD">JSOP_LOOPHEAD [-0, +0] (ICINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>109 (0x6d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t icIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Another no-op.</p> + + <p>This opcode is the target of the backwards jump for some loop. See <code>JSOP_JUMPTARGET</code> for the icIndex operand.</p> + </dd> + <dt id="JSOP_OR">JSOP_OR [-1, +1] (JUMP, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>68 (0x44)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>cond</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>cond</code></td> + </tr> + </tbody> + </table> + + <p>Converts the top of stack value into a boolean, if the result is <code>true</code>, jumps to a 32-bit offset from the current bytecode.</p> + </dd> +</dl> + +<h4 id="Switch_Statement">Switch Statement</h4> + +<dl> + <dt id="JSOP_CASE">JSOP_CASE [-2, +1] (JUMP)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>121 (0x79)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val, cond</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val(if !cond)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>val</code> and <code>cond</code>. If <code>cond</code> is <code>true</code>, jumps to a 32-bit offset from the current bytecode, re-pushes <code>val</code> onto the stack if <code>false</code>.</p> + </dd> + <dt id="JSOP_CONDSWITCH">JSOP_CONDSWITCH [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>120 (0x78)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This no-op appears after the bytecode for EXPR in <code>switch (EXPR) {...}</code> if the switch cannot be optimized using <code>JSOP_TABLESWITCH</code>.</p> + + <p>For a non-optimized switch statement like this:</p> + + <pre class="notranslate"> switch (EXPR) { + case V0: + C0; + ... + default: + D; + } +</pre> + + <p>the bytecode looks like this:</p> + + <pre class="notranslate"> (EXPR) + condswitch + (V0) + case ->C0 + ... + default ->D + (C0) + ... + (D) +</pre> + + <p>Note that code for all case-labels is emitted first, then code for the body of each case clause.</p> + </dd> + <dt id="JSOP_DEFAULT">JSOP_DEFAULT [-1, +0] (JUMP)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>122 (0x7a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This appears after all cases in a <code>JSOP_CONDSWITCH</code>, whether there is a <code>default:</code> label in the switch statement or not. Pop the switch operand from the stack and jump to a 32-bit offset from the current bytecode. offset from the current bytecode.</p> + </dd> + <dt id="JSOP_TABLESWITCH">JSOP_TABLESWITCH [-1, +0] (TABLESWITCH, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>70 (0x46)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t len, int32_t low, int32_t high,uint24_t firstResumeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>len</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>i</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>i</code>, if <code>low <= i <= high</code>, jumps to a 32-bit offset: offset is stored in the script's resumeOffsets</p> + + <pre class="notranslate"> list at index 'firstResumeIndex + (i - low)' +</pre> + + <p>jumps to a 32-bit offset: <code>len</code> from the current bytecode otherwise</p> + </dd> +</dl> + +<h4 id="For-In_Statement">For-In Statement</h4> + +<dl> + <dt id="JSOP_ENDITER">JSOP_ENDITER [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>78 (0x4e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>iter</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Exits a for-in loop by popping the iterator object from the stack and closing it.</p> + </dd> + <dt id="JSOP_ISGENCLOSING">JSOP_ISGENCLOSING [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>187 (0xbb)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val, res</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a boolean indicating whether the top of the stack is MagicValue(<code>JS_GENERATOR_CLOSING</code>).</p> + </dd> + <dt id="JSOP_ISNOITER">JSOP_ISNOITER [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>77 (0x4d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val, res</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a boolean indicating whether the value on top of the stack is MagicValue(<code>JS_NO_ITER_VALUE</code>).</p> + </dd> + <dt id="JSOP_ITER">JSOP_ITER [-1, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>75 (0x4b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>iter</code></td> + </tr> + </tbody> + </table> + + <p>Sets up a for-in loop. It pops the top of stack value as <code>val</code> and pushes <code>iter</code> which is an iterator for <code>val</code>.</p> + </dd> + <dt id="JSOP_MOREITER">JSOP_MOREITER [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>76 (0x4c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>iter</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>iter, val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the next iterated value onto the stack. If no value is available, MagicValue(<code>JS_NO_ITER_VALUE</code>) is pushed.</p> + </dd> +</dl> + +<h4 id="With_Statement">With Statement</h4> + +<dl> + <dt id="JSOP_ENTERWITH">JSOP_ENTERWITH [-1, +0] (SCOPE)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>3 (0x03)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t staticWithIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, converts it to an object, and adds a <code>WithEnvironmentObject</code> wrapping that object to the environment chain.</p> + + <p>There is a matching <code>JSOP_LEAVEWITH</code> instruction later. All name lookups between the two that may need to consult the With object are deoptimized.</p> + </dd> + <dt id="JSOP_LEAVEWITH">JSOP_LEAVEWITH [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>4 (0x04)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the environment chain object pushed by <code>JSOP_ENTERWITH</code>.</p> + </dd> +</dl> + +<h4 id="Exception_Handling">Exception Handling</h4> + +<dl> + <dt id="JSOP_EXCEPTION">JSOP_EXCEPTION [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>118 (0x76)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>exception</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the current pending exception onto the stack and clears the pending exception. This is only emitted at the beginning of code for a catch-block, so it is known that an exception is pending. It is used to implement catch-blocks and <code>yield*</code>.</p> + </dd> + <dt id="JSOP_FINALLY">JSOP_FINALLY [-0, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>135 (0x87)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>false, resumeIndex</code></td> + </tr> + </tbody> + </table> + + <p>This opcode has a def count of 2, but these values are already on the stack (they're pushed by <code>JSOP_GOSUB</code>).</p> + </dd> + <dt id="JSOP_GOSUB">JSOP_GOSUB [-2, +0] (JUMP)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>116 (0x74)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t offset</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>false, resumeIndex</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This opcode is used for entering a <code>finally</code> block. Jumps to a 32-bit offset from the current pc.</p> + + <p>Note: this op doesn't actually push/pop any values, but it has a use count of 2 (for the <code>false</code> + resumeIndex values pushed by preceding bytecode ops) because the <code>finally</code> entry point does not expect these values on the stack. See also <code>JSOP_FINALLY</code> (it has a def count of 2).</p> + + <p>When the execution resumes from <code>finally</code> block, those stack values are popped.</p> + </dd> + <dt id="JSOP_RETSUB">JSOP_RETSUB [-2, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>117 (0x75)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This opcode is used for returning from a <code>finally</code> block.</p> + + <p>Pops the top two values on the stack as <code>rval</code> and <code>lval</code>. Then: - If <code>lval</code> is true, throws <code>rval</code>. - If <code>lval</code> is false, jumps to the resumeIndex stored in <code>lval</code>.</p> + </dd> + <dt id="JSOP_THROW">JSOP_THROW [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>112 (0x70)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>v</code>, sets pending exception as <code>v</code>, then raises error.</p> + </dd> + <dt id="JSOP_THROWMSG">JSOP_THROWMSG [-0, +0] (UINT16)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>74 (0x4a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t msgNumber</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Sometimes we know when emitting that an operation will always throw.</p> + + <p>Throws the indicated <code>JSMSG</code>.</p> + </dd> + <dt id="JSOP_TRY">JSOP_TRY [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>134 (0x86)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This no-op appears at the top of the bytecode for a <code>TryStatement</code>.</p> + + <p>Location information for catch/finally blocks is stored in a side table, <code>script->trynotes()</code>.</p> + </dd> +</dl> + +<h4 id="Function">Function</h4> + +<dl> + <dt id="JSOP_CALL">JSOP_CALL [-(argc+2), +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>58 (0x3a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>callee</code> with <code>this</code> and <code>args</code>, pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_CALLITER">JSOP_CALLITER [-2, +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>145 (0x91)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc (must be 0)</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Like <code>JSOP_CALL</code>, but used as part of for-of and destructuring bytecode to provide better error messages.</p> + </dd> + <dt id="JSOP_CALL_IGNORES_RV">JSOP_CALL_IGNORES_RV [-(argc+2), +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>231 (0xe7)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Like <code>JSOP_CALL</code>, but tells the function that the return value is ignored. stack.</p> + </dd> + <dt id="JSOP_CHECKISCALLABLE">JSOP_CHECKISCALLABLE [-1, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>219 (0xdb)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t kind</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Checks that the top value on the stack is callable, and throws a TypeError if not. The operand <code>kind</code> is used only to generate an appropriate error message.</p> + </dd> + <dt id="JSOP_EVAL">JSOP_EVAL [-(argc+2), +1] (ARGC, INVOKE, TYPESET, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>123 (0x7b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>eval</code> with <code>args</code> and pushes return value onto the stack.</p> + + <p>If <code>eval</code> in global scope is not original one, invokes the function with <code>this</code> and <code>args</code>, and pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_FUNAPPLY">JSOP_FUNAPPLY [-(argc+2), +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>79 (0x4f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>callee</code> with <code>this</code> and <code>args</code>, pushes return value onto the stack.</p> + + <p>This is for <code>f.apply</code>.</p> + </dd> + <dt id="JSOP_FUNCALL">JSOP_FUNCALL [-(argc+2), +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>108 (0x6c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>callee</code> with <code>this</code> and <code>args</code>, pushes return value onto the stack.</p> + + <p>If <code>callee</code> is determined to be the canonical <code>Function.prototype.call</code> function, then this operation is optimized to directly call <code>callee</code> with <code>args[0]</code> as <code>this</code>, and the remaining arguments as formal args to <code>callee</code>.</p> + + <p>Like <code>JSOP_FUNAPPLY</code> but for <code>f.call</code> instead of <code>f.apply</code>.</p> + </dd> + <dt id="JSOP_FUNWITHPROTO">JSOP_FUNWITHPROTO [-1, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>52 (0x34)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t funcIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>proto</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a clone of a function with a given [[Prototype]] onto the stack.</p> + </dd> + <dt id="JSOP_GETRVAL">JSOP_GETRVAL [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>2 (0x02)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Pushes stack frame's <code>rval</code> onto the stack.</p> + </dd> + <dt id="JSOP_LAMBDA">JSOP_LAMBDA [-0, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>130 (0x82)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t funcIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a closure for a named or anonymous function expression onto the stack.</p> + </dd> + <dt id="JSOP_LAMBDA_ARROW">JSOP_LAMBDA_ARROW [-1, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>131 (0x83)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t funcIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>new.target</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>new.target</code>, pushes an arrow function with lexical <code>new.target</code> onto the stack.</p> + </dd> + <dt id="JSOP_NEW">JSOP_NEW [-(argc+3), +1] (ARGC, INVOKE, TYPESET, IC, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>82 (0x52)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1], newTarget</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>callee</code> as a constructor with <code>this</code> and <code>args</code>, pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_OPTIMIZE_SPREADCALL">JSOP_OPTIMIZE_SPREADCALL [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>178 (0xb2)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>arr</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>arr, optimized</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top stack value, pushes the value and a boolean value that indicates whether the spread operation for the value can be optimized in spread call.</p> + </dd> + <dt id="JSOP_RETRVAL">JSOP_RETRVAL [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>153 (0x99)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Stops interpretation and returns value set by <code>JSOP_SETRVAL</code>. When not set, returns <code>undefined</code>.</p> + + <p>Also emitted at end of script so interpreter don't need to check if opcode is still in script range.</p> + </dd> + <dt id="JSOP_RETURN">JSOP_RETURN [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>5 (0x05)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>rval</code>, stops interpretation of current script and returns <code>rval</code>.</p> + </dd> + <dt id="JSOP_SETFUNNAME">JSOP_SETFUNNAME [-2, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>182 (0xb6)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t prefixKind</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>fun, name</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>fun</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>name</code> and <code>fun</code>, defines the name of <code>fun</code> to <code>name</code> with prefix if any, and pushes <code>fun</code> back onto the stack.</p> + </dd> + <dt id="JSOP_SETRVAL">JSOP_SETRVAL [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>152 (0x98)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>rval</code>, sets the return value in stack frame as <code>rval</code>.</p> + </dd> + <dt id="JSOP_SPREADCALL">JSOP_SPREADCALL [-3, +1] (INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>41 (0x29)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>spreadcall variant of <code>JSOP_CALL</code>.</p> + + <p>Invokes <code>callee</code> with <code>this</code> and <code>args</code>, pushes the return value onto the stack.</p> + + <p><code>args</code> is an Array object which contains actual arguments.</p> + </dd> + <dt id="JSOP_SPREADEVAL">JSOP_SPREADEVAL [-3, +1] (INVOKE, TYPESET, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>43 (0x2b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>spreadcall variant of <code>JSOP_EVAL</code></p> + + <p>Invokes <code>eval</code> with <code>args</code> and pushes the return value onto the stack.</p> + + <p>If <code>eval</code> in global scope is not original one, invokes the function with <code>this</code> and <code>args</code>, and pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_SPREADNEW">JSOP_SPREADNEW [-4, +1] (INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>42 (0x2a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args, newTarget</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>spreadcall variant of <code>JSOP_NEW</code></p> + + <p>Invokes <code>callee</code> as a constructor with <code>this</code> and <code>args</code>, pushes the return value onto the stack.</p> + </dd> + <dt id="JSOP_SPREADSUPERCALL">JSOP_SPREADSUPERCALL [-4, +1] (INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>166 (0xa6)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args, newTarget</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>spreadcall variant of <code>JSOP_SUPERCALL</code>.</p> + + <p>Behaves exactly like <code>JSOP_SPREADNEW</code>.</p> + </dd> + <dt id="JSOP_STRICTEVAL">JSOP_STRICTEVAL [-(argc+2), +1] (ARGC, INVOKE, TYPESET, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>124 (0x7c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Invokes <code>eval</code> with <code>args</code> and pushes return value onto the stack.</p> + + <p>If <code>eval</code> in global scope is not original one, invokes the function with <code>this</code> and <code>args</code>, and pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_STRICTSPREADEVAL">JSOP_STRICTSPREADEVAL [-3, +1] (INVOKE, TYPESET, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>50 (0x32)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>spreadcall variant of <code>JSOP_EVAL</code></p> + + <p>Invokes <code>eval</code> with <code>args</code> and pushes the return value onto the stack.</p> + + <p>If <code>eval</code> in global scope is not original one, invokes the function with <code>this</code> and <code>args</code>, and pushes return value onto the stack.</p> + </dd> + <dt id="JSOP_SUPERCALL">JSOP_SUPERCALL [-(argc+3), +1] (ARGC, INVOKE, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>165 (0xa5)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argc</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee, this, args[0], ..., args[argc-1], newTarget</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Behaves exactly like <code>JSOP_NEW</code>, but allows JITs to distinguish the two cases.</p> + </dd> + <dt id="JSOP_TRYSKIPAWAIT">JSOP_TRYSKIPAWAIT [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>223 (0xdf)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>value</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>value_or_resolved, canskip</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value as <code>value</code>, checks if the await for <code>value</code> can be skipped. If the await operation can be skipped and the resolution value for <code>value</code> can be acquired, pushes the resolution value and <code>true</code> onto the stack. Otherwise, pushes <code>value</code> and <code>false</code> on the stack.</p> + </dd> +</dl> + +<h4 id="Generator">Generator</h4> + +<dl> + <dt id="JSOP_ASYNCAWAIT">JSOP_ASYNCAWAIT [-2, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>151 (0x97)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>value, gen</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>promise</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>value</code> and <code>gen</code> from the stack, then starts "awaiting" for <code>value</code> to be resolved, which will then resume the execution of <code>gen</code>. Pushes the async function promise on the stack, so that it'll be returned to the caller on the very first "await".</p> + </dd> + <dt id="JSOP_ASYNCRESOLVE">JSOP_ASYNCRESOLVE [-2, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>192 (0xc0)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t fulfillOrReject</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>valueOrReason, gen</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>promise</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>valueOrReason</code> and <code>gen</code> from the stack, then pushes the promise resolved with <code>valueOrReason</code>. `gen` must be the internal generator object created in async functions. The pushed promise is the async function's result promise, which is stored in `gen`.</p> + </dd> + <dt id="JSOP_AWAIT">JSOP_AWAIT [-2, +1] (RESUMEINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>209 (0xd1)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t resumeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>promise, gen</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>resolved</code></td> + </tr> + </tbody> + </table> + + <p>Pops the generator and the return value <code>promise</code>, stops interpretation and returns <code>promise</code>. Pushes resolved value onto the stack.</p> + </dd> + <dt id="JSOP_CHECKISOBJ">JSOP_CHECKISOBJ [-1, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>14 (0x0e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t kind</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>result</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>result</code></td> + </tr> + </tbody> + </table> + + <p>Checks that the top value on the stack is an object, and throws a TypeError if not. The operand <code>kind</code> is used only to generate an appropriate error message.</p> + </dd> + <dt id="JSOP_FINALYIELDRVAL">JSOP_FINALYIELDRVAL [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>204 (0xcc)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>gen</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the generator and suspends and closes it. Yields the value in the frame's return value slot.</p> + </dd> + <dt id="JSOP_GENERATOR">JSOP_GENERATOR [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>212 (0xd4)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>generator</code></td> + </tr> + </tbody> + </table> + + <p>Initializes generator frame, creates a generator and pushes it on the stack.</p> + </dd> + <dt id="JSOP_INITIALYIELD">JSOP_INITIALYIELD [-1, +1] (RESUMEINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>202 (0xca)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t resumeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>generator</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>generator</code></td> + </tr> + </tbody> + </table> + + <p>Pops the generator from the top of the stack, suspends it and stops interpretation.</p> + </dd> + <dt id="JSOP_RESUME">JSOP_RESUME [-2, +1] (UINT8, INVOKE)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>205 (0xcd)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>resume kind (AbstractGeneratorObject::ResumeKind)</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>gen, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Pops the generator and argument from the stack, pushes a new generator frame and resumes execution of it. Pushes the return value after the generator yields.</p> + </dd> + <dt id="JSOP_TOASYNCITER">JSOP_TOASYNCITER [-2, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>210 (0xd2)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>iter, next</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>asynciter</code></td> + </tr> + </tbody> + </table> + + <p>Pops the iterator and its next method from the top of the stack, and create async iterator from it and push the async iterator back onto the stack.</p> + </dd> + <dt id="JSOP_YIELD">JSOP_YIELD [-2, +1] (RESUMEINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>203 (0xcb)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t resumeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>rval1, gen</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval2</code></td> + </tr> + </tbody> + </table> + + <p>Pops the generator and the return value <code>rval1</code>, stops interpretation and returns <code>rval1</code>. Pushes sent value from <code>send()</code> onto the stack.</p> + </dd> +</dl> + +<h4 id="Debugger">Debugger</h4> + +<dl> + <dt id="JSOP_DEBUGGER">JSOP_DEBUGGER [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>115 (0x73)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Invokes debugger.</p> + </dd> + <dt id="JSOP_DEBUGLEAVELEXICALENV">JSOP_DEBUGLEAVELEXICALENV [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>201 (0xc9)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>The opcode to assist the debugger.</p> + </dd> +</dl> + +<h3 id="Variables_and_Scopes">Variables and Scopes</h3> + +<h4 id="Variables">Variables</h4> + +<dl> + <dt id="JSOP_BINDNAME">JSOP_BINDNAME [-0, +1] (ATOM, NAME, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>110 (0x6e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>env</code></td> + </tr> + </tbody> + </table> + + <p>Looks up name on the environment chain and pushes the environment which contains the name onto the stack. If not found, pushes global lexical environment onto the stack.</p> + </dd> + <dt id="JSOP_DEFCONST">JSOP_DEFCONST [-0, +0] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>128 (0x80)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Defines the new constant binding on global lexical environment.</p> + + <p>Throws if a binding with the same name already exists on the environment, or if a var binding with the same name exists on the global.</p> + </dd> + <dt id="JSOP_DEFFUN">JSOP_DEFFUN [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>127 (0x7f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>fun</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Defines the given function on the current scope.</p> + + <p>This is used for global scripts and also in some cases for function scripts where use of dynamic scoping inhibits optimization.</p> + </dd> + <dt id="JSOP_DEFLET">JSOP_DEFLET [-0, +0] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>162 (0xa2)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Defines the new mutable binding on global lexical environment.</p> + + <p>Throws if a binding with the same name already exists on the environment, or if a var binding with the same name exists on the global.</p> + </dd> + <dt id="JSOP_DEFVAR">JSOP_DEFVAR [-0, +0] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>129 (0x81)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Defines the new binding on the frame's current variables-object (the environment on the environment chain designated to receive new variables).</p> + + <p>Throws if the current variables-object is the global object and a binding with the same name exists on the global lexical environment.</p> + + <p>This is used for global scripts and also in some cases for function scripts where use of dynamic scoping inhibits optimization.</p> + </dd> + <dt id="JSOP_DELNAME">JSOP_DELNAME [-0, +1] (ATOM, NAME, CHECKSLOPPY)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>36 (0x24)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p>Looks up name on the environment chain and deletes it, pushes <code>true</code> onto the stack if succeeded (if the property was present and deleted or if the property wasn't present in the first place), <code>false</code> if not.</p> + + <p>Strict mode code should never contain this opcode.</p> + </dd> + <dt id="JSOP_GETIMPORT">JSOP_GETIMPORT [-0, +1] (ATOM, NAME, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>176 (0xb0)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Gets the value of a module import by name and pushes it onto the stack.</p> + </dd> + <dt id="JSOP_GETNAME">JSOP_GETNAME [-0, +1] (ATOM, NAME, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>59 (0x3b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Looks up name on the environment chain and pushes its value onto the stack.</p> + </dd> + <dt id="JSOP_SETNAME">JSOP_SETNAME [-2, +1] (ATOM, NAME, PROPSET, DETECTING, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>111 (0x6f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>env, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops an environment and value from the stack, assigns value to the given name, and pushes the value back on the stack</p> + </dd> + <dt id="JSOP_STRICTSETNAME">JSOP_STRICTSETNAME [-2, +1] (ATOM, NAME, PROPSET, DETECTING, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>49 (0x31)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>env, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops a environment and value from the stack, assigns value to the given name, and pushes the value back on the stack. If the set failed, then throw a TypeError, per usual strict mode semantics.</p> + </dd> +</dl> + +<h4 id="Free_Variables">Free Variables</h4> + +<dl> + <dt id="JSOP_BINDGNAME">JSOP_BINDGNAME [-0, +1] (ATOM, NAME, GNAME, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>214 (0xd6)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>global</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the global environment onto the stack if the script doesn't have a non-syntactic global scope. Otherwise will act like <code>JSOP_BINDNAME</code>.</p> + + <p><code>nameIndex</code> is only used when acting like <code>JSOP_BINDNAME</code>.</p> + </dd> + <dt id="JSOP_BINDVAR">JSOP_BINDVAR [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>213 (0xd5)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>env</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the nearest <code>var</code> environment.</p> + </dd> + <dt id="JSOP_GETGNAME">JSOP_GETGNAME [-0, +1] (ATOM, NAME, TYPESET, GNAME, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>154 (0x9a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Looks up name on global environment and pushes its value onto the stack, unless the script has a non-syntactic global scope, in which case it acts just like <code>JSOP_NAME</code>.</p> + + <p>Free variable references that must either be found on the global or a ReferenceError.</p> + </dd> + <dt id="JSOP_INITGLEXICAL">JSOP_INITGLEXICAL [-1, +1] (ATOM, NAME, PROPINIT, GNAME, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>161 (0xa1)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Initializes an uninitialized global lexical binding with the top of stack value.</p> + </dd> + <dt id="JSOP_SETGNAME">JSOP_SETGNAME [-2, +1] (ATOM, NAME, PROPSET, DETECTING, GNAME, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>155 (0x9b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>env, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>val</code> and <code>env</code>, sets property of <code>env</code> as <code>val</code> and pushes <code>val</code> back on the stack.</p> + + <p><code>env</code> should be the global lexical environment unless the script has a non-syntactic global scope, in which case acts like <code>JSOP_SETNAME</code>.</p> + </dd> + <dt id="JSOP_STRICTSETGNAME">JSOP_STRICTSETGNAME [-2, +1] (ATOM, NAME, PROPSET, DETECTING, GNAME, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>156 (0x9c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>env, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>val</code> and <code>env</code>, sets property of <code>env</code> as <code>val</code> and pushes <code>val</code> back on the stack. Throws a TypeError if the set fails, per strict mode semantics.</p> + + <p><code>env</code> should be the global lexical environment unless the script has a non-syntactic global scope, in which case acts like <code>JSOP_STRICTSETNAME</code>.</p> + </dd> +</dl> + +<h4 id="Local_Variables">Local Variables</h4> + +<dl> + <dt id="JSOP_CHECKLEXICAL">JSOP_CHECKLEXICAL [-0, +0] (LOCAL, NAME)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>138 (0x8a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t localno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Checks if the value of the local variable is the <code>JS_UNINITIALIZED_LEXICAL</code> magic, throwing an error if so.</p> + </dd> + <dt id="JSOP_GETLOCAL">JSOP_GETLOCAL [-0, +1] (LOCAL, NAME)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>86 (0x56)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t localno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the value of local variable onto the stack.</p> + </dd> + <dt id="JSOP_INITLEXICAL">JSOP_INITLEXICAL [-1, +1] (LOCAL, NAME, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>139 (0x8b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t localno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Initializes an uninitialized local lexical binding with the top of stack value.</p> + </dd> + <dt id="JSOP_SETLOCAL">JSOP_SETLOCAL [-1, +1] (LOCAL, NAME, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>87 (0x57)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t localno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Stores the top stack value to the given local.</p> + </dd> + <dt id="JSOP_THROWSETCALLEE">JSOP_THROWSETCALLEE [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>179 (0xb3)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Throws a runtime TypeError for invalid assignment to the callee in a named lambda, which is always a <code>const</code> binding. This is a different bytecode than <code>JSOP_SETCONST</code> because the named lambda callee, if not closed over, does not have a frame slot to look up the name with for the error message.</p> + </dd> + <dt id="JSOP_THROWSETCONST">JSOP_THROWSETCONST [-1, +1] (LOCAL, NAME, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>169 (0xa9)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t localno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Throws a runtime TypeError for invalid assignment to <code>const</code>. The localno is used for better error messages.</p> + </dd> +</dl> + +<h4 id="Aliased_Variables">Aliased Variables</h4> + +<dl> + <dt id="JSOP_CHECKALIASEDLEXICAL">JSOP_CHECKALIASEDLEXICAL [-0, +0] (ENVCOORD, NAME)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>140 (0x8c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t hops, uint24_t slot</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Checks if the value of the aliased variable is the <code>JS_UNINITIALIZED_LEXICAL</code> magic, throwing an error if so.</p> + </dd> + <dt id="JSOP_GETALIASEDVAR">JSOP_GETALIASEDVAR [-0, +1] (ENVCOORD, NAME, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>136 (0x88)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t hops, uint24_t slot</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>aliasedVar</code></td> + </tr> + </tbody> + </table> + + <p>Pushes aliased variable onto the stack.</p> + + <p>An "aliased variable" is a var, let, or formal arg that is aliased. Sources of aliasing include: nested functions accessing the vars of an enclosing function, function statements that are conditionally executed, <code>eval</code>, <code>with</code>, and <code>arguments</code>. All of these cases require creating a CallObject to own the aliased variable.</p> + + <p>An ALIASEDVAR opcode contains the following immediates:</p> + + <pre class="notranslate">uint8 hops: the number of environment objects to skip to find the + EnvironmentObject containing the variable being accessed +uint24 slot: the slot containing the variable in the EnvironmentObject + (this 'slot' does not include RESERVED_SLOTS). +</pre> + </dd> + <dt id="JSOP_INITALIASEDLEXICAL">JSOP_INITALIASEDLEXICAL [-1, +1] (ENVCOORD, NAME, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>141 (0x8d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t hops, uint24_t slot</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Initializes an uninitialized aliased lexical binding with the top of stack value.</p> + </dd> + <dt id="JSOP_SETALIASEDVAR">JSOP_SETALIASEDVAR [-1, +1] (ENVCOORD, NAME, PROPSET, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>137 (0x89)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t hops, uint24_t slot</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Sets aliased variable as the top of stack value.</p> + </dd> + <dt id="JSOP_THROWSETALIASEDCONST">JSOP_THROWSETALIASEDCONST [-1, +1] (ENVCOORD, NAME, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>170 (0xaa)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t hops, uint24_t slot</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Throws a runtime TypeError for invalid assignment to <code>const</code>. The environment coordinate is used for better error messages.</p> + </dd> +</dl> + +<h4 id="Intrinsics">Intrinsics</h4> + +<dl> + <dt id="JSOP_GETINTRINSIC">JSOP_GETINTRINSIC [-0, +1] (ATOM, NAME, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>143 (0x8f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>intrinsic[name]</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the value of the intrinsic onto the stack.</p> + + <p>Intrinsic names are emitted instead of <code>JSOP_*NAME</code> ops when the <code>CompileOptions</code> flag <code>selfHostingMode</code> is set.</p> + + <p>They are used in self-hosted code to access other self-hosted values and intrinsic functions the runtime doesn't give client JS code access to.</p> + </dd> + <dt id="JSOP_SETINTRINSIC">JSOP_SETINTRINSIC [-1, +1] (ATOM, NAME, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>144 (0x90)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Stores the top stack value in the specified intrinsic.</p> + </dd> +</dl> + +<h4 id="Block-local_Scope">Block-local Scope</h4> + +<dl> + <dt id="JSOP_FRESHENLEXICALENV">JSOP_FRESHENLEXICALENV [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>197 (0xc5)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Replaces the current block on the env chain with a fresh block that copies all the bindings in the block. This operation implements the behavior of inducing a fresh lexical environment for every iteration of a for(let ...; ...; ...) loop, if any declarations induced by such a loop are captured within the loop.</p> + </dd> + <dt id="JSOP_POPLEXICALENV">JSOP_POPLEXICALENV [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>200 (0xc8)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops lexical environment from the env chain.</p> + </dd> + <dt id="JSOP_PUSHLEXICALENV">JSOP_PUSHLEXICALENV [-0, +0] (SCOPE)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>199 (0xc7)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t scopeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pushes lexical environment onto the env chain.</p> + </dd> + <dt id="JSOP_RECREATELEXICALENV">JSOP_RECREATELEXICALENV [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>198 (0xc6)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Recreates the current block on the env chain with a fresh block with uninitialized bindings. This operation implements the behavior of inducing a fresh lexical environment for every iteration of a for-in/of loop whose loop-head has a (captured) lexical declaration.</p> + </dd> +</dl> + +<h4 id="This">This</h4> + +<dl> + <dt id="JSOP_CHECKRETURN">JSOP_CHECKRETURN [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>190 (0xbe)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>this</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Check if a derived class constructor has a valid return value and <code>this</code> value before it returns. If the return value is not an object, stores the <code>this</code> value to the return value slot.</p> + </dd> + <dt id="JSOP_CHECKTHIS">JSOP_CHECKTHIS [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>189 (0xbd)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>this</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Throw if the value on top of the stack is the TDZ MagicValue. Used in derived class constructors.</p> + </dd> + <dt id="JSOP_CHECKTHISREINIT">JSOP_CHECKTHISREINIT [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>191 (0xbf)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>this</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Throw an exception if the value on top of the stack is not the TDZ MagicValue. Used in derived class constructors.</p> + </dd> + <dt id="JSOP_FUNCTIONTHIS">JSOP_FUNCTIONTHIS [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>185 (0xb9)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Determines the <code>this</code> value for current function frame and pushes it onto the stack. Emitted in the prologue of functions with a this-binding.</p> + </dd> + <dt id="JSOP_GIMPLICITTHIS">JSOP_GIMPLICITTHIS [-0, +1] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>157 (0x9d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the implicit <code>this</code> value for calls to the associated name onto the stack; only used when the implicit this might be derived from a non-syntactic scope (instead of the global itself).</p> + + <p>Note that code evaluated via the Debugger API uses DebugEnvironmentProxy objects on its scope chain, which are non-syntactic environments that refer to syntactic environments. As a result, the binding we want may be held by a syntactic environments such as CallObject or VarEnvrionmentObject.</p> + </dd> + <dt id="JSOP_GLOBALTHIS">JSOP_GLOBALTHIS [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>186 (0xba)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code>this</code> value for current stack frame onto the stack. Emitted when <code>this</code> refers to the global <code>this</code>.</p> + </dd> + <dt id="JSOP_IMPLICITTHIS">JSOP_IMPLICITTHIS [-0, +1] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>226 (0xe2)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>this</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the implicit <code>this</code> value for calls to the associated name onto the stack.</p> + </dd> +</dl> + +<h4 id="Super">Super</h4> + +<dl> + <dt id="JSOP_SUPERBASE">JSOP_SUPERBASE [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>103 (0x67)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>homeObjectProto</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the prototype of the home object for |callee| onto the stack.</p> + </dd> + <dt id="JSOP_SUPERFUN">JSOP_SUPERFUN [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>164 (0xa4)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>callee</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>superFun</code></td> + </tr> + </tbody> + </table> + + <p>Push the function to invoke with |super()|. This is the prototype of the function passed in as |callee|.</p> + </dd> +</dl> + +<h4 id="Arguments">Arguments</h4> + +<dl> + <dt id="JSOP_ARGUMENTS">JSOP_ARGUMENTS [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>9 (0x09)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>arguments</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the <code>arguments</code> object for the current function activation.</p> + + <p>If <code><code>JSS</code>cript</code> is not marked <code>needsArgsObj</code>, then a <code>JS_OPTIMIZED_ARGUMENTS</code> magic value is pushed. Otherwise, a proper arguments object is constructed and pushed.</p> + + <p>This opcode requires that the function does not have rest parameter.</p> + </dd> + <dt id="JSOP_CALLEE">JSOP_CALLEE [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>132 (0x84)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>callee</code></td> + </tr> + </tbody> + </table> + + <p>Pushes current callee onto the stack.</p> + + <p>Used for named function expression self-naming, if lightweight.</p> + </dd> + <dt id="JSOP_ENVCALLEE">JSOP_ENVCALLEE [-0, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>206 (0xce)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t numHops</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>callee</code></td> + </tr> + </tbody> + </table> + + <p>Load the callee stored in a CallObject on the environment chain. The numHops operand is the number of environment objects to skip on the environment chain.</p> + </dd> + <dt id="JSOP_GETARG">JSOP_GETARG [-0, +1] (QARG, NAME)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>84 (0x54)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>arguments[argno]</code></td> + </tr> + </tbody> + </table> + + <p>Fast get op for function arguments and local variables.</p> + + <p>Pushes <code>arguments[argno]</code> onto the stack.</p> + </dd> + <dt id="JSOP_NEWTARGET">JSOP_NEWTARGET [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>148 (0x94)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>new.target</code></td> + </tr> + </tbody> + </table> + + <p>Push "new.target"</p> + </dd> + <dt id="JSOP_REST">JSOP_REST [-0, +1] (TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>224 (0xe0)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rest</code></td> + </tr> + </tbody> + </table> + + <p>Creates rest parameter array for current function call, and pushes it onto the stack.</p> + </dd> + <dt id="JSOP_SETARG">JSOP_SETARG [-1, +1] (QARG, NAME)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>85 (0x55)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t argno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Fast set op for function arguments and local variables.</p> + + <p>Sets <code>arguments[argno]</code> as the top of stack value.</p> + </dd> +</dl> + +<h4 id="Var_Scope">Var Scope</h4> + +<dl> + <dt id="JSOP_POPVARENV">JSOP_POPVARENV [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>181 (0xb5)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops a var environment from the env chain.</p> + </dd> + <dt id="JSOP_PUSHVARENV">JSOP_PUSHVARENV [-0, +0] (SCOPE)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>180 (0xb4)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t scopeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pushes a var environment onto the env chain.</p> + </dd> +</dl> + +<h4 id="Modules">Modules</h4> + +<dl> + <dt id="JSOP_DYNAMIC_IMPORT">JSOP_DYNAMIC_IMPORT [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>233 (0xe9)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>arg</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>rval</code></td> + </tr> + </tbody> + </table> + + <p>Dynamic import of the module specified by the string value on the top of the stack.</p> + </dd> + <dt id="JSOP_IMPORTMETA">JSOP_IMPORTMETA [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>232 (0xe8)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>import.meta</code></td> + </tr> + </tbody> + </table> + + <p>Push "import.meta"</p> + </dd> +</dl> + +<h3 id="Operators">Operators</h3> + +<h4 id="Comparison_Operators">Comparison Operators</h4> + +<dl> + <dt id="JSOP_EQ">JSOP_EQ [-2, +1] (DETECTING, IC)<br> + JSOP_GE [-2, +1] (IC)<br> + JSOP_GT [-2, +1] (IC)<br> + JSOP_LE [-2, +1] (IC)<br> + JSOP_LT [-2, +1] (IC)<br> + JSOP_NE [-2, +1] (DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_EQ: 18 (0x12)<br> + JSOP_GE: 23 (0x17)<br> + JSOP_GT: 22 (0x16)<br> + JSOP_LE: 21 (0x15)<br> + JSOP_LT: 20 (0x14)<br> + JSOP_NE: 19 (0x13)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval OP rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values from the stack and pushes the result of comparing them.</p> + </dd> + <dt id="JSOP_STRICTEQ">JSOP_STRICTEQ [-2, +1] (DETECTING, IC)<br> + JSOP_STRICTNE [-2, +1] (DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_STRICTEQ: 72 (0x48)<br> + JSOP_STRICTNE: 73 (0x49)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval OP rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values from the stack, then pushes the result of applying the operator to the two values.</p> + </dd> +</dl> + +<h4 id="Arithmetic_Operators">Arithmetic Operators</h4> + +<dl> + <dt id="JSOP_ADD">JSOP_ADD [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>27 (0x1b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval + rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes the result of <code>lval + rval</code>.</p> + </dd> + <dt id="JSOP_DEC">JSOP_DEC [-1, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>235 (0xeb)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(val - 1)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the numeric value <code>val</code> from the stack, then pushes <code>val - 1</code>.</p> + </dd> + <dt id="JSOP_INC">JSOP_INC [-1, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>234 (0xea)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(val + 1)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the numeric value <code>val</code> from the stack, then pushes <code>val + 1</code>.</p> + </dd> + <dt id="JSOP_DIV">JSOP_DIV [-2, +1] (IC)<br> + JSOP_MOD [-2, +1] (IC)<br> + JSOP_MUL [-2, +1] (IC)<br> + JSOP_SUB [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_DIV: 30 (0x1e)<br> + JSOP_MOD: 31 (0x1f)<br> + JSOP_MUL: 29 (0x1d)<br> + JSOP_SUB: 28 (0x1c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval OP rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes the result of applying the arithmetic operation to them.</p> + </dd> + <dt id="JSOP_NEG">JSOP_NEG [-1, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>34 (0x22)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(-val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the value <code>val</code> from the stack, then pushes <code>-val</code>.</p> + </dd> + <dt id="JSOP_POS">JSOP_POS [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>35 (0x23)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(+val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the value <code>val</code> from the stack, then pushes <code>+val</code>. (<code>+val</code> is the value converted to a number.)</p> + </dd> + <dt id="JSOP_POW">JSOP_POW [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>150 (0x96)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval ** rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes the result of <code>Math.pow(lval, rval)</code>.</p> + </dd> + <dt id="JSOP_TONUMERIC">JSOP_TONUMERIC [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>236 (0xec)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>ToNumeric(val)</code></td> + </tr> + </tbody> + </table> + + <p>Pop <code>val</code> from the stack, then push the result of <code>ToNumeric(val)</code>.</p> + </dd> +</dl> + +<h4 id="Bitwise_Logical_Operators">Bitwise Logical Operators</h4> + +<dl> + <dt id="JSOP_BITAND">JSOP_BITAND [-2, +1] (IC)<br> + JSOP_BITOR [-2, +1] (IC)<br> + JSOP_BITXOR [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_BITAND: 17 (0x11)<br> + JSOP_BITOR: 15 (0x0f)<br> + JSOP_BITXOR: 16 (0x10)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval OP rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes the result of the operation applied to the two operands, converting both to 32-bit signed integers if necessary.</p> + </dd> + <dt id="JSOP_BITNOT">JSOP_BITNOT [-1, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>33 (0x21)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(~val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the value <code>val</code> from the stack, then pushes <code>~val</code>.</p> + </dd> +</dl> + +<h4 id="Bitwise_Shift_Operators">Bitwise Shift Operators</h4> + +<dl> + <dt id="JSOP_LSH">JSOP_LSH [-2, +1] (IC)<br> + JSOP_RSH [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_LSH: 24 (0x18)<br> + JSOP_RSH: 25 (0x19)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval OP rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes the result of the operation applied to the operands.</p> + </dd> + <dt id="JSOP_URSH">JSOP_URSH [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>26 (0x1a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>lval, rval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(lval >>> rval)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>lval</code> and <code>rval</code> from the stack, then pushes <code>lval >>> rval</code>.</p> + </dd> +</dl> + +<h4 id="Logical_Operators">Logical Operators</h4> + +<dl> + <dt id="JSOP_NOT">JSOP_NOT [-1, +1] (DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>32 (0x20)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(!val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the value <code>val</code> from the stack, then pushes <code>!val</code>.</p> + </dd> +</dl> + +<h4 id="Special_Operators">Special Operators</h4> + +<dl> + <dt id="JSOP_DELELEM">JSOP_DELELEM [-2, +1] (ELEM, CHECKSLOPPY)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>38 (0x26)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>propval</code> and <code>obj</code>, deletes <code>propval</code> property from <code>obj</code>, pushes <code>true</code> onto the stack if succeeded, <code>false</code> if not.</p> + </dd> + <dt id="JSOP_DELPROP">JSOP_DELPROP [-1, +1] (ATOM, PROP, CHECKSLOPPY)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>37 (0x25)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, deletes property from it, pushes <code>true</code> onto the stack if succeeded, <code>false</code> if not.</p> + </dd> + <dt id="JSOP_IN">JSOP_IN [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>113 (0x71)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>id, obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(id in obj)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>id</code> and <code>obj</code> from the stack, then pushes <code>id in obj</code>. This will throw a <code>TypeError</code> if <code>obj</code> is not an object.</p> + + <p>Note that <code>obj</code> is the top value.</p> + </dd> + <dt id="JSOP_INSTANCEOF">JSOP_INSTANCEOF [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>114 (0x72)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, ctor</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(obj instanceof ctor)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>obj</code> and <code>ctor</code> from the stack, then pushes <code>obj instanceof ctor</code>. This will throw a <code>TypeError</code> if <code>obj</code> is not an object.</p> + </dd> + <dt id="JSOP_STRICTDELPROP">JSOP_STRICTDELPROP [-1, +1] (ATOM, PROP, CHECKSTRICT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>46 (0x2e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value and attempts to delete the given property from it. Pushes <code>true</code> onto success, else throws a TypeError per strict mode property-deletion requirements.</p> + </dd> + <dt id="JSOP_TYPEOF">JSOP_TYPEOF [-1, +1] (DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>39 (0x27)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(typeof val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the value <code>val</code> from the stack, then pushes <code>typeof val</code>.</p> + </dd> + <dt id="JSOP_TYPEOFEXPR">JSOP_TYPEOFEXPR [-1, +1] (DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>196 (0xc4)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(typeof val)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top stack value as <code>val</code> and pushes <code>typeof val</code>. Note that this opcode isn't used when, in the original source code, <code>val</code> is a name -- see <code><code>JSOP_TYPEOF</code></code> for that. (This is because <code>typeof undefinedName === "undefined"</code>.)</p> + </dd> + <dt id="JSOP_VOID">JSOP_VOID [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>40 (0x28)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>undefined</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top value on the stack and pushes <code>undefined</code>.</p> + </dd> +</dl> + +<h4 id="Stack_Operations">Stack Operations</h4> + +<dl> + <dt id="JSOP_DUP">JSOP_DUP [-1, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>12 (0x0c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v, v</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a copy of the top value on the stack.</p> + </dd> + <dt id="JSOP_DUP2">JSOP_DUP2 [-2, +4]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>13 (0x0d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v1, v2</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v1, v2, v1, v2</code></td> + </tr> + </tbody> + </table> + + <p>Duplicates the top two values on the stack.</p> + </dd> + <dt id="JSOP_DUPAT">JSOP_DUPAT [-0, +1] (UINT24)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>44 (0x2c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t n</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v[n], v[n-1], ..., v[1], v[0]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v[n], v[n-1], ..., v[1], v[0], v[n]</code></td> + </tr> + </tbody> + </table> + + <p>Duplicates the Nth value from the top onto the stack.</p> + </dd> + <dt id="JSOP_PICK">JSOP_PICK [-0, +0] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>133 (0x85)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t n</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v[n], v[n-1], ..., v[1], v[0]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v[n-1], ..., v[1], v[0], v[n]</code></td> + </tr> + </tbody> + </table> + + <p>Picks the nth element from the stack and moves it to the top of the stack.</p> + </dd> + <dt id="JSOP_POP">JSOP_POP [-1, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>81 (0x51)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top value off the stack.</p> + </dd> + <dt id="JSOP_POPN">JSOP_POPN [-n, +0] (UINT16)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>11 (0x0b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t n</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v[n-1], ..., v[1], v[0]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Pops the top <code>n</code> values from the stack.</p> + </dd> + <dt id="JSOP_SWAP">JSOP_SWAP [-2, +2]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>10 (0x0a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v1, v2</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v2, v1</code></td> + </tr> + </tbody> + </table> + + <p>Swaps the top two values on the stack. This is useful for things like post-increment/decrement.</p> + </dd> + <dt id="JSOP_UNPICK">JSOP_UNPICK [-0, +0] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>183 (0xb7)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t n</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>v[n], v[n-1], ..., v[1], v[0]</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v[0], v[n], v[n-1], ..., v[1]</code></td> + </tr> + </tbody> + </table> + + <p>Moves the top of the stack value under the nth element of the stack. Note: n must NOT be 0.</p> + </dd> +</dl> + +<h4 id="Debugger_2">Debugger</h4> + +<dl> + <dt id="JSOP_DEBUGAFTERYIELD">JSOP_DEBUGAFTERYIELD [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>208 (0xd0)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Bytecode emitted after <code>yield</code> expressions to help the Debugger fix up the frame in the JITs. No-op in the interpreter.</p> + </dd> +</dl> + +<h3 id="Literals">Literals</h3> + +<h4 id="Constants">Constants</h4> + +<dl> + <dt id="JSOP_BIGINT">JSOP_BIGINT [-0, +1] (BIGINT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>237 (0xed)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t constIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a BigInt constant onto the stack.</p> + </dd> + <dt id="JSOP_BUILTINPROTO">JSOP_BUILTINPROTO [-0, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>221 (0xdd)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t kind</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>%BuiltinPrototype%</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the current global's builtin prototype for a given proto key.</p> + </dd> + <dt id="JSOP_DOUBLE">JSOP_DOUBLE [-0, +1] (DOUBLE)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>60 (0x3c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>DoubleValue literal</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>9</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes numeric constant onto the stack.</p> + </dd> + <dt id="JSOP_FALSE">JSOP_FALSE [-0, +1]<br> + JSOP_TRUE [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>JSOP_FALSE: 66 (0x42)<br> + JSOP_TRUE: 67 (0x43)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>true/false</code></td> + </tr> + </tbody> + </table> + + <p>Pushes boolean value onto the stack.</p> + </dd> + <dt id="JSOP_INT32">JSOP_INT32 [-0, +1] (INT32)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>216 (0xd8)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int32_t val</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes 32-bit int immediate integer operand onto the stack.</p> + </dd> + <dt id="JSOP_INT8">JSOP_INT8 [-0, +1] (INT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>215 (0xd7)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>int8_t val</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes 8-bit int immediate integer operand onto the stack.</p> + </dd> + <dt id="JSOP_IS_CONSTRUCTING">JSOP_IS_CONSTRUCTING [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>65 (0x41)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>JS_IS_CONSTRUCTING</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code><code>JS_IS_CONSTRUCTING</code></code></p> + </dd> + <dt id="JSOP_NULL">JSOP_NULL [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>64 (0x40)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>null</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code>null</code> onto the stack.</p> + </dd> + <dt id="JSOP_ONE">JSOP_ONE [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>63 (0x3f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>1</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code>1</code> onto the stack.</p> + </dd> + <dt id="JSOP_STRING">JSOP_STRING [-0, +1] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>61 (0x3d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t atomIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>atom</code></td> + </tr> + </tbody> + </table> + + <p>Pushes string constant onto the stack.</p> + </dd> + <dt id="JSOP_SYMBOL">JSOP_SYMBOL [-0, +1] (UINT8)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>45 (0x2d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint8_t symbol (the JS::SymbolCode of the symbol to use)</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>2</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>symbol</code></td> + </tr> + </tbody> + </table> + + <p>Push a well-known symbol onto the operand stack.</p> + </dd> + <dt id="JSOP_UINT16">JSOP_UINT16 [-0, +1] (UINT16)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>88 (0x58)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint16_t val</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>3</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes unsigned 16-bit int immediate integer operand onto the stack.</p> + </dd> + <dt id="JSOP_UINT24">JSOP_UINT24 [-0, +1] (UINT24)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>188 (0xbc)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t val</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pushes unsigned 24-bit int immediate integer operand onto the stack.</p> + </dd> + <dt id="JSOP_UNDEFINED">JSOP_UNDEFINED [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>1 (0x01)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>undefined</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code>undefined</code> onto the stack.</p> + </dd> + <dt id="JSOP_UNINITIALIZED">JSOP_UNINITIALIZED [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>142 (0x8e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>uninitialized</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a <code>JS_UNINITIALIZED_LEXICAL</code> value onto the stack, representing an uninitialized lexical binding.</p> + + <p>This opcode is used with the <code>JSOP_INITLEXICAL</code> opcode.</p> + </dd> + <dt id="JSOP_ZERO">JSOP_ZERO [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>62 (0x3e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>0</code></td> + </tr> + </tbody> + </table> + + <p>Pushes <code>0</code> onto the stack.</p> + </dd> +</dl> + +<h4 id="Object">Object</h4> + +<dl> + <dt id="JSOP_CALLELEM">JSOP_CALLELEM [-2, +1] (ELEM, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>193 (0xc1)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[propval]</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>propval</code> and <code>obj</code>, pushes <code>propval</code> property of <code>obj</code> onto the stack. Requires the value under <code>obj</code> to be the receiver of the following call.</p> + + <p>Like <code>JSOP_GETELEM</code> but for call context.</p> + </dd> + <dt id="JSOP_CALLPROP">JSOP_CALLPROP [-1, +1] (ATOM, PROP, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>184 (0xb8)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[name]</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, pushes property of it onto the stack. Requires the value under <code>obj</code> to be the receiver of the following call.</p> + + <p>Like <code>JSOP_GETPROP</code> but for call context.</p> + </dd> + <dt id="JSOP_CALLSITEOBJ">JSOP_CALLSITEOBJ [-0, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>101 (0x65)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t objectIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes the call site object specified by objectIndex onto the stack. Defines the raw property specified by objectIndex + 1 on the call site object and freezes both the call site object as well as its raw property.</p> + </dd> + <dt id="JSOP_CHECKCLASSHERITAGE">JSOP_CHECKCLASSHERITAGE [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>51 (0x33)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>heritage</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>heritage</code></td> + </tr> + </tbody> + </table> + + <p>Ensures the result of a class's heritage expression is either null or a constructor.</p> + </dd> + <dt id="JSOP_CHECKOBJCOERCIBLE">JSOP_CHECKOBJCOERCIBLE [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>163 (0xa3)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Throw if the value on the stack is not coerscible to an object (is |null| or |undefined|).</p> + </dd> + <dt id="JSOP_GETBOUNDNAME">JSOP_GETBOUNDNAME [-1, +1] (ATOM, NAME, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>195 (0xc3)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>env</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>v</code></td> + </tr> + </tbody> + </table> + + <p>Pops an environment, gets the value of a bound name on it. If the name is not bound to the environment, throw a ReferenceError. Used in conjunction with BINDNAME.</p> + </dd> + <dt id="JSOP_GETELEM">JSOP_GETELEM [-2, +1] (ELEM, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>55 (0x37)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[propval]</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>propval</code> and <code>obj</code>, pushes <code>propval</code> property of <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_GETELEM_SUPER">JSOP_GETELEM_SUPER [-3, +1] (ELEM, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>125 (0x7d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, propval, obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[propval]</code></td> + </tr> + </tbody> + </table> + + <p>LIKE <code>JSOP_GETELEM</code> but takes receiver on stack, and the propval is evaluated before the obj.</p> + </dd> + <dt id="JSOP_GETPROP">JSOP_GETPROP [-1, +1] (ATOM, PROP, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>53 (0x35)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[name]</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, pushes property of it onto the stack.</p> + </dd> + <dt id="JSOP_GETPROP_SUPER">JSOP_GETPROP_SUPER [-2, +1] (ATOM, PROP, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>104 (0x68)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj[name]</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values, and pushes the property of one, using the other as the receiver.</p> + </dd> + <dt id="JSOP_INITELEM">JSOP_INITELEM [-3, +1] (ELEM, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>94 (0x5e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a numeric property in an object literal, like <code>{1: x}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITELEM_GETTER">JSOP_INITELEM_GETTER [-3, +1] (ELEM, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>99 (0x63)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a numeric getter in an object literal like <code>{get 2() {}}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> getter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITELEM_SETTER">JSOP_INITELEM_SETTER [-3, +1] (ELEM, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>100 (0x64)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a numeric setter in an object literal like <code>{set 2(v) {}}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> setter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENELEM">JSOP_INITHIDDENELEM [-3, +1] (ELEM, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>175 (0xaf)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable numeric property in an object literal, like <code>{1: x}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENELEM_GETTER">JSOP_INITHIDDENELEM_GETTER [-3, +1] (ELEM, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>173 (0xad)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable numeric getter in an object literal like <code>{get 2() {}}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> getter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENELEM_SETTER">JSOP_INITHIDDENELEM_SETTER [-3, +1] (ELEM, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>174 (0xae)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, id, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable numeric setter in an object literal like <code>{set 2(v) {}}</code>.</p> + + <p>Pops the top three values on the stack as <code>val</code>, <code>id</code> and <code>obj</code>, defines <code>id</code> setter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENPROP">JSOP_INITHIDDENPROP [-2, +1] (ATOM, PROP, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>147 (0x93)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable data-property on an object.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines <code>nameIndex</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENPROP_GETTER">JSOP_INITHIDDENPROP_GETTER [-2, +1] (ATOM, PROP, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>171 (0xab)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable getter in an object literal.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines getter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHIDDENPROP_SETTER">JSOP_INITHIDDENPROP_SETTER [-2, +1] (ATOM, PROP, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>172 (0xac)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-enumerable setter in an object literal.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines setter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITHOMEOBJECT">JSOP_INITHOMEOBJECT [-2, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>92 (0x5c)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>fun, homeObject</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>fun</code></td> + </tr> + </tbody> + </table> + + <p>Initialize the home object for functions with super bindings.</p> + + <p>This opcode takes the function and the object to be the home object, does the set, and leaves the function on the stack.</p> + </dd> + <dt id="JSOP_INITLOCKEDPROP">JSOP_INITLOCKEDPROP [-2, +1] (ATOM, PROP, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>146 (0x92)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a non-configurable, non-writable, non-enumerable data-property on an object.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines <code>nameIndex</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITPROP">JSOP_INITPROP [-2, +1] (ATOM, PROP, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>93 (0x5d)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a named property in an object literal, like <code>{a: x}</code>.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines <code>nameIndex</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITPROP_GETTER">JSOP_INITPROP_GETTER [-2, +1] (ATOM, PROP, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>97 (0x61)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a getter in an object literal.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines getter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITPROP_SETTER">JSOP_INITPROP_SETTER [-2, +1] (ATOM, PROP, PROPINIT, DETECTING)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>98 (0x62)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize a setter in an object literal.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, defines setter of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_MUTATEPROTO">JSOP_MUTATEPROTO [-2, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>194 (0xc2)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, newProto</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p><code>__proto__: v</code> inside an object initializer.</p> + + <p>Pops the top two values on the stack as <code>newProto</code> and <code>obj</code>, sets prototype of <code>obj</code> as <code>newProto</code>, pushes <code>true</code> onto the stack if succeeded, <code>false</code> if not.</p> + </dd> + <dt id="JSOP_NEWINIT">JSOP_NEWINIT [-0, +1] (UINT32, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>89 (0x59)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>(uint32_t extra)</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes newly created object onto the stack.</p> + + <p>This opcode has four extra bytes so it can be exchanged with <code>JSOP_NEWOBJECT</code> during emit.</p> + </dd> + <dt id="JSOP_NEWOBJECT">JSOP_NEWOBJECT [-0, +1] (OBJECT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>91 (0x5b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t baseobjIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes newly created object onto the stack.</p> + + <p>This opcode takes an object with the final shape, which can be set at the start and slots then filled in directly.</p> + </dd> + <dt id="JSOP_OBJECT">JSOP_OBJECT [-0, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>80 (0x50)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t objectIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes deep-cloned object literal or singleton onto the stack.</p> + </dd> + <dt id="JSOP_OBJWITHPROTO">JSOP_OBJWITHPROTO [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>83 (0x53)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>proto</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes newly created object onto the stack with provided [[Prototype]].</p> + </dd> + <dt id="JSOP_SETELEM">JSOP_SETELEM [-3, +1] (ELEM, PROPSET, DETECTING, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>56 (0x38)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top three values on the stack as <code>val</code>, <code>propval</code> and <code>obj</code>, sets <code>propval</code> property of <code>obj</code> as <code>val</code>, pushes <code>val</code> onto the stack.</p> + </dd> + <dt id="JSOP_SETELEM_SUPER">JSOP_SETELEM_SUPER [-4, +1] (ELEM, PROPSET, DETECTING, CHECKSLOPPY)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>158 (0x9e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, propval, obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>LIKE <code>JSOP_SETELEM</code>, but takes receiver on the stack, and the propval is evaluated before the base.</p> + </dd> + <dt id="JSOP_SETPROP">JSOP_SETPROP [-2, +1] (ATOM, PROP, PROPSET, DETECTING, CHECKSLOPPY, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>54 (0x36)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code> and performs <code>obj.prop = val</code>, pushing <code>val</code> back onto the stack.</p> + </dd> + <dt id="JSOP_SETPROP_SUPER">JSOP_SETPROP_SUPER [-3, +1] (ATOM, PROP, PROPSET, DETECTING, CHECKSLOPPY)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>107 (0x6b)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top three values on the stack as <code>val</code>, <code>obj</code> and <code>receiver</code>, and performs <code>obj.prop = val</code>, pushing <code>val</code> back onto the stack.</p> + </dd> + <dt id="JSOP_STRICTDELELEM">JSOP_STRICTDELELEM [-2, +1] (ELEM, CHECKSTRICT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>47 (0x2f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>succeeded</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>propval</code> and <code>obj</code>, and attempts to delete <code>propval</code> property from <code>obj</code>. Pushes <code>true</code> onto the stack on success, else throws a TypeError per strict mode property deletion requirements.</p> + </dd> + <dt id="JSOP_STRICTSETELEM">JSOP_STRICTSETELEM [-3, +1] (ELEM, PROPSET, DETECTING, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>57 (0x39)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, propval, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top three values on the stack as <code>val</code>, <code>propval</code> and <code>obj</code>, sets <code>propval</code> property of <code>obj</code> as <code>val</code>, pushes <code>val</code> onto the stack. Throws a TypeError if the set fails, per strict mode semantics.</p> + </dd> + <dt id="JSOP_STRICTSETELEM_SUPER">JSOP_STRICTSETELEM_SUPER [-4, +1] (ELEM, PROPSET, DETECTING, CHECKSTRICT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>159 (0x9f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, propval, obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>LIKE <code>JSOP_STRICTSETELEM</code>, but takes receiver on the stack, and the propval is evaluated before the base.</p> + </dd> + <dt id="JSOP_STRICTSETPROP">JSOP_STRICTSETPROP [-2, +1] (ATOM, PROP, PROPSET, DETECTING, CHECKSTRICT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>48 (0x30)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, and performs <code>obj.prop = val</code>, pushing <code>val</code> back onto the stack. Throws a TypeError if the set-operation failed (per strict mode semantics).</p> + </dd> + <dt id="JSOP_STRICTSETPROP_SUPER">JSOP_STRICTSETPROP_SUPER [-3, +1] (ATOM, PROP, PROPSET, DETECTING, CHECKSTRICT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>105 (0x69)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>receiver, obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top three values on the stack as <code>val</code> and <code>obj</code>, and <code>receiver</code>, and performs <code>obj.prop = val</code>, pushing <code>val</code> back onto the stack. Throws a TypeError if the set-operation failed (per strict mode semantics).</p> + </dd> + <dt id="JSOP_TOID">JSOP_TOID [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>225 (0xe1)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>propertyNameValue</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>propertyKey</code></td> + </tr> + </tbody> + </table> + + <p>Replace the top-of-stack value propertyNameValue with ToPropertyKey(propertyNameValue).</p> + </dd> +</dl> + +<h4 id="Array">Array</h4> + +<dl> + <dt id="JSOP_HOLE">JSOP_HOLE [-0, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>218 (0xda)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>hole</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a <code>JS_ELEMENTS_HOLE</code> value onto the stack, representing an omitted property in an array literal (e.g. property 0 in the array <code>[, 1]</code>).</p> + + <p>This opcode is used with the <code>JSOP_NEWARRAY</code> opcode.</p> + </dd> + <dt id="JSOP_INITELEM_ARRAY">JSOP_INITELEM_ARRAY [-2, +1] (UINT32, ELEM, PROPINIT, DETECTING, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>96 (0x60)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t index</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Initialize an array element.</p> + + <p>Pops the top two values on the stack as <code>val</code> and <code>obj</code>, sets <code>index</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> onto the stack.</p> + </dd> + <dt id="JSOP_INITELEM_INC">JSOP_INITELEM_INC [-3, +2] (ELEM, PROPINIT, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>95 (0x5f)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj, index, val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj, (index + 1)</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top three values on the stack as <code>val</code>, <code>index</code> and <code>obj</code>, sets <code>index</code> property of <code>obj</code> as <code>val</code>, pushes <code>obj</code> and <code>index + 1</code> onto the stack.</p> + + <p>This opcode is used in Array literals with spread and spreadcall arguments.</p> + </dd> + <dt id="JSOP_LENGTH">JSOP_LENGTH [-1, +1] (ATOM, PROP, TYPESET, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>217 (0xd9)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t nameIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj['length']</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top of stack value, pushes the <code>length</code> property of it onto the stack.</p> + </dd> + <dt id="JSOP_NEWARRAY">JSOP_NEWARRAY [-0, +1] (UINT32, IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>90 (0x5a)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t length</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes newly created array onto the stack.</p> + + <p>This opcode takes the final length, which is preallocated.</p> + </dd> + <dt id="JSOP_NEWARRAY_COPYONWRITE">JSOP_NEWARRAY_COPYONWRITE [-0, +1] (OBJECT)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>102 (0x66)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t objectIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>obj</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a newly created array onto the stack, whose elements are the same as that of a template object's copy on write elements.</p> + </dd> +</dl> + +<h4 id="RegExp">RegExp</h4> + +<dl> + <dt id="JSOP_REGEXP">JSOP_REGEXP [-0, +1] (REGEXP)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>160 (0xa0)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t regexpIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>regexp</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a regular expression literal onto the stack. It requires special "clone on exec" handling.</p> + </dd> +</dl> + +<h4 id="Class">Class</h4> + +<dl> + <dt id="JSOP_CLASSCONSTRUCTOR">JSOP_CLASSCONSTRUCTOR [-0, +1] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>167 (0xa7)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>atom className</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>constructor</code></td> + </tr> + </tbody> + </table> + + <p>Push a default constructor for a base class literal.</p> + </dd> + <dt id="JSOP_DERIVEDCONSTRUCTOR">JSOP_DERIVEDCONSTRUCTOR [-1, +1] (ATOM)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>168 (0xa8)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>atom className</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>proto</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>constructor</code></td> + </tr> + </tbody> + </table> + + <p>Push a default constructor for a derived class literal.</p> + </dd> +</dl> + +<h3 id="Other">Other</h3> + +<dl> + <dt id="JSOP_DEBUGCHECKSELFHOSTED">JSOP_DEBUGCHECKSELFHOSTED [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>177 (0xb1)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>checkVal</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>checkVal</code></td> + </tr> + </tbody> + </table> + + <p>Examines the top stack value, asserting that it's either a self-hosted function or a self-hosted intrinsic. This opcode does nothing in a non-debug build.</p> + </dd> + <dt id="JSOP_FORCEINTERPRETER">JSOP_FORCEINTERPRETER [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>207 (0xcf)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>No-op bytecode only emitted in some self-hosted functions. Not handled by the JITs so the script always runs in the interpreter.</p> + </dd> + <dt id="JSOP_HASOWN">JSOP_HASOWN [-2, +1] (IC)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>211 (0xd3)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>id, obj</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>(obj.hasOwnProperty(id))</code></td> + </tr> + </tbody> + </table> + + <p>Pops the top two values <code>id</code> and <code>obj</code> from the stack, then pushes obj.hasOwnProperty(id)</p> + + <p>Note that <code>obj</code> is the top value.</p> + </dd> + <dt id="JSOP_ITERNEXT">JSOP_ITERNEXT [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>222 (0xde)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>val</code></td> + </tr> + </tbody> + </table> + + <p>NOP opcode to hint to IonBuilder that the value on top of the stack is the (likely string) key in a for-in loop.</p> + </dd> + <dt id="JSOP_JUMPTARGET">JSOP_JUMPTARGET [-0, +0] (ICINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>230 (0xe6)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t icIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>This opcode is a no-op and it indicates the location of a jump instruction target. Some other opcodes act as jump targets as well, see BytecodeIsJumpTarget. The IC index is used by the Baseline interpreter.</p> + </dd> + <dt id="JSOP_LINENO">JSOP_LINENO [-0, +0] (UINT32)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>119 (0x77)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint32_t lineno</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>5</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>Embedded lineno to speedup <code>pc->line</code> mapping.</p> + </dd> + <dt id="JSOP_NOP">JSOP_NOP [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>0 (0x00)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>No operation is performed.</p> + </dd> + <dt id="JSOP_NOP_DESTRUCTURING">JSOP_NOP_DESTRUCTURING [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>229 (0xe5)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>No-op used by the decompiler to produce nicer error messages about destructuring code.</p> + </dd> + <dt id="JSOP_RESUMEINDEX">JSOP_RESUMEINDEX [-0, +1] (RESUMEINDEX)</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>126 (0x7e)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code>uint24_t resumeIndex</code></td> + </tr> + <tr> + <th>Length</th> + <td><code>4</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>resumeIndex</code></td> + </tr> + </tbody> + </table> + + <p>Pushes a resumeIndex (stored as 24-bit operand) on the stack.</p> + + <p>Resume indexes are used for ops like <code>JSOP_YIELD</code> and <code>JSOP_GOSUB</code>. <code>JSS</code>cript and BaselineScript have lists of resume entries (one for each resumeIndex); this lets the JIT resume at these ops from JIT code.</p> + </dd> + <dt id="JSOP_TOSTRING">JSOP_TOSTRING [-1, +1]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>228 (0xe4)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code>val</code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code>ToString(val)</code></td> + </tr> + </tbody> + </table> + + <p>Converts the value on the top of the stack to a String.</p> + </dd> + <dt id="JSOP_TRY_DESTRUCTURING">JSOP_TRY_DESTRUCTURING [-0, +0]</dt> + <dd> + <table class="standard-table"> + <tbody> + <tr> + <th>Value</th> + <td><code>220 (0xdc)</code></td> + </tr> + <tr> + <th>Operands</th> + <td><code> </code></td> + </tr> + <tr> + <th>Length</th> + <td><code>1</code></td> + </tr> + <tr> + <th>Stack Uses</th> + <td><code> </code></td> + </tr> + <tr> + <th>Stack Defs</th> + <td><code> </code></td> + </tr> + </tbody> + </table> + + <p>No-op used by the exception unwinder to determine the correct environment to unwind to when performing IteratorClose due to destructuring.</p> + </dd> +</dl> diff --git a/files/ja/mozilla/projects/spidermonkey/internals/garbage_collection/index.html b/files/ja/mozilla/projects/spidermonkey/internals/garbage_collection/index.html new file mode 100644 index 0000000000..e12b08f89b --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/internals/garbage_collection/index.html @@ -0,0 +1,131 @@ +--- +title: Garbage collection +slug: Mozilla/Projects/SpiderMonkey/Internals/Garbage_collection +translation_of: Mozilla/Projects/SpiderMonkey/Internals/Garbage_collection +--- +<div class="note"> + <strong>この文書について: これはSpiderMonkeyのGC内部についての雑多な草案です。内容が古いまたは不正確な場合があります。</strong></div> +<div class="warning"> + <p><strong>警告:</strong>SpiderMonkey ガベージコレクションTipsは悲しいことに古い内容であり、完全に無視されるべきものとなってしまいました、</p> +</div> +<h2 id="デザインの概要">デザインの概要</h2> +<p>SpiderMonkeyは、オプションでインクリメンタルマーキングモード(<span style="line-height: 1.5;">incremental marking mode)を有効にされたマーク & スイープ方式のガベージコレクション(GC)を持っています。マークフェイズでは、インクリメンタルマーキングに必要なマークスタックを用います。ファイナライザを伴わないオブジェクトのスイープは、バックグラウンドスレッドにて実行されます。</span></p> +<p>世代別GCおよびコンパクションGC(compacting GC)の実装に向けた作業が進行中です。</p> +<p> </p> +<h2 id="主要なデータ構造">主要なデータ構造</h2> +<h3 id="Cell">Cell</h3> +<p><strong>Cell</strong> は、外部からも使用される、GCによって割当と回収が行われるメモリーの単位です。つまり、GC以外から見れば、GCの仕事はCellの割当と自動的な回収ということになります。</p> +<p>例えばJSObjectのように、CellはGCによって割り当てられる全てのクラスの基底クラスとなります。</p> +<h3 id="Allocation_Kind">Allocation Kind</h3> +<p>Cellは、Allocation Kindにより分類されます。Allocation Kindはオブジェクトのサイズおよびファイナライズの振る舞いを定義します。Allocation Kindは<strong>AllocKind列挙型</strong>によって定義されます。</p> +<p>Arenas always hold objects of the same allocation kind. Thus, an arena holds objects all of the same size and finalization behavior.</p> +<h3 id="Compartment">Compartment</h3> +<p>JSヒープはCompartmentに分割されます。Compartmentの要点は以下になります:</p> +<ul> + <li>あらゆるCell(JSヒープオブジェクト)は、Compartmentのどれか一つに属します(ヒープはCompartmentに分類されることを意味します)。</li> + <li>オブジェクトは、別のCompartment内のオブジェクトに対する直接のポインタを保持することはできません。代わりに、他のオブジェクト用のラッパーを保持することになります。ラッパーは、Compartment間のセキュリティチェックに用いられます。同じCompartment内のオブジェクトは同じアクセス権限を持っているため、セキュリティチェックの必要はありませんが、cross-compartment wrapper(Compartment間ラッパー)のトラバース時にチェックが行われるかもしれません。</li> + <li>エンジンは同時にひとつのCompartmentのGCが可能です。同様に、エンジンは他をGCしている場合を除いて、Compartmentの集合に対してGCが可能です。cross-compartment wrapperは、ひとつないし複数のCompartmentのGCのrootとして用いられます。</li> +</ul> +<p>Compartmentは、SpiderMonkeyにおける、GCを含む特にメモリに関連した事項の構造的かつ分野横断的なコンセプトになっています。詳細は<a href="“/ja/SpiderMonkey/SpiderMonkey_compartments" title="https://developer.mozilla.org/ja/SpiderMonkey/SpiderMonkey_compartments">Compartments</a>を参照してください。</p> +<p><strong>JSCompartment</strong>はGCに関連した重要なフィールドを保持しています:</p> +<dl> + <dt style="margin-left: 40px;"> + ArenaLists型 arenas</dt> + <dd style="margin-left: 40px;"> + この構造体は、それぞれのAllocation KindのArenaの2つのリストを記録しています。未使用のArenaのリストと、割当済みのArenaのリストです。</dd> + <dt style="margin-left: 40px;"> + bool型 needsBarrier</dt> + <dd style="margin-left: 40px;"> + このCompartmentにおけるGCが、インクリメンタルバリアの実行を必要とする場合にtrueとなります。すなわり、このCompartmentが現在インクリメンタルGCを実行しているかどうかを表します。</dd> + <dt style="margin-left: 40px;"> + CompartmentGCState型 gcState</dt> + <dd style="margin-left: 40px;"> + このCompartmentが現在GCを実行しているかどうかを表します。もし実行していなければ、GCの実行がスケジュールされているかを表します。</dd> + <dt style="margin-left: 40px;"> + size_t型 gcBytes, gcTriggerBytes, gcMallocBytes, gcMaxMallocBytes</dt> + <dd style="margin-left: 40px;"> + GCのスケジュールに使用される情報を表します</dd> + <dt style="margin-left: 40px;"> + WrapperMap型 crossCompartmentWrappers</dt> + <dd style="margin-left: 40px;"> + このCompartment内のオブジェクトのラッパーの集合です。Mapのキーはオブジェクト、値はラッパーです。同じオブジェクトに対するラッパーが複数回要求される場合、エンジンが同一のラッパーを毎回返せるようにするためにマッピングが必要とされます。ラッパーオブジェクトの集合は同様に、単一および複数のcompartmentの(non-globalな)GCにおいても必要となります</dd> +</dl> +<h3 id="Zone">Zone</h3> +<p>TODO(原文ママ)</p> +<h3 id="Chunk">Chunk</h3> +<p>Chunkはメモリの割当における最大の内部単位となります。</p> +<p>Chunkは1MBのサイズを持ち、内部にArena、パディング、Mark Bitmap(ChunkBitmap)、解放されたArenaのビットマップ、およびChunkヘッダ(ChunkInfo)を保持しています。</p> +<p>ChunkInfoは、ChunkInfo::freeArenasHeadから開始しており、ArenaHeader::nextを介してリンクしている未割当のArenaのリストを保持します。また、ChunkInfoは未割当のArenaの数の基本的な情報を保持しています。</p> +<p>TODO ChunkInfo next/prev(原文ママ)</p> +<h3 id="Arena">Arena</h3> +<p>Arenaはメモリ割当の内部単位です。</p> +<p>Arenaは1ページ(ほぼ全てのプラットフォームで4096バイト)の大きさであり、ArenaHeaderと、僅かなパディングとなるバイト領域と、整列された要素の配列を含みます。Arena内のすべての要素は、同じAllocation Kindとサイズを持ちます。</p> +<p>すべてのArenaは、ArenaHeader::firstFreeSpanOffetsから始まる自由なメモリ区間のリストを保持します。自由なメモリ区間の最後のCell(最後であるのが望ましい)は、次の自由なメモリ区間を表すFreeSpanを保持します。</p> +<h3 id="Free_Span">Free Span</h3> +<p><strong>構造体<code>FreeSpan</code></strong>は、Arena内の自由なCell <strong>[first, last]</strong>の連続を表します。FreeSpanは、自由なメモリ区間から割当を行うための関数を保持しています。</p> +<h3 id="Mark_Bitmap">Mark Bitmap</h3> +<p>マークビットマップは<strong>ChunkBitmap</strong>によって表されます。</p> +<p>マークビットマップはGC Cellごとのビットを持ちます。故に、複数のCellによって構成されているオブジェクトは、ビットマップ中の複数のビットを使います。</p> +<h2 id="Exact_Stack_Rooting_API">Exact Stack Rooting API</h2> +<div class="note"> + <p><strong>注</strong>:GC rootの実装とおよびSpiderMonkey内での使用についての情報となります。SpiderMonkeyを埋め込んで使う場合の、Rooting APIの使用方法については、<a href="“/ja/docs/SpiderMonkey/GC_Rooting_Guide" title='“/ja/docs/SpiderMonkey/GC_Rooting_Guide"'> GC Rooting Guide</a>を参照してください。</p> +</div> +<p>GC rootの実装とおよびSpiderMonkey内での使用についての情報となります。 <a href="/en-US/docs/SpiderMonkey/Internals/GC/Exact_Stack_Rooting" title="/en-US/docs/SpiderMonkey/Internals/GC/Exact_Stack_Rooting">Exact Stack Rooting</a>.</p> +<h2 id="マーキング">マーキング</h2> +<p>TODO(原文ママ)</p> +<h2 id="インクリメンタルマーキング">インクリメンタルマーキング</h2> +<p>インクリメンタルマーキングは、マーキングの最中に(JavaScriptプログラムによる)状態の変更が発生しても、他のマーキング作業の実行が可能であることを意味します。つまり、マーキングによる長時間のプログラムの実行の停止の代わりに、小さな停止の集まりがGCの実行となるのです。停止時間は10msもしくはそれ以下に抑えられます。</p> +<p>長時間の停止が必要となる可能性も常に存在します。インクリメンタルGCの間のメモリ割当の頻度が高い場合、エンジンはインクリメンタルGCの完了の前にout of memoryを実行するかもしれません。そのような場合、エンジンは幾つかのメモリーの返還とプログラムの実行の継続のために、非インクリメンタルな完全なGCを直ちに再実行しなくてはなりません。</p> +<h3 id="Incremental_write_barrier(インクリメンタル書き込みバリア)">Incremental write barrier(インクリメンタル書き込みバリア)</h3> +<h4 id="write_barrierを必要とする問題">write barrierを必要とする問題</h4> +<p>インクリメンタルGCは正確性の担保のためにwrite barrierを必要とします。</p> +<p>TODO(原文ママ)、基本的な問題を表す図を用意する<img alt="Very poor diagram showing IGC hazard that requires a write barrier" src="https://mdn.mozillademos.org/files/5187/IGC-hazard.png" style="width: 640px; height: 400px;"></p> +<p>基本的な問題は以下の通りです(色の説明については、辞書を参照)。オブジェクトAはblackかつポインタ領域を所持しています。オブジェクトBはwhiteとします。ここで、インクリメンタルなスライスが止まり、プログラムの実行による状態の変更が再開しました。プログラムがBをAに保存したことにより、AはBへのポインタを持つことになります。そして、Bへのすべての既存のポインタが削除されました。そのとき、</p> +<ul> + <li>Bは生存している。なぜならAはblackであり、Bへのポインタを含んでいるから。</li> + <li>Bはマーク作業が実行されない。なぜならBはAを介してのみ到達可能であり、Aがblackである故にAはすでにマーク作業が完了しているから。</li> + <li>以上により、Bは生存しているが、GCの回収対象となってしまう。</li> +</ul> +<p>write barrierは、ポインタの保存の発生前に実行され、生存しているオブジェクトが回収されないようにするために情報を記録する機構の一つです。</p> +<h4 id="SpiderMonkeyのincremental_write_barrier">SpiderMonkeyのincremental write barrier</h4> +<p>SpiderMonkeyは、(相対的に)シンプルな、s<strong>snapshot-at-the-beginning allocate-black barrier</strong>と呼ばれる一般的なincremental write barrierを用いています。</p> +<p>このバリアの動作を理解するために、事象を単純にするために、新規にオブジェクトが割り当てられることの無いインクリメンタルGCを仮定します。生存しているオブジェクトを回収しないようにするためにはどうすればよいでしょうか? 一つの方法としては、インクリメンタルGCの最初の時点で生存していたすべてのオブジェクトをマークするという手法があります(これは、オブジェクトへの全ての参照が現在のインクリメンタルGC中に消えた場合は、次のインクリメンタルGC時にそのオブジェクトが回収されるということです)。この手法は、インクリメンタルGCの開始時に生存しているオブジェクトのスナップショットを保存し、それら全てをマークするのと<em>コンセプト上は</em>同義であるために、<strong>snapshot-at-the-beginning</strong>と呼ばれています。実際にはスナップショットを撮る訳ではありません。そのような場合は完全な非インクリメンタルなマーク作業が必要となります。</p> +<p style="">snapshot-at-the-beginningバリアの実装は単純です。GCポインタを保持する場所がプログラムによって上書きされたタイミングで、バリアは開始します。バリアは単純にポインタによって指し示されているオブジェクトをblackにします。鍵となるのは、オブジェクトへの全てのポインタが上書きされた場合にのみ、オブジェクトはマークされず”死んだもの”となりうるという点です。そのため、オブジェクトへのポインタが上書きされたタイミングでオブジェクトをblackにすれば、オブジェクトが”死ぬ”ということは発生し得ないのです。</p> +<p style="">FIXME(原文ママ):指し示されたオブジェクトをblackにするだけは十分ではないと思います。マークされていない別のオブジェクトがあったら何がおこりますか? マークスタックについても言及すべきです。「指し示されているオブジェクトをblackにする」というのは、「再帰的に指し示されたオブジェクトをblackにする」という意味で書かれていますか?</p> +<p>これで、メモリの割当の正確性についても話します。新規に割り当てられたオブジェクトはGCの開始時には存在していませんでした。snapshot-at-the-beginningバリアはこれについては巧くカバーしません。ですが、もし新規に割り当てられたオブジェクトが生存している場合は、それが回収されないようにする必要があります。これは簡単で、インクリメンタルGC中に新規にオブジェクトが割り当てられたら、それをマークすれば良いのです。これを名付けて<strong>allocate-black</strong>と言います。</p> +<h4 id="SpiderMonkeyの_incremental_read_barrier(インクリメンタル読み取りバリア)">SpiderMonkeyの incremental read barrier(インクリメンタル読み取りバリア)</h4> +<p>インクリメンタルGCの教科書的な実装では、write barrierしかありません。SpiderMonkeyでは、weak pointer(用語集参照)のためにread barrierも用意しています。</p> +<p>TODO(原文ママ):解説の完成</p> +<h4 id="実装の詳細">実装の詳細</h4> +<p>write barrierは実行時のコストを伴うので、SpiderMonkeyはインクリメンタルGCの実行中以外ではスキップするようにしています。各compartmentの<code>needsBarrier()</code>フラグによって、バリアが必要かどうかを示しています。</p> +<p><code>T*</code>型のフィールドのように、全ての<code>T</code>型はwrite barrierを必要としており、<code>T::writeBarrierPre(old)</code>という関数が存在しています。たとえば、<code>JSObject*</code>がwrite barrierを必要とする場合、関数<code>ObjectImpl::writeBarrierPre(ObjectImpl *old)</code>が存在します(<code>JSObject</code>は<code>ObjectImpl</code>を継承しています。)。 <code><strong>zone->needsBarrier()</strong></code>がtrueである場合、<code>writeBarrierPre()</code>は<code>old</code>をマークする、ということです。</p> +<p>HeapPtr<t>クラスはwrite barrierの起動を簡単にするために提供されています。HeapPtr<t>は<strong><code>T*</code></strong>をカプセル化し、割当時にwrite barrierを起動します。これにより、GCポインタ型のオブジェクトの領域は、通常、HeapPtr<T><t>として定義されています。<strong>HeapValue</strong>クラスはValueに対して同じことを行います。<strong>HeapSlot</strong>(および関連する<strong>HeapSlotArray</strong>)も同様に、オブジェクトスロットに対するものです。<strong>HeapId</strong>は、同じくjsidに対する物です。TODO(原文ママ):なぜHeapValueとHeapSlotの2つが存在するのか</t></t></t></p> +<p>オブジェクトのプライベート領域は、特別に取り扱う必要があります。プライベート領域自体は、エンジンに対しては隠されていますが、マークされる必要があるものを指し示すかもしれません(例:JSObjectのポインタの配列)。この例では、プライベート領域が上書きされた場合、JSObjectのポインタは”死ぬ”ことになります。そのため、write barrierはそれらをマークしなければなりません。<strong>ObjectImpl::privateWriteBarrierPre</strong>はプライベート領域が上書きされる前にJSObjectクラスのトレースフックによって起動され、これに対処します。</p> +<p>他の詳細事項として、write barrierは新規に確保されたオブジェクトのフィールドの初期化時には、上書きされるポインタが存在しないことから、スキップすることができます。</p> +<h2 id="Sweeping(スイーピング)">Sweeping(スイーピング)</h2> +<p>TODO(原文ママ)</p> +<h2 id="世代別GC">世代別GC</h2> +<p>TODO(原文ママ)</p> +<h2 id="GC統計API">GC統計API</h2> +<p>実行時に<a href="“/ja/docs/SpiderMonkey/Internals/GC/Statistics_API" title='“/ja/docs/SpiderMonkey/Internals/GC/StatisticsAPI"'>GC統計API</a>.を通じて、GCが保持する明確な統計情報にアクセスする事ができます。</p> +<h2 id="ソースファイル">ソースファイル</h2> +<p><strong>jsgc{.h,inlines.h,.cpp}</strong> GCを起動するためのエントリーポイントを含む内部API関数群を定義します。</p> +<p><strong>jsgcstats.{h,cpp}</strong> 保守的なスタックスキャンに基づく情報収集のための構造体ConservativeGCStatsを定義します。TODO(原文ママ):削除されたときに消す</p> +<p><strong>gc/Barrier[-inl].h</strong> インクリメンタルおよび世代別用のwrite barrierを実装しています。</p> +<p><strong>gc/Heap.h</strong> GCのヒープ構造の根幹を成す、<code>Chunk</code>, <code>ChunkInfo</code>, <code>ChunkBitmap</code>, <code>Arena</code>, <code>ArenaHeader</code>, <code>Cell</code>, <code>FreeSpan</code>といった一連の構造体を定義します。</p> +<p><strong>gc/Marking.{h,cpp}</strong> 多様なGC対象用のマーク作業関数の全てを定義します。</p> +<p><strong>gc/Memory.{h,cpp}</strong> ページの配置と解放(mapping and unmapping)のための僅かな関数に加えて、プラットフォーム固有の実装を保持しています。配置・解放(map/unmap)用の関数はチャンクの確保と解放(allocate and release )用のために、 jsgc.cppによって使用されています。使用されておらずディスクに格納する代わりメモリ破棄が可能なページをOS伝えるなどに用いる、確保または解放(commit or decommit)のための関数もあります。</p> +<p><strong>gc/Root.h</strong> GCルートとして用いられる変数クラスを定義します。</p> +<p><strong>gc/Statistics.{h,cpp}</strong> SpiderMonkey GCのパフォーマンスカウンタとして保存される Statics構造体を定義しています。</p> +<h2 id="用語の解説">用語の解説</h2> +<p>TODO(原文ママ): SpiderMonkeyの実装と色の名前が一致しているかを確認</p> +<p><strong>black(黒)</strong>一般的な計算機科学の文脈において、マークフェイズ中、マーク済かつ子供がgray(マークキューに積まれている)なオブジェクトをblackとします。SpiderMonkeyでは、マークビットが設定されたオブジェクトをblackと見なします。</p> +<p><strong>gray(灰色)</strong>:一般的な計算機科学の文脈において、マークフェイズ中、マークキューに積まれているオブジェクトをgrayとします。SpiderMonkeyでは、マークスタック内のオブジェクトの子孫かつblackで無いものはgrayとなります。つまり、状態が明白でないオブジェクトがgrayであるということです。</p> +<p><strong>Handle(ハンドル)</strong> 私たちのGCでは、Handleはルートによって登録されたどこかを指し示すポインタです。</p> +<p><strong>root</strong> TODO(原文ママ): 上からコピーする</p> +<p><strong>weak pointer(弱参照ポインタ)</strong> 一般的な計算機科学の文脈において、weak pointerはGC目的で指し示された値が生存し続ける必要がなくなるポインタです。具体的には、既にポインタの指し示す対象が既にGCされている場合は、weak pointerのget()メソッドが返す値はnullポインタとなります。Gecko/SpiderMonkeyでは、weak pointerはマークされていないがGC対象となりうるオブジェクトへのポインタとなります。そのため、get()メソッドは存在せず、指し示す値がGCされたかどうかの保証も存在しません。プログラマは、指し示されたオブジェクトの生存時間が、weak pointerの生存時間よりも長いことを保証する必要があります。TODO(原文ママ) これが正しいか確認。</p> +<p><strong>white(白)</strong> 一般的な計算機科学の文脈において、マークフェイズ中、まだ辿れていないオブジェクトはwhiteとなります。マークされなかった場合、マークフェイズの後にオブジェクトはwhiteとなります。SpiderMonkeyでは、grayでもblackでもない(blackでもマークスタック内のオブジェクトの子でもない)オブジェクトがwhiteとなります。</p> +<h2 id="クリーンアップの可能性">クリーンアップの可能性</h2> +<p><strong>MarkPagesInUse</strong> はすべてのプラットフォームで何の操作も実施しません。</p> +<p>統計ファイルのマージ。</p> +<p><code>ArenaLists::refillFreeLists</code>は悪いネーミングです。それは、たとえ<code>Arena</code>の解放リストが完全ではなくても、<code>Cell</code>の確保を試みるように見えます。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/internals/index.html b/files/ja/mozilla/projects/spidermonkey/internals/index.html new file mode 100644 index 0000000000..49e8157aa7 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/internals/index.html @@ -0,0 +1,290 @@ +--- +title: Internals +slug: Mozilla/Projects/SpiderMonkey/Internals +tags: + - JavaScript + - SpiderMonkey + - 要更新 + - 要翻訳 +translation_of: Mozilla/Projects/SpiderMonkey/Internals +--- +<div>{{SpiderMonkeySidebar("Internals")}}</div> + +<h2 id="Design_walk-through" name="Design_walk-through">設計</h2> + +<p>SpiderMonkey は型付けされていないバイトコードと JavaScript で扱いうる値を表す<code><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Reference/JS::Value" title="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Reference/JS::Value"> JS::Value </a></code>型に対する演算を高速に行えるインタプリタです。Just-In-Time (JIT) コンパイラやガベージコレクションの機構を備え、JavaScript の値が持つ基本的な振る舞いと <a href="http://www.ecma-international.org/ecma-262/5.1/#sec-15">ECMA 262-5.1 §15</a> とその他の拡張で定義された標準ライブラリを実装し、いくつかのパブリックな API が提供されています。</p> + +<h3 id="インタプリタ">インタプリタ</h3> + +<p>多くの移植可能なインタプリタと同様、SpiderMonkey のインタプリタは主に単一の長大な関数として実装されています。バイトコードを 1 つずつ実行され、現在の命令に対応するコードへの分岐は <code>switch </code>文を利用して行われます(コンパイラによっては、より高速な手法が利用されます)。JS で記述された関数同士の呼び出し時にはJavaScript のスタックフレームが伸長し、C のスタックは消費されません。一方 JS で記述された関数から、C で定義された関数を呼び出し、また JS で記述された関数を呼ぶような場合は、コールスタックは通常通りに消費されるため、インタプリタは再突入可能となっています。</p> + +<p>SpiderMonkey バイトコードの処理には、引数の型による多くの特例が存在します。通常はインタプリタのループ内で処理されますが、邪魔な抽象化を無視する場合もあります。密な配列やプロパティキャッシュのような最適化は、<code>jsinterp.cpp</code> に定義されている <code>jsarray.*</code> や <code>jsobj.*</code> によって隠蔽され、透過的に行われるわけでは「ありません」。</p> + +<p>インタプリタに関する状態は、インタプリタのエントリポイントに引数として渡されます。暗黙的な状態は <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JSRuntime" title="SpiderMonkey/JSAPI_Reference/JSRuntime">JSContext</a></code> 型の値にまとめられており、API であろうがなかろうが、SpiderMonkey のすべての関数は第 1 引数に、JSContext 型のポインタをとります。</p> + +<h3 id="コンパイラ">コンパイラ</h3> + +<p>コンパイラは JavaScript のソースコードを処理し、<em>script</em> を生成します。script にはバイトコードとそのソースコード、ソースに対するアノテーション、文字列、数値、識別子のリテラルが含まれます。またソースコード中で定義されている関数も含む、オブジェクトも script には含まれます。それぞれの関数は入れ子になった script を保持します。</p> + +<p>The compiler consists of: a random-logic rather than table-driven lexical scanner, a recursive-descent parser that produces an AST, and a tree-walking code generator. Semantic and lexical feedback are used to disambiguate hard cases such as missing semicolons, assignable expressions ("lvalues" in C parlance), and whether <code>/</code> is the division symbol or the start of a regular expression. The compiler attempts no error recovery; it bails out on the first error. The emitter does some constant folding and a few codegen optimizations; about the fanciest thing it does is to attach source notes to the script for the decompiler's benefit.</p> + +<p>The decompiler implements <code>Function.toSource()</code>, which reconstructs a function's source code. It translates postfix bytecode into infix source by consulting a separate byte-sized code, called <em>source notes</em>, to disambiguate bytecodes that result from more than one grammatical production.</p> + +<h3 id="Garbage_collector">Garbage collector</h3> + +<p>The GC is a mark-and-sweep, non-conservative (exact) collector. It is used to hold JS objects and string descriptors (<a href="http://dxr.mozilla.org/mozilla-central/source/js/src/vm/String.h">JSString</a>), but not string bytes. It runs automatically only when maxbytes (as passed to <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_NewRuntime" title="SpiderMonkey/JSAPI_Reference/JS_NewRuntime">JS_NewRuntime</a></code>) bytes of GC things have been allocated and another thing-allocation request is made. JS API users should call <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_GC" title="SpiderMonkey/JSAPI_Reference/JS_GC">JS_GC</a></code> or <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_MaybeGC" title="SpiderMonkey/JSAPI_Reference/JS_MaybeGC">JS_MaybeGC</a></code> between script executions or from the <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetOperationCallback" title="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetOperationCallback">operation callback</a>, as often as necessary.</p> + +<p>Because the GC is exact, C/C++ applications must ensure that all live objects, strings, and numbers are GC-reachable.</p> + +<h3 id="JavaScript_values">JavaScript values</h3> + +<p>The type <code><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Reference/JS::Value" title="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Reference/JS::Value">JS::Value</a></code> represents a JavaScript value.</p> + +<p>The representation is 64 bits and uses NaN-boxing on all platforms, although the exact NaN-boxing format depends on the platform. NaN-boxing is a technique based on the fact that in IEEE-754 there are 2**47 different bit patterns that all represent NaN. Hence, we can encode any floating-point value as a C++ <code>double </code>(noting that JavaScript NaN must be represented as one canonical NaN format). Other values are encoded as a value and a type tag:</p> + +<ul> + <li>On x86, ARM, and similar 32-bit platforms, we use what we call "nunboxing", in which non-<code>double </code>values are a 32-bit type tag and a 32-bit payload, which is normally either a pointer or a signed 32-bit integer. There are a few special values: <code>NullValue()</code>, <code>UndefinedValue()</code>, <code>TrueValue()</code> and <code>FalseValue().</code></li> + <li>On x64 and similar 64-bit platforms, pointers are longer than 32 bits, so we can't use the nunboxing format. Instead, we use "punboxing", which has 17 bits of tag and 47 bits of payload.</li> +</ul> + +<p>Only JIT code really depends on the layout--everything else in the engine interacts with values through functions like <code>val.isDouble()</code>. Most parts of the JIT also avoid depending directly on the layout: the files <code>PunboxAssembler.h</code> and <code>NunboxAssembler.h</code> are used to generate native code that depends on the value layout.</p> + +<p>Objects consist of a possibly shared structural description, called the map or scope; and unshared property values in a vector, called the slots. Each property has an <a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/jsid" title="SpiderMonkey/JSAPI_Reference/jsid">id</a>, either a nonnegative integer or an atom (unique string), with the same tagged-pointer encoding as a <code>jsval</code>.</p> + +<p>The atom manager consists of a hash table associating strings uniquely with scanner/parser information such as keyword type, index in script or function literal pool, etc. Atoms play three roles: as literals referred to by unaligned 16-bit immediate bytecode operands, as unique string descriptors for efficient property name hashing, and as members of the root GC set for exact GC.</p> + +<h3 id="Standard_library">Standard library</h3> + +<p>The methods for arrays, booleans, dates, functions, numbers, and strings are implemented using the JS API. Most are <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JSFastNative" title="SpiderMonkey/JSAPI_Reference/JSFastNative">JSFastNative</a></code>s. Most string methods are customized to accept a primitive string as the <code>this</code> argument. (Otherwise, SpiderMonkey converts primitive values to objects before invoking their methods, per <span class="pl-s1"><span class="pl-s">ECMA 262-3 §</span></span>11.2.1.)</p> + +<h3 id="Error_handling">Error handling</h3> + +<p>SpiderMonkey has two interdependent error-handling systems: JavaScript exceptions (which are <em>not</em> implemented with, or even compatible with, any kind of native C/C++ exception handling) and error reporting. In general, both functions inside SpiderMonkey and JSAPI callback functions signal errors by calling <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_ReportError" title="SpiderMonkey/JSAPI_Reference/JS_ReportError">JS_ReportError</a></code> or one of its variants, or <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_SetPendingException" title="SpiderMonkey/JSAPI_Reference/JS_SetPendingException">JS_SetPendingException</a></code>, and returning <code><a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JSBool" title="SpiderMonkey/JSAPI_Reference/JSBool">JS_FALSE</a></code> or <code>NULL</code>.</p> + +<h3 id="Public_APIs">Public APIs</h3> + +<p>The public C/C++ interface, called the JSAPI, is in most places a thin (but source-compatible across versions) layer over the implementation. See the <a href="/en-US/docs/SpiderMonkey/JSAPI_User_Guide" title="JSAPI_User_Guide">JSAPI User Guide</a>. There is an additional public API for JavaScript debuggers, <a href="/en-US/docs/JSDBGAPI_Reference" title="JSDBGAPI_Reference">JSDBGAPI</a>, but {{Source("js/jsd/jsdebug.h")}} might be a better API for debuggers. Another API, <a href="/en-US/docs/JSXDRAPI" title="JSXDRAPI">JSXDRAPI</a>, provides serialization for JavaScript scripts. (XUL Fastload uses this.)</p> + +<h3 id="Just-In-Time_compiler">Just-In-Time compiler</h3> + +<p>SpiderMonkey contains a <a href="https://blog.mozilla.org/javascript/2013/04/05/the-baseline-compiler-has-landed/">baseline compiler</a> as first tier. A second tier JIT, code-named <em>IonMonkey</em> was enabled in <a href="https://blog.mozilla.org/javascript/2012/09/12/ionmonkey-in-firefox-18/" title="https://blog.mozilla.org/javascript/2012/09/12/ionmonkey-in-firefox-18/">Firefox 18</a>. <a href="https://wiki.mozilla.org/IonMonkey">IonMonkey</a> is an optimizing compiler.</p> + +<h3 id="Self-hosting_of_built-in_functions_in_JS">Self-hosting of built-in functions in JS</h3> + +<p>Starting with Firefox 17, SpiderMonkey has the ability to implement built-in functions in self-hosted JS code. This code is compiled in a special compilation mode that gives it access to functionality that's not normally exposed to JS code, but that's required for safe and specification-conformant implementation of built-in functions.</p> + +<p>All self-hosted code lives in <code>.js</code> files under <code>builtin/</code>. For details on implementing self-hosted built-ins, see <a href="/en-US/docs/SpiderMonkey/Internals/self-hosting" title="SpiderMonkey/self-hosting">self-hosting</a>.</p> + +<h2 id="File_walkthrough" name="File_walkthrough">File walkthrough</h2> + +<h4 id="jsapi.cpp.2C_jsapi.h" name="jsapi.cpp.2C_jsapi.h">jsapi.cpp, jsapi.h</h4> + +<p>The public API to be used by almost all client code.</p> + +<h4 id="jspubtd.h.2C_jsprvtd.h" name="jspubtd.h.2C_jsprvtd.h">jspubtd.h, jsprvtd.h</h4> + +<p>These files exist to group struct and scalar typedefs so they can be used everywhere without dragging in struct definitions from N different files. The <code>jspubtd.h</code> file contains public typedefs, and is included automatically when needed. The <code>jsprvtd.h</code> file contains private typedefs and is included by various .h files that need type names, but not type sizes or declarations.</p> + +<h4 id="jsdbgapi.cpp.2C_jsdbgapi.h" name="jsdbgapi.cpp.2C_jsdbgapi.h">jsdbgapi.cpp, jsdbgapi.h</h4> + +<p>The debugging API. Provided so far:</p> + +<p><strong>Traps</strong>, with which breakpoints, single-stepping, step over, step out, and so on can be implemented. The debugger will have to consult jsopcode.def on its own to figure out where to plant trap instructions to implement functions like step out, but a future jsdbgapi.h will provide convenience interfaces to do these things. At most one trap per bytecode can be set. When a script (<code><a href="/en-US/docs/JSScript" title="JSScript">JSScript</a></code>) is destroyed, all traps set in its bytecode are cleared.</p> + +<p><strong>Watchpoints</strong>, for intercepting set operations on properties and running a debugger-supplied function that receives the old value and a pointer to the new one, which it can use to modify the new value being set.</p> + +<p><strong>Line number</strong> to PC and back mapping functions. The line-to-PC direction "rounds" toward the next bytecode generated from a line greater than or equal to the input line, and may return the PC of a for-loop update part, if given the line number of the loop body's closing brace. Any line after the last one in a script or function maps to a PC one byte beyond the last bytecode in the script. An example, from perfect.js:</p> + +<pre class="brush:js;first-line:14">function perfect(n) { + print("The perfect numbers up to " + n + " are:"); + // We build sumOfDivisors[i] to hold a string expression for + // the sum of the divisors of i, excluding i itself. + var sumOfDivisors = new ExprArray(n + 1, 1); + for (var divisor = 2; divisor <= n; divisor++) { + for (var j = divisor + divisor; j <= n; j += divisor) { + sumOfDivisors[j] += " + " + divisor; + } + // At this point everything up to 'divisor' has its sumOfDivisors + // expression calculated, so we can determine whether it's perfect + // already by evaluating. + if (eval(sumOfDivisors[divisor]) == divisor) { + print("" + divisor + " = " + sumOfDivisors[divisor]); + } + } + delete sumOfDivisors; + print("That's all."); +}</pre> + +<p>The line number to PC and back mappings can be tested using the js program with the following script:</p> + +<pre class="brush:js">load("perfect.js"); +print(perfect); +dis(perfect); +print(); +for (var ln = 0; ln <= 40; ln++) { + var pc = line2pc(perfect, ln); + var ln2 = pc2line(perfect, pc); + print("\tline " + ln + " => pc " + pc + " => line " + ln2); +} +</pre> + +<p>The result of the for loop over lines 0 to 40 inclusive is:</p> + +<pre>line 0 => pc 0 => line 16 +line 1 => pc 0 => line 16 +line 2 => pc 0 => line 16 +line 3 => pc 0 => line 16 +line 4 => pc 0 => line 16 +line 5 => pc 0 => line 16 +line 6 => pc 0 => line 16 +line 7 => pc 0 => line 16 +line 8 => pc 0 => line 16 +line 9 => pc 0 => line 16 +line 10 => pc 0 => line 16 +line 11 => pc 0 => line 16 +line 12 => pc 0 => line 16 +line 13 => pc 0 => line 16 +line 14 => pc 0 => line 16 +line 15 => pc 0 => line 16 +line 16 => pc 0 => line 16 +line 17 => pc 19 => line 20 +line 18 => pc 19 => line 20 +line 19 => pc 19 => line 20 +line 20 => pc 19 => line 20 +line 21 => pc 36 => line 21 +line 22 => pc 53 => line 22 +line 23 => pc 74 => line 23 +line 24 => pc 92 => line 22 +line 25 => pc 106 => line 28 +line 26 => pc 106 => line 28 +line 27 => pc 106 => line 28 +line 28 => pc 106 => line 28 +line 29 => pc 127 => line 29 +line 30 => pc 154 => line 21 +line 31 => pc 154 => line 21 +line 32 => pc 161 => line 32 +line 33 => pc 172 => line 33 +line 34 => pc 172 => line 33 +line 35 => pc 172 => line 33 +line 36 => pc 172 => line 33 +line 37 => pc 172 => line 33 +line 38 => pc 172 => line 33 +line 39 => pc 172 => line 33 +line 40 => pc 172 => line 33 +</pre> + +<h4 id="jsconfig.h" name="jsconfig.h">jsconfig.h</h4> + +<p>Various configuration macros defined as 0 or 1 depending on how <code><a href="/en-US/docs/JS_VERSION" title="JS_VERSION">JS_VERSION</a></code> is defined (as 10 for JavaScript 1.0, 11 for JavaScript 1.1, etc.). Not all macros are tested around related code yet. In particular, JS 1.0 support is missing from SpiderMonkey.</p> + +<h4 id="js.cpp.2C_jsshell.msg" name="js.cpp.2C_jsshell.msg">js.cpp, jsshell.msg</h4> + +<p>The "JS shell", a simple interpreter program that uses the JS API and more than a few internal interfaces (some of these internal interfaces could be replaced by <code>jsapi.h</code> calls). The js program built from this source provides a test vehicle for evaluating scripts and calling functions, trying out new debugger primitives, etc.</p> + +<p>A look at the places where <code>jsshell.msg</code> is used in <code>js.cpp</code> shows how error messages can be handled in JSAPI applications. These messages can be localized at compile time by replacing the <code>.msg</code> file; or, with a little modification to the source, at run time.</p> + +<p><a href="/en-US/docs/SpiderMonkey/Introduction_to_the_JavaScript_shell" title="https://developer.mozilla.org/en/introduction_to_the_javascript_shell">More information on the JavaScript shell</a>.</p> + +<h4 id="js.msg" name="js.msg">js.msg</h4> + +<p>SpiderMonkey error messages.</p> + +<h4 id="jsarray..2A.2C_jsbool..2A.2C_jdsdate..2A.2C_jsfun..2A.2C_jsmath..2A.2C_jsnum..2A.2C_jsstr..2A" name="jsarray..2A.2C_jsbool..2A.2C_jdsdate..2A.2C_jsfun..2A.2C_jsmath..2A.2C_jsnum..2A.2C_jsstr..2A">jsarray.*, jsbool.*, jsdate.*, jsfun.*, jsmath.*, jsnum.*, jsstr.*</h4> + +<p>These file pairs implement the standard classes and (where they exist) their underlying primitive types. They have similar structure, generally starting with class definitions and continuing with internal constructors, finalizers, and helper functions.</p> + +<h4 id="jsobj..2A.2C_jsscope..2A" name="jsobj..2A.2C_jsscope..2A">jsobj.*, jsscope.*</h4> + +<p>These two pairs declare and implement the JS object system. All of the following happen here:</p> + +<ul> + <li>creating objects by class and prototype, and finalizing objects;</li> + <li>defining, looking up, getting, setting, and deleting properties;</li> + <li>creating and destroying properties and binding names to them.</li> +</ul> + +<p>The details of a native object's map (scope) are mostly hidden in <code>jsscope.{{mediawiki.external('ch')}}</code>.</p> + +<h4 id="jsatom.cpp.2C_jsatom.h" name="jsatom.cpp.2C_jsatom.h">jsatom.cpp, jsatom.h</h4> + +<p>The atom manager. Contains well-known string constants, their atoms, the global atom hash table and related state, the js_Atomize() function that turns a counted string of bytes into an atom, and literal pool (<code>JSAtomMap</code>) methods.</p> + +<h4 id="jsarena.cpp.2C_jsarena.h" name="jsarena.cpp.2C_jsarena.h">jsarena.cpp, jsarena.h</h4> + +<p>Last-In-First-Out allocation macros that amortize malloc costs and allow for en-masse freeing. See the paper mentioned in <code>jsarena.h</code>'s major comment.</p> + +<h4 id="jsgc.cpp.2C_jsgc.h" name="jsgc.cpp.2C_jsgc.h">jsgc.cpp, jsgc.h</h4> + +<p>The garbage collector and tracing routines.</p> + +<h4 id="jsinterp..2A.2C_jscntxt..2A.2C_jsinvoke.cpp" name="jsinterp..2A.2C_jscntxt..2A.2C_jsinvoke.cpp">jsinterp.*, jscntxt.*, jsinvoke.cpp</h4> + +<p>The bytecode interpreter, and related functions such as Call and AllocStack, live in <em>jsinterp.cpp</em>. The JSContext constructor and destructor are factored out into <em>jscntxt.cpp</em> for minimal linking when the compiler part of JS is split from the interpreter part into a separate program.</p> + +<p><code>jsinvoke.cpp</code> is a build hack used on some platforms to build <code>js_Interpret</code> under different compiler options from the rest of <code>jsinterp.cpp</code>.</p> + +<h4 id="jstracer.*_nanojit*">jstracer.*, nanojit/*</h4> + +<p><a href="/en-US/docs/SpiderMonkey/Internals/Tracing_JIT" title="SpiderMonkey/Internals/Tracing JIT">The tracing JIT</a>. The interface between the JIT and the rest of SpiderMonkey is conceptually small—the interpreter calls into the trace recorder—but as with everything else, there are tendrils everywhere.</p> + +<h4 id="jsemit..2A.2C_jsopcode.tbl.2C_jsopcode..2A.2C_jsparse..2A.2C_jsscan..2A.2C_jsscript..2A" name="jsemit..2A.2C_jsopcode.tbl.2C_jsopcode..2A.2C_jsparse..2A.2C_jsscan..2A.2C_jsscript..2A">jsemit.*, jsopcode.tbl, jsopcode.*, jsparse.*, jsscan.*, jsscript.*</h4> + +<p>Compiler and decompiler modules. The <em>jsopcode.tbl</em> file is a C preprocessor source that defines almost everything there is to know about JS bytecodes. See its major comment for how to use it. For now, a debugger will use it and its dependents such as <em>jsopcode.h</em> directly, but over time we intend to extend <em>jsdbgapi.h</em> to hide uninteresting details and provide conveniences. The code generator is split across paragraphs of code in <em>jsparse.cpp</em>, and the utility methods called on <code>JSCodeGenerator</code> appear in <em>jsemit.cpp</em>. Source notes generated by <em>jsparse.cpp</em> and <em>jsemit.cpp</em> are used in <em>jsscript.cpp</em> to map line number to program counter and back.</p> + +<h4 id="jstypes.h" name="jstypes.h">jstypes.h</h4> + +<p>Fundamental representation types and utility macros. This file alone among all .h files in SpiderMonkey must be included first by .cpp files. It is not nested in .h files, as other prerequisite .h files generally are, since it is also a direct dependency of most .cpp files and would be over-included if nested in addition to being directly included.</p> + +<h4 id="jsbit.h.2C_jslog2.cpp" name="jsbit.h.2C_jslog2.cpp">jsbit.h, jslog2.cpp</h4> + +<p>Bit-twiddling routines. Most of the work here is selectively enabling compiler-specific intrinsics such as GCC's <code>__builtin_ctz</code>, which is useful in calculating base-2 logarithms of integers.</p> + +<h4 id="jsutil.cpp.2C_jsutil.h" name="jsutil.cpp.2C_jsutil.h">jsutil.cpp, jsutil.h</h4> + +<p>The <code>JS_ASSERT</code> macro is used throughout the source as a proof device to make invariants and preconditions clear to the reader, and to hold the line during maintenance and evolution against regressions or violations of assumptions that it would be too expensive to test unconditionally at run-time. Certain assertions are followed by run-time tests that cope with assertion failure, but only where I'm too smart or paranoid to believe the assertion will never fail...</p> + +<h4 id="jsclist.h" name="jsclist.h">jsclist.h</h4> + +<p>Doubly-linked circular list struct and macros.</p> + +<h4 id="jscpucfg.cpp" name="jscpucfg.cpp">jscpucfg.cpp</h4> + +<p>This standalone program generates <em>jscpucfg.h</em>, a header file containing bytes per word and other constants that depend on CPU architecture and C compiler type model. It tries to discover most of these constants by running its own experiments on the build host, so if you are cross-compiling, beware.</p> + +<h4 id="jsdtoa.cpp.2C_jsdtoa.h.2C_dtoa.c" name="jsdtoa.cpp.2C_jsdtoa.h.2C_dtoa.c">jsdtoa.cpp, jsdtoa.h, dtoa.c</h4> + +<p>dtoa.c contains David Gay's portable double-precision floating point to string conversion code, with Permission To Use notice included. jsdtoa.cpp <code>#include</code>s this file.</p> + +<h4 id="jshash.cpp.2C_jshash.h.2C_jsdhash.cpp.2C_jsdhash.h" name="jshash.cpp.2C_jshash.h.2C_jsdhash.cpp.2C_jsdhash.h">jshash.cpp, jshash.h, jsdhash.cpp, jsdhash.h</h4> + +<p>Portable, extensible hash tables. These use multiplicative hash for strength reduction over division hash, yet with very good key distribution over power of two table sizes. jshash resolves collisions via chaining, so each entry burns a malloc and can fragment the heap. jsdhash uses open addressing.</p> + +<h4 id="jslong.cpp.2C_jslong.h" name="jslong.cpp.2C_jslong.h">jslong.cpp, jslong.h</h4> + +<p>64-bit integer emulation, and compatible macros that use intrinsic C types, like <code>long long</code>, on platforms where they exist (most everywhere, these days).</p> + +<h4 id="jsprf..2A" name="jsprf..2A">jsprf.*</h4> + +<p>Portable, buffer-overrun-resistant sprintf and friends. For no good reason save lack of time, the %e, %f, and %g formats cause your system's native sprintf, rather than <code>JS_dtoa()</code>, to be used. This bug doesn't affect SpiderMonkey, because it uses its own <code>JS_dtoa()</code> call in <code>jsnum.cpp</code> to convert from double to string, but it's a bug that we'll fix later, and one you should be aware of if you intend to use a <code>JS_*printf()</code> function with your own floating type arguments - various vendor sprintf's mishandle NaN, +/-Inf, and some even print normal floating values inaccurately.</p> + +<h4 id="prmjtime.c.2C_prmjtime.h" name="prmjtime.c.2C_prmjtime.h">prmjtime.c, prmjtime.h</h4> + +<p>Time functions. These interfaces are named in a way that makes local vs. universal time confusion likely. Caveat emptor, and we're working on it. To make matters worse, Java (and therefore JavaScript) uses "local" time numbers (offsets from the epoch) in its Date class.</p> + +<h4 id="jsfile.cpp.2C_jsfile.h.2C_jsfile.msg" name="jsfile.cpp.2C_jsfile.h.2C_jsfile.msg">jsfile.cpp, jsfile.h, jsfile.msg</h4> + +<p>Obsolete. Do not use these files.</p> + +<h4 id="Makefile.in.2C_build.mk" name="Makefile.in.2C_build.mk">Makefile.in, build.mk</h4> + +<p>Mozilla makefiles. If you're building Gecko or Firefox, the larger build system will use these files. They are also used for current standalone builds.</p> + +<h4 id="Makefile.ref.2C_rules.mk.2C_config.mk.2C_config.2F.2A" name="Makefile.ref.2C_rules.mk.2C_config.mk.2C_config.2F.2A">Makefile.ref, rules.mk, config.mk, config/*</h4> + +<p>Obsolete SpiderMonkey standalone makefiles from 1.8 and earlier. See <a href="/en-US/docs/SpiderMonkey/Build_Documentation#Building_SpiderMonkey_1.8_or_earlier" title="SpiderMonkey/Build Documentation#Building SpiderMonkey 1.8 or earlier">SpiderMonkey Build Documentation</a>.</p> + +<h3 id="See_also">See also</h3> + +<ul> + <li><a href="/jsd" title="jsd">jsd</a></li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/internals/thread_safety/index.html b/files/ja/mozilla/projects/spidermonkey/internals/thread_safety/index.html new file mode 100644 index 0000000000..90bfb3fb10 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/internals/thread_safety/index.html @@ -0,0 +1,56 @@ +--- +title: Thread Safety +slug: Mozilla/Projects/SpiderMonkey/Internals/Thread_Safety +tags: + - JavaScript + - SpiderMonkey +--- +<p>This page describes implementation details of the <a href="/ja/SpiderMonkey" title="ja/SpiderMonkey">SpiderMonkey</a> JavaScript engine. It is mainly of interest to people working on SpiderMonkey itself, but this information is also helpful for anyone embedding SpiderMonkey in a multithreaded environment. See also <code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>.</p> +<p>{{ 英語版章題("General background") }}</p> +<h4 id="General_background" name="General_background">General background</h4> +<p>SpiderMonkeyは、最上位の構造体として<code><a href="/ja/JS_NewRuntime" title="ja/JS_NewRuntime">JSRuntime</a></code>を利用します。これらの構造体は、メモリの管理とグローバルなデータ構造を扱います。 通常の場合プログラムは、多くのスレッドを利用する場合でも、1つだけ<code>JSRuntime</code>を使います。<code>JSRuntime</code>は、JSオブジェクトが動作する 世界といってもよいでしょう。オブジェクトは、他の<code>JSRuntime</code>に移って動作することはできません。 <span class="comment">SpiderMonkey has a top-level struct, <code><a href="/ja/JS_NewRuntime" title="ja/JS_NewRuntime"></code>, that handles, among other things, memory management and "global" data structures. A program typically has only one <code>JSRuntime</code>, even if it has many threads. The <code>JSRuntime</code> is the universe in which JS objects live; they can't travel to other <code>JSRuntime</code>s.</a></span></p> +<p>全てのJSコードとほとんどのJSAPIの呼び出しは、<code><a href="/ja/JS_NewContext" title="ja/JS_NewContext">JSContext</a></code>の中で動作します。<code>JSContext</code>は、 <code>JSRuntime</code>の子供のようなもので、例えば、例外の処理などは、<code>JSContext</code>ごとに実行されます。 各<code>JSContext</code>は、同時に複数スレッドからアクセスしてはなりません。 <span class="comment">All JS code and most JSAPI calls run within a <code><a href="/ja/JS_NewContext" title="ja/JS_NewContext">JSContext</a></code>. The <code>JSContext</code> is a child of the <code>JSRuntime</code>; exception handling, for example, is per-<code>JSContext</code>. Each <code>JSContext</code> must be used by only one thread at a time.</span></p> +<p>オブジェクトは、同じ<code>JSRuntime</code>内の<code>JSContext</code>間で共有できます。コンテキストとオブジェクトの間には、固定的な関係はありません。 <span class="comment">Objects may be shared among <code>JSContext</code>s within a <code>JSRuntime</code>. There's no fixed association between an object and a context.</span></p> +<p>SpiderMonkeyにおけるスレッドセーフ機能は、<code>-DJS_THREADSAFE</code>をつけてコンパイルすることで有効になります。<code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>を有効にしたビルドでは、次のような操作について特別な処理が行われます。 <span class="comment">Thread-safety in SpiderMonkey is turned on by compiling with <code>-DJS_THREADSAFE</code>. In a <code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code> build, these operations are handled specially:</span></p> +<ul> <li><code>JSRuntime</code>のデータ構造にアクセスする場合</li> <li>ガーベジコレクションを行う場合</li> <li>オブジェクトのプロパティにアクセスする場合</li> +</ul> +<p><span class="comment">* access to <code>JSRuntime</code> data structures * garbage collection * access to properties of objects</span></p> +<p><code>JSRuntime</code>のデータ構造へのアクセスは、mutexによってシリアライズされます。 GCとプロパティに関する処理については、もう少し詳しく説明します。 <span class="comment">Accesses to <code>JSRuntime</code> data structures are serialized with a few mutexes. The treatment of GC and properties requires more explanation.</span></p> +<p>{{ 英語版章題("Making GC thread-safe") }}</p> +<h4 id="Making_GC_thread-safe" name="Making_GC_thread-safe">Making GC thread-safe</h4> +<p><code>JS_THREADSAFE</code>を用いるときは、APIを若干変更します。プログラム中でJSAPIを呼び出すときは、次に示す"request"で くくらなくてはなりません。 <span class="comment">With <code>JS_THREADSAFE</code>, the API changes slightly. The program must group JSAPI calls into "requests":</span></p> +<pre class="eval"> <a href="/ja/JS_SetContextThread" title="ja/JS_SetContextThread">JS_SetContextThread</a>(cx); + <a href="/ja/JS_BeginRequest" title="ja/JS_BeginRequest">JS_BeginRequest</a>(cx); + /* ... do stuff ... */ + <a href="/ja/JS_EndRequest" title="ja/JS_EndRequest">JS_EndRequest</a>(cx); + <a href="/ja/JS_ClearContextThread" title="ja/JS_ClearContextThread">JS_ClearContextThread</a>(cx); +</pre> +<p>複数のスレッドがrequest内で同じ<code>JSRuntime</code>を同時にアクセスできるため、この操作がボトルネックになることはありません。詳細は<a href="/ja/JS_BeginRequest" title="ja/JS_BeginRequest">JS_BeginRequest</a>を参照してください。 <span class="comment">It isn't a bottleneck; multiple threads are allowed to be in requests on the same <code>JSRuntime</code> at once. See <a href="/ja/JS_BeginRequest" title="ja/JS_BeginRequest">JS_BeginRequest</a>.</span></p> +<p>requestの最も顕著な効果は、いつでも複数のスレッドがrequestのくくりを実行することができるか、1つのスレッドだけがGCを実行していて他のスレッドが停止させられている 用にすることです。JS_GC()を呼び出しても、他のスレッドが停止させられるまでは、処理がブロックされます。つまり、他のスレッドがJSAPIを呼び出していないか (呼び出していないときには、特に注意する必要がないので)、JSAPIを実行中であってもGCが終了するのを待っているブロックしている状態になるまで、 GCの実行は停止させられます。 <span class="comment">The most obvious effect of a request is: at any given moment there can either be multiple threads in active requests, or one thread doing GC and all requests suspended. A call to JS_GC() will block until the latter becomes possible. In other words, GC waits until each other thread is either outside JSAPI (in which case we don't care what it's doing) or else in JSAPI, but blocked, waiting for GC to finish.</span></p> +<p>requestのくくりの中にいないときには、スレッドは、GCに影響を与えるような処理を行ってはいけません。 当たり前のことですが、requestのくくりの中では、GCが抑止されてしまうので、ブロックしたり、時間のかかる処理を行ってはいけません。 <span class="comment">Threads must not do anything that would affect GC while outside a request. And obviously you shouldn't block or otherwise dilly-dally while in a request; it prohibits GC. 最適化のために、スレッドには、スレッドごとの大きさごとに分けられた、割り当て可能なGC用のメモリの集合に関するフリーリストを持っています。 このリストにより、ほとんどの場合ロックせずにメモリを割り当てることができます。スレッドがロックを必要とするのは、スレッドの対応するフリーリストが 空だった場合だけです。このようなことが怒った場合に、ロックして広域のGC割り当てを行い、<code>JSRuntime</code>から、フリーリストに領域を補充します。 <!--As an optimization, each thread has its own size-classified freelists containing chunks of GC-managed memory ready to be allocated. This allows allocation to avoid locking most of the time (a significant speed win). A thread needs to lock on allocation only when the relevant per-thread freelist is empty. When this happens, the thread also refills that freelist from the <code>JSRuntime</code>-wide GC allocator while it's in the lock.</span></p> +<p>{{ 英語版章題("Making property accesses thread-safe") }}</p> +<h4 id="Making_property_accesses_thread-safe" name="Making_property_accesses_thread-safe">Making property accesses thread-safe</h4> +<p>JSAPIのユーザにとっては、プロパティへのアクセスは全てシリアライズされているように見えます。これから記述する方法は、SpiderMonkeyの内部に関するもので ユーザにとっては見えない、最適化についてです。 <span class="comment">To the JSAPI user, all property accesses appear to be serialized. The scheme described below is an optimization, internal to SpiderMonkey and invisible to the user.</span></p> +<p>SpiderMonkeyの実装では、mutableなオブジェクトは必要に応じて暗黙のうちにロックされます。ロックの手順は、うまく最適化されていて、単なるmutexではありません。 <span class="comment">SpiderMonkey implicitly locks mutable objects as needed. The locking protocol is cleverly optimized. It's not a simple mutex.</span></p> +<p>それぞれの、mutableなオブジェクトは、<code>JSContext</code>が"占有"している(つまり、コンテキストがロックをしなくてもプロパティにアクセスできる) か、<code>JSRuntime</code>内の<code>JSContext</code>で、"共有"しているかのいずれかです。(繰り返しになりますが、JSAPIのユーザにとっては、全てのオブジェクトは 共有されており、この"所有関係"は、ユーザには見えないように最適化されています。) <span class="comment">Each mutable object is either "owned" by a <code>JSContext</code>, meaning that context may access its properties without locking; or "shared" across all <code>JSContext</code>s in the <code>JSRuntime</code>. (Again, to the end user, all objects are shared--this "ownership" is a transparent optimization.)</span></p> +<p>初期状態では、オブジェクトの所有者は、オブジェクトを作った<code>JSContext</code.です。他の<code>JSContext</code>がオブジェクトにアクセスしようとするまでは、 ロックは全く必要ではありません。他のコンテキストがアクセスしようとした時点で、<code>JSRuntime</code>の広域ロックを取得します。ただ、この時点においても プロパティへの通常のアクセスは、1つのオブジェクト(つまり、プロパティを持っているオブジェクトのこと)のmutable部分に触る必要があるだけです。 従って、デッドロックは問題になりません。* また、スレッドがロックする必要がある場合でも、オブジェクトを所有しているコンテキストが requestのくくりを実行していないのであれば、コストのかかる他のスレッドとのランデブ**を避けることができます。 <span class="comment">Initially an object is owned by the <code>JSContext</code> in which it was created. Locking is never needed until some other <code>JSContext</code> tries to access the object. At that point, we acquire a <code>JSRuntime</code>-wide lock. But even then, each ordinary property access only needs to touch mutable parts of one object (the one that has the property), so deadlock isn't an issue.* And even though the calling thread must lock, it can still avoid a costly rendezvous** with another thread, if the context that owns the object is not currently in a request.</span></p> +<p>I found it helpful to read the code for <code><a href="http://lxr.mozilla.org/seamonkey/ident?i=OBJ_GET_SLOT" class="external">OBJ_GET_SLOT</a></code>, defined in <a href="http://hg.mozilla.org/mozilla-central/?file/tip/js/src/jsobj.h" class="external">jsobj.h</a>, and track down the various things it calls.</p> +<pre class="eval"> /* Thread-safe functions and wrapper macros for accessing slots in obj. */ + #define OBJ_GET_SLOT(cx,obj,slot) \ + (OBJ_CHECK_SLOT(obj, slot), \ + (OBJ_IS_NATIVE(obj) && OBJ_SCOPE(obj)->ownercx == cx) \ + ? LOCKED_OBJ_GET_SLOT(obj, slot) \ + : js_GetSlotThreadSafe(cx, obj, slot)) +</pre> +<p>Here <code>OBJ_CHECK_SLOT()</code> is just an assertion. <code>LOCKED_OBJ_GET_SLOT()</code> is the fast path; it amounts to an array access. <code>OBJ_SCOPE(obj)->ownercx</code> is the object's owning context, or <code>NULL</code> if the object is "shared". (An <code>OBJ_SCOPE</code> is just a handy place to stick this field; it is often shared across multiple objects, so all this locking is somewhat higher than object-level.)</p> +<p>This may appear unsafe, at least in SMP environments where writing a word isn't guaranteed to make the new value immediately visible to other CPUs. Requests save the day again: entering or leaving a request always briefly acquires a lock, which forces a read-write barrier. This barrier is necessary and sufficient to make several of these optimizations safe.</p> +<p>In short, any <code>JSContext</code> may touch any object, yet not only is locking usually optimized away, the threads don't even have to execute atomic instructions or barrier instructions in the most common path.</p> +<hr> +<p>* deadlock isn't an issue: That is, SpiderMonkey doesn't need any special code to detect and avoid potential deadlock when getting or setting an ordinary property, because it can't happen--you're only locking one object at a time. Assigning to <code>__proto__</code> is an example of a special case: SpiderMonkey checks for prototype chain cycles, which means locking the whole chain. So in that case, and maybe others, SpiderMonkey does extra work to avoid deadlock.</p> +<p>** can still avoid a costly rendezvous: That is, it can avoid "asking" that thread to surrender the object and then waiting for the thread to respond. It just takes the object. See <a href="http://lxr.mozilla.org/seamonkey/ident?i=ClaimScope" class="external">ClaimScope</a> in jslock.c.</p> +<p>{{ 英語版章題("Patent") }}</p> +<h4 id="Patent" name="Patent">Patent</h4> +<p>The SpiderMonkey request model is patented: <a href="http://www.wipo.int/pctdb/en/wo.jsp?wo=2003042845" class=" external" rel="freelink">http://www.wipo.int/pctdb/en/wo.jsp?wo=2003042845</a></p> +<p>The Mozilla Public License in the SpiderMonkey source code grants a worldwide royalty-free license to this invention.</p> + +<p>{{ languages( { "en": "en/SpiderMonkey_Internals/Thread_Safety" } ) }} </p> diff --git a/files/ja/mozilla/projects/spidermonkey/introduction_to_the_javascript_shell/index.html b/files/ja/mozilla/projects/spidermonkey/introduction_to_the_javascript_shell/index.html new file mode 100644 index 0000000000..f07dc77d69 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/introduction_to_the_javascript_shell/index.html @@ -0,0 +1,376 @@ +--- +title: JavaScript シェルの紹介 +slug: Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell +--- +<div>{{SpiderMonkeySidebar("General")}}</div> + +<div class="summary"> +<p><strong>JavaScript シェル</strong> (<code>js</code>) は <a href="/ja/docs/Mozilla/Projects/SpiderMonkey">SpiderMonkey</a> ソース配布に含まれているコマンドラインプログラムです。 これは、Python の対話型プロンプト、Lisp の read-eval-print ループ、または Ruby の irb に相当する JavaScript です。この記事では、シェルを使用して JavaScript コードを試したり JavaScript プログラムを実行したりする方法について説明します。</p> +</div> + +<p>SpiderMonkey JavaScript シェルを入手するには、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation">SpiderMonkey ビルドドキュメント</a>を参照するか、<a href="https://archive.mozilla.org/pub/firefox/nightly/latest-mozilla-central/">Nightly Builds</a> からプラットフォーム用にコンパイルされたバイナリをダウンロードしてください。</p> + +<p>他の JavaScript シェルのリストについては、<a href="/ja/docs/JavaScript/Shells">JavaScript シェル</a>を参照してください。</p> + +<div class="note"> +<p>メモ: SpiderMonkey 44 {{geckoRelease(44)}} 以降、標準の Web 互換の JavaScript バージョンがデフォルトで使用されます (JS 1.7 以降ではなくなりました)。組み込みの <code>version()</code> シェルは、従来の機能をテストするためにまだ存在しています。</p> +</div> + +<h2 id="Using_the_JavaScript_shell" name="Using_the_JavaScript_shell">JavaScript シェルを実行する</h2> + +<p>シェルには2つの動作モードがあります。インタラクティブシェルとして使用することができます。ここでは、プロンプトで JavaScript コードを入力してすぐに満足のいく結果を得ることができます。これは、新機能の実験やテストに便利です。実行する JavaScript プログラムファイルをコマンドラインで渡すこともできます。その場合、プログラムは自動的に実行されます。</p> + +<p>ビルドの資料に従って、make install を使用してビルド済みシェルをインストールした後は、次のコマンドを使用して対話モードでシェルを実行できます。</p> + +<pre class="eval">js +</pre> + +<p style="text-align: right;">[ If you get " symbol lookup error: ./js: undefined symbol: PR_SetCurrentThreadName" e.g. from a Bash console when using a pre-compiled binary, try <path to your Firefox's run-mozilla.sh>/run-mozilla.sh ./js -- that worked for me]</p> + +<p>ファイル <code>foo.js</code> 内の JavaScript コードを実行したい場合は、次のコマンドを使用できます:</p> + +<pre class="eval">js foo.js +</pre> + +<p><code>foo.js</code> を実行してからインタラクティブシェルにドロップするには、次のようにします:</p> + +<pre class="eval">js -f foo.js -i +</pre> + +<h2 id="リファレンス">リファレンス</h2> + +<div class="note"><strong>メモ:</strong> JavaScript シェルは JavaScript エンジンのテスト環境として使用されるため、使用可能なオプションと組み込み関数は時間の経過とともに変わる可能性があります。</div> + +<h3 id="Command_line_options" name="Command_line_options">コマンドラインオプション</h3> + +<p>シェルを制御するために指定できるコマンドラインオプションは多数あります。これらは以下に要約されています。文書化されていないものがあるかどうかを確認するには、必ず自分の jsshell で <strong>-h</strong> を使用してください。</p> + +<dl> + <dt><code>-c, --compileonly</code></dt> + <dd>プログラムをコンパイルして実行しないようシェルに指示します。これは、プログラムを実行せずにプログラム内の構文エラーを素早くチェックするのに便利な方法です。</dd> + <dt><code>-e <em>script</em></code></dt> + <dd>指定した<em>スクリプト</em>を実行します。これは、実行するコードを含むリテラル文字列です。</dd> + <dt><code>-f <em>filename</em></code></dt> + <dd><em>filename</em> で指定された JavaScript プログラムを実行します。</dd> + <dt><code>-i</code></dt> + <dd>インタラクティブモードを有効にします。(ファイル名が指定されていない場合はデフォルト)</dd> + <dt><code>--no-ion</code></dt> + <dd>最適化 JIT コンパイラを無効にします。</dd> + <dt><code>--no-baseline</code></dt> + <dd>ベースライン JIT コンパイラを無効にします。</dd> + <dt><code>-P</code></dt> + <dd>ファイルの最初の行が "/usr/bin/env js -P" の場合、ファイルの内容は JavaScript エンジンによって解釈されます。</dd> + <dd>これにより、JavaScript ファイルを UNIX および OS X マシン上で実行可能にすることができます。</dd> + <dt><code>-s</code></dt> + <dd>厳密な警告モードを有効にします。</dd> + <dt><code>-w, --warnings</code></dt> + <dd>警告メッセージを有効にします。</dd> + <dt><code>-W</code>, --nowarnings</dt> + <dd>警告メッセージを無効にします。</dd> +</dl> + +<h3 id="Environment_options" name="Environment_options">環境オプション</h3> + +<p>js シェルの動作を変更するために設定できる環境変数がいくつかあります。</p> + +<dl> + <dt><code>JS_STDOUT=<em>file</em></code></dt> + <dd>標準出力を <em>file</em> にリダイレクトします。</dd> + <dt><code>JS_STDERR=<em>file</em></code></dt> + <dd>標準エラー出力を <em>file</em> にリダイレクトします。</dd> +</dl> + +<h3 id="Built-in_functions" name="Built-in_functions">組み込み関数</h3> + +<p>JavaScript シェルをより便利にするために、JavaScript プログラムからでもインタラクティブモードでも使える、多くの組み込み関数が提供されています。</p> + +<div class="warning"> +<p><strong>注</strong>: このリストは不完全であり、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Shell_global_objects">Shell のグローバルオブジェクト</a>と重複しています。詳しくは {{Source("js/src/shell/js.cpp")}} を参照してください (<code>shell_functions</code>について)。</p> +</div> + +<h4 id="build.28.29" name="build.28.29"><code>build()</code></h4> + +<p>JavaScript シェルが構築された日時を返します。</p> + +<div class="note"><strong>メモ:</strong> パラメータなしの <code>clear()</code> は本当にすべてをクリアします。これにはこれらすべての組み込み関数が含まれます。</div> + +<h4 id="clone.28function.2C_.5Bscope.5D.29" name="clone.28function.2C_.5Bscope.5D.29"><code>clone(<em>function, [scope]</em>)</code></h4> + +<p>指定された <var>function</var> オブジェクトを複製します。scope が指定されていない場合、新しいオブジェクトの親は元のオブジェクトのものと同じです。それ以外の場合、新しいオブジェクトは <em>scope</em> で指定されたオブジェクトの範囲内に配置されます。</p> + +<h4 id="countHeap" name="countHeap"><code>countHeap(<em>[start[, kind]]</em>)</code></h4> + +<p>{{ jsapi_minversion_inline("1.8") }} ヒープ内のライブ GC のもの、または <em>start</em> から到達可能なもので、指定された値が null ではないものの数を数えます。<em>kind</em> はすべてのものを数える <code>'all'</code> (デフォルト)、またはその種類のものだけを数えるための <code>'object'</code>, <code>'double'</code>, <code>'string'</code>, <code>'function'</code>, <code>'qname'</code>, <code>'namespace'</code>, <code>'xml'</code> のいずれかです。</p> + +<h4 id="evalcx.28string.5B.2C_object.5D.29" name="evalcx.28string.5B.2C_object.5D.29"><code>dumpHeap(<em>[fileName[, start[, toFind[, maxDepth[, toIgnore]]]]]</em>)</code></h4> + +<p>{{ jsapi_minversion_inline("1.8") }} 既存のすべてのオブジェクト (または特定の興味深い部分グラフ) のグラフをファイルにダンプします。詳しくは、この関数の C/C++ バージョン、<code>JS_DumpHeap</code> を参照してください。</p> + +<h4 id="evalcx.28string.5B.2C_object.5D.29" name="evalcx.28string.5B.2C_object.5D.29"><code>evalcx(<em>string[, object]</em>)</code></h4> + +<p>JavaScript コードを文字列で評価します。<em>object</em> が指定されている場合、コードはそのオブジェクト内で実行され、サンドボックスとして扱われます。</p> + +<p><em>string</em> が空で <em>object</em> が指定されていない場合、<code>evalcx()</code> は、意欲的な標準クラスを持つ新しいオブジェクトを返します。</p> + +<p><em>string</em> が "lazy" で <em>object</em> が指定されていない場合、<code>evalcx()</code> は lazy 標準クラスを持つ新しいオブジェクトを返します。</p> + +<div class="note"><strong>メモ:</strong> <code>evalcx()</code> は、シェル内で <code>evalInSandbox</code> のような環境をテストするために、JavaScript エンジンの内部で深く作業している人にのみ役立ちます。</div> + +<h4 id="gc.28.29" name="gc.28.29"><code>gc()</code></h4> + +<p>ガベージコレクタを実行してメモリを解放します。</p> + +<h4 id="gcparam.28.29" name="gcparam.28.29"><code>gcparam(<em>name[, value]</em>)</code></h4> + +<p>{{ jsapi_minversion_inline("1.8") }} ガベージコレクタのパラメータを読み込むか設定します。</p> + +<p>名前は <a href="https://searchfox.org/mozilla-central/source/js/src/builtin/TestingFunctions.cpp#464">https://searchfox.org/mozilla-central/source/js/src/builtin/TestingFunctions.cpp#464</a> の <code>FOR_EACH_GC_PARAM</code> で定義されているパラメータキーのいずれか (<code>'maxBytes'</code>、<code>'maxMallocBytes'</code>、'<code>gcNumber</code>' など) でなければなりません。</p> + +<p><em>value</em> が指定されていない場合、<code>gcparam()</code> は name という名前の GC パラメータに関連付けられている現在の値を返します。</p> + +<p><em>value</em> が指定されている場合、それは正の uint32 に変換可能でなければなりません。<code>gcparam()</code> は GC パラメータの <em>name</em> を <em>value</em> に設定します。</p> + +<p>詳しくは C/C++ 関数の <code><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetGCParameter">JS_GetGCParameter</a></code> および <a class="internal" href="https://developer.mozilla.org/En/SpiderMonkey/JSAPI_Reference/JS_SetGCParameter" title="en/SpiderMonkey/JSAPI Reference/JS SetGCParameter"><code>JS_SetGCParameter</code></a> を参照してください。</p> + +<h4 id="gczeal.28.29" name="gczeal.28.29"><code>gczeal(level)</code></h4> + +<p>{{ jsapi_minversion_inline("1.8") }} <code>DEBUG</code> のみ。デバッグ機能である GC の活動量のレベルを設定します。これは、通常の定期的なガベージコレクションの場合は 0、非常に頻繁な GC の場合は 1、非常に頻繁な GC の場合は 2 になります。<br> + 0 以外は JavaScript の実行を非常に遅くしますが、GC 関連のバグを明らかにしたり再現したりするのに役立ちます。詳しくは、この関数の C/C++ バージョンである <code><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetGCZeal">JS_SetGCZeal</a></code> を参照してください。</p> + +<h4 id="getpda.28object.29" name="getpda.28object.29"><code>getpda(<em>object</em>)</code></h4> + +<p>指定した <em>object</em> のプロパティ記述子を返します。</p> + +<h4 id="getslx.28object.29" name="getslx.28object.29"><code>getslx(<em>object</em>)</code></h4> + +<p>指定されたオブジェクトを構成するコードの行数であるスクリプト行エクステントを返します。</p> + +<h4 id="help.28.5Bcommand_....5D.29" name="help.28.5Bcommand_....5D.29"><code>help(<em>[command ...]</em>)</code></h4> + +<p>指定されたコマンド、または指定されていない場合は使用可能なすべての機能に関する簡単なヘルプ情報を表示します。</p> + +<h4 id="intern.28string.29" name="intern.28string.29"><code>intern(<em>string</em>)</code></h4> + +<p>指定された <var>string</var> をアトムテーブルに内部化します。すべての文字列はアトムと呼ばれる一意の識別子を持ちます。このシステムにより、文字列間の比較が簡単になります。</p> + +<div class="note"><strong>メモ:</strong> この関数は、JavaScript エンジンをテストするときにのみ使用されることを意図しています。</div> + +<h4 id="line2pc.28.5Bfunction.2C_.5D_line.29" name="line2pc.28.5Bfunction.2C_.5D_line.29"><code>line2pc(<em>[function, ] line</em>)</code></h4> + +<p>指定されたコード行に対応するプログラムカウンタ値を返します。<em>function</em> が指定されている場合、<em>line</em> は指定された関数へのオフセットです。</p> + +<h4 id="load.28filename1_.5Bfilename.5D.29" name="load.28filename1_.5Bfilename.5D.29"><code>load(<em>filename1</em> <em>[filename]</em>)</code></h4> + +<p>指定された名前で JavaScript ファイルをロードします。</p> + +<div class="note"><strong>メモ:</strong> JavaScript 以外のファイルをロードするには、<code>read()</code> を使用してください。</div> + +<h4 id="options.28.5Boption_....5D.29" name="options.28.5Boption_....5D.29"><code>options(<em>[option ...]</em>)</code></h4> + +<p>オプションを設定または取得できます。コマンドラインでオプションを指定した場合、<code>options</code> を呼び出した結果は、どのオプションを要求したかを示します。新しいオプションを渡して設定することもできます。</p> + +<p>利用可能なオプションは以下のとおりです:</p> + +<table class="standard-table"> + <tbody> + <tr> + <td class="header">オプション名</td> + <td class="header">説明</td> + </tr> + <tr> + <td><code>strict</code></td> + <td>ストリクトモードが有効になります。</td> + </tr> + <tr> + <td><code>werror</code></td> + <td>警告はエラーとして扱われます。</td> + </tr> + <tr> + <td><code>atline</code></td> + <td><code>atline</code> が有効になっているとき、<code>//@line <em>num</em></code> の形式のコメントは次の行の番号を <code><em>num</em></code> に設定します。</td> + </tr> + </tbody> +</table> + +<h4 id="pc2line.28function.2C_.5Bpc.5D.29" name="pc2line.28function.2C_.5Bpc.5D.29"><code>pc2line(<em>function, [pc]</em>)</code></h4> + +<p>指定された <em>function</em> の最初の行に対応する JavaScript コードの行番号を返します。関数にプログラムカウンタオフセットを指定した場合は、そのオフセットを含むコード行の行番号が返されます。</p> + +<h4 id="print.28.5Bexpression_....5D.29" name="print.28.5Bexpression_....5D.29"><code>print(<em>[expression ...]</em>)</code></h4> + +<p><em>expression(s)</em> を評価し、その結果を <code>stdout</code> にスペース (" ") で区切って表示し、改行 ("\n") で終了します。</p> + +<h4 id="print.28.5Bexpression_....5D.29" name="print.28.5Bexpression_....5D.29"><code>putstr(<em>expression</em>)</code></h4> + +<p><em>expression</em> を評価し、その結果を <code>stdout</code> に表示します。</p> + +<h4 id="quit.28.29" name="quit.28.29"><code>quit(<em>[status]</em>)</code></h4> + +<p>シェルを終了します。省略した場合、<em>status</em> はデフォルトで 0 になります。</p> + +<h4 id="read.28filename.5B.2C_type.5D.29" name="read.28filename.5B.2C_type.5D.29"><code>read(<em>filename[, type]</em>)</code></h4> + +<p>ファイルの内容を読み込んで返します。typeが "binary" の場合は <code>Uint8Array</code> が返され、それ以外の場合は UTF-8 でデコードされた文字列が返されます。</p> + +<h4 id="readline.28.29" name="readline.28.29"><code>readline()</code></h4> + +<p><code>stdin</code> から単一行の入力を読み込み、呼び出し元に返します。これを使って JavaScript でインタラクティブシェルプログラムを作成することができます。</p> + +<h4 id="scatter.28fnArray.29" name="scatter.28fnArray.29">Reflect.parse()</h4> + +<p><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Parser_API" title="en/SpiderMonkey/Parser_API">Parser API</a> を参照してください。</p> + +<div class="note"><strong>メモ:</strong> この関数は、JavaScript エンジンをテストするときにのみ使用することを意図しています。</div> + +<h4 id="seal.28object.5B.2C_deep.5D.29" name="seal.28object.5B.2C_deep.5D.29"><code>seal(<em>object[, deep]</em>)</code></h4> + +<p>指定した <em>object</em>、または <em>deep</em> が <code>true</code> の場合はオブジェクトグラフをシールします。オブジェクトまたはオブジェクトグラフを封印することで、それらのオブジェクトの変更を無効にします。</p> + +<h4 id="sleep.28dt.29" name="sleep.28dt.29"><code>sleep(dt)</code></h4> + +<p>{{ jsapi_minversion_inline("1.8") }} <code><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_THREADSAFE">JS_THREADSAFE</a></code> でのみビルドされます。<em>dt</em> 秒間スリープします。秒の端数がサポートされています。成功した場合に<code>true</code>、スリープが中断された場合に<code>false</code>を返します。</p> + +<h4 id="stackQuota" name="stackQuota"><code>stackQuota(<em>[number]</em>)</code> {{obsolete_inline}}</h4> + +<p>スクリプトスタッククォータを取得または設定します。</p> + +<h4 id="throwError.28.29" name="throwError.28.29"><code>throwError()</code></h4> + +<p><code>JS_ReportError()</code> 関数からエラーをスローします。</p> + +<div class="note"><strong>メモ:</strong> この関数は、JavaScript エンジンをテストするときにのみ使用することを意図しています。</div> + +<h4 id="trap.28.5Bfunction.2C_.5Bpc.2C.5D.5D_expression.29" name="trap.28.5Bfunction.2C_.5Bpc.2C.5D.5D_expression.29"><code>trap(<em>[function, [pc,]] expression</em>)</code></h4> + +<p>JavaScript コードの特定の位置にトラップを設定します。関数 <em>function</em> の <em>pc</em> で指定されたオフセットのバイトコードが実行されようとしているとき、式は評価されます。</p> + +<p><code>line2pc()</code> と組み合わせて使用すると、これは強力なデバッグメカニズムです。たとえば、関数 <code>doSomething()</code> の 6 行目が実行されたときにメッセージを表示したい場合は、次のように入力します。</p> + +<pre>trap(doSomething, line2pc(doSomething, 6), "print('line 6!\n')"); +</pre> + +<div class="note"><strong>メモ:</strong> トラップが設定されると、<code>untrap()</code> を使用してトラップを削除するまで、プログラム内の対応するバイトコードが <code>trap</code> バイトコードに置き換えられます。</div> + +<h4 id="untrap.28function_.5B.2C_pc.5D.29" name="untrap.28function_.5B.2C_pc.5D.29"><code>untrap(<em>function [, pc]</em>)</code></h4> + +<p>オフセット <em>pc</em> で指定した <em>function</em> からトラップを削除します。<em>pc</em> が指定されていない場合、トラップは関数のエントリポイントから削除されます。</p> + +<p>指定された場所にトラップがない場合、この機能は無効です。</p> + +<h4 id="version.28.5Bnumber.5D.29" name="version.28.5Bnumber.5D.29"><code>version(<em>[number]</em>)</code></h4> + +<p><code>version()</code> 関数を使用すると、JavaScript のバージョン番号を取得または設定できます。これは、特定のバージョンの JavaScript でのみ使用可能な構文にアクセスするのに役立ちます (たとえば、<a href="/ja/docs/Web/JavaScript/New_in_JavaScript/1.7#Using_JavaScript_1.7">JavaScript 1.7 の使用</a>を参照)。</p> + +<h3 id="Debug_functions" name="Debug_functions">デバッグ関数</h3> + +<p>これらの組み込み関数は <code>DEBUG</code> ビルドでのみ利用可能です。</p> + +<h4 id="dis.28.5Bfunction.5D.29" name="dis.28.5Bfunction.5D.29"><code>dis(<em>[function]</em>)</code></h4> + +<p>プログラム全体、または指定された <em>function</em> の JavaScript バイトコードを逆アセンブルします。</p> + +<p>たとえば、以下の JavaScript 関数を入力したとします。</p> + +<pre class="eval">function test() { + var i = 3; + print(i+2); +} +</pre> + +<p>それから <code>dis(test);</code> コマンドを実行すると、この出力が得られます。</p> + +<pre>main: +00000: uint16 3 +00003: setvar 0 +00006: pop +00007: name "print" +00010: pushobj +00011: getvar 0 +00014: uint16 2 +00017: add +00018: call 1 +00021: pop +00022: stop + +Source notes: + 0: 0 [ 0] newline + 1: 3 [ 3] decl offset 0 + 2: 7 [ 4] newline + 3: 18 [ 11] xdelta + 4: 18 [ 0] pcbase offset 11 +</pre> + +<h4 id="dissrc.28.5Bfunction.5D.29" name="dissrc.28.5Bfunction.5D.29"><code>dissrc(<em>[function]</em>)</code></h4> + +<p>プログラム全体または指定された <em>function</em> の JavaScript バイトコードを逆アセンブルして、ソース行を表示します。この関数は、シェルの起動時に <code>-f</code> フラグを使用するか、<code>load()</code> 関数を使用してファイルからロードされたプログラムに対してのみ機能します。</p> + +<p>プログラムに関数 <code>doStuff()</code> が含まれている場合は、次のようになります。</p> + +<pre>function doStuff(input) { + print("Enter a number: "); + var n1 = readline(); + print("Enter another one: "); + var n2 = readline(); + + print("You entered " + n1 + " and " + n2 + "\n"); +} +</pre> + +<p><code>dissrc(doStuff)</code> 関数を呼び出すと、次の出力が得られます。</p> + +<pre>;------------------------- 10: print("Enter a number: "); +00000: 10 name "print" +00003: 10 pushobj +00004: 10 string "Enter a number: " +00007: 10 call 1 +00010: 10 pop +;------------------------- 11: var n1 = readline(); +00011: 11 name "readline" +00014: 11 pushobj +00015: 11 call 0 +00018: 11 setvar 0 +00021: 11 pop +;------------------------- 12: print("Enter another one: "); +00022: 12 name "print" +00025: 12 pushobj +00026: 12 string "Enter another one: " +00029: 12 call 1 +00032: 12 pop +;------------------------- 13: var n2 = readline(); +00033: 13 name "readline" +00036: 13 pushobj +00037: 13 call 0 +00040: 13 setvar 1 +00043: 13 pop +;------------------------- 14: +;------------------------- 15: print("You entered " + n1 + " and " + n2 + "\n"); +00044: 15 name "print" +00047: 15 pushobj +00048: 15 string "You entered " +00051: 15 getvar 0 +00054: 15 add +00055: 15 string " and " +00058: 15 add +00059: 15 getvar 1 +00062: 15 add +00063: 15 string "\\n" +00066: 15 add +00067: 15 call 1 +00070: 15 pop +00071: 15 stop +</pre> + +<h4 id="dumpheap.28.28.5BfileName.5B.2C_start.5B.2C_toFind.5B.2C_maxDepth.5B.2C_toIgnore.5D.5D.5D.5D.5D.29" name="dumpheap.28.28.5BfileName.5B.2C_start.5B.2C_toFind.5B.2C_maxDepth.5B.2C_toIgnore.5D.5D.5D.5D.5D.29"><code>dumpheap((<em>[fileName[, start[, toFind[, maxDepth[, toIgnore]]]]]</em>)</code></h4> + +<p>GC 情報をダンプします。これは <code><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DumpHeap">JS_DumpHeap</a></code> の軽量なラッパーです。</p> + +<h4 id="gczeal.28zeal.29" name="gczeal.28zeal.29"><code>gczeal(<em>zeal</em>)</code></h4> + +<p>GC の危険性の発見に役立つように、頻繁な GC を有効にします。<em>zeal</em> は整数です。意味は <code><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetGCZeal">JS_SetGCZeal</a></code> のパラメータと同じです。</p> + +<h4 id="notes.28.5Bfunction.5D.29" name="notes.28.5Bfunction.5D.29"><code>notes(<em>[function]</em>)</code></h4> + +<p>指定した機能のソースノートを表示します。ソースノートには、バイトコードをソースコードにマップする情報が含まれています。これは、<code>dissrc()</code> 関数を使用する場合など、コードを逆コンパイルするときに使用されます。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_cookbook/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_cookbook/index.html new file mode 100644 index 0000000000..efb0e70aa0 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_cookbook/index.html @@ -0,0 +1,514 @@ +--- +title: JSAPI Cookbook +slug: Mozilla/Projects/SpiderMonkey/JSAPI_Cookbook +tags: + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_Cookbook +--- +<p>この記事は僅かなJavaScript共通の用語であるJSAPIについて記載しています。</p> + +<div class="note"><strong>Note:</strong> <a class="internal" href="/En/SpiderMonkey/FOSS" title="En/SpiderMonkey/FOSS">FOSS</a> wiki ページには、 SpiderMonkey と JSAPI を使用する際に生活を楽にする他のライブラリやプログラムへのリンクがいくつか含まれています。</div> + +<h2 id="基礎">基礎</h2> + +<h3 id="Finding_the_global_object">Finding the global object</h3> + +<p>それらのレシピの多くは、最初に現在の大域オブジェクトを見つけることを要求します。</p> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var global = this; +</pre> + +<p>There is a function, <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetGlobalForScopeChain">JS_GetGlobalForScopeChain</a>(cx)</code>という関数があります。最良の考え方でありときにそれは大域オブジェクトの取得する場合最良の方法です。しかし<code><a href="/en/SpiderMonkey/JSAPI_Reference/JSNative">JSNative</a></code> の中では、これを実行する正しい方法は:</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSBool myNative(JSContext *cx, uintN argc, jsval *vp) +{ + CallArgs args = CallArgsFromVp(argc, vp); + JSObject *global = <a href="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_GetGlobalForObject" title="/en-US/docs/SpiderMonkey/JSAPI_Reference/JS_GetGlobalForObject">JS_GetGlobalForObject</a>(cx, &args.callee()); + ... +} +</pre> + +<h3 id="関数定義">関数定義</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +function justForFun() { + return null; +} +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSBool justForFun(JSContext *cx, uintN argc, jsval *vp) +{ + JS_SET_RVAL(cx, vp, <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_NULL" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_NULL">JSVAL_NULL</a>); + return JS_TRUE; +} + +... + +/* + * Add this to your JSContext setup code. + * This makes your C function visible as a global function in JavaScript. + */ +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_DefineFunction" title="en/SpiderMonkey/JSAPI_Reference/JS_DefineFunction">JS_DefineFunction</a>(cx, global, "justForFun", &justForFun, 0, 0)) + return JS_FALSE; +</pre> + +<p>JSAPI関数を一度に定義する場合、JS_DefineFunctions. を用います。 <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_DefineFunctions" title="en/SpiderMonkey/JSAPI_Reference/JS_DefineFunctions">JS_DefineFunctions</a></code>.</p> + +<h3 id="配列の生成">配列の生成</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var x = []; // or "x = Array()", or "x = new Array" +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSObject *x = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_NewArrayObject" title="en/SpiderMonkey/JSAPI_Reference/JS_NewArrayObject">JS_NewArrayObject</a>(cx, 0, NULL); +if (x == NULL) + return JS_FALSE; +</pre> + +<h3 id="オブジェクトの生成">オブジェクトの生成</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var x = {}; // or "x = Object()", or "x = new Object" +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSObject *x = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_NewObject" title="en/SpiderMonkey/JSAPI_Reference/JS_NewObject">JS_NewObject</a>(cx, NULL, NULL, NULL); +if (x == NULL) + return JS_FALSE; +</pre> + +<h3 id="オブジェクトの生成と初期化">オブジェクトの生成と初期化</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var person = new Person("Dave", 24); +</pre> + +<p>JavaScriptではとても単純に処理されています。しかし、JSAPIのアプリケーションでは以下に記述するように3つのことを処理する必要があります:</p> + +<ul> + <li>コンストラクタを参照する、 <code>Person</code></li> + <li>引数を準備する <code>("Dave", 24)</code></li> + <li><code>new</code> キーワードで示す処理を擬似的に作り出すために <a href="/en/SpiderMonkey/JSAPI_Reference/JS_New" title="en/SpiderMonkey/JSAPI_Reference/JS_New"><code>JS_New</code></a> を呼び出します。</li> +</ul> + +<p>(コンストラクタがどのよいうな引数も取らないならば、2番目の段階は省略して 3段階目の処理である <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_New" title="en/SpiderMonkey/JSAPI_Reference/JS_New">JS_New</a>(cx, constructor, 0, NULL)</code> を呼び出せます。)</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ + +jsval constructor_val; +JSObject *constructor; /* BUG - not rooted */ +JSString *name_str; +jsval argv[2]; /* BUG - not rooted */ +JSObject *obj; + +/* Step 1 - Get the value of |Person| and check that it is an object. */ +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_GetProperty">JS_GetProperty</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetGlobalObject" title="en/SpiderMonkey/JSAPI_Reference/JS_GetGlobalObject">JS_GetGlobalObject</a>(cx), "Person", &constructor_val)) + return JS_FALSE; +if (<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a>(constructor_val)) { + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_ReportError" title="en/SpiderMonkey/JSAPI_Reference/JS_ReportError">JS_ReportError</a>(cx, "Person is not a constructor"); + return JS_FALSE; +} +constructor = <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>(constructor_val); + +/* Step 2 - Set up the arguments. */ +name_str = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ" title="en/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ">JS_NewStringCopyZ</a>(cx, "Dave"); +if (!name_str) + return JS_FALSE; +argv[0] = <a href="/en/SpiderMonkey/JSAPI_Reference/STRING_TO_JSVAL" title="en/SpiderMonkey/JSAPI_Reference/STRING_TO_JSVAL">STRING_TO_JSVAL</a>(name_str); +argv[1] = <a href="/en/SpiderMonkey/JSAPI_Reference/INT_TO_JSVAL" title="en/SpiderMonkey/JSAPI_Reference/INT_TO_JSVAL">INT_TO_JSVAL</a>(24); + +/* Step 3 - Call |new Person(...argv)|, passing the arguments. */ +obj = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_New" title="en/SpiderMonkey/JSAPI_Reference/JS_New">JS_New</a>(cx, constructor, 2, argv); +if (!obj) + return JS_FALSE; +</pre> + +<h3 id="大域的なJS関数の呼び出し">大域的なJS関数の呼び出し</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var r = foo(); // where f is a global function +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> + * + * Suppose the script defines a global JavaScript + * function foo() and we want to call it from C. + */ +jsval r; +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName" title="en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName">JS_CallFunctionName</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetGlobalObject" title="en/SpiderMonkey/JSAPI_Reference/JS_GetGlobalObject">JS_GetGlobalObject</a>(cx), "foo", 0, NULL, &r)) + return JS_FALSE; +</pre> + +<h3 id="局所変数を投資てJS関数を呼び出す">局所変数を投資てJS関数を呼び出す</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var r = f(); // where f is a local variable +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> + * + * Suppose f is a local C variable of type jsval. + */ +jsval r; +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionValue" title="en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionValue">JS_CallFunctionValue</a>(cx, NULL, f, 0, NULL, &r) + return JS_FALSE; +</pre> + +<h3 id="Returning_an_integer" name="Returning_an_integer">整数の戻り値</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +return 23; +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> + * + * Warning: This only works for integers that fit in 32 bits. + * Otherwise, convert the number to floating point (see the next example). + */ +<a href="/en/SpiderMonkey/JSAPI_Reference/JS_SET_RVAL" title="en/SpiderMonkey/JSAPI_Reference/JS_SET_RVAL">JS_SET_RVAL</a>(cx, vp, <a href="/en/SpiderMonkey/JSAPI_Reference/INT_TO_JSVAL" title="en/SpiderMonkey/JSAPI_Reference/INT_TO_JSVAL">INT_TO_JSVAL</a>(23)); +return JS_TRUE; +</pre> + +<h3 id="Returning_a_floating-point_number" name="Returning_a_floating-point_number">浮動小数点少数の戻り値</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +return 3.14159; +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +<a href="/en/SpiderMonkey/JSAPI_Reference/jsdouble" title="en/SpiderMonkey/JSAPI_Reference/jsdouble">jsdouble</a> n = 3.14159; +return <a href="/en/SpiderMonkey/JSAPI_Reference/JS_NewNumberValue" title="en/SpiderMonkey/JSAPI_Reference/JS_NewNumberValue">JS_NewNumberValue</a>(cx, n, rval); +</pre> + +<h2 id="Exception_handling" name="Exception_handling">例外処理</h2> + +<h3 id="throw" name="throw"><code>throw</code></h3> + +<p>新規に最も共通の用語である <code>エラー</code> オブジェクトを生成した場合、それをハンドラに投げる場合 <a href="/en/SpiderMonkey/JSAPI_Reference/JS_ReportError" title="en/SpiderMonkey/JSAPI_Reference/JS_ReportError"><code>JS_ReportError</code></a> が処理を行います。 Note JavaScript の例外はC++の例外処理とは異なります。JSAPIコードでは呼び出し側に誤りを通知するために <code>JS_FALSE</code> を返す必要があります。</p> + +<pre class="notranslate">// <strong>JavaScript</strong> +throw new Error("Failed to grow " + varietal + ": too many greenflies."); +</pre> + +<pre class="notranslate">/* <strong>JSAPI</strong> */ +<a>JS_ReportError</a>(cx, "Failed to grow %s: too many greenflies.", varietal); +return JS_FALSE; +</pre> + +<p>エラーメッセージを他国間対応にするには、 <code>SyntaxError</code> や <code>TypeError</code>等のようにエラー種別を投げるように、 <a href="/en/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="en/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber"><code>JS_ReportErrorNumber</code></a> を代わりに用います。</p> + +<p>JavaScriptでは <code>Error</code> オブジェクトだけでなく、他の値を渡す事もサポートしています。 C/C++ から <code>jsval</code> という値を受け取るために<a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException"><code>JS_SetPendingException</code></a> を使います。</p> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +throw exc; +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +<a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException">JS_SetPendingException</a>(cx, exc); +return JS_FALSE; +</pre> + +<p><code>JS_ReportError</code> が新規に <code>Error</code> オブジェクトを生成するとき、現在実行中のスタックの先頭にあるJavaScriptコードの行の属性である <code>fileName</code> と <code>lineNumber</code> をセットします。 これは通常、あなたが本当に必要としているものとは一致しないネイティブ関数を呼び出したコードの行になります。JSAPIコードは直接 <code>Error</code> オブジェクトを生成し、コンストラクタに追加の引数を渡す事でことでこれを無視することができます:</p> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +throw new Error(message, filename, lineno); +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSBool ThrowError(JSContext *cx, JSObject *global, + const char *message, const char *filename, int32 lineno) +{ + JSString *messageStr; + JSString *filenameStr; + jsval args[3]; + jsval exc; + + messageStr = JS_NewStringCopyZ(cx, message); + if (!messageStr) + return JS_FALSE; + filenameStr = JS_NewStringCopyZ(cx, filename); + if (!filenameStr) + return JS_FALSE; + + args[0] = STRING_TO_JSVAL(messageStr); + args[1] = STRING_TO_JSVAL(filenameStr); + args[2] = INT_TO_JSVAL(lineno); + if (<a href="/en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName" title="en/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName">JS_CallFunctionName</a>(cx, global, "Error", 3, args, &exc)) + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_SetPendingException">JS_SetPendingException</a>(cx, exc); + return JS_FALSE; +} + +... + +return ThrowError(cx, global, message, __FILE__, __LINE__); +</pre> + +<p>ここのJSAPIコードは、<code>new</code> がJSAPIを用いて擬似的に作り出すことが難しいため、 <code>new</code> なしに <code>throw Error(message)</code> を擬似的に作り出します。この場合、スクリプトが <code>Error</code>を再定義しなければ、同じ事になります。</p> + +<h3 id="catch" name="catch"><code>catch</code></h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +try { + // try some stuff here; for example: + foo(); + bar(); +} catch (exc) { + // do error-handling stuff here +} +</pre> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ + jsval exc; + + /* try some stuff here; for example: */ + if (!JS_CallFunctionName(cx, global, "foo", 0, NULL, &r)) + goto catch_block; /* instead of returning JS_FALSE */ + if (!JS_CallFunctionName(cx, global, "bar", 0, NULL, &r)) + goto catch_block; /* instead of returning JS_FALSE */ + return JS_TRUE; + +catch_block: + if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_GetPendingException">JS_GetPendingException</a>(cx, &exc)) + return JS_FALSE; + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_ClearPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_ClearPendingException">JS_ClearPendingException</a>(cx); + /* do error-handling stuff here */ + return JS_TRUE; +</pre> + +<h3 id="finally" name="finally"><code>finally</code></h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +try { + foo(); + bar(); +} finally { + cleanup(); +} +</pre> + +<p>C/C++の浄化コードがJSAPI内にコールバックしなければ、処理は単純になります:</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ + <a href="/En/SpiderMonkey/JSAPI_Reference/JSBool" title="En/SpiderMonkey/JSAPI_Reference/JSBool">JSBool</a> success = JS_FALSE; + + if (!JS_CallFunctionName(cx, global, "foo", 0, NULL, &r)) + goto finally_block; /* instead of returning JS_FALSE immediately */ + if (!JS_CallFunctionName(cx, global, "bar", 0, NULL, &r)) + goto finally_block; + success = JS_TRUE; + /* Intentionally fall through to the finally block. */ + +finally_block: + cleanup(); + return success; +</pre> + +<p>しかしながら、 <code>cleanup()</code> が実際にJavaScriptの関数であれば、それらはcatchされます。エラーが発生したとき、 <code>JSContext</code><em>の例外処理の待機がセットされます。</em> これは上の例で <code>foo()</code> や <code>bar()</code> で発生するならば、待機中の例外処理は より悪い状態になるであろう <code>cleanup()</code> 処理を呼び出しているときにセットされます。これを避ける為に、JSAPIコードの実装では <code>finally</code> ブロックには以下のことが必要ですt:</p> + +<ul> + <li>古い例外を保存する</li> + <li>cleanupコードを走らせる為に、待機中の例外処理をクリアします</li> + <li>あなたのcleanup処理wp実行します</li> + <li>古い例外を復帰させます</li> + <li>例外が発生していたならば、例外処理を上位に伝えるために、JS_FALSEを戻り値として返します</li> +</ul> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ + <a href="/En/SpiderMonkey/JSAPI_Reference/JSBool" title="En/SpiderMonkey/JSAPI_Reference/JSBool">JSBool</a> success = JS_FALSE; + <a href="/en/SpiderMonkey/JSAPI_Reference/JSExceptionState" title="en/SpiderMonkey/JSAPI_Reference/JSExceptionState">JSExceptionState</a> *exc_state; + + if (!JS_CallFunctionName(cx, global, "foo", 0, NULL, &r)) + goto finally_block; /* instead of returning JS_FALSE immediately */ + if (!JS_CallFunctionName(cx, global, "bar", 0, NULL, &r)) + goto finally_block; + success = JS_TRUE; + /* Intentionally fall through to the finally block. */ + +finally_block: + exc_state = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SaveExceptionState" title="en/SpiderMonkey/JSAPI_Reference/JS_SaveExceptionState">JS_SaveExceptionState</a>(cx); + if (exc_state == NULL) + return JS_FALSE; + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_ClearPendingException" title="en/SpiderMonkey/JSAPI_Reference/JS_ClearPendingException">JS_ClearPendingException</a>(cx); + + if (!JS_CallFunctionName(cx, global, "cleanup", 0, NULL, &r)) { + /* The new error replaces the previous one, so discard the saved exception state. */ + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_DropExceptionState" title="en/SpiderMonkey/JSAPI_Reference/JS_DropExceptionState">JS_DropExceptionState</a>(cx, exc_state); + return JS_FALSE; + } + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_RestoreExceptionState" title="en/SpiderMonkey/JSAPI_Reference/JS_RestoreExceptionState">JS_RestoreExceptionState</a>(cx, exc_state); + return success; +</pre> + +<h2 id="Object_properties" name="Object_properties">オブジェクトの属性</h2> + +<h3 id="Getting_a_property" name="Getting_a_property">属性の取得</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +var x = y.myprop; +</pre> + +<p>JSAPI関数で、属性を取得する関数が <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_GetProperty">JS_GetProperty</a></code>です。<code>JSObject *</code> を引数として必要とします。 JavaScriptの値は、通常 <code>jsval</code> 変数に保存されるため、変数のキャストまたは変換が必要になります。</p> + +<p><code>y</code> (ブール値、数値、文字列、 <code>null</code>, または <code>undefined</code>などではなく)がオブジェクトであることが確実な場合、これは非常に単純です。 <code><a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a></code> を使い、 <code>y</code> を <code>JSObject *</code>の型にキャストします。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +jsval x; + +assert(<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">!JSVAL_IS_PRIMITIVE</a>(y)); +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_GetProperty">JS_GetProperty</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>(y), "myprop", &x)) + return JS_FALSE; +</pre> + +<p>もし <code>y</code> がオブジェクトでなければ、コードは壊れます。これはときに受け入れ難いことです。代替的にJavaScriptに振る舞いを擬似的に実行することになります。非常に良い考えですJavaScriptはクラッシュしません。しかし、その正確な振る舞いの実装では、非常に複雑なものになります。</p> + +<p>多くの実装では、特別に処理が扱いやすくなるわけではありません。通常、 <code>!<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a>(y)</code> を検査し、良いメッセージとともに <code>Error</code> を投げることが最良な処理です。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +jsval x; + +if (<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a>(y)) + return ThrowError(cx, global, "Parameter y must be an object.", __FILE__, __LINE__); /* see the <a href="#throw">#throw</a> example */ +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_GetProperty">JS_GetProperty</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>(y), "myprop", &x)) + return JS_FALSE; +</pre> + +<h3 id="Setting_a_property" name="Setting_a_property">属性の設定</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +y.myprop = x; +</pre> + +<p><code>y</code> がオブジェクトではない場合を懸念するならば、上述の属性の取得を参照して下さい。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +assert(!<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a>(y)); +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_SetProperty">JS_SetProperty</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>(y), "myprop", &x)) + return JS_FALSE; +</pre> + +<h3 id="Checking_for_a_property" name="Checking_for_a_property">属性の検査</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +if ("myprop" in y) { + // then do something +} +</pre> + +<p><code>y</code> がオブジェクトではない場合を懸念するならば、上述の属性の取得を参照して下さい。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSBool found; + +assert(!<a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a>(y)); +if (!<a href="/en/SpiderMonkey/JSAPI_Reference/JS_HasProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_HasProperty">JS_HasProperty</a>(cx, <a href="/en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="en/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>(y), "myprop", &found)) + return JS_FALSE; +if (found) { + // then do something +} +</pre> + +<h3 id="固定属性を定義する">固定属性を定義する</h3> + +<p>これはビルトイン関数 <code>Object.defineProperty()</code>に関わる最初の3つの例です。この関数は、オブジェクトの個別の属性の挙動に関してはっきりした操作をJavaScriptのコードに与えます。</p> + +<p>この関数を使って、上書きや削除できない固定属性を生成できます。<code>writable: false</code> によって属性を読み出し専用に作り、 <code>configurable: false</code> に設定して、再定義や削除されることから防ぎます。 フラグ <code>enumerable: true</code> は forループ内にあるときにこの属性が設定されます。</p> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +Object.defineProperty(obj, "prop", {value: 123, + writable: false, + enumerable: true, + configurable: false}); +</pre> + +<p>JSAPI関数の類似した関数に、 <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_DefineProperty" title="en/SpiderMonkey/JSAPI_Reference/JS_DefineProperty">JS_DefineProperty</a></code>があります。属性 <code>JSPROP_READONLY</code> を持っており、その属性は<code>writeable: false</code>に一致します。<code>JSPROP_ENUMERATE</code> は <code>enumerable: true</code>,に一致し、 <code>JSPROP_PERMANENT</code> は <code>configurable: false</code>にその属性が一致します。これらの設定の相対的な挙動を得るためには、必要ない属性のビットを単純に省いて下さい。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +if (!JS_DefineProperty(cx, obj, "prop", INT_TO_JSVAL(123), + JS_PropertyStub, JS_StrictPropertyStub, + JSPROP_READONLY | JSPROP_ENUMERATE | JSPROP_PERMANENT)) { + return JS_FALSE; +} +</pre> + +<h3 id="設定と取得の属性の定義">設定と取得の属性の定義</h3> + +<p><code>Object.defineProperty()</code> は二つのアクセス関数の属性を定義する為に用いることができます。</p> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +Object.defineProperty(obj, "prop", {get: GetPropFunc, + set: SetPropFunc, + enumerable: true}); +</pre> + +<p>JSAPIバージョンでは、 <code>GetPropFunc</code> と <code>SetPropFunc</code> が <a href="/en/SpiderMonkey/JSAPI_Reference/JSNative" title="en/SpiderMonkey/JSAPI_Reference/JSNative"><code>JSNative</code></a>型のC/C++ 関数関数として用意されています。of type .</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +if (!JS_DefineProperty(cx, obj, "prop", JSVAL_VOID, + (JSPropertyOp) GetPropFunc, (JSStrictPropertyOp) SetPropFunc, + JSPROP_SHARED | JSPROP_NATIVE_ACCESSORS | JSPROP_ENUMERATE)) { + return JS_FALSE; +} +</pre> + +<h3 id="取得のための呼び出し専用属性の定義">取得のための呼び出し専用属性の定義</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +Object.defineProperty(obj, "prop", {get: GetPropFunc, + enumerable: true}); +</pre> + +<p>JSAPIバージョン では、属性を読み出し専用に定義し、設定用にはNULLを通します。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +if (!JS_DefineProperty(cx, obj, "prop", JSVAL_VOID, + GetPropFunc, NULL, + JSPROP_SHARED | JSPROP_NATIVE_ACCESSORS | JSPROP_ENUMERATE)) { + return JS_FALSE; +} +</pre> + +<h2 id="Prototypes" name="Prototypes">プロトタイプチェインの働き</h2> + +<h3 id="String.prototypeにネイティブでは読み出し専用属性を定義します">String.prototypeにネイティブでは読み出し専用属性を定義します</h3> + +<pre class="eval notranslate">// <strong>JavaScript</strong> +Object.defineProperty(String.prototype, "md5sum", {get: GetMD5Func, + enumerable: true}); +</pre> + +<p>何かが大域的なStringオブジェクトを別な何かに取り替えるならば、以下のようなトリックは動作しません。</p> + +<pre class="eval notranslate">/* <strong>JSAPI</strong> */ +JSObject *string, *string_prototype; +jsval val; + +// Get the String constructor from the global object. +if (!JS_GetProperty(cx, global, "String", &val)) + return JS_FALSE; +if (JSVAL_IS_PRIMITIVE(val)) + return ThrowError(cx, global, "String is not an object", __FILE__, __LINE__); +string = JSVAL_TO_OBJECT(val); + +// Get String.prototype. +if (!JS_GetProperty(cx, string, "prototype", &val)) + return JS_FALSE; +if (JSVAL_IS_PRIMITIVE(val)) + return ThrowError(cx, global, "String.prototype is not an object", __FILE__, __LINE__); +string_prototype = JSVAL_TO_OBJECT(val); + +// ...and now we can add some new functionality to all strings. +if (!JS_DefineProperty(cx, string_prototype, "md5sum", JSVAL_VOID, GetMD5Func, NULL, + JSPROP_SHARED | JSPROP_NATIVE_ACCESSORS | JSPROP_ENUMERATE)) + return JS_FALSE; +</pre> + +<h2 id="Wanted" name="Wanted">Wanted</h2> + +<ul> + <li>Simulating <code>for</code> and <code>for each</code>.</li> + <li>Actually outputting errors.</li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/alphabetical_list/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/alphabetical_list/index.html new file mode 100644 index 0000000000..4bf1ac4123 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/alphabetical_list/index.html @@ -0,0 +1,228 @@ +--- +title: Alphabetical List +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/Alphabetical_List +tags: + - JSAPI_Reference + - SpiderMonkey +--- +<p>参照: <a href="/ja/docs/JSAPI_Reference">グループ別一覧</a>, <a href="/ja/docs/tag/JSAPI_Reference">カテゴリ表示 (自動)</a>.</p> +<ul> + <li><a href="/ja/docs/BOOLEAN_TO_JSVAL">BOOLEAN_TO_JSVAL</a></li> + <li><a href="/ja/docs/DOUBLE_TO_JSVAL">DOUBLE_TO_JSVAL</a></li> + <li><a href="/ja/docs/INT_FITS_IN_JSVAL">INT_FITS_IN_JSVAL</a></li> + <li><a href="/ja/docs/INT_TO_JSVAL">INT_TO_JSVAL</a></li> + <li><a href="/ja/docs/JS_AddNamedRoot">JS_AddNamedRoot</a></li> + <li><a href="/ja/docs/JS_AddRoot">JS_AddRoot</a></li> + <li><a href="/ja/docs/JS_AliasElement">JS_AliasElement</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_AliasProperty">JS_AliasProperty</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_BeginRequest">JS_BeginRequest</a></li> + <li><a href="/ja/docs/JS_CallFunction">JS_CallFunction</a></li> + <li><a href="/ja/docs/JS_CallFunctionName">JS_CallFunctionName</a></li> + <li><a href="/ja/docs/JS_CallFunctionValue">JS_CallFunctionValue</a></li> + <li><a href="/ja/docs/JS_CheckAccess">JS_CheckAccess</a></li> + <li><a href="/ja/docs/JS_ClearContextThread">JS_ClearContextThread</a></li> + <li><a href="/ja/docs/JS_ClearScope">JS_ClearScope</a></li> + <li><a href="/ja/docs/JS_CloneFunctionObject">JS_CloneFunctionObject</a></li> + <li><a href="/ja/docs/JS_CompareStrings">JS_CompareStrings</a></li> + <li><a href="/ja/docs/JS_CompileFile">JS_CompileFile</a></li> + <li><a href="/ja/docs/JS_CompileFunction">JS_CompileFunction</a></li> + <li><a href="/ja/docs/JS_CompileFunctionForPrincipals">JS_CompileFunctionForPrincipals</a></li> + <li><a href="/ja/docs/JS_CompileScript">JS_CompileScript</a></li> + <li><a href="/ja/docs/JS_CompileScriptForPrincipals">JS_CompileScriptForPrincipals</a></li> + <li><a href="/ja/docs/JS_CompileUCFunction">JS_CompileUCFunction</a></li> + <li><a href="/ja/docs/JS_CompileUCFunctionForPrincipals">JS_CompileUCFunctionForPrincipals</a></li> + <li><a href="/ja/docs/JS_CompileUCScript">JS_CompileUCScript</a></li> + <li><a href="/ja/docs/JS_CompileUCScriptForPrincipals">JS_CompileUCScriptForPrincipals</a></li> + <li><a href="/ja/docs/JS_ConstructObject">JS_ConstructObject</a></li> + <li><a href="/ja/docs/JS_ContextIterator">JS_ContextIterator</a></li> + <li><a href="/ja/docs/JS_ConvertArguments">JS_ConvertArguments</a></li> + <li><a href="/ja/docs/JS_ConvertStub">JS_ConvertStub</a></li> + <li><a href="/ja/docs/JS_ConvertValue">JS_ConvertValue</a></li> + <li><a href="/ja/docs/JS_DecompileFunction">JS_DecompileFunction</a></li> + <li><a href="/ja/docs/JS_DecompileFunctionBody">JS_DecompileFunctionBody</a></li> + <li><a href="/ja/docs/JS_DecompileScript">JS_DecompileScript</a></li> + <li><a href="/ja/docs/JS_DefineConstDoubles">JS_DefineConstDoubles</a></li> + <li><a href="/ja/docs/JS_DefineElement">JS_DefineElement</a></li> + <li><a href="/ja/docs/JS_DefineFunction">JS_DefineFunction</a></li> + <li><a href="/ja/docs/JS_DefineFunctions">JS_DefineFunctions</a></li> + <li><a href="/ja/docs/JS_DefineObject">JS_DefineObject</a></li> + <li><a href="/ja/docs/JS_DefineProperties">JS_DefineProperties</a></li> + <li><a href="/ja/docs/JS_DefineProperty">JS_DefineProperty</a></li> + <li><a href="/ja/docs/JS_DefinePropertyWithTinyId">JS_DefinePropertyWithTinyId</a></li> + <li><a href="/ja/docs/JS_DefineUCProperty">JS_DefineUCProperty</a></li> + <li><a href="/ja/docs/JS_DefineUCPropertyWithTinyID">JS_DefineUCPropertyWithTinyID</a></li> + <li><a href="/ja/docs/JS_DeleteElement">JS_DeleteElement</a></li> + <li><a href="/ja/docs/JS_DeleteElement2">JS_DeleteElement2</a></li> + <li><a href="/ja/docs/JS_DeleteProperty">JS_DeleteProperty</a></li> + <li><a href="/ja/docs/JS_DeleteProperty2">JS_DeleteProperty2</a></li> + <li><a href="/ja/docs/JS_DeleteUCProperty2">JS_DeleteUCProperty2</a></li> + <li><a href="/ja/docs/JS_DestroyContext">JS_DestroyContext</a></li> + <li><a href="/ja/docs/JS_DestroyIdArray">JS_DestroyIdArray</a></li> + <li><a href="/ja/docs/JS_DestroyRuntime">JS_DestroyRuntime</a></li> + <li><a href="/ja/docs/JS_DestroyScript">JS_DestroyScript</a></li> + <li><a href="/ja/docs/JS_DumpNamedRoots">JS_DumpNamedRoots</a></li> + <li><a href="/ja/docs/JS_EndRequest">JS_EndRequest</a></li> + <li><a href="/ja/docs/JS_Enumerate">JS_Enumerate</a></li> + <li><a href="/ja/docs/JS_EnumerateStub">JS_EnumerateStub</a></li> + <li><a href="/ja/docs/JS_EvaluateScript">JS_EvaluateScript</a></li> + <li><a href="/ja/docs/JS_EvaluateScriptForPrincipals">JS_EvaluateScriptForPrincipals</a></li> + <li><a href="/ja/docs/JS_EvaluateUCScript">JS_EvaluateUCScript</a></li> + <li><a href="/ja/docs/JS_EvaluateUCScriptForPrincipals">JS_EvaluateUCScriptForPrincipals</a></li> + <li><a href="/ja/docs/JS_ExecuteScript">JS_ExecuteScript</a></li> + <li><a href="/ja/docs/JS_FinalizeStub">JS_FinalizeStub</a></li> + <li><a href="/ja/docs/JS_Finish">JS_Finish</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_free">JS_free</a></li> + <li><a href="/ja/docs/JS_GC">JS_GC</a></li> + <li><a href="/ja/docs/JS_GetArrayLength">JS_GetArrayLength</a></li> + <li><a href="/ja/docs/JS_GetClass">JS_GetClass</a></li> + <li><a href="/ja/docs/JS_GetConstructor">JS_GetConstructor</a></li> + <li><a href="/ja/docs/JS_GetContextPrivate">JS_GetContextPrivate</a></li> + <li><a href="/ja/docs/JS_GetContextThread">JS_GetContextThread</a></li> + <li><a href="/ja/docs/JS_GetElement">JS_GetElement</a></li> + <li><a href="/ja/docs/JS_GetEmptyStringValue">JS_GetEmptyStringValue</a></li> + <li><a href="/ja/docs/JS_GetFunctionName">JS_GetFunctionName</a></li> + <li><a href="/ja/docs/JS_GetFunctionObject">JS_GetFunctionObject</a></li> + <li><a href="/ja/docs/JS_GetGlobalObject">JS_GetGlobalObject</a></li> + <li><a href="/ja/docs/JS_GetImplementationVersion">JS_GetImplementationVersion</a></li> + <li><a href="/ja/docs/JS_GetInstancePrivate">JS_GetInstancePrivate</a></li> + <li><a href="/ja/docs/JS_GetNaNValue">JS_GetNaNValue</a></li> + <li><a href="/ja/docs/JS_GetNegativeInfinityValue">JS_GetNegativeInfinityValue</a></li> + <li><a href="/ja/docs/JS_GetParent">JS_GetParent</a></li> + <li><a href="/ja/docs/JS_GetPositiveInfinityValue">JS_GetPositiveInfinityValue</a></li> + <li><a href="/ja/docs/JS_GetPrivate">JS_GetPrivate</a></li> + <li><a href="/ja/docs/JS_GetProperty">JS_GetProperty</a></li> + <li><a href="/ja/docs/JS_GetPropertyAttributes">JS_GetPropertyAttributes</a></li> + <li><a href="/ja/docs/JS_GetPrototype">JS_GetPrototype</a></li> + <li><a href="/ja/docs/JS_GetRuntime">JS_GetRuntime</a></li> + <li><a href="/ja/docs/JS_GetScopeChain">JS_GetScopeChain</a></li> + <li><a href="/ja/docs/JS_GetStringBytes">JS_GetStringBytes</a></li> + <li><a href="/ja/docs/JS_GetStringChars">JS_GetStringChars</a></li> + <li><a href="/ja/docs/JS_GetStringLength">JS_GetStringLength</a></li> + <li><a href="/ja/docs/JS_GetTypeName">JS_GetTypeName</a></li> + <li><a href="/ja/docs/JS_GetUCProperty">JS_GetUCProperty</a></li> + <li><a href="/ja/docs/JS_GetVersion">JS_GetVersion</a></li> + <li><a href="/ja/docs/JS_HasArrayLength">JS_HasArrayLength</a></li> + <li><a href="/ja/docs/JS_IdToValue">JS_IdToValue</a></li> + <li><a href="/ja/docs/JS_Init">JS_Init</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_InitClass">JS_InitClass</a></li> + <li><a href="/ja/docs/JS_InitStandardClasses">JS_InitStandardClasses</a></li> + <li><a href="/ja/docs/JS_InstanceOf">JS_InstanceOf</a></li> + <li><a href="/ja/docs/JS_InternString">JS_InternString</a></li> + <li><a href="/ja/docs/JS_InternUCString">JS_InternUCString</a></li> + <li><a href="/ja/docs/JS_InternUCStringN">JS_InternUCStringN</a></li> + <li><a href="/ja/docs/JS_IsArrayObject">JS_IsArrayObject</a></li> + <li><a href="/ja/docs/JS_IsConstructing">JS_IsConstructing</a></li> + <li><a href="/ja/docs/JS_IsRunning">JS_IsRunning</a></li> + <li><a href="/ja/docs/JS_Lock">JS_Lock</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_LockGCThing">JS_LockGCThing</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_LookupElement">JS_LookupElement</a></li> + <li><a href="/ja/docs/JS_LookupProperty">JS_LookupProperty</a></li> + <li><a href="/ja/docs/JS_LookupUCProperty">JS_LookupUCProperty</a></li> + <li><a href="/ja/docs/JS_malloc">JS_malloc</a></li> + <li><a href="/ja/docs/JS_MaybeGC">JS_MaybeGC</a></li> + <li><a href="/ja/docs/JS_NewArrayObject">JS_NewArrayObject</a></li> + <li><a href="/ja/docs/JS_NewContext">JS_NewContext</a></li> + <li><a href="/ja/docs/JS_NewDouble">JS_NewDouble</a></li> + <li><a href="/ja/docs/JS_NewDoubleValue">JS_NewDoubleValue</a></li> + <li><a href="/ja/docs/JS_NewFunction">JS_NewFunction</a></li> + <li><a href="/ja/docs/JS_NewIdArray">JS_NewIdArray</a></li> + <li><a href="/ja/docs/JS_NewNumberValue">JS_NewNumberValue</a></li> + <li><a href="/ja/docs/JS_NewObject">JS_NewObject</a></li> + <li><a href="/ja/docs/JS_NewRuntime">JS_NewRuntime</a></li> + <li><a href="/ja/docs/JS_NewScriptObject">JS_NewScriptObject</a></li> + <li><a href="/ja/docs/JS_NewString">JS_NewString</a></li> + <li><a href="/ja/docs/JS_NewStringCopyN">JS_NewStringCopyN</a></li> + <li><a href="/ja/docs/JS_NewStringCopyZ">JS_NewStringCopyZ</a></li> + <li><a href="/ja/docs/JS_NewUCString">JS_NewUCString</a></li> + <li><a href="/ja/docs/JS_NewUCStringCopyN">JS_NewUCStringCopyN</a></li> + <li><a href="/ja/docs/JS_NewUCStringCopyZ">JS_NewUCStringCopyZ</a></li> + <li><a href="/ja/docs/JS_ObjectIsFunction">JS_ObjectIsFunction</a></li> + <li><a href="/ja/docs/JS_PropertyStub">JS_PropertyStub</a></li> + <li><a href="/ja/docs/JS_realloc">JS_realloc</a></li> + <li><a href="/ja/docs/JS_RemoveRoot">JS_RemoveRoot</a></li> + <li><a href="/ja/docs/JS_ReportError">JS_ReportError</a></li> + <li><a href="/ja/docs/JS_ReportOutOfMemory">JS_ReportOutOfMemory</a></li> + <li><a href="/ja/docs/JS_ResolveStub">JS_ResolveStub</a></li> + <li><a href="/ja/docs/JS_ResumeRequest">JS_ResumeRequest</a></li> + <li><a href="/ja/docs/JS_SetArrayLength">JS_SetArrayLength</a></li> + <li><a href="/ja/docs/JS_SetBranchCallback">JS_SetBranchCallback</a></li> + <li><a href="/ja/docs/JS_SetContextPrivate">JS_SetContextPrivate</a></li> + <li><a href="/ja/docs/JS_SetContextThread">JS_SetContextThread</a></li> + <li><a href="/ja/docs/JS_SetElement">JS_SetElement</a></li> + <li><a href="/ja/docs/JS_SetErrorReporter">JS_SetErrorReporter</a></li> + <li><a href="/ja/docs/JS_SetGCCallback">JS_SetGCCallback</a></li> + <li><a href="/ja/docs/JS_SetGlobalObject">JS_SetGlobalObject</a></li> + <li><a href="/ja/docs/JS_SetParent">JS_SetParent</a></li> + <li><a href="/ja/docs/JS_SetPrivate">JS_SetPrivate</a></li> + <li><a href="/ja/docs/JS_SetProperty">JS_SetProperty</a></li> + <li><a href="/ja/docs/JS_SetPropertyAttributes">JS_SetPropertyAttributes</a></li> + <li><a href="/ja/docs/JS_SetPrototype">JS_SetPrototype</a></li> + <li><a href="/ja/docs/JS_SetUCProperty">JS_SetUCProperty</a></li> + <li><a href="/ja/docs/JS_SetVersion">JS_SetVersion</a></li> + <li><a href="/ja/docs/JS_strdup">JS_strdup</a></li> + <li><a href="/ja/docs/JS_SuspendRequest">JS_SuspendRequest</a></li> + <li><a href="/ja/docs/JS_TypeOfValue">JS_TypeOfValue</a></li> + <li><a href="/ja/docs/JS_Unlock">JS_Unlock</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_UnlockGCThing">JS_UnlockGCThing</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JS_ValueToBoolean">JS_ValueToBoolean</a></li> + <li><a href="/ja/docs/JS_ValueToECMAInt32">JS_ValueToECMAInt32</a></li> + <li><a href="/ja/docs/JS_ValueToECMAUint32">JS_ValueToECMAUint32</a></li> + <li><a href="/ja/docs/JS_ValueToFunction">JS_ValueToFunction</a></li> + <li><a href="/ja/docs/JS_ValueToId">JS_ValueToId</a></li> + <li><a href="/ja/docs/JS_ValueToInt32">JS_ValueToInt32</a></li> + <li><a href="/ja/docs/JS_ValueToNumber">JS_ValueToNumber</a></li> + <li><a href="/ja/docs/JS_ValueToObject">JS_ValueToObject</a></li> + <li><a href="/ja/docs/JS_ValueToString">JS_ValueToString</a></li> + <li><a href="/ja/docs/JS_ValueToUint16">JS_ValueToUint16</a></li> + <li><a href="/ja/docs/JSCLASS_HAS_PRIVATE">JSCLASS_HAS_PRIVATE</a></li> + <li><a href="/ja/docs/JSCLASS_NEW_ENUMERATE">JSCLASS_NEW_ENUMERATE</a></li> + <li><a href="/ja/docs/JSCLASS_NEW_RESOLVE">JSCLASS_NEW_RESOLVE</a></li> + <li><a href="/ja/docs/JSClass">JSClass</a></li> + <li><a href="/ja/docs/JSConstDoubleSpec">JSConstDoubleSpec</a></li> + <li><a href="/ja/docs/JSErrorReport">JSErrorReport</a></li> + <li><a href="/ja/docs/JSFUN_BOUND_METHOD">JSFUN_BOUND_METHOD</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JSFUN_GLOBAL_PARENT">JSFUN_GLOBAL_PARENT</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JSFunctionSpec">JSFunctionSpec</a></li> + <li><a href="/ja/docs/JSIdArray">JSIdArray</a></li> + <li><a href="/ja/docs/JSObjectOps">JSObjectOps</a></li> + <li><a href="/ja/docs/JSPRINCIPALS_DROP">JSPRINCIPALS_DROP</a></li> + <li><a href="/ja/docs/JSPRINCIPALS_HOLD">JSPRINCIPALS_HOLD</a></li> + <li><a href="/ja/docs/JSPrincipals">JSPrincipals</a></li> + <li><a href="/ja/docs/JSPROP_ENUMERATE">JSPROP_ENUMERATE</a></li> + <li><a href="/ja/docs/JSPROP_EXPORTED">JSPROP_EXPORTED</a></li> + <li><a href="/ja/docs/JSPROP_INDEX">JSPROP_INDEX</a></li> + <li><a href="/ja/docs/JSPROP_PERMANENT">JSPROP_PERMANENT</a></li> + <li><a href="/ja/docs/JSPROP_READONLY">JSPROP_READONLY</a></li> + <li><a href="/ja/docs/JSProperty">JSProperty</a></li> + <li><a href="/ja/docs/JSPropertySpec">JSPropertySpec</a></li> + <li><a href="/ja/docs/JSRESOLVE_ASSIGNING">JSRESOLVE_ASSIGNING</a></li> + <li><a href="/ja/docs/JSRESOLVE_QUALIFIED">JSRESOLVE_QUALIFIED</a></li> + <li><a href="/ja/docs/JSVAL_FALSE">JSVAL_FALSE</a></li> + <li><a href="/ja/docs/JSVAL_IS_BOOLEAN">JSVAL_IS_BOOLEAN</a></li> + <li><a href="/ja/docs/JSVAL_IS_DOUBLE">JSVAL_IS_DOUBLE</a></li> + <li><a href="/ja/docs/JSVAL_IS_GCTHING">JSVAL_IS_GCTHING</a></li> + <li><a href="/ja/docs/JSVAL_IS_INT">JSVAL_IS_INT</a></li> + <li><a href="/ja/docs/JSVAL_IS_NULL">JSVAL_IS_NULL</a></li> + <li><a href="/ja/docs/JSVAL_IS_NUMBER">JSVAL_IS_NUMBER</a></li> + <li><a href="/ja/docs/JSVAL_IS_OBJECT">JSVAL_IS_OBJECT</a></li> + <li><a href="/ja/docs/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a></li> + <li><a href="/ja/docs/JSVAL_IS_STRING">JSVAL_IS_STRING</a></li> + <li><a href="/ja/docs/JSVAL_IS_VOID">JSVAL_IS_VOID</a></li> + <li><a href="/ja/docs/JSVAL_LOCK">JSVAL_LOCK</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JSVAL_NULL">JSVAL_NULL</a></li> + <li><a href="/ja/docs/JSVAL_ONE">JSVAL_ONE</a></li> + <li><a href="/ja/docs/JSVAL_TO_BOOLEAN">JSVAL_TO_BOOLEAN</a></li> + <li><a href="/ja/docs/JSVAL_TO_DOUBLE">JSVAL_TO_DOUBLE</a></li> + <li><a href="/ja/docs/JSVAL_TO_GCTHING">JSVAL_TO_GCTHING</a></li> + <li><a href="/ja/docs/JSVAL_TO_INT">JSVAL_TO_INT</a></li> + <li><a href="/ja/docs/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a></li> + <li><a href="/ja/docs/JSVAL_TO_PRIVATE">JSVAL_TO_PRIVATE</a></li> + <li><a href="/ja/docs/JSVAL_TO_STRING">JSVAL_TO_STRING</a></li> + <li><a href="/ja/docs/JSVAL_TRUE">JSVAL_TRUE</a></li> + <li><a href="/ja/docs/JSVAL_UNLOCK">JSVAL_UNLOCK</a> - <small><span style="background-color: red; padding: .1em .5em;">非推奨</span></small></li> + <li><a href="/ja/docs/JSVAL_VOID">JSVAL_VOID</a></li> + <li><a href="/ja/docs/JSVAL_ZERO">JSVAL_ZERO</a></li> + <li><a href="/ja/docs/OBJECT_TO_JSVAL">OBJECT_TO_JSVAL</a></li> + <li><a href="/ja/docs/PRIVATE_TO_JSVAL">PRIVATE_TO_JSVAL</a></li> + <li><a href="/ja/docs/STRING_TO_JSVAL">STRING_TO_JSVAL</a></li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/index.html new file mode 100644 index 0000000000..5bb96c5566 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/index.html @@ -0,0 +1,926 @@ +--- +title: JSAPI リファレンス +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference +tags: + - JSAPI_Reference + - JavaScript + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference +--- +<section class="Quick_links" id="Quick_Links"> + <ol> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey"><strong><em>SpiderMonkey</em></strong></a></li> + + <li><strong>References:</strong></li> + <li class="toggle"> + <details> + <summary>JSAPI reference</summary> + <ol><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/Alphabetical_List" title="参照: グループ別一覧, カテゴリ表示 (自動)."><code>Alphabetical List</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/Alphabetical_List$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_CompileFile" title=""><code>JS CompileFile</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_CompileFile$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ConstructObject" title="新たにJavaScriptオブジェクトを生成し、コンストラクタを呼び出します。 Create a new JavaScript object and invoke its constructor."><code>JS ConstructObject</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ConstructObject$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyContext" title=""><code>JS DestroyContext</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyContext$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyRuntime" title=""><code>JS DestroyRuntime</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyRuntime$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_EvaluateScript" title=""><code>JS EvaluateScript</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_EvaluateScript$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntime" title=""><code>JS GetRuntime</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntime$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntimePrivate" title=""><code>JS GetRuntimePrivate</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntimePrivate$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewContext" title=""><code>JS NewContext</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewContext$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewRuntime" title="JavaScript ランタイムの初期化を行います。 "><code>JS NewRuntime</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewRuntime$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ShutDown" title=""><code>JS ShutDown</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ShutDown$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSRuntime" title=""><code>JSRuntime</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSRuntime$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSType" title="列挙型 JSType の値は、 JavaScript の値の型を表します。"><code>JSType</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSType$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DefineObject" title=""><code>JS_DefineObject</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DefineObject$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Init" title="JS_Init は廃止されました。替わりに JS_NewRuntime を使用して下さい。"><code>JS_Init</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Init$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Lock" title="JS ランタイム環境をロックします。"><code>JS_Lock</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Lock$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewObject" title=""><code>JS_NewObject</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewObject$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/jsint" title="C 言語 / C++ の整数型のエイリアスです。"><code>jsint</code></a> <a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_reference/jsint$translate" style="opacity: 0.5;" title="まだボランティアによって日本語に翻訳されていない記事です。MDNに参加して、翻訳してみませんか?">[翻訳する]</a></li></ol> + </details> + </li> + <li class="toggle"> + <details> + <summary>Debugger-API</summary> + <ol><li><a href="/ja/docs/Tools/Debugger-API/Debugger">Debugger</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Environment">Debugger.Environment</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Frame">Debugger.Frame</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Memory">Debugger.Memory</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Object">Debugger.Object</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Script">Debugger.Script</a></li><li><a href="/ja/docs/Tools/Debugger-API/Debugger.Source">Debugger.Source</a></li><li><a href="/ja/docs/Tools/Debugger-API/Tutorial-Debugger-Statement">Tools/Debugger-API/Tutorial-Debugger-Statement</a></li><li><a href="/ja/docs/Tools/Debugger-API/Tutorial-Breakpoint">チュートリアル: Debuggerを使用したブレークポイントの設定</a></li><li><a href="/ja/docs/Tools/Debugger-API/Tutorial-Allocation-Log-Tree">チュートリアル: コールパスごとの割り当てを表示する</a></li><li><a href="/ja/docs/Tools/Debugger-API/Conventions">一般的な規則</a></li></ol> + </details> + </li> + <li><strong>Guides:</strong></li> + <li class="toggle"> + <details> + <summary>General</summary> + <ol> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation">Build documentation</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell">Introduction to the JavaScript shell</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide">JSAPI user guide</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/JSAPI_Cookbook">JSAPI cookbook</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/How_to_embed_the_JavaScript_engine">How to embed the JavaScript engine</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/GC_Rooting_Guide">GC Rooting Guide</a></li> + </ol> + </details> + </li> + <li class="toggle"> + <details> + <summary>SpiderMonkey internals</summary> + <ol><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Internals/Garbage_collection">Garbage collection</a></li><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Internals/Thread_Safety">Thread Safety</a></li></ol> + </details> + </li> + + <li><strong>Contributing to SpiderMonkey:</strong></li> + <li class="toggle"> + <details> + <summary>Getting started</summary> + <ol> + <li><a href="https://wiki.mozilla.org/JavaScript:New_to_SpiderMonkey">New to SpiderMonkey</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Setting_up_CDT_to_work_on_SpiderMonkey">Setting up CDT to work on SpiderMonkey</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Hacking_Tips">Hacking tips</a></li> + </ol> + </details> + </li> + <li class="toggle"> + <details> + <summary>Tests</summary> + <ol> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Running_Automated_JavaScript_Tests">Running Automated JavaScript Tests</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Creating_JavaScript_tests">Creating JavaScript tests</a></li> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Running_Parsemark">Running Parsemark</a></li> + </ol> + </details> + </li> + + <li><strong>Releases:</strong></li> + <li class="toggle"> + <details> + <summary>Release notes</summary> + <ol><li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Releases/52">SpiderMonkey 52</a></li></ol> + </details> + </li> + <li><strong><a href="/ja/docs/MDN">Documentation:</a></strong></li> + <li class="toggle"> + <details> + <summary>Useful lists</summary> + <ol> + <li><a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Index">All pages index</a></li> + <li><a href="/ja/docs/tag/SpiderMonkey">Pages tagged "SpiderMonkey"</a></li> + </ol> + </details> + </li> + <li class="toggle"> + <details> + <summary>Contribute</summary> + <ol> + <li><a href="/ja/docs/MDN/Doc_status/SpiderMonkey">SpiderMonkey doc status</a></li> + <li><a href="/ja/docs/MDN">The MDN project</a></li> + </ol> + </details> + </li> + </ol> +</section> + +<p><strong>JSAPI</strong> は、<a href="/ja/SpiderMonkey" title="ja/SpiderMonkey">SpiderMonkey</a> JavaScript エンジンのための C API です。JSAPI の使用方法を学ぶには、<a href="/ja/SpiderMonkey/Embedding_SpiderMonkey" title="ja/SpiderMonkey/Embedding_SpiderMonkey">JSAPI User Guide</a> および <a href="/ja/SpiderMonkey/JSAPI_Phrasebook" title="ja/SpiderMonkey/JSAPI_Phrasebook">JSAPI Phrasebook</a> をご覧ください。</p> + +<div class="note">補足: <a class="internal" href="/ja/SpiderMonkey/FOSS" title="ja/SpiderMonkey/FOSS">FOSS</a> のページに、Spidermonkey と JASPI の使用を助ける、他のライブラリやプログラムへのリンクがあります。</div> + +<p><a href="/ja/SpiderMonkey/JSAPI_Reference/Alphabetical_List" title="ja/SpiderMonkey/JSAPI_Reference/Alphabetical_List">アルファベット順一覧</a></p> + +<p><span id="Runtimes_and_contexts"></span></p> + +<h3 id="Runtimes_and_contexts" name="Runtimes_and_contexts">ランタイムとコンテキスト</h3> + +<ul> + <li>typedef <a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a></li> + <li><a href="/ja/JS_NewRuntime" title="ja/JS_NewRuntime">JS_NewRuntime</a></li> + <li><a href="/ja/JS_DestroyRuntime" title="ja/JS_DestroyRuntime">JS_DestroyRuntime</a></li> + <li><a href="/ja/JS_ShutDown" title="ja/JS_ShutDown">JS_ShutDown</a></li> + <li><a href="/ja/JS_GetRuntimePrivate" title="ja/JS_GetRuntimePrivate">JS_GetRuntimePrivate</a></li> + <li><a href="/ja/JS_GetRuntimePrivate" title="ja/JS_GetRuntimePrivate">JS_SetRuntimePrivate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Init" title="ja/JS_Init">JS_Init</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Finish" title="ja/JS_Finish">JS_Finish</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ContextIterator" title="ja/JS_ContextIterator">JS_ContextIterator</a></li> +</ul> + +<ul> + <li>typedef <a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a></li> + <li><a href="/ja/JS_NewContext" title="ja/JS_NewContext">JS_NewContext</a></li> + <li><a href="/ja/JS_DestroyContext" title="ja/JS_DestroyContext">JS_DestroyContext</a></li> + <li><a href="/ja/JS_DestroyContext" title="ja/JS_DestroyContext">JS_DestroyContextMaybeGC</a></li> + <li><a href="/ja/JS_DestroyContext" title="ja/JS_DestroyContext">JS_DestroyContextNoGC</a></li> + <li><a href="/ja/JS_GetRuntime" title="ja/JS_GetRuntime">JS_GetRuntime</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetContextPrivate" title="ja/JS_GetContextPrivate">JS_GetContextPrivate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetContextPrivate" title="ja/JS_GetContextPrivate">JS_SetContextPrivate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetOptions" title="ja/JS_GetOptions">JS_GetOptions</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JS_SetOptions</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_ATLINE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_COMPILE_N_GO</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_DONT_REPORT_UNCAUGHT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_NATIVE_BRANCH_CALLBACK</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JSOPTION_RELIMIT">JSOPTION_RELIMIT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_STRICT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_VAROBJFIX</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_WERROR</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_XML</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_ANONFUNFIX</a><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8.1_(未リリース)">SpiderMonkey 1.8.1 (未リリース)</a> の新機能</span>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_JIT</a><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8.1_(未リリース)">SpiderMonkey 1.8.1 (未リリース)</a> の新機能</span>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_NO_SCRIPT_RVAL</a><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8.1_(未リリース)">SpiderMonkey 1.8.1 (未リリース)</a> の新機能</span>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOptions" title="ja/JS_SetOptions">JSOPTION_UNROOTED_GLOBAL</a><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8.1_(未リリース)">SpiderMonkey 1.8.1 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ToggleOptions" title="ja/JS_ToggleOptions">JS_ToggleOptions</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetBranchCallback" title="ja/JS_SetBranchCallback">JS_SetBranchCallback</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_SetOperationCallback</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_ClearOperationCallback</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_GetOperationCallback</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_GetOperationLimit</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_SetOperationLimit</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_MAX_OPERATION_LIMIT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="ja/JS_SetOperationCallback">JS_OPERATION_WEIGHT_BASE</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetThreadStackLimit" title="ja/JS_SetThreadStackLimit">JS_SetThreadStackLimit</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetScriptStackQuota" title="ja/JS_SetScriptStackQuota">JS_SetScriptStackQuota</a></li> +</ul> + +<ul> + <li>enum <a href="/ja/SpiderMonkey/JSAPI_Reference/JSVersion" title="ja/JSVersion">JSVersion</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSVersion" title="ja/SpiderMonkey/JSAPI_Reference/JSVERSION_ECMA_3">JSVERSION_ECMA_3</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSVERSION_DEFAULT" title="ja/JSVERSION_DEFAULT">JSVERSION_DEFAULT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSVERSION_LATEST" title="ja/JSVERSION_LATEST">JSVERSION_LATEST</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetImplementationVersion" title="ja/JS_GetImplementationVersion">JS_GetImplementationVersion</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetVersion" title="ja/JS_GetVersion">JS_GetVersion</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetVersion" title="ja/JS_SetVersion">JS_SetVersion</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_StringToVersion" title="ja/JS_StringToVersion">JS_StringToVersion</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_VersionToString" title="ja/JS_VersionToString">JS_VersionToString</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGlobalObject" title="ja/JS_GetGlobalObject">JS_GetGlobalObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGlobalObject" title="ja/JS_SetGlobalObject">JS_SetGlobalObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InitClass" title="ja/JS_InitClass">JS_InitClass</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InitStandardClasses" title="ja/JS_InitStandardClasses">JS_InitStandardClasses</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ResolveStandardClass" title="ja/JS_ResolveStandardClass">JS_ResolveStandardClass</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EnumerateStandardClasses" title="ja/JS_EnumerateStandardClasses">JS_EnumerateStandardClasses</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EnumerateResolvedStandardClasses" title="ja/JS_EnumerateResolvedStandardClasses">JS_EnumerateResolvedStandardClasses</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IsAssigning" title="ja/JS_IsAssigning">JS_IsAssigning</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IsConstructing" title="ja/JS_IsConstructing">JS_IsConstructing</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IsRunning" title="ja/JS_IsRunning">JS_IsRunning</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetScopeChain" title="ja/JS_GetScopeChain">JS_GetScopeChain</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SaveFrameChain" title="ja/JS_SaveFrameChain">JS_SaveFrameChain</a>, <a href="/en/JS_RestoreFrameChain" title="en/JS_RestoreFrameChain">JS_RestoreFrameChain</a></li> +</ul> + +<p>ロケールコールバック:</p> + +<ul> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSLocaleCallbacks" title="ja/JSLocaleCallbacks">JSLocaleCallbacks</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetLocaleCallbacks" title="ja/JS_GetLocaleCallbacks">JS_GetLocaleCallbacks</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetLocaleCallbacks" title="ja/JS_SetLocaleCallbacks">JS_SetLocaleCallbacks</a></li> +</ul> + +<p>ロケールコールバック型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSLocaleToUpperCase" title="ja/JSLocaleToUpperCase">JSLocaleToUpperCase</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSLocaleToLowerCase" title="ja/JSLocaleToLowerCase">JSLocaleToLowerCase</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSLocaleCompare" title="ja/JSLocaleCompare">JSLocaleCompare</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSLocaleToUnicode" title="ja/JSLocaleToUnicode">JSLocaleToUnicode</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JSErrorCallback</a></li> +</ul> + +<p><span id="Scripts"></span></p> + +<h3 id="Scripts" name="Scripts">スクリプト</h3> + +<p>一部の JavaScript コードは直接実行されます:</p> + +<ul> + <li><a href="/ja/JS_EvaluateScript" title="ja/JS_EvaluateScript">JS_EvaluateScript</a></li> + <li><a href="/ja/JS_EvaluateScript" title="ja/JS_EvaluateScript">JS_EvaluateUCScript</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EvaluateScriptForPrincipals" title="ja/JS_EvaluateScriptForPrincipals">JS_EvaluateScriptForPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EvaluateScriptForPrincipals" title="ja/JS_EvaluateScriptForPrincipals">JS_EvaluateUCScriptForPrincipals</a></li> +</ul> + +<p>JavaScript コードを可能な <code>JSScript</code> へとコンパイルする代わりに、複数のアイテムを実行することができます。</p> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/JSScript" title="ja/JSScript">JSScript</a></li> + <li><a href="/ja/JS_CompileFile" title="ja/JS_CompileFile">JS_CompileFile</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFileHandle" title="ja/JS_CompileFileHandle">JS_CompileFileHandle</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFileHandle" title="ja/JS_CompileFileHandle">JS_CompileFileHandleForPrincipals</a></li> + <li><a href="/ja/JS_CompileScript" title="ja/JS_CompileScript">JS_CompileScript</a></li> + <li><a href="/ja/JS_CompileScript" title="ja/JS_CompileScript">JS_CompileUCScript</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileScriptForPrincipals" title="ja/JS_CompileScriptForPrincipals">JS_CompileScriptForPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileScriptForPrincipals" title="ja/JS_CompileScriptForPrincipals">JS_CompileUCScriptForPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_BufferIsCompilableUnit" title="ja/JS_BufferIsCompilableUnit">JS_BufferIsCompilableUnit</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetScriptObject" title="ja/JS_GetScriptObject">JS_GetScriptObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewScriptObject" title="ja/JS_NewScriptObject">JS_NewScriptObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ExecuteScript" title="ja/JS_ExecuteScript">JS_ExecuteScript</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ExecuteScriptPart" title="ja/JS_ExecuteScriptPart">JS_ExecuteScriptPart</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DecompileScript" title="ja/JS_DecompileScript">JS_DecompileScript</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DestroyScript" title="ja/JS_DestroyScript">JS_DestroyScript</a></li> +</ul> + +<p>JavaScript コードを関数へとコンパイルすることもできます:</p> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/JSFunction" title="ja/JSFunction">JSFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFunction" title="ja/JS_CompileFunction">JS_CompileFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFunctionForPrincipals" title="ja/JS_CompileFunctionForPrincipals">JS_CompileFunctionForPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFunction" title="ja/JS_CompileFunction">JS_CompileUCFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompileFunctionForPrincipals" title="ja/JS_CompileFunctionForPrincipals">JS_CompileUCFunctionForPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DecompileFunction" title="ja/JS_DecompileFunction">JS_DecompileFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DecompileFunctionBody" title="ja/JS_DecompileFunctionBody">JS_DecompileFunctionBody</a></li> +</ul> + +<p><span id="Error_handling"></span></p> + +<h3 id="Error_handling" name="Error_handling">エラーハンドリング</h3> + +<ul> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSErrorReport" title="ja/JSErrorReport">JSErrorReport</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportError" title="ja/JS_ReportError">JS_ReportError</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportWarning" title="ja/JS_ReportWarning">JS_ReportWarning</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JS_ReportErrorNumber</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JS_ReportErrorNumberUC</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JS_ReportErrorFlagsAndNumber</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JS_ReportErrorFlagsAndNumberUC</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportOutOfMemory" title="ja/JS_ReportOutOfMemory">JS_ReportOutOfMemory</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetErrorReporter" title="ja/JS_SetErrorReporter">JS_SetErrorReporter</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSREPORT_IS_EXCEPTION" title="ja/JSREPORT_IS_EXCEPTION">JSREPORT_IS_EXCEPTION</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSREPORT_IS_STRICT" title="ja/JSREPORT_IS_STRICT">JSREPORT_IS_STRICT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSREPORT_IS_WARNING" title="ja/JSREPORT_IS_WARNING">JSREPORT_IS_WARNING</a></li> +</ul> + +<p>次の関数は、C/C++ 関数に JavaScript 例外のスローとキャッチを許可します。:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IsExceptionPending" title="ja/JS_IsExceptionPending">JS_IsExceptionPending</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPendingException" title="ja/JS_GetPendingException">JS_GetPendingException</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPendingException" title="ja/JS_SetPendingException">JS_SetPendingException</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearPendingException" title="ja/JS_ClearPendingException">JS_ClearPendingException</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ThrowStopIteration" title="ja/JS_ThrowStopIteration">JS_ThrowStopIteration</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></li> +</ul> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/JSExceptionState" title="ja/JSExceptionState">JSExceptionState</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SaveExceptionState" title="ja/JS_SaveExceptionState">JS_SaveExceptionState</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_RestoreExceptionState" title="ja/JS_RestoreExceptionState">JS_RestoreExceptionState</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DropExceptionState" title="ja/JS_DropExceptionState">JS_DropExceptionState</a></li> +</ul> + +<p>これらの関数は、エラーを例外に、例外をエラーに翻訳します:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportPendingException" title="ja/JS_ReportPendingException">JS_ReportPendingException</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ErrorFromException" title="ja/JS_ErrorFromException">JS_ErrorFromException</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ThrowReportedError" title="ja/JS_ThrowReportedError">JS_ThrowReportedError</a></li> +</ul> + +<p><span id="Values_and_types"></span></p> + +<h3 id="Values_and_types" name="Values_and_types">値と型</h3> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/Jsval" title="ja/jsval">jsval</a></li> +</ul> + +<p><code>jsval</code> 定数:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_NULL" title="ja/JSVAL_NULL">JSVAL_NULL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_VOID" title="ja/JSVAL_VOID">JSVAL_VOID</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TRUE" title="ja/JSVAL_TRUE">JSVAL_TRUE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TRUE" title="ja/JSVAL_TRUE">JSVAL_FALSE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_ZERO" title="ja/JSVAL_ZERO">JSVAL_ZERO</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_ONE" title="ja/JSVAL_ONE">JSVAL_ONE</a></li> +</ul> + +<p><code>jsval</code> の型をチェックする関数とマクロ:</p> + +<ul> + <li>enum <a href="/ja/SpiderMonkey/JSAPI_Reference/JSType" title="ja/JSType">JSType</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_TypeOfValue" title="ja/JS_TypeOfValue">JS_TypeOfValue</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_NULL" title="ja/JSVAL_IS_NULL">JSVAL_IS_NULL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_VOID" title="ja/JSVAL_IS_VOID">JSVAL_IS_VOID</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_BOOLEAN" title="ja/JSVAL_IS_BOOLEAN">JSVAL_IS_BOOLEAN</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_NUMBER" title="ja/JSVAL_IS_NUMBER">JSVAL_IS_NUMBER</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_INT" title="ja/JSVAL_IS_INT">JSVAL_IS_INT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_DOUBLE" title="ja/JSVAL_IS_DOUBLE">JSVAL_IS_DOUBLE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_STRING" title="ja/JSVAL_IS_STRING">JSVAL_IS_STRING</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_OBJECT" title="ja/JSVAL_IS_OBJECT">JSVAL_IS_OBJECT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_PRIMITIVE" title="ja/JSVAL_IS_PRIMITIVE">JSVAL_IS_PRIMITIVE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_IS_GCTHING" title="ja/JSVAL_IS_GCTHING">JSVAL_IS_GCTHING</a></li> +</ul> + +<p>関数の引数を圧縮または展開する高レベル型変換ルーチン。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PushArguments" title="ja/JS_PushArguments">JS_PushArguments</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PushArguments" title="ja/JS_PushArguments">JS_PushArgumentsVA</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PopArguments" title="ja/JS_PopArguments">JS_PopArguments</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ConvertArguments" title="ja/JS_ConvertArguments">JS_ConvertArguments</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ConvertArgumentsVA" title="ja/JS_ConvertArgumentsVA">JS_ConvertArgumentsVA</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddArgumentFormatter" title="ja/JS_AddArgumentFormatter">JS_AddArgumentFormatter</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddArgumentFormatter" title="ja/JS_AddArgumentFormatter">JS_RemoveArgumentFormatter</a></li> +</ul> + +<p>次の関数は JS 値を変数型に変換します。これらは任意の型の <code>jsval</code> に安全に適用することができます。これらは新しいオブジェクトを返します。例えば、<code>JS_ValueToObject(cx, s)</code> の <code>s</code> は新しい <code>String</code> ラッパーオブジェクトを作成する文字列です。これらの関数は JavaScript メソッドを呼び出します。例えば、<code>JS_ValueToString(cx, obj)</code> は <code>obj.toString()</code> を呼び出します。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToBoolean" title="ja/JS_ValueToBoolean">JS_ValueToBoolean</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToConstructor" title="ja/JS_ValueToConstructor">JS_ValueToConstructor</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToECMAInt32" title="ja/JS_ValueToECMAInt32">JS_ValueToECMAInt32</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToECMAInt32" title="ja/JS_ValueToECMAInt32">JS_ValueToECMAUint32</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToFunction" title="ja/JS_ValueToFunction">JS_ValueToFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToInt32" title="ja/JS_ValueToInt32">JS_ValueToInt32</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToNumber" title="ja/JS_ValueToNumber">JS_ValueToNumber</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToObject" title="ja/JS_ValueToObject">JS_ValueToObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToString" title="ja/JS_ValueToString">JS_ValueToString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToECMAInt32" title="ja/JS_ValueToECMAInt32">JS_ValueToUint16</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ConvertValue" title="ja/JS_ConvertValue">JS_ConvertValue</a></li> +</ul> + +<p>高速な未チェックの型キャストマクロ。これらのマクロは正しい型として知られていない値に適用してはいけません。C のキャストのように、正しくない値に適用するとクラッシュの原因となります。これらは新しいオブジェクトを作成したり JavaScript コード内に呼び出したりすることはありません。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_BOOLEAN" title="ja/JSVAL_TO_BOOLEAN">JSVAL_TO_BOOLEAN</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/BOOLEAN_TO_JSVAL" title="ja/BOOLEAN_TO_JSVAL">BOOLEAN_TO_JSVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_INT" title="ja/JSVAL_TO_INT">JSVAL_TO_INT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/INT_TO_JSVAL" title="ja/INT_TO_JSVAL">INT_TO_JSVAL</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/INT_FITS_IN_JSVAL" title="ja/INT_FITS_IN_JSVAL">INT_FITS_IN_JSVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_DOUBLE" title="ja/JSVAL_TO_DOUBLE">JSVAL_TO_DOUBLE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/DOUBLE_TO_JSVAL" title="ja/DOUBLE_TO_JSVAL">DOUBLE_TO_JSVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_OBJECT" title="ja/JSVAL_TO_OBJECT">JSVAL_TO_OBJECT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/OBJECT_TO_JSVAL" title="ja/OBJECT_TO_JSVAL">OBJECT_TO_JSVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_STRING" title="ja/JSVAL_TO_STRING">JSVAL_TO_STRING</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/STRING_TO_JSVAL" title="ja/STRING_TO_JSVAL">STRING_TO_JSVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_TO_GCTHING" title="ja/JSVAL_TO_GCTHING">JSVAL_TO_GCTHING</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/PRIVATE_TO_JSVAL" title="ja/PRIVATE_TO_JSVAL">JSVAL_TO_PRIVATE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/PRIVATE_TO_JSVAL" title="ja/PRIVATE_TO_JSVAL">PRIVATE_TO_JSVAL</a></li> +</ul> + +<p><code>typeof</code> のように振る舞う関数:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetTypeName" title="ja/JS_GetTypeName">JS_GetTypeName</a></li> +</ul> + +<p><code>===</code> のように振る舞う関数:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_StrictlyEqual" title="ja/SpiderMonkey/JSAPI_Reference/JS_StrictlyEqual">JS_StrictlyEqual</a></li> +</ul> + +<p><span id="Memory_management"></span></p> + +<h3 id="Memory_management" name="Memory_management">メモリ管理</h3> + +<p>これらの関数は、標準 C 関数の <code>malloc</code> 系のように動作します。ただし、エラーは <code>errno</code> ではなく、SpiderMonkey のエラー API を使用して報告されます:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_malloc" title="ja/JS_malloc">JS_malloc</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_malloc" title="ja/JS_free">JS_free</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_malloc" title="ja/JS_realloc">JS_realloc</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_malloc" title="ja/JS_strdup">JS_strdup</a></li> +</ul> + +<p>JavaScript オブジェクト、文字列、浮動小数点数はガーベッジコレクションの対象となります。これらの関数は、ガーベッジコレクタ(GC) へのアクセスを提供します:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GC" title="ja/JS_GC">JS_GC</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MaybeGC" title="ja/JS_MaybeGC">JS_MaybeGC</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JS_GetGCParameter</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JS_SetGCParameter</a>, enum <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JSGCParamKey</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JSGC_MAX_BYTES</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JSGC_MAX_MALLOC_BYTES</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/JS_SetGCParameter">JSGC_STACKPOOL_LIFESPAN</a>, <a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/SpiderMonkey/JSAPI Reference/JSGC TRIGGER FACTOR">JSGC_TRIGGER_FACTOR</a>, <a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/SpiderMonkey/JSAPI Reference/JSGC BYTES">JSGC_BYTES</a>, <a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetGCParameter" title="ja/SpiderMonkey/JSAPI Reference/JSGC NUMBER">JSGC_NUMBER</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JS_SetGCCallback</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JS_SetGCCallbackRT</a>, enum <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGCStatus</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGC_BEGIN</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGC_MARK_END</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGC_FINALIZE_END</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGC_END</a></li> + <li><a href="/ja/JS_MarkGCThing" title="ja/JS_MarkGCThing">JS_MarkGCThing</a></li> + <li><a href="/ja/JS_IsAboutToBeFinalized" title="ja/JS_IsAboutToBeFinalized">JS_IsAboutToBeFinalized</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearNewbornRoots" title="ja/JS_ClearNewbornRoots">JS_ClearNewbornRoots</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCZeal" title="ja/JS_SetGCZeal">JS_SetGCZeal</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DumpHeap" title="ja/JS_DumpHeap">JS_DumpHeap</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> +</ul> + +<p>これら残りの API は、アプリケーションがガーベッジコレクションを行う前に、オブジェクトをガーベッジコレクタによる破壊から保護します。</p> + +<p>変数が <em>root</em> の場合、その変数へのポインタはガーベッジコレクタによって開放されません。ルートオブジェクトに対しての失敗は、よくある奇妙なクラッシュの原因です。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddRoot" title="ja/JS_AddRoot">JS_AddRoot</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddRoot" title="ja/JS_AddRoot">JS_AddNamedRoot</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddRoot" title="ja/JS_AddRoot">JS_AddNamedRootRT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_RemoveRoot" title="ja/JS_RemoveRoot">JS_RemoveRoot</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_RemoveRootRT" title="ja/JS_RemoveRootRT">JS_RemoveRootRT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MapGCRoots">JS_MapGCRoots</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JSGCMapRootFun">JSGCMapRootFun</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MAP_GCROOT_NEXT">JS_MAP_GCROOT_NEXT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MAP_GCROOT_REMOVE">JS_MAP_GCROOT_REMOVE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MAP_GCROOT_STOP">JS_MAP_GCROOT_STOP</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DumpNamedRoots" title="ja/JS_DumpNamedRoots">JS_DumpNamedRoots</a></li> +</ul> + +<p>ローカルのルートのスコープは、オブジェクトを別の方法でガーベッジコレクタから保護します。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EnterLocalRootScope" title="ja/JS_EnterLocalRootScope">JS_EnterLocalRootScope</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LeaveLocalRootScope" title="ja/JS_LeaveLocalRootScope">JS_LeaveLocalRootScope</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LeaveLocalRootScopeWithResult" title="ja/JS_LeaveLocalRootScopeWithResult">JS_LeaveLocalRootScopeWithResult</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ForgetLocalRoot" title="ja/JS_ForgetLocalRoot">JS_ForgetLocalRoot</a></li> +</ul> + +<p><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span> オブジェクトが、SpiderMonkey のデータ構造 ("slots") に格納されていない、他のガーベッジコレクタの対象への参照を含む場合、このオブジェクトは、ガーベッジコレクタのこれらの参照へのトラバース (<span style="color: green;">traverse</span>)を有効にするため、<code><a href="/ja/JSClass.mark" title="ja/JSClass.mark">JSTraceOp</a></code> フックを実装しなければなりません。しかし、ガーベッジコレクタは手の届く範囲のオブジェクトのみを整理しますが、すべてのオブジェクトを見つけることはできないため、クラッシュを引き起こします。(SpiderMonkey 1.7 以前のバージョンでは <code>JSMarkOp</code> フックが代わりに使用されます。これは SpiderMonkey 1.8 のリリース後は非推奨です。)</p> + +<p>トレース API は、ガーベッジコレクタと <code>JSTraceOp</code> フックによって使用されます。JSAPI アプリケーションもまた、これらの API をオブジェクトグラフを検査するために使用します。(例えば、これらの API は JS ガーベッジコレクタと他のガーベッジコレクタの、とても円滑な統合をサポートします。)</p> + +<ul> + <li><a href="/ja/JSVAL_IS_TRACEABLE" title="ja/JSVAL_IS_TRACEABLE">JSVAL_IS_TRACEABLE</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JSVAL_TO_TRACEABLE" title="ja/JSVAL_TO_TRACEABLE">JSVAL_TO_TRACEABLE</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JSVAL_TRACE_KIND" title="ja/JSVAL_TRACE_KIND">JSVAL_TRACE_KIND</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li>struct <a href="/ja/JSTracer" title="ja/JSTracer">JSTracer</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_TRACER_INIT" title="ja/JS_TRACER_INIT">JS_TRACER_INIT</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CallTracer" title="ja/JS_CallTracer">JS_CallTracer</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SET_TRACING_DETAILS" title="ja/JS_SET_TRACING_DETAILS">JS_SET_TRACING_DETAILS</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_SET_TRACING_INDEX" title="ja/JS_SET_TRACING_INDEX">JS_SET_TRACING_INDEX</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_SET_TRACING_NAME" title="ja/JS_SET_TRACING_NAME">JS_SET_TRACING_NAME</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CALL_TRACER" title="ja/JS_CALL_TRACER">JS_CALL_TRACER</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CALL_VALUE_TRACER" title="ja/JS_CALL_VALUE_TRACER">JS_CALL_VALUE_TRACER</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CALL_OBJECT_TRACER" title="ja/JS_CALL_OBJECT_TRACER">JS_CALL_OBJECT_TRACER</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CALL_STRING_TRACER" title="ja/JS_CALL_STRING_TRACER">JS_CALL_STRING_TRACER</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_CALL_DOUBLE_TRACER" title="ja/JS_CALL_DOUBLE_TRACER">JS_CALL_DOUBLE_TRACER</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_TraceChildren" title="ja/JS_TraceChildren">JS_TraceChildren</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_TraceRuntime" title="ja/JS_TraceRuntime">JS_TraceRuntime</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/JS_PrintTraceThingInfo" title="ja/JS_PrintTraceThingInfo">JS_PrintTraceThingInfo</a> (DEBUG-only) <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> +</ul> + +<p>その他の GC API:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_LOCK" title="ja/JSVAL_LOCK">JSVAL_LOCK</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSVAL_UNLOCK" title="ja/JSVAL_UNLOCK">JSVAL_UNLOCK</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LockGCThing" title="ja/JS_LockGCThing">JS_LockGCThing</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/JS_LockGCThingRT" title="ja/JS_LockGCThingRT">JS_LockGCThingRT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LockGCThing" title="ja/JS_LockGCThing">JS_UnlockGCThing</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/JS_UnlockGCThingRT" title="ja/JS_UnlockGCThingRT">JS_UnlockGCThingRT</a></li> +</ul> + +<p><span id="Numbers"></span></p> + +<h3 id="Numbers" name="Numbers">数値</h3> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewNumberValue" title="ja/JS_NewNumberValue">JS_NewNumberValue</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewDoubleValue" title="ja/JS_NewDoubleValue">JS_NewDoubleValue</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewDouble" title="ja/JS_NewDouble">JS_NewDouble</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSConstDoubleSpec" title="ja/JSConstDoubleSpec">JSConstDoubleSpec</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineConstDoubles" title="ja/JS_DefineConstDoubles">JS_DefineConstDoubles</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetNaNValue" title="ja/JS_GetNaNValue">JS_GetNaNValue</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPositiveInfinityValue" title="ja/JS_GetPositiveInfinityValue">JS_GetNegativeInfinityValue</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPositiveInfinityValue" title="ja/JS_GetPositiveInfinityValue">JS_GetPositiveInfinityValue</a></li> +</ul> + +<p><span id="Strings"></span></p> + +<h3 id="Strings" name="Strings">文字列</h3> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/JSString" title="ja/JSString">JSString</a></li> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/jschar" title="ja/jschar">jschar</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewString" title="ja/JS_NewString">JS_NewString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyN" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyN">JS_NewStringCopyN</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ">JS_NewStringCopyZ</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewString" title="ja/JS_NewString">JS_NewUCString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyN" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyN">JS_NewUCStringCopyN</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewStringCopyZ">JS_NewUCStringCopyZ</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewGrowableString" title="ja/JS_NewGrowableString">JS_NewGrowableString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewDependentString" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewDependentString">JS_NewDependentString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetEmptyStringValue" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetEmptyStringValue">JS_GetEmptyStringValue</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CompareStrings" title="ja/SpiderMonkey/JSAPI_Reference/JS_CompareStrings">JS_CompareStrings</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ConcatStrings" title="ja/JS_ConcatStrings">JS_ConcatStrings</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes">JS_GetStringBytes</a> <span class="icon-only-inline" title="これは廃止されたAPIであり、今後の動作は保障されていません。ご注意下さい。"><i class="icon-trash"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes">JS_GetStringBytesZ</a> <span class="icon-only-inline" title="これは廃止されたAPIであり、今後の動作は保障されていません。ご注意下さい。"><i class="icon-trash"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringChars" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetStringChars">JS_GetStringChars</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringLength" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetStringLength">JS_GetStringLength</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MakeStringImmutable" title="ja/SpiderMonkey/JSAPI_Reference/JS_MakeStringImmutable">JS_MakeStringImmutable</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_UndependString" title="ja/SpiderMonkey/JSAPI_Reference/JS_UndependString">JS_UndependString</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CStringsAreUTF8" title="ja/JS_CStringsAreUTF8">JS_CStringsAreUTF8</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CStringsAreUTF8" title="ja/JS_SetCStringsAreUTF8">JS_SetCStringsAreUTF8</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DecodeBytes" title="ja/JS_DecodeBytes">JS_DecodeBytes</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_EncodeCharacters" title="ja/JS_EncodeCharacters">JS_EncodeCharacters</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes" title="ja/SpiderMonkey/JSAPI Reference/JS GetStringBytes">JS_EncodeString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes" title="ja/SpiderMonkey/JSAPI Reference/JS GetStringBytes">JS_EncodeStringToBuffer</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetStringBytes" title="ja/SpiderMonkey/JSAPI Reference/JS GetStringBytes">JS_GetStringEncodingLength</a></li> +</ul> + +<p><em>Interning</em> 文字列は SpiderMonkey エンジンに、可能ならば既存の文字列オブジェクトを再使用するように伝えます。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InternString" title="ja/SpiderMonkey/JSAPI_Reference/JS_InternString">JS_InternString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InternString" title="ja/SpiderMonkey/JSAPI_Reference/JS_InternString">JS_InternUCString</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InternString" title="ja/SpiderMonkey/JSAPI_Reference/JS_InternString">JS_InternUCStringN</a></li> +</ul> + +<p><em>external strings</em> のための文字データはアプリケーションによって提供されるメモリに格納されます。アプリケーションはこれを、SpiderMonkey のヒープとアプリケーションのメモリの間で、<span style="border-bottom: 1px dashed green;" title="copying data back and forth">データを先や後へコピーする</span>ことを防止するために使用します。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddExternalStringFinalizer" title="ja/JS_AddExternalStringFinalizer">JS_AddExternalStringFinalizer</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_RemoveExternalStringFinalizer" title="ja/JS_RemoveExternalStringFinalizer">JS_RemoveExternalStringFinalizer</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetExternalStringGCType" title="ja/JS_GetExternalStringGCType">JS_GetExternalStringGCType</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewExternalString" title="ja/JS_NewExternalString">JS_NewExternalString</a></li> +</ul> + +<p><span id="Objects"></span></p> + +<h3 id="Objects" name="Objects">オブジェクト</h3> + +<ul> + <li>typedef <a href="/ja/SpiderMonkey/JSAPI_Reference/JSObject" title="ja/JSObject">JSObject</a></li> + <li><a href="/ja/JS_ConstructObject" title="ja/JS_ConstructObject">JS_ConstructObject</a></li> + <li><a href="/ja/JS_ConstructObject" title="ja/JS_ConstructObjectWithArguments">JS_ConstructObjectWithArguments</a></li> + <li><a href="/ja/JS_DefineObject" title="ja/JS_DefineObject">JS_DefineObject</a></li> + <li><a href="/ja/JS_NewObject" title="ja/JS_NewObject">JS_NewObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewGlobalObject" title="ja/SpiderMonkey/JSAPI Reference/JS NewGlobalObject">JS_NewGlobalObject</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewObject" title="ja/JS_NewObject">JS_NewObjectWithGivenProto</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_New" title="ja/SpiderMonkey/JSAPI Reference/JS New">JS_New</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GET_CLASS" title="ja/JS_GET_CLASS">JS_GET_CLASS</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GET_CLASS" title="ja/JS_GET_CLASS">JS_GetClass</a></li> + <li><a href="/ja/JS_GetClassObject" title="ja/JS_GetClassObject">JS_GetClassObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetConstructor" title="ja/JS_GetConstructor">JS_GetConstructor</a></li> + <li><a href="/ja/JS_GetGlobalForObject" title="ja/JS_GetGlobalForObject">JS_GetGlobalForObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetInstancePrivate" title="ja/JS_GetInstancePrivate">JS_GetInstancePrivate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetParent" title="ja/JS_GetParent">JS_GetParent</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetParent" title="ja/JS_SetParent">JS_SetParent</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPrivate" title="ja/JS_GetPrivate">JS_GetPrivate</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPrivate" title="ja/JS_SetPrivate">JS_SetPrivate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPrototype" title="ja/JS_GetPrototype">JS_GetPrototype</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPrototype" title="ja/JS_SetPrototype">JS_SetPrototype</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetReservedSlot" title="ja/JS_GetReservedSlot">JS_GetReservedSlot</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetReservedSlot" title="ja/JS_GetReservedSlot">JS_SetReservedSlot</a></li> + <li><a href="/ja/JS_HasInstance" title="ja/JS_HasInstance">JS_HasInstance</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InstanceOf" title="ja/JS_InstanceOf">JS_InstanceOf</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SealObject" title="ja/JS_SealObject">JS_SealObject</a></li> +</ul> + +<p><span id="Properties"></span></p> + +<h3 id="Properties" name="Properties">プロパティ</h3> + +<p>これらの関数は、直接スクリプトがオブジェクトのプロパティにアクセスする方法に相当します:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="ja/JS_GetProperty">JS_GetProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="ja/JS_GetProperty">JS_GetUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetProperty" title="ja/JS_GetProperty">JS_GetPropertyById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetProperty" title="ja/JS_SetProperty">JS_SetProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetProperty" title="ja/JS_SetProperty">JS_SetUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetProperty" title="ja/JS_SetProperty">JS_SetPropertyById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_HasProperty" title="ja/JS_HasProperty">JS_HasProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_HasProperty" title="ja/JS_HasProperty">JS_HasUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_HasProperty" title="ja/JS_HasProperty">JS_HasPropertyById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteProperty" title="ja/JS_DeleteProperty">JS_DeleteProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteProperty" title="ja/JS_DeleteProperty">JS_DeletePropertyById</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteProperty2" title="ja/JS_DeleteProperty2">JS_DeleteProperty2</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteProperty2" title="ja/JS_DeleteProperty2">JS_DeleteUCProperty2</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteProperty2" title="ja/JS_DeleteProperty2">JS_DeletePropertyById2</a></li> +</ul> + +<p>次の低レベルの関数は、JSAPI アプリケーションが、プロパティの実装方法の詳細へのアクセスを許可します。"Define" は "set" の低レベル版であり、追加の設定へのアクセスを提供し、setter を呼び出しません。同様に、"lookup" は "get" の低レベル版であり、追加のオプションを与え、getter を呼び出しません。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AlreadyHasOwnProperty" title="ja/JS_AlreadyHasOwnElement">JS_AlreadyHasOwnElement</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AlreadyHasOwnProperty" title="ja/JS_AlreadyHasOwnProperty">JS_AlreadyHasOwnProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AlreadyHasOwnProperty" title="ja/JS_AlreadyHasOwnProperty">JS_AlreadyHasOwnUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AlreadyHasOwnProperty" title="ja/JS_AlreadyHasOwnProperty">JS_AlreadyHasOwnPropertyById</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearScope" title="ja/JS_ClearScope">JS_ClearScope</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineProperties" title="ja/JS_DefineProperties">JS_DefineProperties</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineProperty" title="ja/JS_DefineProperty">JS_DefineProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineProperty" title="ja/JS_DefineProperty">JS_DefineUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineProperty" title="ja/JS_DefineProperty">JS_DefinePropertyById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefinePropertyWithTinyId" title="ja/JS_DefinePropertyWithTinyId">JS_DefinePropertyWithTinyId</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefinePropertyWithTinyId" title="ja/JS_DefinePropertyWithTinyId">JS_DefineUCPropertyWithTinyId</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Enumerate" title="ja/JS_Enumerate">JS_Enumerate</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JS_GetPropertyAttributes</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JS_GetUCPropertyAttributes</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_ENUMERATE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_EXPORTED</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_GETTER</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_INDEX</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_PERMANENT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_READONLY</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_SETTER</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttributes" title="ja/JS_GetPropertyAttributes">JSPROP_SHARED</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttrsGetterAndSetter" title="ja/JS_GetPropertyAttrsGetterAndSetter">JS_GetPropertyAttrsGetterAndSetter</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttrsGetterAndSetter" title="ja/JS_GetPropertyAttrsGetterAndSetter">JS_GetUCPropertyAttrsGetterAndSetter</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyAttrsGetterAndSetter" title="ja/JS_GetPropertyAttrsGetterAndSetter">JS_GetPropertyAttrsGetterAndSetterById</a></li> + <li><a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetPropertyDescriptorById" title="ja/SpiderMonkey/JSAPI Reference/JS GetPropertyDescriptorById">JS_GetPropertyDescriptorById</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8_(未リリース)">SpiderMonkey 1.8 (未リリース)</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupProperty" title="ja/JS_LookupProperty">JS_LookupProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupProperty" title="ja/JS_LookupProperty">JS_LookupUCProperty</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupProperty" title="ja/JS_LookupProperty">JS_LookupPropertyById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupProperty" title="ja/JS_LookupProperty">JS_LookupPropertyWithFlags</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupProperty" title="ja/JS_LookupProperty">JS_LookupPropertyWithFlagsById</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewPropertyIterator" title="ja/JS_NewPropertyIterator">JS_NewPropertyIterator</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NextProperty" title="ja/JS_NextProperty">JS_NextProperty</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPropertyAttributes" title="ja/JS_SetPropertyAttributes">JS_SetPropertyAttributes</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPropertyAttributes" title="ja/JS_SetPropertyAttributes">JS_SetUCPropertyAttributes</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AliasProperty" title="ja/JS_AliasProperty">JS_AliasProperty</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> +</ul> + +<p>次の関数は、<code>JS_GetProperty</code> および <code>JS_GetPropertyById</code> のように振る舞います。ただし、E4X XML オブジェクト上の操作は除きます。</p> + +<ul> + <li><a href="/ja/JS_GetMethod" title="ja/JS_GetMethod">JS_GetMethod</a>, <a href="/ja/JS_GetMethodById" title="ja/JS_GetMethodById">JS_GetMethodById</a></li> +</ul> + +<p>SpiderMonkey 拡張は lvalue(オブジェクトのプロパティへの参照) を返すネイティブ関数を許可します:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetCallReturnValue2" title="ja/JS_SetCallReturnValue2">JS_SetCallReturnValue2</a></li> +</ul> + +<p><code><a href="/ja/SpiderMonkey/JSAPI_Reference/jsid" title="ja/jsid">jsid</a></code> は <code>jsval</code> の一種です。ごく少数の API が、<code>jsval</code> の代わりに <code>jsid</code> をプロパティ名に使用します: <code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JS_CheckAccess</a></code> および <code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Enumerate" title="ja/JS_Enumerate">JS_Enumerate</a></code>, <code><a href="/ja/JS_GetMethodById" title="ja/JS_GetMethodById">JS_GetMethodById</a></code>, <code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NextProperty" title="ja/JS_NextProperty">JS_NextProperty</a></code>。</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IdToValue" title="ja/JS_IdToValue">JS_IdToValue</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ValueToId" title="ja/JS_ValueToId">JS_ValueToId</a></li> + <li><a href="/ja/JS_GetObjectId" title="ja/JS_GetObjectId">JS_GetObjectId</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSIdArray" title="ja/JSIdArray">JSIdArray</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DestroyIdArray" title="ja/JS_DestroyIdArray">JS_DestroyIdArray</a></li> +</ul> + +<p><code>jsid</code> 定数:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_VOID" title="ja/JSID_VOID">JSID_VOID</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_EMPTY" title="ja/JSID_EMPTY">JSID_EMPTY</a></li> +</ul> + +<p><code>jsid</code> の型を調べる関数とマクロ:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_VOID" title="ja/JSID_IS_VOID">JSID_IS_VOID</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_INT" title="ja/JSID_IS_INT">JSID_IS_INT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_STRING" title="ja/JSID_IS_STRING">JSID_IS_STRING</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_OBJECT" title="ja/JSID_IS_OBJECT">JSID_IS_OBJECT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_GCTHING" title="ja/JSID_IS_GCTHING">JSID_IS_GCTHING</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_ZERO" title="ja/JSID_IS_ZERO">JSID_IS_ZERO</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_EMPTY" title="ja/JSID_IS_EMPTY">JSID_IS_EMPTY</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSID_IS_DEFAULT_XML_NAMESPACE" title="ja/JSID_IS_DEFAULT_XML_NAMESPACE">JSID_IS_DEFAULT_XML_NAMESPACE</a></li> +</ul> + +<p><span id="Classes"></span></p> + +<h3 id="Classes" name="Classes">クラス</h3> + +<p>これらの API 機能は、C/C++ に実装された JavaScript からアクセス可能なカスタムクラス—オブジェクト型の定義に使用されます。</p> + +<ul> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass" title="ja/SpiderMonkey/JSAPI_Reference/JSClass">JSClass</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSExtendedClass" title="ja/SpiderMonkey/JSAPI_Reference/JSExtendedClass">JSExtendedClass</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps">JSObjectOps</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSXMLObjectOps" title="ja/SpiderMonkey/JSAPI_Reference/JSXMLObjectOps">JSXMLObjectOps</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSFunctionSpec" title="ja/SpiderMonkey/JSAPI_Reference/JSFunctionSpec">JSFunctionSpec</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSProperty" title="ja/SpiderMonkey/JSAPI_Reference/JSProperty">JSProperty</a></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSPropertySpec" title="ja/SpiderMonkey/JSAPI_Reference/JSPropertySpec">JSPropertySpec</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_InitClass" title="ja/SpiderMonkey/JSAPI_Reference/JS_InitClass">JS_InitClass</a></li> +</ul> + +<p>ネイティブプロパティとメソッドをクラスに追加:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSNative" title="ja/SpiderMonkey/JSAPI_Reference/JSNative">JSNative</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JSFastNative</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSFunctionSpec" title="ja/SpiderMonkey/JSAPI_Reference/JSFunctionSpec">JSFunctionSpec</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_FS" title="ja/JS_FS">JS_FS</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_FS" title="ja/JS_FN">JS_FN</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_FS" title="ja/JS_FS_END">JS_FS_END</a> <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></li> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSPropertySpec" title="ja/SpiderMonkey/JSAPI_Reference/JSPropertySpec">JSPropertySpec</a></li> +</ul> + +<p><code>JSFastNative</code> メソッドはこれらのマクロを使用します: <span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span></p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_CALLEE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_THIS</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_THIS_OBJECT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_ARGV</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_RVAL</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/SpiderMonkey/JSAPI_Reference/JSFastNative">JS_SET_RVAL</a></li> +</ul> + +<p><code>JSClass</code> の振る舞いとそのインスタンスは、コールバック関数を使用して多くの方法でカスタマイズすることができます。</p> + +<p><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass" title="ja/SpiderMonkey/JSAPI_Reference/JSClass">JSClass</a> メソッド型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSPropertyOp" title="ja/SpiderMonkey/JSAPI_Reference/JSPropertyOp">JSPropertyOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSEnumerateOp" title="ja/SpiderMonkey/JSAPI_Reference/JSEnumerateOp">JSEnumerateOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.enumerate" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.enumerate">JSNewEnumerateOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.resolve" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.resolve">JSResolveOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSNewResolveOp</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSRESOLVE_ASSIGNING</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSRESOLVE_CLASSNAME</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSRESOLVE_DECLARING</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSRESOLVE_DETECTING</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp" title="ja/SpiderMonkey/JSAPI_Reference/JSNewResolveOp">JSRESOLVE_QUALIFIED</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defaultValue" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defaultValue">JSConvertOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.finalize" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.finalize">JSFinalizeOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.getObjectOps" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.getObjectOps">JSGetObjectOps</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.checkAccess" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.checkAccess">JSCheckAccessOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.xdrObject" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.xdrObject">JSXDRObjectOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.hasInstance" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.hasInstance">JSHasInstanceOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.mark" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.mark">JSMarkOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSTraceOp" title="ja/SpiderMonkey/JSAPI_Reference/JSTraceOp">JSTraceOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.reserveSlots" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.reserveSlots">JSReserveSlotsOp</a></li> +</ul> + +<p><a href="/ja/SpiderMonkey/JSAPI_Reference/JSExtendedClass" title="ja/SpiderMonkey/JSAPI_Reference/JSExtendedClass">JSExtendedClass</a> メソッド型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSIteratorOp" title="ja/SpiderMonkey/JSAPI_Reference/JSIteratorOp">JSIteratorOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSEqualityOp" title="ja/SpiderMonkey/JSAPI_Reference/JSEqualityOp">JSEqualityOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOp" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOp">JSObjectOp</a></li> +</ul> + +<p><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps">JSObjectOps</a> メソッド型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.newObjectMap" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.newObjectMap">JSNewObjectMapOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.destroyObjectMap" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.destroyObjectMap">JSObjectMapOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.lookupProperty" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.lookupProperty">JSLookupPropOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defineProperty" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defineProperty">JSDefinePropOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getProperty" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getProperty">JSPropertyIdOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getAttributes" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getAttributes">JSAttributesOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defaultValue" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.defaultValue">JSConvertOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.enumerate" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.enumerate">JSNewEnumerateOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.checkAccess" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.checkAccess">JSCheckAccessIdOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOp" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOp">JSObjectOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.dropProperty" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.dropProperty">JSPropertyRefOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.xdrObject" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.xdrObject">JSXDRObjectOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.hasInstance" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.hasInstance">JSHasInstanceOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.setProto" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.setProto">JSSetObjectSlotOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSTraceOp" title="ja/SpiderMonkey/JSAPI_Reference/JSTraceOp">JSTraceOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.finalize" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.finalize">JSFinalizeOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getRequiredSlot" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getRequiredSlot">JSGetRequiredSlotOp</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getRequiredSlot" title="ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.getRequiredSlot">JSSetRequiredSlotOp</a></li> +</ul> + +<p><a href="/ja/SpiderMonkey/JSAPI_Reference/JSXMLObjectOps" title="ja/SpiderMonkey/JSAPI_Reference/JSXMLObjectOps">JSXMLObjectOps</a> メソッド型:</p> + +<ul> + <li><a href="/ja/JSGetMethodOp" title="ja/JSGetMethodOp">JSGetMethodOp</a></li> + <li><a href="/ja/JSSetMethodOp" title="ja/JSSetMethodOp">JSSetMethodOp</a></li> + <li><a href="/ja/JSEnumerateValuesOp" title="ja/JSEnumerateValuesOp">JSEnumerateValuesOp</a></li> + <li><a href="/ja/JSEqualityOp" title="ja/JSEqualityOp">JSEqualityOp</a></li> + <li><a href="/ja/JSConcatenateOp" title="ja/JSConcatenateOp">JSConcatenateOp</a></li> +</ul> + +<p>これらの stub 関数はカスタム <code>JSClass</code> の作成時に使用されます:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub" title="ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub">JS_ConvertStub</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub" title="ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub">JS_EnumerateStub</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub" title="ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub">JS_FinalizeStub</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub" title="ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub">JS_PropertyStub</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub" title="ja/SpiderMonkey/JSAPI_Reference/JS_PropertyStub">JS_ResolveStub</a></li> +</ul> + +<p><code>JSClass</code> の振る舞いは、これらのフラグを使用してカスタマイズできます:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSClass.flags</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_CONSTUCT_PROTOTYPE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_GLOBAL_FLAGS</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_HAS_PRIVATE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_HAS_RESERVED_SLOTS</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_IS_EXTENDED</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_MARK_IS_TRACE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_NEW_ENUMERATE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_NEW_RESOLVE</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_NEW_RESOLVE_GETS_START</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_PRIVATE_IS_NSISUPPORTS</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.flags" title="ja/SpiderMonkey/JSAPI_Reference/JSClass.flags">JSCLASS_SHARE_ALL_PROPERTIES</a></li> +</ul> + +<p><span id="Arrays"></span></p> + +<h3 id="Arrays" name="Arrays">配列</h3> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewArrayObject" title="ja/JS_NewArrayObject">JS_NewArrayObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_IsArrayObject" title="ja/JS_IsArrayObject">JS_IsArrayObject</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_HasArrayLength" title="ja/JS_HasArrayLength">JS_HasArrayLength</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetArrayLength" title="ja/JS_GetArrayLength">JS_GetArrayLength</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetArrayLength" title="ja/JS_SetArrayLength">JS_SetArrayLength</a></li> +</ul> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AliasElement" title="ja/JS_AliasElement">JS_AliasElement</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineElement" title="ja/JS_DefineElement">JS_DefineElement</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteElement" title="ja/JS_DeleteElement">JS_DeleteElement</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DeleteElement2" title="ja/JS_DeleteElement2">JS_DeleteElement2</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetElement" title="ja/JS_GetElement">JS_GetElement</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LookupElement" title="ja/JS_LookupElement">JS_LookupElement</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetElement" title="ja/JS_SetElement">JS_SetElement</a></li> +</ul> + +<p><span id="Functions"></span></p> + +<h3 id="Functions" name="Functions">関数</h3> + +<p>関数またはオブジェクトのメソッドの呼び出し:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CallFunction" title="ja/JS_CallFunction">JS_CallFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CallFunctionName" title="ja/JS_CallFunctionName">JS_CallFunctionName</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CallFunctionValue" title="ja/JS_CallFunctionValue">JS_CallFunctionValue</a></li> +</ul> + +<p>関数アクセサリ:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ObjectIsFunction" title="ja/JS_ObjectIsFunction">JS_ObjectIsFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionArity" title="ja/JS_GetFunctionArity">JS_GetFunctionArity</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionFlags" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionFlags">JS_GetFunctionFlags</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionId" title="ja/JS_GetFunctionId">JS_GetFunctionId</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionName" title="ja/JS_GetFunctionName">JS_GetFunctionName</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetFunctionObject" title="ja/JS_GetFunctionObject">JS_GetFunctionObject</a></li> +</ul> + +<p>関数の生成:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CloneFunctionObject" title="ja/JS_CloneFunctionObject">JS_CloneFunctionObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineFunction" title="ja/JS_DefineFunction">JS_DefineFunction</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineFunction" title="ja/JS_DefineFunction">JS_DefineUCFunction</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DefineFunctions" title="ja/JS_DefineFunctions">JS_DefineFunctions</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewFunction" title="ja/JS_NewFunction">JS_NewFunction</a></li> +</ul> + +<p><span id="RegExps"></span></p> + +<h3 id="RegExps" name="RegExps">正規表現</h3> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject">JS_NewRegExpObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject" title="ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject">JS_NewUCRegExpObject</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetRegExpInput" title="ja/SpiderMonkey/JSAPI_Reference/JS_SetRegExpInput">JS_SetRegExpInput</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearRegExpRoots" title="ja/SpiderMonkey/JSAPI_Reference/JS_ClearRegExpRoots">JS_ClearRegExpRoots</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearRegExpStatics" title="ja/SpiderMonkey/JSAPI_Reference/JS_ClearRegExpStatics">JS_ClearRegExpStatics</a></li> +</ul> + +<p><span id="Security"></span></p> + +<h3 id="Security" name="Security">セキュリティ</h3> + +<p><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8.1">SpiderMonkey 1.8.1</a> の新機能</span> セキュリティのコールバックは、ランタイムごと、またはコンテキストごとに設定できます。</p> + +<ul> + <li> + <ul> + <li>struct <a href="/ja/SpiderMonkey/JSAPI_Reference/JSPrincipals" title="ja/JSPrincipals">JSPrincipals</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSPRINCIPALS_HOLD" title="ja/JSPRINCIPALS_HOLD">JSPRINCIPALS_HOLD</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JSPRINCIPALS_HOLD" title="ja/JSPRINCIPALS_HOLD">JSPRINCIPALS_DROP</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetObjectPrincipalsFinder" title="ja/JS_SetObjectPrincipalsFinder">JS_SetObjectPrincipalsFinder</a> <span class="inlineIndicator standardNote">JSAPI 1.8 まで</span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPrincipalsTranscoder" title="ja/JS_SetPrincipalsTranscoder">JS_SetPrincipalsTranscoder</a> <span class="inlineIndicator standardNote">JSAPI 1.8 まで</span></li> + </ul> + + <ul> + <li>enum <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSAccessMode</a> – <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_PROTO</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_PARENT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_IMPORT</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_WATCH</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_READ</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JSACC_WRITE</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_CheckAccess" title="ja/JS_CheckAccess">JS_CheckAccess</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSObjectOps.checkAccess" title="ja/JSObjectOps.checkAccess">JSObjectOps.checkAccess</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSClass.checkAccess" title="ja/JSClass.checkAccess">JSClass.checkAccess</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetCheckObjectAccessCallback" title="ja/JS_SetCheckObjectAccessCallback">JS_SetCheckObjectAccessCallback</a> <span class="inlineIndicator standardNote">JSAPI 1.8 まで</span></li> + </ul> + + <ul> + <li><a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetSecurityCallbacks" title="ja/SpiderMonkey/JSAPI Reference/JS GetSecurityCallbacks">JS_GetSecurityCallbacks</a>, <a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetSecurityCallbacks" title="ja/SpiderMonkey/JSAPI Reference/JS GetSecurityCallbacks">JS_SetContextSecurityCallbacks</a>, <a class="internal" href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetSecurityCallbacks" title="ja/SpiderMonkey/JSAPI Reference/JS GetSecurityCallbacks">JS_GetRuntimeSecurityCallbacks</a>, <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetSecurityCallbacks" title="ja/SpiderMonkey/JSAPI_Reference/JS_GetSecurityCallbacks">JS_SetRuntimeSecurityCallbacks</a></li> + </ul> + </li> +</ul> + +<p><span id="Threading"></span></p> + +<h3 id="Threading" name="Threading">スレッド</h3> + +<p>次の関数は SpiderMonkey のスレッドモデルをサポートしています。</p> + +<p><span class="inlineIndicator standardNote">JSAPI 1.7 まで</span> これらは <code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE" title="ja/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE">JS_THREADSAFE</a></code> ビルドでのみ利用可能です。</p> + +<p><span style="border: 1px solid rgb(129, 129, 81); background: rgb(255, 255, 225); font-size: 9px; vertical-align: text-top;"><a href="https://developer.mozilla.org/ja/docs/SpiderMonkey/1.8">SpiderMonkey 1.8</a> の新機能</span> これらの関数はいつでも利用可能です。ただし、<code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code> 無しのビルドでは何もしません</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="ja/JS_BeginRequest">JS_BeginRequest</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="ja/JS_BeginRequest">JS_EndRequest</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_YieldRequest" title="ja/JS_YieldRequest">JS_YieldRequest</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="ja/JS_SuspendRequest">JS_SuspendRequest</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="ja/JS_SuspendRequest">JS_ResumeRequest</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_GetContextThread" title="ja/JS_GetContextThread">JS_GetContextThread</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearContextThread" title="ja/JS_ClearContextThread">JS_SetContextThread</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ClearContextThread" title="ja/JS_ClearContextThread">JS_ClearContextThread</a></li> +</ul> + +<p>次の関数はすべてのビルドに存在します。ただし、<code><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE" title="ja/SpiderMonkey/JSAPI_Reference/JS_THREADSAFE">JS_THREADSAFE</a></code> 無しのビルドでは何もしません:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_LockRuntime" title="ja/SpiderMonkey/JSAPI_Reference/JS_LockRuntime">JS_LockRuntime</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_UnlockRuntime" title="ja/SpiderMonkey/JSAPI_Reference/JS_UnlockRuntime">JS_UnlockRuntime</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Lock" title="ja/JS_Lock">JS_Lock</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Unlock" title="ja/JS_Unlock">JS_Unlock</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> +</ul> + +<p><span id="Time"></span></p> + +<h3 id="Time" name="Time">時間</h3> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_Now" title="ja/SpiderMonkey/JSAPI_Reference/JS_Now">JS_Now</a></li> +</ul> + +<p><span id="Callback_Types"></span></p> + +<h3 id="Callback_Types" name="Callback_Types">コールバック型</h3> + +<p>ネイティブ関数型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSNative" title="ja/JSNative">JSNative</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFastNative" title="ja/JSFastNative">JSFastNative</a></li> +</ul> + +<p>その他のコールバック型:</p> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddExternalStringFinalizer" title="ja/JS_AddExternalStringFinalizer">JSStringFinalizeOp</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddExternalStringFinalizer" title="ja/JS_AddExternalStringFinalizer">JS_AddExternalStringFinalizer</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_TRACER_INIT" title="ja/JS_TRACER_INIT">JSTraceCallback</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_TRACER_INIT" title="ja/JS_TRACER_INIT">JS_TRACER_INIT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SET_TRACING_DETAILS" title="ja/JS_SET_TRACING_DETAILS">JSTraceNamePrinter</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SET_TRACING_DETAILS" title="ja/JS_SET_TRACING_DETAILS">JS_SET_TRACING_DETAILS</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetContextCallback" title="ja/JS_SetContextCallback">JSContextCallback</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetContextCallback" title="ja/JS_SetContextCallback">JS_SetContextCallback</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JSGCCallback</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetGCCallback" title="ja/JS_SetGCCallback">JS_SetGCCallback</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetExtraGCRoots" title="ja/JS_SetExtraGCRoots">JSTraceDataOp</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetExtraGCRoots" title="ja/JS_SetExtraGCRoots">JS_SetExtraGCRoots</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetBranchCallback" title="ja/JS_SetBranchCallback">JSBranchCallback</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetBranchCallback" title="ja/JS_SetBranchCallback">JS_SetBranchCallback</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetErrorReporter" title="ja/JS_SetErrorReporter">JSErrorReporter</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetErrorReporter" title="ja/JS_SetErrorReporter">JS_SetErrorReporter</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JSErrorCallback</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_ReportErrorNumber" title="ja/JS_ReportErrorNumber">JS_ReportErrorNumber</a> and friends</li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddArgumentFormatter" title="ja/JS_AddArgumentFormatter">JSArgumentFormatter</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_AddArgumentFormatter" title="ja/JS_AddArgumentFormatter">JS_AddArgumentFormatter</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPrincipalsTranscoder" title="ja/JS_SetPrincipalsTranscoder">JSPrincipalsTranscoder</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetPrincipalsTranscoder" title="ja/JS_SetPrincipalsTranscoder">JS_SetPrincipalsTranscoder</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetObjectPrincipalsFinder" title="ja/JS_SetObjectPrincipalsFinder">JSObjectPrincipalsFinder</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_SetObjectPrincipalsFinder" title="ja/JS_SetObjectPrincipalsFinder">JS_SetObjectPrincipalsFinder</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MapGCRoots">JSGCRootMapFun</a> - used by <a href="/ja/SpiderMonkey/JSAPI_Reference/JS_MapGCRoots" title="ja/JS_MapGCRoots">JS_MapGCRoots</a></li> +</ul> + +<p>上記の<a href="#Classes">クラス</a>も参照してください。</p> + +<p><span id="Macros"></span></p> + +<h3 id="Macros" name="Macros">マクロ</h3> + +<ul> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_DEFAULT_XML_NAMESPACE_ID" title="ja/JS_DEFAULT_XML_NAMESPACE_ID">JS_DEFAULT_XML_NAMESPACE_ID</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_BOUND_METHOD" title="ja/JSFUN_BOUND_METHOD">JSFUN_BOUND_METHOD</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_GETTER" title="ja/JSFUN_GETTER">JSFUN_GETTER</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_GLOBAL_PARENT" title="ja/JSFUN_GLOBAL_PARENT">JSFUN_GLOBAL_PARENT</a> <span title="これは非推奨 API です。未だ動作しているかも知れませんが、将来的に削除される可能性があります。"><i class="icon-thumbs-down-alt"> </i></span></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_HEAVYWEIGHT" title="ja/JSFUN_HEAVYWEIGHT">JSFUN_HEAVYWEIGHT</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_LAMBDA" title="ja/JSFUN_LAMBDA">JSFUN_LAMBDA</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JSFUN_SETTER" title="ja/JSFUN_SETTER">JSFUN_SETTER</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject" title="ja/JSREG_GLOB">JSREG_GLOB</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject" title="ja/JSREG_FOLD">JSREG_FOLD</a></li> + <li><a href="/ja/SpiderMonkey/JSAPI_Reference/JS_NewRegExpObject" title="ja/JSREG_MULTILINE">JSREG_MULTILINE</a></li> +</ul> + +<p><span id="C++_features"></span></p> + +<h3 id="C.2B.2B_features" name="C.2B.2B_features">C++ の機能</h3> + +<ul> + <li>class <a href="/ja/JSAutoRequest" title="ja/JSAutoRequest">JSAutoRequest</a></li> + <li>class <a href="/ja/JSAutoLocalRootScope" title="ja/JSAutoLocalRootScope">JSAutoLocalRootScope</a></li> + <li>class <a href="/ja/JS::PerfMeasurement" title="ja/JS::PerfMeasurement">JS::PerfMeasurement</a> (in <code>jsperf.h</code>)</li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_compilefile/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_compilefile/index.html new file mode 100644 index 0000000000..a6d409dc85 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_compilefile/index.html @@ -0,0 +1,66 @@ +--- +title: JS CompileFile +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_CompileFile +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_CompileUTF8File +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_CompileFile</code></div> + +<p></p> + +<p>外部ファイルに含まれるスクリプトをコンパイルします。 <span class="comment">Compile a script stored in an external file.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval"><a href="/ja/JSScript" title="ja/JSScript">JSScript</a> * <strong>JS_CompileFile</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx, <a href="/ja/JSObject" title="ja/JSObject">JSObject</a> *obj, + const char *filename); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *</code></td> + <td>スクリプトをコンパイルするときのコンテキスト {{ Jsapi-requires-request() }}</td> + </tr> + <tr> + <td><code>obj</code></td> + <td><code>JSObject *</code></td> + <td>スクリプトと関連付けるオブジェクト<span class="comment">Object with which the script is associated.</span></td> + </tr> + <tr> + <td><code>filename</code></td> + <td><code>const char *</code></td> + <td>スクリプトを含むファイルの名前<span class="comment">Name of file containing the script to compile.</span></td> + </tr> + </tbody> +</table> + +<h2 id=".E8.A7.A3.E8.AA.AC" name=".E8.A7.A3.E8.AA.AC">解説</h2> + +<p><code>JS_CompileFile</code>は、JavaScriptエンジンで実行するために外部ファイルのスクリプトをコンパイルする関数です。 <span class="comment"><code>JS_CompileFile</code> compiles the text of script in an external file location for execution by the JS engine.</span></p> + +<p><code>filename</code>は、コンパイル対象のスクリプトを含んでいるファイルの名前を引数に取ります。 <span class="comment"><code>filename</code> is the name of the file containing the script to compile.</span></p> + +<p>コンパイルが成功したとき、<code>JS_CompileFile</code>はコンパイル済みのスクリプトへのポインタを返値とします。失敗時には<code>NULL</code>を返します。 <span class="comment">On success, <code>JS_CompileFile</code> returns a pointer to the compiled script. Otherwise it returns <code>NULL</code>.</span></p> + +<p>ファイル名でスクリプトを指定するのではなく、文字列の引数として関数に渡す場合には、<code><a href="/ja/JS_CompileScript" title="ja/JS_CompileScript">JS_CompileScript</a></code>を使ってください。 <span class="comment">To pass a script as an argument to a function rather than having to specify a file location, use <code><a href="/ja/JS_CompileScript">JS_CompileScript</a></code> instead.</span></p> + +<h2 id=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE" name=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE">関連項目</h2> + +<p>{{ LXRSearch("ident", "i", "JS_CompileFile") }}</p> + +<p><a href="/ja/JS_CompileScript" title="ja/JS_CompileScript">JS_CompileScript</a>, <a href="/ja/JS_DecompileScript" title="ja/JS_DecompileScript">JS_DecompileScript</a>, <a href="/ja/JS_DestroyScript" title="ja/JS_DestroyScript">JS_DestroyScript</a>, <a href="/ja/JS_EvaluateScript" title="ja/JS_EvaluateScript">JS_EvaluateScript</a>, <a href="/ja/JS_ExecuteScript" title="ja/JS_ExecuteScript">JS_ExecuteScript</a></p> + +<p>{{ languages( { "en": "en/JS_CompileFile" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_constructobject/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_constructobject/index.html new file mode 100644 index 0000000000..ae7b116ff2 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_constructobject/index.html @@ -0,0 +1,63 @@ +--- +title: JS ConstructObject +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ConstructObject +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ConstructObject +--- +<p></p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_ConstructObject</code></div> +<p></p> + +<p>新たにJavaScriptオブジェクトを生成し、コンストラクタを呼び出します。 <span class="comment">Create a new JavaScript object and invoke its constructor.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval"><a href="/ja/JSObject" title="ja/JSObject">JSObject</a> * <strong>JS_ConstructObject</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx, <a href="/ja/JSClass" title="ja/JSClass">JSClass</a> *clasp, + <a href="/ja/JSObject" title="ja/JSObject">JSObject</a> *proto, <a href="/ja/JSObject" title="ja/JSObject">JSObject</a> *parent); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *</code></td> + <td>新たなオブジェクトを配置するコンテキスト<span class="comment">The context in which to create the new object. {{ jsapi-requires-request }}</td> </tr> <tr> <td><code>clasp</code></td> <td><code><a href="/ja/JSClass">JSClass</a> *</code></td> <td>オブジェクト生成時に利用するクラスへのポインタ。<code>NULL</code>を指定したときは、一般的なJavaScript <code>Object</code>が生成されます。<!--Pointer to the class to use for the new object. If this is <code>NULL</code>, an ordinary JavaScript <code>Object</code> is created.</span></td> + </tr> + <tr> + <td><code>proto</code></td> + <td><code><a href="/ja/JSObject" title="ja/JSObject">JSObject</a> *</code></td> + <td>クラスとなるプロトタイプオブジェクトへのポインタ<span class="comment">Pointer to the prototype object to use for the new class.</span></td> + </tr> + <tr> + <td><code>parent</code></td> + <td><code><a href="/ja/JSObject" title="ja/JSObject">JSObject</a> *</code></td> + <td>新たなオブジェクトの __parent__ プロパティに指定するオブジェクトへのポインタ<span class="comment">Pointer to which to set the new object's __parent__ property.</span></td> + </tr> + </tbody> +</table> + +<h2 id=".E8.A7.A3.E8.AA.AC" name=".E8.A7.A3.E8.AA.AC">解説</h2> + +<p><code>JS_ConstructObject</code>は、与えられたクラス、プロトタイプ、親オブジェクト、コンストラクタ関数をもとに新たなオブジェクトのインスタンスを生成する関数です。<code>cx</code>には、新たなオブジェクトを配置するランタイムと結び付けられたコンテキストへのポインタを指定します。<code>clasp</code>には、ファイナライズ処理などの内部関数が定義された既存クラスへのポインタを指定します。<code>proto</code>は、新たなオブジェクトのプロトタイプとなるオブジェクトへのポインタを指定する引数です。 <span class="comment"><code>JS_ConstructObject</code> instantiates a new object based on a specified class, prototype, and parent object, and then invokes its constructor function. <code>cx</code> is a pointer to a context associated with the runtime in which to establish the new object. <code>clasp</code> is a pointer to an existing class to use for internal methods, such as finalize. <code>proto</code> is an optional pointer to the prototype object with which to associate the new object.</span></p> + +<p>自分自身をプロトタイプオブジェクトにするには、<code>proto</code>に<code>NULL</code>を指定してください。このとき、<code>clasp</code>がプロトタイプを定義している場合には、<code>JS_ConstructObject</code>は新たなオブジェクトのプロトタイプにそれを用います。定義していない場合は、空オブジェクトスタブをプロトタイプとします。 <span class="comment">Set <code>proto</code> to <code>NULL</code> to force JS to assign a prototype object for you. In this case, <code>JS_ConstructObject</code> attempts to assign the new object the prototype object belonging to <code>clasp</code>, if one is defined there. Otherwise, it creates an empty object stub for the prototype.</span></p> + +<p><code>parent</code>には、新規オブジェクトの親プロパティとなるオブジェクトへのポインタを指定します。この引数はオプションであり、<code>parent</code>に<code>NULL</code>を指定することで親プロパティを持たないオブジェクトになります。 <span class="comment"><code>parent</code> is an optional pointer to an existing object to which to set the new object's parent object property. You can set <code>parent</code> to <code>NULL</code> if you do not want to set the parent property.</span></p> + +<p><code>JS_ConstructObject</code>が成功したとき、新たに生成されたオブジェクトへのポインタをその返値とします。失敗したときは<code>NULL</code>を返します。 <span class="comment">On success, <code>JS_ConstructObject</code> returns a pointer to the newly instantiated object. Otherwise it returns <code>NULL</code>.</span></p> + +<h2 id=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE" name=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE">関連項目</h2> + +<p>{{ LXRSearch("ident", "i", "JS_ConstructObject") }}</p> + +<p><a href="/ja/JS_DefineObject" title="ja/JS_DefineObject">JS_DefineObject</a>, <a href="/ja/JS_GetFunctionObject" title="ja/JS_GetFunctionObject">JS_GetFunctionObject</a>, <a href="/ja/JS_NewArrayObject" title="ja/JS_NewArrayObject">JS_NewArrayObject</a>, <a href="/ja/JS_NewObject" title="ja/JS_NewObject">JS_NewObject</a>, <a href="/ja/JS_ValueToObject" title="ja/JS_ValueToObject">JS_ValueToObject</a></p> + +<p>{{ languages( { "en": "en/JS_ConstructObject" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_defineobject/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_defineobject/index.html new file mode 100644 index 0000000000..782201ccc5 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_defineobject/index.html @@ -0,0 +1,126 @@ +--- +title: JS_DefineObject +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DefineObject +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DefineObject +--- +<p> +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_NewRuntime</code></div> +<p></p> + +<p>あるオブジェクトのプロパティとなるオブジェクトを生成する関数です。 <span class="comment">Create an object that is a property of another object.</span> {{ 英語版章題("Syntax") }}</p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval">JSObject * JS_DefineObject(JSContext *cx, JSObject *obj, + const char *name, JSClass *clasp, JSObject *proto, + uintN flags); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code>JSContext *</code></td> + <td>エラー報告に用いるランタイム環境から派生したコンテキストへのポインタ<span class="comment">Pointer to a JS context from which to derive runtime information for error reporting.</span> {{ Jsapi-requires-request() }}</td> + </tr> + <tr> + <td><code>obj</code></td> + <td><code>JSObject *</code></td> + <td>生成したオブジェクトをプロパティとして持つオブジェクトへのポインタ<span class="comment">Object to which this new object belongs as a property.</span></td> + </tr> + <tr> + <td><code>name</code></td> + <td><code>const char *</code></td> + <td><code>obj</code>でのプロパティ名<span class="comment">Name of the property that encapsulates the new object in <code>obj</code>.</span></td> + </tr> + <tr> + <td><code>clasp</code></td> + <td><code>JSClass *</code></td> + <td>オブジェクト生成に用いるクラス<span class="comment">Class to use for the new object.</span></td> + </tr> + <tr> + <td><code>proto</code></td> + <td><code>JSObject *</code></td> + <td>オブジェクト生成に用いるプロトタイプ<span class="comment">Prototype object to use for the new object.</span></td> + </tr> + <tr> + <td><code>flags</code></td> + <td><code>uintN</code></td> + <td>生成したオブジェクトの属性を指定するフラグ<span class="comment">Property flags for the new object.</span></td> + </tr> + </tbody> +</table> + +<p>{{ 英語版章題("Description") }}</p> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_DefineObject</code>は、オブジェクトのインスタンスを生成し、それを引数<code>obj</code>で指定した既存オブジェクトのプロパティとして設定する関数です。引数<code>name</code>で、<code>obj</code>でのプロパティ名を指定し、<code>flags</code>でそのプロパティの属性を指定します。以下の表で設定可能な<code>flags</code>の値を示します。これらの値は単一、あるいは複数の値の論理和として引数に与えることができます。 <span class="comment"><code>JS_DefineObject</code> instantiates and names a new object for an existing object, <code>obj</code>. <code>name</code> is the property name to assign to <code>obj</code> to hold the new object, and <code>flags</code> contains the property flags to set for the newly created property. The following table lists possible values you can pass in <code>flags</code>, either singly, or <code>OR</code>'d together:</span></p> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Flag</th> + <th>Purpose</th> + </tr> + <tr> + <td><code>JSPROP_ENUMERATE</code></td> + <td><code>for</code>と<code>in</code>ループを使ったアクセス(<a href="ja/Core_JavaScript_1.5_Guide/Object_Manipulation_Statements">Core JavaScript 1.5 Guide:Object Manipulation Statements</a>)を可能にします。<span class="comment">Property is visible to <code>for</code> and <code>in</code> loops.</span></td> + </tr> + <tr> + <td><code>JSPROP_READONLY</code></td> + <td>プロパティの値を読み取り専用にします。<span class="comment">Property is read only.</span></td> + </tr> + <tr> + <td><code>JSPROP_PERMANENT</code></td> + <td>プロパティの削除を不可能にします。<span class="comment">Property cannot be deleted.</span></td> + </tr> + <tr> + <td><code>JSPROP_EXPORTED</code></td> + <td>Property can be imported by other objects.</td> + </tr> + <tr> + <td><code>JSPROP_INDEX</code></td> + <td>Property is actually an index into an array of properties, and is cast to a const <code>char *</code>.</td> + </tr> + </tbody> +</table> + +<p>引数<code>clasp</code>はオブジェクトの生成時に用いる基底クラスへのポインタ、引数<code>proto</code>はプロトタイプへのポインタをそれぞれとります。<code>proto</code>に<code>NULL</code>を指定した場合、JavaScriptは自分自身をプロトタイプとします。引数<code>obj</code>はオブジェクトの親オブジェクトになります。 <span class="comment"><code>clasp</code> is a pointer to the base class to use when creating the new object, and <code>proto</code> is an pointer to the prototype upon which to base the new object. If you set <code>proto</code> to <code>NULL</code>, JS sets the prototype object for you. The parent object for the new object is set to <code>obj</code>.</span></p> + +<p><code>JS_DefineObject</code>が成功したとき、返値は新たに生成したプロパティオブジェクトへのポインタになります。もしすでにプロパティが設定されていた場合、オブジェクトは生成されず、返り値は<code>NULL</code>になります。 <span class="comment"><code>JS_DefineObject</code> returns a pointer to the newly created property object if successful. If the property already exists, or cannot be created, <code>JS_DefineObject</code> returns <code>NULL</code>.</span> {{ 英語版章題("See Also") }}</p> + +<h3 id=".E5.8F.82.E7.85.A7" name=".E5.8F.82.E7.85.A7">参照</h3> + +<table class="fullwidth-table"> + <tbody> + <tr> + <td>Groups</td> + <td><a href="ja/JSAPI_Reference#Functions">Functions</a></td> + </tr> + <tr> + <td>Documents</td> + <td>{{ LXRSearch("ident", "i", "JS_DefineObject", "LXR ID Search") }}</td> + </tr> + <tr> + <td>Entries</td> + <td> + <p><a href="ja/JSClass">JSClass</a>, <a href="ja/JS_DefineConstDoubles">JS_DefineConstDoubles</a>, <a href="ja/JS_DefineElement">JS_DefineElement</a>, <a href="ja/JS_DefineFunction">JS_DefineFunction</a>, <a href="ja/JS_DefineFunctions">JS_DefineFunctions</a>, <a href="ja/JS_DefineProperties">JS_DefineProperties</a>, <a href="ja/JS_DefineProperty">JS_DefineProperty</a>, <a href="ja/JS_DefinePropertyWithTinyId">JS_DefinePropertyWithTinyId</a>, <a href="ja/JS_NewObject">JS_NewObject</a>, <a href="ja/JS_ValueToObject">JS_ValueToObject</a></p> + </td> + </tr> + </tbody> +</table> + +<div class="noinclude"> </div> + +<p>{{ languages( { "en": "en/JS_DefineObject" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroycontext/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroycontext/index.html new file mode 100644 index 0000000000..be77b35a40 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroycontext/index.html @@ -0,0 +1,55 @@ +--- +title: JS DestroyContext +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyContext +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyContext +--- +<p> + + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_DestroyContext</code></div> + + +<p></p> + +<p><code>JSContext</code>を解放します。</p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval">void <strong>JS_DestroyContext</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx); + +void <strong>JS_DestroyContextNoGC</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx); + +void <strong>JS_DestroyContextMaybeGC</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *</code></td> + <td>解放するコンテキスト</td> + </tr> + </tbody> +</table> + +<h2 id=".E8.A7.A3.E8.AA.AC" name=".E8.A7.A3.E8.AA.AC">解説</h2> + +<p>これらの関数はコンテキスト<code>cx</code>を解放します。それに加え、<code>JS_DestroyContext</code>は実行し、<code>cx</code>の<a href="/ja/JS_GetGlobalObject" title="ja/JS_GetGlobalObject">グローバルオブジェクト</a>が利用したメモリを回収するためにガベージコレクションを実行します。<code>JS_DestroyContextNoGC</code>はガベージコレクションを実行しません。<code>JS_DestroyContextMaybeGC</code>では、JavaScriptエンジンが十分なメモリ領域を解放できる可能性を判断し、ガベージコレクションを実行するか否かを判断します。 <span class="comment">These functions destroy a context, <code>cx</code>. <code>JS_DestroyContext</code> additionally performs garbage collection to reclaim any memory that was being used by <code>cx</code>'s <a href="/ja/JS_GetGlobalObject">global object</a>. <code>JS_DestroyContextNoGC</code> does not perform garbage collection. <code>JS_DestroyContextMaybeGC</code> may or may not perform garbage collection; the engine makes an educated guess as to whether enough memory would be reclaimed to justify the work.</span></p> + +<p><code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>を有効にしたビルドでは、<code>cx</code>のrequest内でこの関数を呼ばないでください。</p> + +<p><code><a href="/ja/JS_SetContextCallback" title="ja/JS_SetContextCallback">JS_SetContextCallback</a></code>が以前に実行された場合は、そこで設定したコールバック関数が実行されます。 <span class="comment">In a <code><a href="/ja/JS_THREADSAFE">JS_THREADSAFE</a></code> build, the caller must '''not''' be in a request on <code>cx</code>. If <code><a href="/ja/JS_SetContextCallback">JS_SetContextCallback</a></code> has been called, this calls the callback.</span></p> + +<p>{{ LXRSearch("ident", "i", "JS_DestroyContext") }}</p> + +<p>{{ languages( { "en": "en/JS_DestroyContext" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroyruntime/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroyruntime/index.html new file mode 100644 index 0000000000..d65b41c6d6 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_destroyruntime/index.html @@ -0,0 +1,45 @@ +--- +title: JS DestroyRuntime +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyRuntime +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DestroyRuntime +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_DestroyRuntime</code></div> + +<p></p> + +<p>JavaScriptランタイム環境を解放します。 <span class="comment">Frees a JavaScript runtime.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval">void <strong>JS_DestroyRuntime</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> *rt); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>rt</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> *</code></td> + <td>解放するランタイム<span class="comment">The runtime to destroy.</span></td> + </tr> + </tbody> +</table> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_DestroyRuntime</code>は、JavaScriptランタイム環境<code>rt</code>を解放する関数です。JSAPIの利用を終えた後は必ず<code>JS_DestroyRuntime</code>を呼び出してください。<code>JS_DestroyRuntime</code>を呼ぶことで、ガベージコレクションおよび<code><a href="/ja/JS_NewRuntime" title="ja/JS_NewRuntime">JS_NewRuntime</a></code>によって確保されたメモリ領域の解放が行われます。 <span class="comment"><code>JS_DestroyRuntime</code> frees the specified the JavaScript runtime environment, <code>rt</code>. Call <code>JS_DestroyRuntime</code> after completing all other JS API calls. <code>JS_DestroyRuntime</code> garbage collects and frees the memory previously allocated by <code><a href="/ja/JS_NewRuntime">JS_NewRuntime</a></code>.</span></p> + +<p>{{ LXRSearch("ident", "i", "JS_DestroyRuntime") }}</p> + +<p>{{ languages( { "en": "en/JS_DestroyRuntime" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_dumpheap/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_dumpheap/index.html new file mode 100644 index 0000000000..4a9b9b3dba --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_dumpheap/index.html @@ -0,0 +1,110 @@ +--- +title: JS_DumpHeap +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DumpHeap +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_DumpHeap +--- +<div>{{SpiderMonkeySidebar("JSAPI")}}</div> + +<p>{{ obsolete_header("jsapi38") }}</p> + +<p>{{ Jsapi_minversion_header("1.8") }}</p> + +<div class="summary"><code>DEBUG</code> のみ。ヒープに割り当てられたもののオブジェクトグラフをダンプします。</div> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="brush: cpp">bool +JS_DumpHeap(JSRuntime *rt, FILE *fp, void* startThing, JSGCTraceKind kind, + void *thingToFind, size_t maxDepth, void *thingToIgnore); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td>{{jsapixref("JSRuntime", "JSContext *")}}</td> + <td>Pointer to a JS context. Every <code>JSContext</code> is permanently associated with a <code>JSRuntime</code>; each <code>JSRuntime</code> contains a GC heap.</td> + </tr> + <tr> + <td><code>fp</code></td> + <td><code>FILE *</code></td> + <td>File for the dump output.</td> + </tr> + <tr> + <td><code>startThing</code></td> + <td><code>void *</code></td> + <td><code>NULL</code> or a pointer to a GC thing (use {{jsapixref("JS::Value", "JS::Value::toGCThing()")}} to obtain a pointer to pass here). When null, dump all things reachable from the runtime roots. When non-null, dump only things reachable from the object indicated.</td> + </tr> + <tr> + <td><code>startKind</code></td> + <td><code>JSGCTraceKind</code></td> + <td>Trace kind of <code>startThing</code>, if <code>startThing</code> is not null. Must be <code>JSTRACE_OBJECT</code> when <code>startThing</code> is null.</td> + </tr> + <tr> + <td><code>thingToFind</code></td> + <td><code>void *</code></td> + <td><code>NULL</code> or a pointer to a GC thing. If this is non-null, JS_DumpHeap only dumps paths in the object graph leading to the specified thing.</td> + </tr> + <tr> + <td><code>maxDepth</code></td> + <td><code>size_t</code></td> + <td>The upper bound on the number of edges to descend from the graph roots.</td> + </tr> + <tr> + <td><code>thingToIgnore</code></td> + <td><code>void *</code></td> + <td><code>NULL</code> or a pointer to a GC thing that will be ignored during graph traversal.</td> + </tr> + </tbody> +</table> + +<pre class="brush: cpp">enum JSGCTraceKind +{ + // These trace kinds have a publicly exposed, although opaque, C++ type. + // Note: The order here is determined by our Value packing. Other users + // should sort alphabetically, for consistency. + JSTRACE_OBJECT = 0x00, + JSTRACE_STRING = 0x01, + JSTRACE_SYMBOL = 0x02, + JSTRACE_SCRIPT = 0x03, + + // Shape details are exposed through JS_TraceShapeCycleCollectorChildren. + JSTRACE_SHAPE = 0x04, + + // The kind associated with a nullptr. + JSTRACE_NULL = 0x06, + + // A kind that indicates the real kind should be looked up in the arena. + JSTRACE_OUTOFLINE = 0x07, + + // The following kinds do not have an exposed C++ idiom. + JSTRACE_BASE_SHAPE = 0x0F, + JSTRACE_JITCODE = 0x1F, + JSTRACE_LAZY_SCRIPT = 0x2F, + JSTRACE_TYPE_OBJECT = 0x3F, + + JSTRACE_LAST = JSTRACE_TYPE_OBJECT +}; +</pre> + +<h2 id="Description" name="Description">Description</h2> + +<p>See {{ Bug(378261) }} for detail.</p> + +<p>When tracing a thing, the GC needs to know about the layout of the object it is looking at. There are a fixed number of different layouts that the GC knows about. The "trace kind" is a static map which tells which layout a GC thing has.</p> + +<p>Although this map is public, the details are completely hidden. Not all of the matching C++ types are exposed, and those that are, are opaque.</p> + +<p>See {{jsapixref("JS::Value", "JS::Value::gcKind()")}} and {{jsapixref("JSTraceCallback")}} in <codde>Tracer.h</codde> for more details.</p> + +<h2 id="See_Also" name="See_Also">See Also</h2> + +<ul> + <li>{{bug(378261)}}</li> + <li>{{bug(1122842)}}</li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_evaluatescript/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_evaluatescript/index.html new file mode 100644 index 0000000000..a58d781ab4 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_evaluatescript/index.html @@ -0,0 +1,93 @@ +--- +title: JS EvaluateScript +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_EvaluateScript +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_EvaluateScript +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_EvaluateScript</code></div> + + +<p></p> + +<p>スクリプトのコンパイルおよび実行を行います。 <span class="comment">Compile and execute a script.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval"><a href="ja/JSBool">JSBool</a> <strong>JS_EvaluateScript</strong>(<a href="ja/JSContext">JSContext</a> *cx, <a href="ja/JSObject">JSObject</a> *obj, + const char *src, <a href="ja/UintN">uintN</a> length, const char *filename, + <a href="ja/UintN">uintN</a> lineno, <a href="ja/Jsval">jsval</a> *rval); + +<a href="ja/JSBool">JSBool</a> <strong>JS_EvaluateUCScript</strong>(<a href="ja/JSContext">JSContext</a> *cx, <a href="ja/JSObject">JSObject</a> *obj, + const <a href="ja/Jschar">jschar</a> *src, <a href="ja/UintN">uintN</a> length, const char *filename, + <a href="ja/UintN">uintN</a> lineno, <a href="ja/Jsval">jsval</a> *rval); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code><a href="ja/JSContext">JSContext</a> *</code></td> + <td>スクリプトを実行するコンテキスト<span class="comment">The context in which to run the script.</span> {{ Jsapi-requires-request() }}</td> + </tr> + <tr> + <td><code>obj</code></td> + <td><code><a href="ja/JSObject">JSObject</a> *</code></td> + <td>スクリプトと関連付けるオブジェクト<span class="comment">Object with which the script is associated.</span></td> + </tr> + <tr> + <td><code>src</code></td> + <td><code>const char *</code><em>or</em> <code>const <a href="ja/Jschar">jschar</a> *</code></td> + <td>コンパイル・実行対象となるスクリプト文字列<span class="comment">String containing the script to compile and execute.</span></td> + </tr> + <tr> + <td><code>length</code></td> + <td><code>size_t</code></td> + <td><code>src</code>の文字列長<span class="comment">The length of <code>src</code>, in characters.</span></td> + </tr> + <tr> + <td><code>filename</code></td> + <td><code>const char *</code></td> + <td>エラーメッセージ出力に利用されるスクリプトのファイル名またはそのURLを示す文字列。<span class="comment">Name of file or URL containing the script. Used to report filename or URL in error messages.</span></td> + </tr> + <tr> + <td><code>lineno</code></td> + <td><code><a href="ja/UintN">uintN</a></code></td> + <td>エラー発生時に出力される行数<span class="comment">Line number. Used to report the offending line in the file or URL if an error occurs.</span></td> + </tr> + <tr> + <td><code>rval</code></td> + <td><code><a href="ja/Jsval">jsval</a> *</code></td> + <td>実行結果の出力先。実行に成功したとき、<code>*rval</code>にはスクリプトの最終行の実行結果の値が格納されます。<span class="comment">Out parameter. On success, <code>*rval</code> receives the value of the last-executed expression statement processed in the script.</span></td> + </tr> + </tbody> +</table> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_EvaluateScript</code>は、オブジェクト<code>obj</code>に結合する形でスクリプトをコンパイル・実行する関数です。実行が成功したとき、<code>rval</code>にスクリプトの最終行の実行結果の値へのポインタが格納されています。この関数のUnicode版として、<code>JS_EvaluateUCScript</code>が用意されています。 <span class="comment"><code>JS_EvaluateScript</code> compiles and executes a script associated with a JS object, <code>obj</code>. On successful completion, <code>rval</code> is a pointer to a variable that holds the value from the last executed expression statement processed in the script. <code>JS_EvaluateUCScript</code> is the Unicode version of the function.</span></p> + +<p><code>src</code>はスクリプト文字列、<code>length</code>はその文字列の長さをそれぞれ引数として取ります。 <span class="comment"><code>src</code> is the string containing the text of the script. <code>length</code> indicates the size of the text version of the script in characters.</span></p> + +<p><code>filename</code>はスクリプトの位置を示すファイル名またはURLを引数として取ります。ここで指定した情報は、コンパイルエラーが発生したときのエラーメッセージに利用されます。<code>lineno</code>も同様にエラーメッセージとして出力される行番号として利用されます。 <span class="comment"><code>filename</code> is the name of the file (or URL) containing the script. This information is used in messages if an error occurs during compilation. Similarly, <code>lineno</code> is used to report the line number of the script or file where an error occurred during compilation.</span></p> + +<p>スクリプトのコンパイルと実行が成功したとき、<code>JS_EvaluateScript</code>および<code>JS_EvaluateUCScript</code>は<code>JS_TRUE</code>を、失敗したときは<code>JS_FALSE</code>をそれぞれ返します。コンパイル・実行に失敗したとき、<code>*rval</code>の値は未定義とみなす必要があります。 <span class="comment">If a script compiles and executes successfully, <code>JS_EvaluateScript</code> or <code>JS_EvaluateUCScript</code> returns <code>JS_TRUE</code>. Otherwise it returns <code>JS_FALSE</code>. On failure, your application should assume that <code>*rval</code> is undefined.</span></p> + +<h2 id=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE" name=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE">関連項目</h2> + +<p>{{ LXRSearch("ident", "i", "JS_EvaluateScript") }}<br> + {{ LXRSearch("ident", "i", "JS_EvaluateUCScript") }}</p> + +<p><a href="ja/JS_CompileFile">JS_CompileFile</a>, <a href="ja/JS_CompileScript">JS_CompileScript</a>, <a href="ja/JS_DecompileScript">JS_DecompileScript</a>, <a href="ja/JS_DestroyScript">JS_DestroyScript</a>, <a href="ja/JS_EvaluateScriptForPrincipals">JS_EvaluateScriptForPrincipals</a>, <a href="ja/JS_ExecuteScript">JS_ExecuteScript</a></p> + +<p>{{ languages( { "en": "en/JS_EvaluateScript" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getgcparameter/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getgcparameter/index.html new file mode 100644 index 0000000000..1bfa969e7c --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getgcparameter/index.html @@ -0,0 +1,323 @@ +--- +title: JS_GetGCParameter +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetGCParameter +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetGCParameter +--- +<div>{{SpiderMonkeySidebar("JSAPI")}}</div> + +<div class="summary"> +<p>ガベージコレクションに関連するパフォーマンスパラメータを調整します。</p> +</div> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="brush: cpp">uint32_t +JS_GetGCParameter(JSRuntime *rt, JSGCParamKey key); + +void +JS_SetGCParameter(JSRuntime *rt, JSGCParamKey key, uint32_t value); + +uint32_t +JS_GetGCParameterForThread(JSContext *cx, JSGCParamKey key); // Added in SpiderMonkeySidebar 17 + +void +JS_SetGCParameterForThread(JSContext *cx, JSGCParamKey key, uint32_t value); // Added in SpiderMonkeySidebar 17 +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>rt</code></td> + <td>{{jsapixref("JSRuntime", "JSRuntime *")}}</td> + <td>The runtime to configure.</td> + </tr> + <tr> + <td><code>cx</code></td> + <td>{{jsapixref("JSRuntime", "JSContext *")}}</td> + <td>The context to configure. {{ Jsapi-requires-request() }}</td> + </tr> + <tr> + <td><code>key</code></td> + <td><code>JSGCParamKey</code></td> + <td>Specifies which garbage collection parameter to get or set.</td> + </tr> + <tr> + <td><code>value</code></td> + <td><code>uint32_t</code></td> + <td><em>(<code>JS_SetGCParameter</code> only)</em> The value to assign to the parameter.</td> + </tr> + </tbody> +</table> + +<pre class="brush: cpp">typedef enum JSGCParamKey { + JSGC_MAX_BYTES, + JSGC_MAX_MALLOC_BYTES, + JSGC_MAX_NURSERY_BYTES, + JSGC_BYTES, + JSGC_NUMBER, + JSGC_MODE, + JSGC_UNUSED_CHUNKS, + JSGC_TOTAL_CHUNKS, + JSGC_SLICE_TIME_BUDGET, + JSGC_MARK_STACK_LIMIT, + JSGC_HIGH_FREQUENCY_TIME_LIMIT, + JSGC_HIGH_FREQUENCY_LOW_LIMIT, + JSGC_HIGH_FREQUENCY_HIGH_LIMIT, + JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MAX, + JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MIN, + JSGC_LOW_FREQUENCY_HEAP_GROWTH, + JSGC_DYNAMIC_HEAP_GROWTH, + JSGC_DYNAMIC_MARK_SLICE, + JSGC_ALLOCATION_THRESHOLD, + JSGC_MIN_EMPTY_CHUNK_COUNT, + JSGC_MAX_EMPTY_CHUNK_COUNT, + JSGC_COMPACTION_ENABLED, + JSGC_ALLOCATION_THRESHOLD_FACTOR, + JSGC_ALLOCATION_THRESHOLD_FACTOR_AVOID_INTERRUPT, + JSGC_NURSERY_FREE_THRESHOLD_FOR_IDLE_COLLECTION, + JSGC_PRETENURE_THRESHOLD, + JSGC_PRETENURE_GROUP_THRESHOLD, + JSGC_NURSERY_FREE_THRESHOLD_FOR_IDLE_COLLECTION_PERCENT, + JSGC_MIN_NURSERY_BYTES, + JSGC_MIN_LAST_DITCH_GC_PERIOD, +} JSGCParamKey; +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Value (C++/JS Shell)</th> + <th>Description</th> + </tr> + <tr> + <td><code>JSGC_MAX_BYTES</code> / <code>"maxBytes"</code></td> + <td>Maximum nominal heap before last ditch GC.</td> + </tr> + <tr> + <td><code>JSGC_MAX_MALLOC_BYTES</code> / <code>"maxMallocBytes"</code></td> + <td>Number of JS_malloc bytes before last ditch GC.</td> + </tr> + <tr> + <td><code>JSGC_MAX_NURSERY_BYTES</code> / <code>"maxNurseryBytes"</code></td> + <td>Maximum size the nursery may grow to, or 0 to disable generational GC.</td> + </tr> + <tr> + <td><code>JSGC_MIN_NURSERY_BYTES</code> / <code>"minNurseryBytes"</code></td> + <td>Minimum size the nursery may shrink to.</td> + </tr> + <tr> + <td><code>JSGC_BYTES</code> / <code>"gcBytes"</code></td> + <td>Amount of bytes allocated by the GC.</td> + </tr> + <tr> + <td><code>JSGC_NUMBER</code> / <code>"gcNumber"</code></td> + <td>Number of times GC has been invoked. Includes both major and minor GC.</td> + </tr> + <tr> + <td><code>JSGC_MODE</code> / <code>"mode"</code></td> + <td> + <p>Select GC mode:</p> + + <dl> + <dt><code>JSGC_MODE_GLOBAL</code> (0)</dt> + <dd>The GC runs all objects are visited in a single<em>slice</em>.</dd> + <dt><code>JSGC_MODE_ZONE</code> (1)</dt> + <dd>The GC runs only the objects that belong to some<em>zones</em> are visited in a single<em>slice</em>.</dd> + <dt><code>JSGC_MODE_INCREMENTAL</code> (2)</dt> + <dd>The GC runs all objects are visited in multiple<em>slices</em>.</dd> + <dt><code>JSGC_MODE_ZONE_INCREMENTAL</code> (3)</dt> + <dd>The GC runs only the objects that belong to some<em>zones</em> are visited in multiple<em>slices</em>.</dd> + </dl> + + <p>This does not affect generational GC, see <code>JSGC_MAX_NURSERY_BYTES</code></p> + </td> + </tr> + <tr> + <td><code>JSGC_UNUSED_CHUNKS</code> / <code>"unusedChunks"</code></td> + <td>Number of cached empty GC chunks.</td> + </tr> + <tr> + <td><code>JSGC_TOTAL_CHUNKS</code> / <code>"totalChunks"</code></td> + <td>Total number of allocated GC chunks.</td> + </tr> + <tr> + <td><code>JSGC_SLICE_TIME_BUDGET</code> / <code>"sliceTimeBudget"</code></td> + <td>Max milliseconds to spend in an incremental GC slice. 0 for infinite.</td> + </tr> + <tr> + <td><code>JSGC_MARK_STACK_LIMIT</code> / <code>"markStackLimit"</code></td> + <td>Maximum size the GC mark stack can grow to (units: entries).</td> + </tr> + <tr> + <td><code>JSGC_HIGH_FREQUENCY_TIME_LIMIT</code> / <code>"highFrequencyTimeLimit"</code></td> + <td>GCs less than this far apart in time will be considered 'high-frequency GCs'.</td> + </tr> + <tr> + <td><code>JSGC_HIGH_FREQUENCY_LOW_LIMIT</code> / <code>"highFrequencyLowLimit"</code></td> + <td rowspan="4"> + <p>Controls for dynamic heap growth. When the GC is in "high frequency" mode (see above) then, the heap will be allowed to grow between collections according to these four parameters. See ZoneHeapThreshold::computeZoneHeapGrowthFactorForHeapSize in GC.cpp for the details.</p> + + <p>The first two parameters are in MB and the remaining two are in percentage of heap size.</p> + </td> + </tr> + <tr> + <td><code>JSGC_HIGH_FREQUENCY_HIGH_LIMIT</code> / <code>"highFrequencyHighLimit"</code></td> + </tr> + <tr> + <td><code>JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MAX</code> / <code>"highFrequencyHeapGrowthMax"</code></td> + </tr> + <tr> + <td><code>JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MIN</code> / <code>"highFrequencyHeapGrowthMin"</code></td> + </tr> + <tr> + <td><code>JSGC_LOW_FREQUENCY_HEAP_GROWTH</code> / <code>"lowFrequencyHeapGrowth"</code></td> + <td>Heap growth percentage for low frequency GCs.</td> + </tr> + <tr> + <td><code>JSGC_DYNAMIC_HEAP_GROWTH</code> / <code>"dynamicHeapGrowth"</code></td> + <td>If false, the heap growth percentage is fixed at 300%. If true, it is determined based on whether GCs are high- or low- frequency.</td> + </tr> + <tr> + <td><code>JSGC_DYNAMIC_MARK_SLICE</code> / <code>"dynamicMarkSlice"</code></td> + <td>If true, high-frequency GCs will use a longer mark slice.</td> + </tr> + <tr> + <td><code>JSGC_ALLOCATION_THRESHOLD</code> / <code>"allocationThreshold"</code></td> + <td>Lower limit after which we limit the heap growth. The heap will be collected if it is greater than: <code>MAX(allocThreshold, lastSize) * thresholdFactor</code>, This establishes allocThreshold as a baseline or default heap size.</td> + </tr> + <tr> + <td><code>JSGC_ALLOCATION_THRESHOLD_FACTOR</code> / <code>"allocationThresholdFactor"</code></td> + <td rowspan="2"> + <p>These thresholds (as percentages) are compared with the zone threshold (above) to decide when to begin an incremental collection. <code>JSGC_ALLOCATION_THRESHOLD_FACTOR_AVOID_INTERRUPT</code> is used when a GC is already in progress for other zones and we may wish to avoid interrupting it.</p> + + <p>Additionally if a zone expands beyond the threshold without this factor, then it will be collected non-incrementally</p> + </td> + </tr> + <tr> + <td><code>JSGC_ALLOCATION_THRESHOLD_FACTOR_AVOID_INTERRUPT</code> / <code>"allocationThresholdfactorAvoidInterrupt"</code></td> + </tr> + <tr> + <td><code>JSGC_MIN_EMPTY_CHUNK_COUNT</code> / <code>"minEmptyChunkCount"</code></td> + <td>We try to keep at least this many unused chunks in the free chunk pool at all times, even after a shrinking GC.</td> + </tr> + <tr> + <td><code>JSGC_MAX_EMPTY_CHUNK_COUNT</code> / <code>"maxEmptyChunkCount"</code></td> + <td>We never keep more than this many unused chunks in the free chunk pool.</td> + </tr> + <tr> + <td><code>JSGC_COMPACTION_ENABLED</code> / <code>"compactingEnabled"</code></td> + <td>non-zero to enable compacting, zero to disable.</td> + </tr> + <tr> + <td><code>JSGC_NURSERY_FREE_THRESHOLD_FOR_IDLE_COLLECTION</code> / <code>"nurseryFreeThresholdForIdleCollection"</code></td> + <td>Collect the nursery in idle time if it has less than this many bytes of free space.</td> + </tr> + <tr> + <td><code>JSGC_NURSERY_FREE_THRESHOLD_FOR_IDLE_COLLECTION_PERCENT</code> / <code>"nurseryFreeThresholdForIdleCollectionPercent"</code></td> + <td>Collect the nursery in idle time if it has less than this percentage of capacity free (value from 0 - 99).</td> + </tr> + <tr> + <td><code>JSGC_PRETENURE_THRESHOLD</code> / <code>"pretenureThreshold"</code></td> + <td>If this percentage of the nursery is tenured and the nursery is at least 4MB, then process object groups to look for pretenuring candidates.</td> + </tr> + <tr> + <td><code>JSGC_PRETENURE_GROUP_THRESHOLD</code> / <code>"pretenureGroupThreshold"</code></td> + <td>If more than this number of objects in a given object group are tenured, then pretenruing will be enabled for new objects in this group.</td> + </tr> + <tr> + <td><code>JSGC_MIN_LAST_DITCH_GC_PERIOD</code> / <code>"minLastDitchGCPeriod"</code></td> + <td>The minimum time to allow between triggering last ditch GCs in seconds.</td> + </tr> + </tbody> +</table> + +<h2 id="Description" name="Description">説明</h2> + +<p><code>JS_GetGCParameter</code> returns the current parameter of the garbage collection.</p> + +<p>If successful, <code>JS_GetGCParameter</code> returns the current parameter.</p> + +<p><code>JS_SetGCParameter</code> ajusts the parameter of the garbage collection.</p> + +<h2 id="See_Also" name="See_Also">あわせて参照</h2> + +<ul> + <li>{{ LXRSearch("ident", "i", "JS_GetGCParameter") }}</li> + <li>{{ LXRSearch("ident", "i", "JS_SetGCParameter") }}</li> + <li>{{bug(474801)}} + <ul> + <li><code>JSGC_BYTES</code></li> + <li><code>JSGC_NUMBER</code></li> + </ul> + </li> + <li>{{bug(474497)}} + <ul> + <li><code>JSGC_MAX_CODE_CACHE_BYTES</code></li> + <li>This option no-longer exists</li> + <li><code>JS_GetGCParameterForThread</code></li> + <li><code>JS_SetGCParameterForThread</code></li> + </ul> + </li> + <li>{{bug(624229)}} + <ul> + <li><code>JSGC_MODE</code></li> + </ul> + </li> + <li>{{bug(631733)}} + <ul> + <li><code>JSGC_UNUSED_CHUNKS</code></li> + </ul> + </li> + <li>{{bug(674480)}} + <ul> + <li><code>JSGC_TOTAL_CHUNKS</code></li> + </ul> + </li> + <li>{{bug(641025)}} + <ul> + <li><code>JSGC_SLICE_TIME_BUDGET</code></li> + </ul> + </li> + <li>{{bug(673551)}} + <ul> + <li><code>JSGC_MARK_STACK_LIMIT</code></li> + </ul> + </li> + <li>{{bug(765435)}} + <ul> + <li><code>JSGC_HIGH_FREQUENCY_TIME_LIMIT</code></li> + <li><code>JSGC_HIGH_FREQUENCY_LOW_LIMIT</code></li> + <li><code>JSGC_HIGH_FREQUENCY_HIGH_LIMIT</code></li> + <li><code>JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MAX</code></li> + <li><code>JSGC_HIGH_FREQUENCY_HEAP_GROWTH_MIN</code></li> + <li><code>JSGC_LOW_FREQUENCY_HEAP_GROWTH</code></li> + <li><code>JSGC_DYNAMIC_HEAP_GROWTH</code></li> + <li><code>JSGC_DYNAMIC_MARK_SLICE</code></li> + </ul> + </li> + <li>{{bug(800063)}} + <ul> + <li><code>JSGC_ALLOCATION_THRESHOLD</code></li> + </ul> + </li> + <li>{{bug(871005)}} + <ul> + <li><code>JSGC_DECOMMIT_THRESHOLD</code></li> + <li>This option is no-longer exists</li> + </ul> + </li> + <li>{{bug(1017141)}} + <ul> + <li><code>JSGC_MIN_EMPTY_CHUNK_COUNT</code></li> + <li><code>JSGC_MAX_EMPTY_CHUNK_COUNT</code></li> + </ul> + </li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntime/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntime/index.html new file mode 100644 index 0000000000..36a7593d57 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntime/index.html @@ -0,0 +1,47 @@ +--- +title: JS GetRuntime +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntime +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntime +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_GetRuntime</code></div> + + + +<p></p> + +<p><code>JSRuntime</code>へのポインタを取得します。 <span class="comment">Retrieves a pointer to the <code>JSRuntime</code>.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval"><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> * <strong>JS_GetRuntime</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *cx); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> *</code></td> + <td>コンテキスト</td> + </tr> + </tbody> +</table> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_GetRuntime</code>は、<code>JSContext</code> <code>cx</code>と関連付けられた<code>JSRuntime</code>へのポインタを取得する関数です。各コンテキストは、その生成時に指定した (<code><a href="/ja/JS_NewContext" title="ja/JS_NewContext">JS_NewContext</a></code>を参照) <code>JSRuntime</code>と関連付けられており、<code>JS_GetRuntime</code>を使うことでその関連付けを取得することができます。 <span class="comment"><code>JS_GetRuntime</code> retrieves a pointer to the <code>JSRuntime</code> with which a specified <code>JSContext</code>, <code>cx</code>, is associated. Each context is associated with a particular <code>JSRuntime</code> when it is created (see <code><a href="/ja/JS_NewContext">JS_NewContext</a></code>); <code>JS_GetRuntime</code> provides a convenient, programmatic way to look up the association.</span></p> + +<p>{{ LXRSearch("ident", "i", "JS_GetRuntime") }}</p> + +<p>{{ languages( { "en": "en/JS_GetRuntime" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntimeprivate/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntimeprivate/index.html new file mode 100644 index 0000000000..c4f3f7937b --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_getruntimeprivate/index.html @@ -0,0 +1,59 @@ +--- +title: JS GetRuntimePrivate +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntimePrivate +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_GetRuntimePrivate +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_GetRuntimePrivate</code></div> + + +<p></p> + +<p><code>JSRuntime</code>オブジェクトと関連付けられたアプリケーション固有のフィールドにアクセスします。 <span class="comment">Access a <code>JSRuntime</code> field for application-specific data.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval">void * <strong>JS_GetRuntimePrivate</strong>(<a href="ja/JSRuntime">JSRuntime</a> *rt); + +void <strong>JS_SetRuntimePrivate</strong>(<a href="ja/JSRuntime">JSRuntime</a> *rt, void *data); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>rt</code></td> + <td><code><a href="ja/JSRuntime">JSRuntime</a> *</code></td> + <td>JavaScriptランタイム環境<span class="comment">Any JS runtime.</span></td> + </tr> + <tr> + <td><code>data</code></td> + <td><code>void *</code></td> + <td><em>(<code>JS_SetRuntimePrivate</code>のみ)</em>ランタイム<code>rt</code>と関連付けるアプリケーション固有のデータへのポインタ <span class="comment">''(in <code>JS_SetRuntimePrivate</code>)'' Pointer to application-defined data to be associated with the runtime <code>rt</code>.</span></td> + </tr> + </tbody> +</table> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p>各<code>JSRuntime</code>内には、アプリケーション内で用いる任意のデータを指し示す<code>void *</code>型のフィールドが存在します。このフィールドは、コールバック関数が容易にアクセスできる領域であるため、その中でのデータ格納に有用に使えます。<code>JS_GetRuntimePrivate</code>でフィールドの値を取得し、<code>JS_SetRuntimePrivate</code>で値を設定します。フィールドの初期値は<code>NULL</code>に設定されています。 <span class="comment">Each <code>JSRuntime</code> has a field of type <code>void *</code> which the application may use for any purpose. It is especially useful for storing data which callbacks may then easily access. <code>JS_GetRuntimePrivate</code> gets the value of this field and <code>JS_SetRuntimePrivate</code> sets it. The field is initially <code>NULL</code>.</span></p> + +<p>このプライベートなデータのメモリ管理はアプリケーション側の責任になります。JavaScriptエンジン自体がこの領域を利用することはありません。 <span class="comment">Memory management for this private data is the application's responsibility. The JavaScript engine itself never uses it.</span></p> + +<h2 id=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE" name=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE">関連項目</h2> + +<p>{{ LXRSearch("ident", "i", "JS_GetRuntimePrivate") }}</p> + +<p><a href="ja/JS_GetContextPrivate">JS_GetContextPrivate</a>, <a href="ja/JS_SetContextPrivate">JS_SetContextPrivate</a>, <a href="ja/JS_GetPrivate">JS_GetPrivate</a>, <a href="ja/JS_SetPrivate">JS_SetPrivate</a>, <a href="ja/JS_GetInstancePrivate">JS_GetInstancePrivate</a></p> + +<p>{{ languages( { "en": "en/JS_GetRuntimePrivate" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_init/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_init/index.html new file mode 100644 index 0000000000..1d52ec7034 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_init/index.html @@ -0,0 +1,35 @@ +--- +title: JS_Init +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Init +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Init +--- +<div>{{obsolete_header}}</div> + + +<h2 id="Syntax" name="Syntax">構文</h2> + + +<pre class="syntaxbox"><a href="/ja/docs/JSRuntime" title="JSRuntime">JSRuntime</a> * <strong>JS_Init</strong>(<a href="/ja/docs/jsint" title="jsint">uint32</a> maxbytes); +</pre> + + +<table class="standard-table"> + <thead> + <tr> + <th>名称</th> + <th>型</th> + <th>説明</th> + </tr> +</thead> +<tbody> + <tr> + <td><code>maxbytes</code></td> + <td><code><a href="/ja/docs/jsint" title="jsint">uint32</a></code></td> + <td>ガベージコレクション実行後に割り当てられたバイト数</td> + </tr> + </tbody> +</table> + + +<h2 id="Description" name="Description">説明</h2> +<p><code>JS_Init</code> は廃止されました。替わりに <code><a href="/ja/docs/JS_NewRuntime" title="JS_NewRuntime">JS_NewRuntime</a></code> を使用して下さい。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_lock/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_lock/index.html new file mode 100644 index 0000000000..1ffb9dee10 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_lock/index.html @@ -0,0 +1,37 @@ +--- +title: JS_Lock +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Lock +tags: + - JSAPI_Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_Lock +--- +<div> + {{obsolete_header("jsapi12")}}</div> +<p>JS ランタイム環境をロックします。</p> +<h2 id="Syntax" name="Syntax">構文</h2> +<pre class="syntaxbox">void <strong>JS_Lock</strong>(<a href="/ja/docs/JSRuntime" title="JSRuntime">JSRuntime</a> *rt); +</pre> +<table class="standard-table"> + <thead> + <tr> + <th>名称</th> + <th>型</th> + <th>説明</th> + </tr> + </thead> + <tbody> + <tr> + <td><code>rt</code></td> + <td><code><a href="/ja/docs/JSRuntime" title="JSRuntime">JSRuntime</a> *</code></td> + <td>ロックするランタイムへのポインタ</td> + </tr> + </tbody> +</table> +<h2 id="Description" name="Description">説明</h2> +<p><code>JS_Lock</code> は非推奨 API です。使用しないで下さい。</p> +<h2 id="See_also" name="See_also">関連情報</h2> +<ul> + <li>{{LXRSearch("ident", "i", "JS_Lock")}}</li> + <li><a href="/ja/docs/JS_GetRuntime" title="JS_GetRuntime"><code>JS_GetRuntime</code></a> 、 <a href="/ja/docs/SpiderMonkey/JSAPI_Reference/JS_Unlock"><code>JS_Unlock</code></a></li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newcontext/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newcontext/index.html new file mode 100644 index 0000000000..ab77638f70 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newcontext/index.html @@ -0,0 +1,93 @@ +--- +title: JS NewContext +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewContext +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewContext +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_NewContext</code></div> + +<p></p> + +<p>新たなJavaScriptコンテキストを生成します。 <span class="comment">Creates a new JavaScript context.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<p><span class="comment">= Syntax =</span></p> + +<pre class="eval"><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a> * <strong>JS_NewContext</strong>(<a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> *rt, size_t stackchunksize); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>rt</code></td> + <td><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> *</code></td> + <td>コンテキストの親となるランタイムを指定します。JavaScriptのオブジェクト、関数、文字列、数値は<code>JSRuntime</code>内のコンテキスト内で共有されますが、<code>JSRuntime</code>をまたぐことはありません。 + <p><span class="comment">Parent runtime for the new context. JavaScript objects, functions, strings, and numbers may be shared among the contexts in a <code>JSRuntime</code>, but they cannot be shared across <code>JSRuntime</code>s.</span></p> + </td> + </tr> + <tr> + <td><code>stackchunksize</code></td> + <td><code>size_t</code></td> + <td> + <p>各スタック領域のサイズをバイトで指定します。標準的には<code>8192</code>が適切な値であり、大抵の場合において調節すべきでないパラメータです。 <span class="comment">The size, in bytes, of each "stack chunk". This is a memory management tuning parameter which most users should not adjust. <code>8192</code> is a good default value.</span></p> + </td> + </tr> + </tbody> +</table> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><span class="comment">= Description =</span> スクリプトの実行および値の保持に利用するコンテキストを新規に生成する関数です。各スクリプトは独自のコンテキスト上で実行され、各コンテキストは特定の<code>JSRuntime</code>オブジェクト<code>rt</code>と関連づけられています。 <span class="comment">Creates a new JavaScript context for executing scripts and examining JavaScript values. Each script runs in its own context, and each context must be associated with a specified <code>JSRuntime</code>, <code>rt</code>.</span></p> + +<p><code>JS_NewContext</code>は、成功したとき新たなコンテキストへのポインタを返します。失敗したときは<code>NULL</code>を返します。 <span class="comment">On success, <code>JS_NewContext</code> returns a pointer to the new context. Otherwise it returns <code>NULL</code>.</span></p> + +<p>この関数の呼び元は、コンテキストを使い終わったら<code><a href="/ja/JS_DestroyContext" title="ja/JS_DestroyContext">JS_DestroyContext</a></code>を実行しなければなりません。<code>JSRuntime</code>を解放する前に、その<code>JSContext</code>をすべて解放する必要があります。 <span class="comment">The caller must call <code><a href="/ja/JS_DestroyContext">JS_DestroyContext</a></code> when it is done using the context. Before a <code>JSRuntime</code> may be destroyed, all the <code>JSContext</code>s associated with it must be destroyed.</span></p> + +<p><code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>を有効にしたビルドでは、ある<code>JSContext</code>を同時にアクセスできるスレッドは一つだけです。新規の<code>JSContext</code>は、初期状態で呼び元のスレッドと関連付けられます。コンテキストがあるスレッドと関連付けられている間は、他のスレッドからそれを利用したり解放することはできません。<code>JSContext</code>を別のスレッドに移動する場合は、<code><a href="/ja/JS_ClearContextThread" title="ja/JS_ClearContextThread">JS_ClearContextThread</a></code>と<code><a href="/ja/JS_SetContextThread" title="ja/JS_SetContextThread">JS_SetContextThread</a></code>を利用してください。 <span class="comment">In a <code><a href="/ja/JS_THREADSAFE">JS_THREADSAFE</a></code> build, only one thread may use a <code>JSContext</code> at a time. The new <code>JSContext</code> is initially associated with the calling thread. As long as it stays associated with that thread, no other thread may use it or destroy it. A <code>JSContext</code> may be transferred from one thread to another by calling <code><a href="/ja/JS_ClearContextThread">JS_ClearContextThread</a></code> and <code><a href="/ja/JS_SetContextThread">JS_SetContextThread</a></code>.</span></p> + +<p>新たに生成した<code>JSContext</code>は、初期状態においてグローバルオブジェクトを持ちません。 <span class="comment">The new <code>JSContext</code> initially has no global object.</span></p> + +<h3 id=".E6.B3.A8.E8.A8.98" name=".E6.B3.A8.E8.A8.98">注記</h3> + +<p><span class="comment">== Notes ==</span> 一度生成されたコンテキストは異なるスクリプトやJSAPI呼び出しのために複数回利用される可能性があります。具体的には、Webブラウザが各HTMLに対応する独立したコンテキストを生成したときに、ページ内のすべてのスクリプトは同じコンテキストを用いて実行されるといったシナリオが考えられます。 <span class="comment">Once created, a context can be used any number of times for different scripts or JSAPI queries. For example, a browser would create a separate context for each HTML page; every script in the page would use the same context.</span></p> + +<p>新規コンテキストは、<code>Object</code>、<code>Date</code>、<code>Array</code>といった標準的なグローバルオブジェクトを一切保持していません。それらを利用するには、<code><a href="/ja/JS_InitStandardClasses" title="ja/JS_InitStandardClasses">JS_InitStandardClasses</a></code>を呼び出す必要があります。JSAPIを利用するアプリケーションで独自の関数やクラスを提供したい場合には、<code><a href="/ja/JS_GetGlobalObject" title="ja/JS_GetGlobalObject">JS_GetGlobalObject</a></code>を使ってそのコンテキストのグローバルオブジェクトを取得し、<code><a href="/ja/JS_DefineFunctions" title="ja/JS_DefineFunctions">JS_DefineFunctions</a></code>および<code><a href="/ja/JS_InitClass" title="ja/JS_InitClass">JS_InitClass</a></code>をそれに適用することで独自のグローバル関数やクラスをコンテキストに追加できます。 <span class="comment">The new context initially does not contain any globals, even standard globals such as <code>Object</code>, <code>Date</code>, and <code>Array</code>. To create them, call <code><a href="/ja/JS_InitStandardClasses">JS_InitStandardClasses</a></code>. A JSAPI application typically also provides some custom functions and classes. Use <code><a href="/ja/JS_GetGlobalObject">JS_GetGlobalObject</a></code> to get a context's global object. Use <code></code> and <code><a href="/ja/JS_InitClass">JS_InitClass</a></code> to add custom global functions and classes to the context.</span></p> + +<p><code>stackchunksize</code>は、JavaScriptのスタックサイズを調節するものではありません(JSAPIでは、スタック長を調節するインタフェースを提供していません)。<code>stackchunksize</code>に大きい値を設定するのは誤った方法です。<code>DEBUG</code>ビルドにおいて、<code>stackchunksize</code>を大きくすると性能が著しく劣化します。一般的には<code>8192</code>が推奨されます。 <span class="comment">The <code>stackchunksize</code> parameter does not control the JavaScript stack size. (The JSAPI does not provide a way to adjust the stack depth limit.) Passing a large number for <code>stackchunksize</code> is a mistake. In a <code>DEBUG</code> build, large chunk sizes can degrade performance dramatically. The usual value of <code>8192</code> is recommended.</span></p> + +<h2 id=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE" name=".E9.96.A2.E9.80.A3.E9.A0.85.E7.9B.AE">関連項目</h2> + +<p><span class="comment">= See Also =</span></p> + +<table class="fullwidth-table"> + <tbody> + <tr> + <td>Groups</td> + <td><a href="/ja/JSAPI_Reference#Functions" title="ja/JSAPI_Reference#Functions">Functions</a></td> + </tr> + <tr> + <td>Documents</td> + <td>{{ LXRSearch("ident", "i", "JS_NewContext", "LXR ID Search") }}</td> + </tr> + <tr> + <td>Entries</td> + <td><a href="/ja/JS_ContextIterator" title="ja/JS_ContextIterator">JS_ContextIterator</a>, + <p><a href="/ja/JS_DestroyContext" title="ja/JS_DestroyContext">JS_DestroyContext</a>, <a href="/ja/JS_SetContextCallback" title="ja/JS_SetContextCallback">JS_SetContextCallback</a></p> + </td> + </tr> + </tbody> +</table> + +<p>{{ languages( { "en": "en/JS_NewContext" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newobject/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newobject/index.html new file mode 100644 index 0000000000..8efb4676c7 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newobject/index.html @@ -0,0 +1,104 @@ +--- +title: JS_NewObject +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewObject +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewObject +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_NewObject</code></div> + +<p></p> + +<p>{{ 英語版章題("Summary") }}</p> + +<h2 id=".E6.A6.82.E8.A6.81" name=".E6.A6.82.E8.A6.81">概要</h2> + +<p>オブジェクトのインスタンスを生成する関数です。<span class="comment">Instantiates a new object.</span></p> + +<p>{{ 英語版章題("Syntax") }}</p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre>JSObject * JS_NewObject(JSContext *cx, JSClass *clasp, JSObject *proto, + JSObject *parent); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code>JSContext *</code></td> + <td>ランタイム環境へのアクセスに用いる JSContext ポインタ<span class="comment">Pointer to a JS context from which to derive runtime information.</span></td> + </tr> + <tr> + <td><code>clasp</code></td> + <td><code>JSClass *</code></td> + <td>オブジェクト生成に用いるクラスへのポインタ<span class="comment">Pointer to the class to use for the new object.</span></td> + </tr> + <tr> + <td><code>proto</code></td> + <td><code>JSObject *</code></td> + <td>クラスとして用いる prototype オブジェクトへのポインタ<span class="comment">Pointer to the prototype object to use for the new class.</span></td> + </tr> + <tr> + <td><code>parent</code></td> + <td><code>JSObject *</code></td> + <td>新規オブジェクトの<code>__parent__</code>プロパティになる親オブジェクトへのポインタ。<span class="comment">Pointer to which to set the new object's <code>__parent__</code> property.</span></td> + </tr> + </tbody> +</table> + +<p>{{ 英語版章題("Description") }}</p> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_NewObject</code>は、引数に指定したクラス、プロトタイプ、親オブジェクトを元にしてオブジェクトのインスタンスを生成する関数です。<code>cx</code>は、新規オブジェクトを生成するランタイム環境の子となるコンテキストへのポインタです。<code>clasp</code>は、<code>finalize</code>のような内部で定義されたメソッドを使う既存クラスへのポインタです。<code>proto</code>は、新規に生成するオブジェクトのプロトタイプとなるオブジェクトへのポインタです。 <span class="comment"><code>JS_NewObject</code> instantiates a new object based on a specified class, prototype, and parent object. <code>cx</code> is a pointer to a context associated with the runtime in which to establish the new object. <code>clasp</code> is a pointer to an existing class to use for internal methods, such as <code>finalize</code>. <code>proto</code> is an optional pointer to the prototype object with which to associate the new object.</span></p> + +<p>Set <code>proto</code> to <code>NULL</code> to force JS to assign a prototype object for you. In this case, <code>JS_NewObject</code> attempts to assign the new object the prototype object belonging to <code>clasp</code>, if one is defined there. Otherwise, it creates an empty object stub for the prototype.</p> + +<p>引数<code>parent</code>は、新たに生成したオブジェクトをプロパティとして持つ親オブジェクトを指定するものです。<code>__parent__</code>プロパティを設定したくない時は、<code>parent</code>に<code>NULL</code>を指定してください。 <span class="comment"><code>parent</code> is an optional pointer to an existing object to which to set the new object's parent object property. You can set parent to <code>NULL</code> if you do not want to set the <code>__parent__</code> property.</span></p> + +<p><code>JS_NewObject</code>が成功したとき、その返値は生成したオブジェクトのインスタンスへのポインタになり、失敗した時はNULLを返します。 <span class="comment">On success, <code>JS_NewObject</code> returns a pointer to the newly instantiated object. Otherwise it returns <code>NULL</code>.</span></p> + +<p>{{ 英語版章題("Notes") }}</p> + +<h3 id=".E6.B3.A8.E8.A8.98" name=".E6.B3.A8.E8.A8.98">注記</h3> + +<p>既存オブジェクトのプロパティとなるオブジェクトを生成するには、<code><a href="ja/JS_DefineObject">JS_DefineObject</a></code>を用いてください。 <span class="comment">To create a new object that is a property of an existing object, use <code>JS_DefineObject</code>.</span></p> + +<p>{{ 英語版章題("See Also") }}</p> + +<h2 id=".E5.8F.82.E7.85.A7" name=".E5.8F.82.E7.85.A7">参照</h2> + +<table class="fullwidth-table"> + <tbody> + <tr> + <td>Groups</td> + <td><a href="ja/JSAPI_Reference#Functions">Functions</a></td> + </tr> + <tr> + <td>Documents</td> + <td>{{ LXRSearch("ident", "i", "JS_NewObject", "LXR ID Search") }}</td> + </tr> + <tr> + <td>Entries</td> + <td> + <p><a href="ja/JSClass">JSClass</a>, <a href="ja/JS_ConstructObject">JS_ConstructObject</a>, <a href="ja/JS_DefineObject">JS_DefineObject</a>, <a href="ja/JS_GetFunctionObject">JS_GetFunctionObject</a>, <a href="ja/JS_NewArrayObject">JS_NewArrayObject</a>, <a href="ja/JS_ValueToObject">JS_ValueToObject</a></p> + </td> + </tr> + </tbody> +</table> + +<div class="noinclude"> </div> + +<p>{{ languages( { "en": "en/JS_NewObject" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newruntime/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newruntime/index.html new file mode 100644 index 0000000000..5db8397cb9 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_newruntime/index.html @@ -0,0 +1,52 @@ +--- +title: JS NewRuntime +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewRuntime +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_NewRuntime +--- +<p></p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_NewRuntime</code></div> +<p></p> + +<p>JavaScript ランタイムの初期化を行います。 {{ 英語版章題("Syntax") }}</p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval"><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a> * <strong>JS_NewRuntime</strong>(uint32 maxbytes); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>maxbytes</code></td> + <td><code>uint32</code></td> + <td>ガベージコレクション動作後の最大メモリ使用量<span class="comment">Maximum number of allocated bytes after which garbage collection is run.</span></td> + </tr> + </tbody> +</table> + +<p>{{ 英語版章題("Description") }}</p> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p><code>JS_NewRuntime</code>は、JavaScriptランタイム環境の初期化を行う関数です。他のJSAPI関数を使うには前もって必ず<code>JS_NewRuntime</code>を呼ぶことになります。<code>JS_NewRuntime</code>は、<code>JSRuntime</code>に用いるメモリ領域を確保し、ランタイム内の初期化を行います。引数<code>maxbytes</code>で、ガベージコレクションが動作した後の最大メモリ使用量を指定します。 <span class="comment"><code>JS_NewRuntime</code> initializes the JavaScript runtime environment. Call <code>JS_NewRuntime</code> before making any other API calls. <code>JS_NewRuntime</code> allocates memory for the <code>JSRuntime</code> and initializes certain internal runtime structures. <code>maxbytes</code> specifies the number of allocated bytes after which garbage collection is run.</span></p> + +<p>一般的に、ほとんどのアプリケーションで必要とされる<code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a></code>は一つのみです。<code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>を有効にしたビルドでは、<code>JSRuntime</code>を共有する<code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSContext</a></code>を各スレッドごとに一つ用意することで、複数スレッドからランタイムにアクセスすることが可能です。複数のランタイムが必要になるのは、JavaScriptの値やオブジェクト、関数をスレッド間で完全に分離させたいときだけです。 <span class="comment">Generally speaking, most applications need only one <code><a href="/ja/JSRuntime">JSRuntime</a></code>. In a <code><a href="/ja/JS_THREADSAFE">JS_THREADSAFE</a></code> build, each runtime is capable of handling multiple execution threads, using one <code><a href="/ja/JSContext">JSContext</a></code> per thread, sharing the same <code>JSRuntime</code>. You only need multiple runtimes if your application requires completely separate JS engines that cannot share values, objects, and functions.</span></p> + +<p><code>JS_NewRuntime</code>が成功したときは、新たに生成されたランタイムへのポインタがその返り値となり、失敗した時は<code>NULL</code>を返します。<code>JS_NewRuntime</code>の呼び出し元は、後で必ずそのランタイムを<code><a href="/ja/JS_DestroyRuntime" title="ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code>を用いて破棄しなければなりません。 <span class="comment">On success, <code>JS_NewRuntime</code> returns a pointer to the newly created runtime, which the caller must later destroy using <code><a href="/ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code>. Otherwise it returns <code>NULL</code>.</span> {{ 英語版章題("Notes") }}</p> + +<h3 id=".E6.B3.A8.E8.A8.98" name=".E6.B3.A8.E8.A8.98">注記</h3> + +<p>一般的には、<code>JS_NewRuntime</code>はアプリケーション内でまず最初に実行し、<code><a href="/ja/JS_DestroyRuntime" title="ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code>や<code><a href="/ja/JS_ShutDown" title="ja/JS_ShutDown">JS_ShutDown</a></code>を終了時に呼ぶことになります。 <span class="comment">Ordinarily, <code>JS_NewRuntime</code> should be the first JSAPI call in an application, and <code><a href="/ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code> and <code><a href="/ja/JS_ShutDown">JS_ShutDown</a></code> should be the last ones.</span></p> + +<p>{{ LXRSearch("ident", "i", "JS_NewRuntime") }}</p> + +<p>{{ languages( { "en": "en/JS_NewRuntime" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_setgczeal/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_setgczeal/index.html new file mode 100644 index 0000000000..0be58ee8dc --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_setgczeal/index.html @@ -0,0 +1,141 @@ +--- +title: JS_SetGCZeal +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetGCZeal +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_SetGCZeal +--- +<div>{{SpiderMonkeySidebar("JSAPI")}}</div> + +<div>{{jsapi_minversion_header("1.8")}}</div> + +<div class="summary"> +<p>GC の活動量、JSAPI アプリケーションの GC 関連のバグを見つけるのに役立つテストおよびデバッグ機能を有効にします。</p> +</div> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="brush: cpp">void +JS_SetGCZeal(JSContext *cx, uint8_t zeal, uint32_t frequency); +</pre> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td>{{jsapixref("JSRuntime", "JSContext *")}}</td> + <td>A context. The GC zeal level of the associated {{jsapixref("JSRuntime")}} is set.</td> + </tr> + <tr> + <td><code>zeal</code></td> + <td><code>uint8_t</code></td> + <td>The desired level of garbage collection.</td> + </tr> + <tr> + <td><code>frequency</code></td> + <td><code>uint32_t</code></td> + <td>With some zeal levels, a GC is triggered every <code>frequency</code> allocations.</td> + </tr> + </tbody> +</table> + +<h2 id="Description" name="Description">説明</h2> + +<p><strong><code>JS_SetGCZeal</code></strong> sets the level of additional garbage collection to perform for a runtime, for the purpose of finding or reproducing bugs.</p> + +<p>There are several different levels which have different functions:</p> + +<table class="fullwidth-table"> + <thead> + <tr> + <th scope="col">Zeal level</th> + <th scope="col">Description</th> + </tr> + </thead> + <tbody> + <tr> + <td>0</td> + <td>Normal amount of collection. The default: no additional collections are performed.</td> + </tr> + <tr> + <td>1</td> + <td>Collect when roots are added or removed.</td> + </tr> + <tr> + <td>2</td> + <td>Collect when every <code>frequency</code> allocations.</td> + </tr> + <tr> + <td>3</td> + <td>Collect on window paints.</td> + </tr> + <tr> + <td>4</td> + <td>Verify pre write barriers between instructions.</td> + </tr> + <tr> + <td>5</td> + <td>Verify pre write barriers between window paints.</td> + </tr> + <tr> + <td>6</td> + <td>Verify stack rooting.</td> + </tr> + <tr> + <td>7</td> + <td>Collect the nursery every <code>frequency</code> nursery allocations.</td> + </tr> + <tr> + <td>8</td> + <td>Incremental GC in two slices: 1) mark roots 2) finish collection.</td> + </tr> + <tr> + <td>9</td> + <td>Incremental GC in two slices: 1) mark all 2) new marking and finish.</td> + </tr> + <tr> + <td>10</td> + <td>Incremental GC in multiple slices.</td> + </tr> + <tr> + <td>11</td> + <td>Verify post write barriers between instructions.</td> + </tr> + <tr> + <td>12</td> + <td>Verify post write barriers between paints.</td> + </tr> + <tr> + <td>13</td> + <td>Check internal hashtables on minor GC.</td> + </tr> + <tr> + <td>14</td> + <td>Perform a shrinking collection every <code>frequency</code> allocations.</td> + </tr> + </tbody> +</table> + +<p>With GC zeal enabled, GC-related crashes are much easier to reproduce (they happen more reliably) and debug (they happen sooner, closer to the source of the bug). The drawback is that GC zeal can cause JavaScript code to run extremely slowly.</p> + +<p>Regularly running your test suite with GC zeal enabled at level 2 is a good practice.</p> + +<p>This function is available only in <code>DEBUG</code> builds. To enable this function in an optimized build, define the macro <code>JS_GC_ZEAL</code> building SpiderMonkey.</p> + +<p>(In a debug build of Gecko, you can also set the current GC zeal level using the <code>javascript.options.gczeal</code> preference.)</p> + +<h2 id="See_Also" name="See_Also">あわせて参照</h2> + +<ul> + <li>{{LXRSearch("ident", "i", "JS_SetGCZeal")}}</li> + <li>{{LXRSearch("ident", "i", "JS_GC_ZEAL")}}</li> + <li>{{jsapixref("JS_ScheduleGC")}}</li> + <li>{{bug(308429)}}</li> + <li>{{bug(650978)}}</li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_shutdown/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_shutdown/index.html new file mode 100644 index 0000000000..5d4e2faacd --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_shutdown/index.html @@ -0,0 +1,34 @@ +--- +title: JS ShutDown +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ShutDown +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_ShutDown +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JS_ShutDown</code></div> + +<p></p> + +<p>ランタイム間で共有している資源を解放します。</p> + +<p><span class="comment">Free all resources shared among runtimes.</span></p> + +<h2 id=".E6.A7.8B.E6.96.87" name=".E6.A7.8B.E6.96.87">構文</h2> + +<pre class="eval">void <strong>JS_ShutDown</strong>(void); +</pre> + +<h2 id=".E8.AA.AC.E6.98.8E" name=".E8.AA.AC.E6.98.8E">説明</h2> + +<p>ランタイム間で共有している資源を解放する関数です。この関数を呼ぶのは<code>JSRuntime</code>オブジェクトが存在しないとき(具体的には、<code><a href="/ja/JS_DestroyRuntime" title="ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code>を読んだ後のプログラムの最後など)だけにしてください。 <span class="comment">Frees all resources shared among runtimes. Call this only when no <code>JSRuntime</code>s exist (for example, at the end of the program, after calling <code><a href="/ja/JS_DestroyRuntime">JS_DestroyRuntime</a></code>).</span></p> + +<p>利用時の注意点: この関数は<code><a class="external" href="http://mxr.mozilla.org/seamonkey/source/js/src/jsdtoa.c">jsdtoa.c</a></code>が確保するメモリ領域と、<code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>オプションを有効にしたビルドにおける<code><a class="external" href="http://mxr.mozilla.org/seamonkey/source/js/src/jslock.c">jslock.c</a></code>が確保するmutex領域を解放します。 <span class="comment">Implementation note: This cleans up memory allocated by <code><a class="external" href="http://mxr.mozilla.org/seamonkey/source/js/src/jsdtoa.c">jsdtoa.c</a></code> and, in <code><a href="/ja/JS_THREADSAFE">JS_THREADSAFE</a></code> builds, mutexes allocated by <code><a class="external" href="http://mxr.mozilla.org/seamonkey/source/js/src/jslock.c">jslock.c</a></code>.</span></p> + +<p>{{ LXRSearch("ident", "i", "JS_ShutDown") }}</p> + +<p>{{ languages( { "en": "en/JS_ShutDown" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_threadsafe/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_threadsafe/index.html new file mode 100644 index 0000000000..b827d4c832 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/js_threadsafe/index.html @@ -0,0 +1,114 @@ +--- +title: JS_THREADSAFE +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_THREADSAFE +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JS_THREADSAFE +--- +<p class="note">{{ note("JS_THREADSAFE は現在恒久的に有効です。") }}</p> + +<p><strong><code>JS_THREADSAFE</code></strong> は、オブジェクトや文字列が共有されていない限り、JavaScript コードの複数のスレッドを同時に実行するためのサポートを可能にするコンパイル時オプションです。</p> + +<p>最近この機能に大きな変更を加えました。最近まで、スレッド間でオブジェクトを共有することでうまくいくことが多かったのですが、スクリプトを使うとクラッシュすることがありました。この機能は完全に削除されました。JavaScript エンジンを使用する各スレッドは、本質的にまったく別のメモリ領域で動作する必要があります。</p> + +<h2 id="Requests" name="Requests">Requests</h2> + +<p>In a <code>JS_THREADSAFE</code> build, the application must separate code that uses the JSAPI from code that performs blocking I/O or time-consuming calculations.</p> + +<p>A <em>request</em> is a region of code that uses the JSAPI. Requests must be bracketed with calls to <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="en/JS_BeginRequest">JS_BeginRequest</a>()</code> and <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="en/JS_BeginRequest">JS_EndRequest</a>()</code>.</p> + +<pre class="eval"><a href="/en/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="en/JS_BeginRequest">JS_BeginRequest</a>(cx); +/* ... do JSAPI stuff ... */ +<a href="/en/SpiderMonkey/JSAPI_Reference/JS_BeginRequest" title="en/JS_BeginRequest">JS_EndRequest</a>(cx); +</pre> + +<p>A request is always associated with a specific <code>JSContext</code> and runs from start to finish on a single thread.</p> + +<p>Most JSAPI functions require the caller to be in a request. In this reference, these JSAPI functions are marked with the words "Requires request", like this:</p> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code>JSContext *</code></td> + <td>The context to use. {{ Jsapi-requires-request() }}</td> + </tr> + </tbody> +</table> + +<p>Most JSAPI callback functions are always called from within a request. These callbacks are (unreliably!) documented with the words "Provides request", like this:</p> + +<table class="fullwidth-table"> + <tbody> + <tr> + <th>Name</th> + <th>Type</th> + <th>Description</th> + </tr> + <tr> + <td><code>cx</code></td> + <td><code>JSContext *</code></td> + <td>The context in which the event ocurred. Provides request. <em>In <code><a href="/en-US/docs/JS_THREADSAFE#Requests">JS_THREADSAFE</a></code> builds, the JavaScript engine calls this callback only from within an active request on <code>cx</code>. The callback does not need to call <code>JS_BeginRequest()</code>).</em></td> + </tr> + </tbody> +</table> + +<p>In particular, <code><a href="/en/SpiderMonkey/JSAPI_Reference/JSNative" title="en/JSNative">JSNative</a></code> callbacks provide a request. This means that any potentially long-running operation in a native must be bracketed with calls to <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="en/JS_SuspendRequest">JS_SuspendRequest</a>()</code> and <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="en/JS_SuspendRequest">JS_ResumeRequest</a>()</code>.</p> + +<pre class="eval"><a href="/En/SpiderMonkey/JSAPI_Reference/JSBool" title="en/JSBool">JSBool</a> socket_recv(<a href="/en/SpiderMonkey/JSAPI_Reference/JSRuntime" title="en/JSRuntime">JSContext</a> *cx, <a href="/en/SpiderMonkey/JSAPI_Reference/jsint" title="en/jsint">unsigned int</a> argc, <a href="/En/SpiderMonkey/JSAPI_Reference/Jsval" title="en/jsval">jsval</a> *vp) +{ + ... + rc = <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="en/JS_SuspendRequest">JS_SuspendRequest</a>(cx); + read_size = recv(socket, buf, size, flags); + <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SuspendRequest" title="en/JS_SuspendRequest">JS_ResumeRequest</a>(cx, rc); + ... +} +</pre> + +<h2 id="Garbage_collection" name="Garbage_collection">Garbage collection</h2> + +<p>Requests help make garbage collection safe when multiple threads are using the JSAPI. For each thread that is in a request:</p> + +<ul> + <li>Almost any call into the JSAPI may trigger garbage collection; but</li> + <li>Garbage collection does not happen at any other time (such as, for example, at the moment before the return value of <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_NewObject" title="en/JS_NewObject">JS_NewObject</a></code> is assigned to a rooted variable).</li> +</ul> + +<p>These are actually the same rules that apply to single-threaded JSAPI programs. But in multithreaded programs, if you break the rules, your program is more likely to crash. This is because in single-threaded programs, a random call into the JSAPI is actually pretty unlikely to trigger GC, especially if the calling thread has not been using up a lot of memory. In a multithreaded program, even if the calling thread has been idle, other threads may be active or may call <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_GC" title="en/JS_GC">JS_GC</a>()</code>.</p> + +<p>The above rules mean that at any given moment, there can be either <strong>(a)</strong> multiple threads in active requests, or <strong>(b)</strong> one thread doing GC and all requests suspended. When one thread calls JS_GC or otherwise finds that garbage collection is necessary, it must wait for all other threads that are in requests to pause before garbage collection can occur. To keep this wait time to a minimum, <strong>applications must avoid long-running requests.</strong> The recommended technique in SpiderMonkey 1.8 and later is to periodically call <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_YieldRequest" title="en/JS_YieldRequest">JS_YieldRequest</a></code> from an <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetOperationCallback" title="en/JS_SetOperationCallback">operation callback</a>.</p> + +<h2 id="Sharing_strings_among_threads" name="Sharing_strings_among_threads">Sharing data among threads</h2> + +<p>"Data can be marshaled across the process boundary through a process known as <em>smuggling</em>." --<em>Mr. Bunny's Guide to ActiveX</em></p> + +<p>Even in JS_THREADSAFE builds, threads cannot safely share objects or strings.</p> + +<p>Instead, data must be copied when it is sent from one thread to another. Use <code>JS_WriteStructuredClone</code> to transform data into a flat array of bytes that can be safely written to disk, sent to another process or even another machine, or just passed to another thread. Then use <code>JS_ReadStructuredClone</code> on the other side to turn the serialized data back into JavaScript objects, strings, and so on.</p> + +<h2 id="Sharing_native_functions_and_private_data_among_threads" name="Sharing_native_functions_and_private_data_among_threads">Sharing native functions and private data among threads</h2> + +<p>In a <code>JS_THREADSAFE</code> build, SpiderMonkey's internal data structures that represent JavaScript values are single-thread-only. In a <code>DEBUG</code> build, this is enforced with assertions.</p> + +<p>However, SpiderMonkey does not protect the application's data structures. <code><a href="/en/SpiderMonkey/JSAPI_Reference/JSNative" title="en/JSNative">JSNative</a></code>s and other callback functions can be called concurrently by multiple threads. Multiple threads can end up accessing <a href="/en/SpiderMonkey/JSAPI_Reference/JS_SetPrivate" title="en/JS_SetPrivate">private data</a> or C/C++ global variables at the same time. It is up to the application to practice safe threading.</p> + +<h2 id="Sharing_contexts_among_threads" name="Sharing_contexts_among_threads">Sharing contexts among threads</h2> + +<p>Ordinarily, a <code>JSContext</code> is created, used, and destroyed by a single thread. This makes sense, as a context can only be used by one thread at a time. However, there are a few cases where an application might need to share contexts across threads. For example:</p> + +<ul> + <li>Many worker threads need to share a "pool" of reusable contexts, to avoid the performance cost of constantly creating and destroying contexts. (This is analogous to a database connection pool.)</li> +</ul> + +<ul> + <li>The application has a <code>JSContext</code> that it needs to use each time some event happens. But the event could happen on any thread.</li> +</ul> + +<p>For such cases, use <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_ClearContextThread" title="en/JS_ClearContextThread">JS_ClearContextThread</a></code> and <code><a href="/en/SpiderMonkey/JSAPI_Reference/JS_ClearContextThread" title="en/JS_ClearContextThread">JS_SetContextThread</a></code> to transfer the context safely from one thread to another.</p> + +<h2 id="Further_info" name="Further_info">Further info</h2> + +<p>Note: <a href="/En/SpiderMonkey/Internals/Thread_Safety" title="en/SpiderMonkey_Internals/Thread_Safety">SpiderMonkey Internals: Thread Safety</a> is mostly obsolete.</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsint/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsint/index.html new file mode 100644 index 0000000000..c5028558cc --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsint/index.html @@ -0,0 +1,42 @@ +--- +title: jsint +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/jsint +tags: + - JSAPI_Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/jsint +--- +<p>C 言語 / C++ の整数型のエイリアスです。</p> + +<h2 id="Syntax" name="Syntax">構文</h2> + +<pre class="syntaxbox">typedef ... jsint; +typedef ... jsuint; + +typedef ... jsword; +typedef ... jsuword; + +typedef ... intN; +typedef ... uintN; + +typedef ... int8; +typedef ... uint8; +typedef ... int16; +typedef ... uint16; +typedef ... int32; +typedef ... uint32; +typedef ... int64; +typedef ... uint64; +</pre> + + +<h2 id="Description" name="Description">説明</h2> + + +<p><strong><code>jsint</code></strong> および <strong><code>jsuint</code></strong> は 32 ビットの整数型です。</p> + + +<p><strong><code>jsword</code></strong> および <strong><code>jsuword</code></strong> はポインタサイズの整数型です。</p> + + +<p><strong><code>intN</code></strong> および <strong><code>uintN</code></strong> はプラットフォームのネイティブの <code>int</code> 型と同じサイズの整数型です。</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsruntime/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsruntime/index.html new file mode 100644 index 0000000000..b221ea62ef --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jsruntime/index.html @@ -0,0 +1,23 @@ +--- +title: JSRuntime +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSRuntime +tags: + - JSAPI Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSRuntime +--- +<p> + +</p><div class="breadcrumbs"><a href="/ja" title="ja">メインページ</a> » <a href="/ja/docs/SpiderMonkey" title="SpiderMonkey">SpiderMonkey</a> » + <a href="/ja/docs/SpiderMonkey/JSAPI_Reference" title="JSAPI_Reference">JSAPI リファレンス</a> » + <code>JSRuntime</code></div> + +<p></p> + +<p>JSAPIにおいて、<strong><code><a href="/ja/JSRuntime" title="ja/JSRuntime">JSRuntime</a></code></strong>はメモリ管理や<strong>グローバル</strong>なデータ構造などを扱う最高位のオブジェクトです。複数のスレッドが動作するプログラムにおいても、プログラム内の<code>JSRuntime</code>は一般的に一つだけです。<code>JSRuntime</code>はJavaScriptのオブジェクトを保持する空間であり、オブジェクトは複数の<code>JSRuntime</code>を跨いで移動することはできません。 <span class="comment">JSAPI, <strong><code><a href="/ja/JSRuntime">JSRuntime</a></code></strong> is the top-level object that handles, among other things, memory management and "global" data structures. A program typically has only one <code>JSRuntime</code>, even if it has many threads. The <code>JSRuntime</code> is the universe in which JavaScript objects live; they can't travel to other <code>JSRuntime</code>s.</span></p> + +<p><strong><code>JSContext</code></strong>は<code>JSRuntime</code>の子に位置し、すべてのJavaScriptコードとJSAPIの関数は<code>JSContext</code>を介して実行されます。<code>JSContext</code>内には、<a href="/ja/JS_GetGlobalObject" title="ja/JS_GetGlobalObject">global object</a>や実行時スタックなどが含まれます。 <a href="/ja/JS_SetPendingException" title="ja/JS_SetPendingException">例外処理</a>、<a href="/ja/JS_SetErrorReporter" title="ja/JS_SetErrorReporter">エラー報告</a>、一部の<a href="/ja/JS_SetOptions" title="ja/JS_SetOptions">JavaScriptのオプション</a> などは各<code>JSContext</code>ごとに管理されます。<code>JS_THREADSAFE</code>オプションを有効にしたビルドでは、複数のスレッドからJavaScriptのコードを呼び出し並行して実行できますが、呼び出し元のスレッドはそれぞれ独立した<code>JSContext</code>を持つ形になります。詳細は<code><a href="/ja/JS_THREADSAFE" title="ja/JS_THREADSAFE">JS_THREADSAFE</a></code>を参照してください。 <span class="comment">All JavaScript code and most JSAPI calls run within a <strong><code>JSContext</code></strong>. The <code>JSContext</code> is a child of the <code>JSRuntime</code>. Among other things, it contains the <a href="/ja/JS_GetGlobalObject">global object</a> and the execution stack. <a href="/ja/JS_SetPendingException">Exception handling</a>, <a href="/ja/JS_SetErrorReporter">error reporting</a>, and some <a href="/ja/JS_SetOptions">language options</a> are per-<code>JSContext</code>. In a <code>JS_THREADSAFE</code> build, multiple threads may run JavaScript code concurrently, but each such thread must have its own <code>JSContext</code>. See <code> <a href="/ja/JS_THREADSAFE">JS_THREADSAFE</a></code> for details.</span></p> + +<p>JavaScriptオブジェクトとそのコンテキストとの関係は固定されたものでなく、オブジェクトは<code>JSRuntime</code>を介してその子となる<code>JSContext</code>間で共有することができます。 <span class="comment">Objects may be shared among <code>JSContext</code>s within a <code>JSRuntime</code>. There's no fixed association between an object and a context.</span></p> + +<p>{{ languages( { "en": "en/JSRuntime" } ) }}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jstype/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jstype/index.html new file mode 100644 index 0000000000..69037c39ee --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_reference/jstype/index.html @@ -0,0 +1,52 @@ +--- +title: JSType +slug: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSType +tags: + - JSAPI_Reference + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_reference/JSType +--- +<p>列挙型 <code>JSType</code> の値は、 JavaScript の値の型を表します。</p> +<table class="standard-table"> + <thead> + <tr> + <th>値</th> + <th>説明</th> + </tr> +</thead> +<tbody> + <tr> + <td><code>JSTYPE_VOID</code></td> + <td><code>undefined</code> 値</td> + </tr> + <tr> + <td><code>JSTYPE_OBJECT</code></td> + <td>JavaScript オブジェクト</td> + </tr> + <tr> + <td><code>JSTYPE_FUNCTION</code></td> + <td>関数</td> + </tr> + <tr> + <td><code>JSTYPE_STRING</code></td> + <td>文字列</td> + </tr> + <tr> + <td><code>JSTYPE_NUMBER</code></td> + <td>数値</td> + </tr> + <tr> + <td><code>JSTYPE_BOOLEAN</code></td> + <td>真偽値 (<code>true</code> / <code>false</code>)</td> + </tr> + <tr> + <td><code>JSTYPE_NULL</code></td> + <td><code>null</code> 値</td> + </tr> + <tr> + <td><code>JSTYPE_XML</code></td> + <td>XML オブジェクト</td> + </tr> + </tbody> +</table> +<p> </p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsapi_user_guide/index.html b/files/ja/mozilla/projects/spidermonkey/jsapi_user_guide/index.html new file mode 100644 index 0000000000..815bdfd6cf --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsapi_user_guide/index.html @@ -0,0 +1,6 @@ +--- +title: JSAPI ユーザガイド +slug: Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide +translation_of: Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide +--- +<p>{{SpiderMonkeySidebar}}{{Draft}}{{Page("/en-US/docs/Mozilla/Projects/SpiderMonkey/JSAPI_User_Guide")}}</p> diff --git a/files/ja/mozilla/projects/spidermonkey/jsdbgapi_reference/index.html b/files/ja/mozilla/projects/spidermonkey/jsdbgapi_reference/index.html new file mode 100644 index 0000000000..c132f23a19 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/jsdbgapi_reference/index.html @@ -0,0 +1,150 @@ +--- +title: JSDBGAPI Reference +slug: Mozilla/Projects/SpiderMonkey/JSDBGAPI_Reference +tags: + - JSDBGAPI_Reference + - JavaScript + - SpiderMonkey +--- +<p> +</p><p>見てのとおり、ほとんどすべての項目がドキュメント化されていません。 +</p><p><tt>trap, untrap, watch, unwatch, line2pc</tt> および <tt>pc2line</tt> 関数の実装は {{ Source("js/src/js.c") }} をご覧ください。{{ Source("js/src/jsdbgapi.h") }} にも (わずかに) コメントがあります。 +</p><p>{{ 英語版章題("Breakpoints") }} +</p> +<h3 id=".E3.83.96.E3.83.AC.E3.83.BC.E3.82.AF.E3.83.9D.E3.82.A4.E3.83.B3.E3.83.88" name=".E3.83.96.E3.83.AC.E3.83.BC.E3.82.AF.E3.83.9D.E3.82.A4.E3.83.B3.E3.83.88"> ブレークポイント </h3> +<ul><li> <code><a href="ja/JS_SetTrap">JS_SetTrap</a></code> +</li><li> <code><a href="ja/JS_GetTrapOpcode">JS_GetTrapOpcode</a></code> +</li><li> <code><a href="ja/JS_ClearTrap">JS_ClearTrap</a></code> +</li><li> <code><a href="ja/JS_ClearScriptTraps">JS_ClearScriptTraps</a></code> +</li><li> <code><a href="ja/JS_ClearAllTraps">JS_ClearAllTraps</a></code> +</li><li> <code><a href="ja/JS_HandleTrap">JS_HandleTrap</a></code> +</li><li> <code><a href="ja/JS_SetInterrupt">JS_SetInterrupt</a></code> +</li><li> <code><a href="ja/JS_ClearInterrupt">JS_ClearInterrupt</a></code> +</li></ul> +<p>{{ 英語版章題("Watchpoints") }} +</p> +<h3 id=".E3.82.A6.E3.82.A9.E3.83.83.E3.83.81.E3.83.9D.E3.82.A4.E3.83.B3.E3.83.88" name=".E3.82.A6.E3.82.A9.E3.83.83.E3.83.81.E3.83.9D.E3.82.A4.E3.83.B3.E3.83.88"> ウォッチポイント </h3> +<ul><li> <code><a href="ja/JS_SetWatchPoint">JS_SetWatchPoint</a></code> +</li><li> <code><a href="ja/JS_ClearWatchPoint">JS_ClearWatchPoint</a></code> +</li><li> <code><a href="ja/JS_ClearWatchPointsForObject">JS_ClearWatchPointsForObject</a></code> +</li><li> <code><a href="ja/JS_ClearAllWatchPoints">JS_ClearAllWatchPoints</a></code> +</li></ul> +<p>{{ 英語版章題("Inspecting the stack") }} +</p> +<h3 id=".E3.82.B9.E3.82.BF.E3.83.83.E3.82.AF.E3.81.AE.E8.AA.BF.E6.9F.BB" name=".E3.82.B9.E3.82.BF.E3.83.83.E3.82.AF.E3.81.AE.E8.AA.BF.E6.9F.BB"> スタックの調査 </h3> +<ul><li> <code><a href="ja/JS_PCToLineNumber">JS_PCToLineNumber</a></code> +</li><li> <code><a href="ja/JS_LineNumberToPC">JS_LineNumberToPC</a></code> +</li><li> <code><a href="ja/JS_GetFunctionScript">JS_GetFunctionScript</a></code> +</li><li> <code><a href="ja/JS_GetFunctionNative">JS_GetFunctionNative</a></code> +</li><li> <code><a href="ja/JS_GetFunctionFastNative">JS_GetFunctionFastNative</a></code> +</li><li> <code><a href="ja/JS_GetScriptPrincipals">JS_GetScriptPrincipals</a></code> +</li></ul> +<ul><li> typedef <code><a href="ja/JSStackFrame">JSStackFrame</a></code> +</li><li> <code><a href="ja/JS_FrameIterator">JS_FrameIterator</a></code> +</li><li> <code><a href="ja/JS_GetFrameScript">JS_GetFrameScript</a></code> +</li><li> <code><a href="ja/JS_GetFramePC">JS_GetFramePC</a></code> +</li><li> <code><a href="ja/JS_GetScriptedCaller">JS_GetScriptedCaller</a></code> +</li><li> <code><a href="ja/JS_StackFramePrincipals">JS_StackFramePrincipals</a></code> +</li><li> <code><a href="ja/JS_EvalFramePrincipals">JS_EvalFramePrincipals</a></code> +</li><li> <code><a href="ja/JS_GetFrameAnnotation">JS_GetFrameAnnotation</a></code> +</li><li> <code><a href="ja/JS_SetFrameAnnotation">JS_SetFrameAnnotation</a></code> +</li><li> <code><a href="ja/JS_GetFramePrincipalArray">JS_GetFramePrincipalArray</a></code> +</li><li> <code><a href="ja/JS_IsNativeFrame">JS_IsNativeFrame</a></code> +</li><li> <code><a href="ja/JS_GetFrameObject">JS_GetFrameObject</a></code> {{ Deprecated_inline() }} +</li><li> <code><a href="ja/JS_GetFrameScopeChain">JS_GetFrameScopeChain</a></code> +</li><li> <code><a href="ja/JS_GetFrameCallObject">JS_GetFrameCallObject</a></code> +</li><li> <code><a href="ja/JS_GetFrameThis">JS_GetFrameThis</a></code> +</li><li> <code><a href="ja/JS_GetFrameFunction">JS_GetFrameFunction</a></code> +</li><li> <code><a href="ja/JS_GetFrameFunctionObject">JS_GetFrameFunctionObject</a></code> +</li><li> <code><a href="ja/JS_IsConstructorFrame">JS_IsConstructorFrame</a></code> +</li><li> <code><a href="ja/JS_IsDebuggerFrame">JS_IsDebuggerFrame</a></code> +</li><li> <code><a href="ja/JS_GetFrameReturnValue">JS_GetFrameReturnValue</a></code> +</li><li> <code><a href="ja/JS_SetFrameReturnValue">JS_SetFrameReturnValue</a></code> +</li><li> <code><a href="ja/JS_GetFrameCalleeObject">JS_GetFrameCalleeObject</a></code> +</li></ul> +<ul><li> <code><a href="ja/JS_GetScriptFilename">JS_GetScriptFilename</a></code> +</li><li> <code><a href="ja/JS_GetScriptBaseLineNumber">JS_GetScriptBaseLineNumber</a></code> +</li><li> <code><a href="ja/JS_GetScriptLineExtent">JS_GetScriptLineExtent</a></code> +</li><li> <code><a href="ja/JS_GetScriptVersion">JS_GetScriptVersion</a></code> +</li></ul> +<ul><li> <code><a href="ja/JS_GetTopScriptFilenameFlags">JS_GetTopScriptFilenameFlags</a></code> +</li><li> <code><a href="ja/JS_GetScriptFilenameFlags">JS_GetScriptFilenameFlags</a></code> +</li><li> <code><a href="ja/JS_FlagScriptFilenamePrefix">JS_FlagScriptFilenamePrefix</a></code> +</li></ul> +<ul><li> <code><a href="ja/JSFILENAME_NULL">JSFILENAME_NULL</a></code> +</li><li> <code><a href="ja/JSFILENAME_SYSTEM">JSFILENAME_SYSTEM</a></code> +</li><li> <code><a href="ja/JSFILENAME_PROTECTED">JSFILENAME_PROTECTED</a></code> +</li></ul> +<p>{{ 英語版章題("Evaluating debug code") }} +</p> +<h3 id=".E3.83.87.E3.83.90.E3.83.83.E3.82.B0.E3.82.B3.E3.83.BC.E3.83.89.E3.81.AE.E8.A9.95.E4.BE.A1" name=".E3.83.87.E3.83.90.E3.83.83.E3.82.B0.E3.82.B3.E3.83.BC.E3.83.89.E3.81.AE.E8.A9.95.E4.BE.A1"> デバッグコードの評価 </h3> +<ul><li> <code><a href="ja/JS_EvaluateInStackFrame">JS_EvaluateInStackFrame</a></code> +</li></ul> +<p>{{ 英語版章題("Examining object properties") }} +</p> +<h3 id=".E3.82.AA.E3.83.96.E3.82.B8.E3.82.A7.E3.82.AF.E3.83.88.E3.83.97.E3.83.AD.E3.83.91.E3.83.86.E3.82.A3.E3.81.AE.E6.A4.9C.E6.9F.BB" name=".E3.82.AA.E3.83.96.E3.82.B8.E3.82.A7.E3.82.AF.E3.83.88.E3.83.97.E3.83.AD.E3.83.91.E3.83.86.E3.82.A3.E3.81.AE.E6.A4.9C.E6.9F.BB"> オブジェクトプロパティの検査 </h3> +<ul><li> typedef <code><a href="ja/JSPropertyDesc">JSPropertyDesc</a></code> +</li></ul> +<ul><li> <code><a href="ja/JSPD_ENUMERATE">JSPD_ENUMERATE</a></code> +</li><li> <code><a href="ja/JSPD_READONLY">JSPD_READONLY</a></code> +</li><li> <code><a href="ja/JSPD_PERMANENT">JSPD_PERMANENT</a></code> +</li><li> <code><a href="ja/JSPD_ALIAS">JSPD_ALIAS</a></code> +</li><li> <code><a href="ja/JSPD_ARGUMENT">JSPD_ARGUMENT</a></code> +</li><li> <code><a href="ja/JSPD_VARIABLE">JSPD_VARIABLE</a></code> +</li><li> <code><a href="ja/JSPD_EXCEPTION">JSPD_EXCEPTION</a></code> +</li><li> <code><a href="ja/JSPD_ERROR">JSPD_ERROR</a></code> +</li></ul> +<ul><li> typedef <code><a href="ja/JSPropertyDescArray">JSPropertyDescArray</a></code> +</li></ul> +<ul><li> <code><a href="ja/JS_PropertyIterator">JS_PropertyIterator</a></code> +</li><li> <code><a href="ja/JS_GetPropertyDesc">JS_GetPropertyDesc</a></code> +</li><li> <code><a href="ja/JS_GetPropertyDescArray">JS_GetPropertyDescArray</a></code> +</li><li> <code><a href="ja/JS_PutPropertyDescArray">JS_PutPropertyDescArray</a></code> +</li></ul> +<p>{{ 英語版章題("Hooks") }} +</p> +<h3 id=".E3.83.95.E3.83.83.E3.82.AF" name=".E3.83.95.E3.83.83.E3.82.AF"> フック </h3> +<ul><li> <code><a href="ja/JS_SetDebuggerHandler">JS_SetDebuggerHandler</a></code> +</li><li> <code><a href="ja/JS_SetSourceHandler">JS_SetSourceHandler</a></code> +</li><li> <code><a href="ja/JS_SetExecuteHook">JS_SetExecuteHook</a></code> +</li><li> <code><a href="ja/JS_SetCallHook">JS_SetCallHook</a></code> +</li><li> <code><a href="ja/JS_SetObjectHook">JS_SetObjectHook</a></code> +</li><li> <code><a href="ja/JS_SetThrowHook">JS_SetThrowHook</a></code> +</li><li> <code><a href="ja/JS_SetDebugErrorHook">JS_SetDebugErrorHook</a></code> +</li><li> <code><a href="ja/JS_SetNewScriptHook">JS_SetNewScriptHook</a></code> +</li><li> <code><a href="ja/JS_SetDestroyScriptHook">JS_SetDestroyScriptHook</a></code> +</li></ul> +<ul><li> <code><a href="ja/JS_GetGlobalDebugHooks">JS_GetGlobalDebugHooks</a></code> +</li><li> <code><a href="ja/JS_SetContextDebugHooks">JS_SetContextDebugHooks</a></code> +</li></ul> +<p>{{ 英語版章題("Memory usage") }} +</p> +<h3 id=".E3.83.A1.E3.83.A2.E3.83.AA.E4.BD.BF.E7.94.A8.E9.87.8F" name=".E3.83.A1.E3.83.A2.E3.83.AA.E4.BD.BF.E7.94.A8.E9.87.8F"> メモリ使用量 </h3> +<ul><li> <code><a href="ja/JS_GetObjectTotalSize">JS_GetObjectTotalSize</a></code> +</li><li> <code><a href="ja/JS_GetFunctionTotalSize">JS_GetFunctionTotalSize</a></code> +</li><li> <code><a href="ja/JS_GetScriptTotalSize">JS_GetScriptTotalSize</a></code> +</li></ul> +<p>{{ 英語版章題("System objects") }} +</p> +<h3 id=".E3.82.B7.E3.82.B9.E3.83.86.E3.83.A0.E3.82.AA.E3.83.96.E3.82.B8.E3.82.A7.E3.82.AF.E3.83.88" name=".E3.82.B7.E3.82.B9.E3.83.86.E3.83.A0.E3.82.AA.E3.83.96.E3.82.B8.E3.82.A7.E3.82.AF.E3.83.88"> システムオブジェクト </h3> +<ul><li> <code><a href="ja/JS_IsSystemObject">JS_IsSystemObject</a></code> +</li><li> <code><a href="ja/JS_NewSystemObject">JS_NewSystemObject</a></code> +</li></ul> +<p>{{ 英語版章題("Profiling") }} +</p> +<h3 id=".E5.88.86.E6.9E.90" name=".E5.88.86.E6.9E.90"> 分析 </h3> +<p>これらの関数は、Mac プロファイラである Shark を使用して SpiderMonkey アプリケーションを分析するために使用されます。<a href="ja/Profiling_JavaScript_with_Shark">Profiling JavaScript with Shark</a> をご覧ください。 +</p> +<ul><li> <code><a href="ja/JS_ConnectShark">JS_ConnectShark</a></code> +</li><li> <code><a href="ja/JS_DisconnectShark">JS_DisconnectShark</a></code> +</li><li> <code><a href="ja/JS_StartChudRemote">JS_StartChudRemote</a></code> +</li><li> <code><a href="ja/JS_StopChudRemote">JS_StopChudRemote</a></code> +</li></ul> +<p>以下の <code><a href="ja/JSNative">JSNative</a></code> 関数は、上記 4 つの API をスクリプトに晒すために使用されます。 +</p> +<ul><li> <code><a href="ja/Js_ConnectShark">js_ConnectShark</a></code> +</li><li> <code><a href="ja/Js_DisconnectShark">js_DisconnectShark</a></code> +</li><li> <code><a href="ja/Js_StartShark">js_StartShark</a></code> +</li><li> <code><a href="ja/Js_StopShark">js_StopShark</a></code> +</li></ul> +{{ languages( { "en": "en/JSDBGAPI_Reference" } ) }} diff --git a/files/ja/mozilla/projects/spidermonkey/parser_api/index.html b/files/ja/mozilla/projects/spidermonkey/parser_api/index.html new file mode 100644 index 0000000000..81b308c6f6 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/parser_api/index.html @@ -0,0 +1,1698 @@ +--- +title: Parser API +slug: Mozilla/Projects/SpiderMonkey/Parser_API +tags: + - API + - Guide + - JavaScript + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Parser_API +--- +<div>{{SpiderMonkeySidebar}}</div> + +<div class="summary"> +<p>最近の<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Build_Documentation">スタンドアロンの SpiderMonkey シェル</a>のビルドには、SpiderMonkey パーサーを反映したものが含まれています。これは JavaScript API として提供されています。これにより、シンタックスハイライト、静的解析、トランスレータ、コンパイラ、難読化ツールなど、JavaScript ソースプログラムを操作するツールを JavaScript で記述することが簡単になります。</p> +</div> + +<div class="note"> +<p><strong>メモ:</strong> このページは SpiderMonkey 特有の振る舞いについて説明しており、不完全かもしれません。最新の ECMAScript 機能を含み、SpiderMonkey フォーマットとの下位互換性があるコミュニティ AST 規格については、<a href="https://github.com/estree/estree">ESTree の仕様</a>をご覧ください。</p> +</div> + +<p>例:</p> + +<pre class="notranslate">> var expr = Reflect.parse("obj.foo + 42").body[0].expression +> expr.left.property +({loc:null, type:"Identifier", name:"foo"}) +> expr.right +({loc:{source:null, start:{line:1, column:10}, end:{line:1, column:12}}, type:"Literal", value:42}) +</pre> + +<p>Firefox 7 以降も利用可能です。次のようにしてグローバルオブジェクトにインポートすることができます。</p> + +<pre class="notranslate">Components.utils.import("resource://gre/modules/reflect.jsm") +</pre> + +<p>または指定されたオブジェクトへ:</p> + +<pre class="notranslate">Components.utils.import("resource://gre/modules/reflect.jsm", obj) +</pre> + +<h2 id="組み込みオブジェクト">組み込みオブジェクト</h2> + +<p>SpiderMonkey シェルであっても Firefox (インポート後) であっても、グローバルシングルトンオブジェクト <code>Reflect</code> は現在 <code>parse</code> メソッドだけを含んでいます。</p> + +<h2 id="Reflect_オブジェクトのプロパティ"><code>Reflect</code> オブジェクトのプロパティ</h2> + +<p><code>Reflect</code> オブジェクトは現在単一のメソッドで構成されています。</p> + +<h4 id="Reflect.parsesrc_options"><code>Reflect.parse(src[, options])</code></h4> + +<p><strong><span style="font-family: Courier New;">src</span></strong> を文字列に強制し、結果を JavaScript プログラムとして解析します。デフォルトでは、解析にされた抽象構文ツリー (AST) を表す Program オブジェクト(以下を参照)が返されます。</p> + +<p>追加のオプションは、以下のプロパティのいずれかを含めることができる <strong><span style="font-family: Courier New;">options</span></strong> オブジェクトを介して提供可能です:</p> + +<table style="border-color: #edf2f7; border-style: solid; border-width: 1px; width: 67%;"> + <tbody> + <tr style="background-color: rgb(241, 246, 251);"> + <td><strong><span style="font-family: Courier New;">loc</span></strong></td> + <td>Boolean</td> + <td>Default: <span style="font-family: Courier New;">true</span></td> + </tr> + <tr> + <td colspan="3">When <strong><span style="font-family: Courier New;">loc</span></strong> is <span style="font-family: Courier New;">true</span>, the parser includes source location information in the returned AST nodes.</td> + </tr> + <tr style="background-color: rgb(241, 246, 251);"> + <td><strong><span style="font-family: Courier New;">source</span></strong></td> + <td>String</td> + <td>Default: <span style="font-family: Courier New;">null</span></td> + </tr> + <tr> + <td colspan="3">A description of the input source; typically a filename, path, or URL. This string is not meaningful to the parsing process, but is produced as part of the source location information in the returned AST nodes.</td> + </tr> + <tr style="background-color: rgb(241, 246, 251);"> + <td><strong><span style="font-family: Courier New;">line</span></strong></td> + <td>Number</td> + <td>Default: <span style="font-family: Courier New;">1</span></td> + </tr> + <tr> + <td colspan="3">The initial line number to use for source location information.</td> + </tr> + <tr style="background-color: rgb(241, 246, 251);"> + <td><strong><span style="font-family: Courier New;">builder</span></strong></td> + <td>Builder</td> + <td>Default: <span style="font-family: Courier New;">null</span></td> + </tr> + <tr> + <td colspan="3"> + <p>A builder object, which can be used to produce AST nodes in custom data formats. The expected callback methods are described under <a href="/en/SpiderMonkey/Parser_API#Builder_objects" title="en/SpiderMonkey/Parser API#Builder objects">Builder Objects</a>.</p> + </td> + </tr> + <tr style="background-color: rgb(241, 246, 251);"> + <td><strong><span style="font-family: Courier New;">target</span></strong></td> + <td>String</td> + <td>Default: <span style="font-family: Courier New;">script</span></td> + </tr> + <tr> + <td colspan="3"> + <p>A type of the parsing target, can be either <span style="font-family: Courier New;">script</span> or <span style="font-family: Courier New;">module</span>.</p> + </td> + </tr> + </tbody> +</table> + +<p>If parsing fails due to a syntax error, an instance of <code>SyntaxError</code> is thrown. The syntax error object thrown by <code>Reflect.parse()</code> has the same <code>message</code> property as the syntax error that would be thrown by <code>eval(src)</code>. The <code>lineNumber</code> and <code>fileName</code> properties of the syntax error object indicate the source location of the syntax error.</p> + +<h2 id="Node_オブジェクト">Node オブジェクト</h2> + +<p>By default, <code>Reflect.parse()</code> produces Node objects, which are plain JavaScript objects (i.e., their prototype derives from the standard <code>Object</code> prototype). All node types implement the following interface:</p> + +<pre class="notranslate">interface Node { + type: string; + loc: SourceLocation | null; +} +</pre> + +<p>The <code>type</code> field is a string representing the AST variant type. Each subtype of Node is documented below with the specific string of its <code>type</code> field. You can use this field to determine which interface a node implements.</p> + +<p>The <code>loc</code> field represents the source location information of the node. If the parser produced no information about the node's source location, the field is <code>null</code>; otherwise it is an object consisting of a start position (the position of the first character of the parsed source region) and an end position (the position of the first character <em>after</em> the parsed source region):</p> + +<pre class="notranslate">interface SourceLocation { + source: string | null; + start: Position; + end: Position; +} +</pre> + +<p>Each <code>Position</code> object consists of a <code>line</code> number (1-indexed) and a <code>column</code> number (0-indexed):</p> + +<pre class="notranslate">interface Position { + line: uint32 >= 1; + column: uint32 >= 0; +}</pre> + +<h3 id="Programs">Programs</h3> + +<pre class="notranslate">interface Program <: Node { + type: "Program"; + body: [ Statement ]; +} +</pre> + +<p>A complete program source tree.</p> + +<h3 id="Functions">Functions</h3> + +<pre class="notranslate">interface Function <: Node { + id: Identifier | null; + params: [ Pattern ]; + defaults: [ Expression ]; + rest: Identifier | null; + body: BlockStatement | Expression; + generator: boolean; + expression: boolean; +} +</pre> + +<p>A function declaration or expression. The <code>body</code> of the function may be a block statement, or in the case of an <a href="/en/JavaScript/New_in_JavaScript/1.8#Expression_closures_%28Merge_into_own_page.2fsection%29" title="https://developer.mozilla.org/en/new_in_javascript_1.8#Expression_closures_(Merge_into_own_page.2fsection)">expression closure</a>, an expression.</p> + +<div class="note"><strong>メモ:</strong> Expression closures are SpiderMonkey-specific.</div> + +<p>If the <code>generator</code> flag is <code>true</code>, the function is a <a href="/en/JavaScript/Guide/Iterators_and_Generators" title="https://developer.mozilla.org/en/Core_JavaScript_1.5_Guide/Iterators_and_Generators">generator function</a>, i.e., contains a <code>yield</code> expression in its body (other than in a nested function).</p> + +<div class="note"><strong>メモ:</strong> Generators are SpiderMonkey-specific.</div> + +<p>If the <code>expression</code> flag is <code>true</code>, the function is an expression closure and the <code>body</code> field is an expression.</p> + +<h3 id="Statements">Statements</h3> + +<pre class="notranslate">interface Statement <: Node { } +</pre> + +<p>Any statement.</p> + +<pre class="notranslate">interface EmptyStatement <: Statement { + type: "EmptyStatement"; +} +</pre> + +<p>An empty statement, i.e., a solitary semicolon.</p> + +<pre class="notranslate">interface BlockStatement <: Statement { + type: "BlockStatement"; + body: [ Statement ]; +} +</pre> + +<p>A block statement, i.e., a sequence of statements surrounded by braces.</p> + +<pre class="notranslate">interface ExpressionStatement <: Statement { + type: "ExpressionStatement"; + expression: Expression; +} +</pre> + +<p>An expression statement, i.e., a statement consisting of a single expression.</p> + +<pre class="notranslate">interface IfStatement <: Statement { + type: "IfStatement"; + test: Expression; + consequent: Statement; + alternate: Statement | null; +} +</pre> + +<p>An <code>if</code> statement.</p> + +<pre class="notranslate">interface LabeledStatement <: Statement { + type: "LabeledStatement"; + label: Identifier; + body: Statement; +} +</pre> + +<p>A labeled statement, i.e., a statement prefixed by a <code>break</code>/<code>continue</code> label.</p> + +<pre class="notranslate">interface BreakStatement <: Statement { + type: "BreakStatement"; + label: Identifier | null; +} +</pre> + +<p>A <code>break</code> statement.</p> + +<pre class="notranslate">interface ContinueStatement <: Statement { + type: "ContinueStatement"; + label: Identifier | null; +} +</pre> + +<p>A <code>continue</code> statement.</p> + +<pre class="notranslate">interface WithStatement <: Statement { + type: "WithStatement"; + object: Expression; + body: Statement; +} +</pre> + +<p>A <code>with</code> statement.</p> + +<pre class="notranslate">interface SwitchStatement <: Statement { + type: "SwitchStatement"; + discriminant: Expression; + cases: [ SwitchCase ]; + lexical: boolean; +} +</pre> + +<p>A <code>switch</code> statement. The lexical flag is metadata indicating whether the <code>switch</code> statement contains any unnested <code>let</code> 宣言 (and therefore introduces a new lexical scope).</p> + +<pre class="notranslate">interface ReturnStatement <: Statement { + type: "ReturnStatement"; + argument: Expression | null; +} +</pre> + +<p>A <code>return</code> statement.</p> + +<pre class="notranslate">interface ThrowStatement <: Statement { + type: "ThrowStatement"; + argument: Expression; +} +</pre> + +<p>A <code>throw</code> statement.</p> + +<pre class="notranslate">interface TryStatement <: Statement { + type: "TryStatement"; + block: BlockStatement; + handler: CatchClause | null; + guardedHandlers: [ CatchClause ]; + finalizer: BlockStatement | null; +} +</pre> + +<p>A <code>try</code> statement.</p> + +<div class="note"><strong>メモ:</strong> Multiple <code>catch</code> clauses are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface WhileStatement <: Statement { + type: "WhileStatement"; + test: Expression; + body: Statement; +} +</pre> + +<p>A <code>while</code> statement.</p> + +<pre class="notranslate">interface DoWhileStatement <: Statement { + type: "DoWhileStatement"; + body: Statement; + test: Expression; +} +</pre> + +<p>A <code>do</code>/<code>while</code> statement.</p> + +<pre class="notranslate">interface ForStatement <: Statement { + type: "ForStatement"; + init: VariableDeclaration | Expression | null; + test: Expression | null; + update: Expression | null; + body: Statement; +} +</pre> + +<p>A <code>for</code> statement.</p> + +<pre class="notranslate">interface ForInStatement <: Statement { + type: "ForInStatement"; + left: VariableDeclaration | Expression; + right: Expression; + body: Statement; + each: boolean; +} +</pre> + +<p>A <code>for</code>/<code>in</code> statement, or, if <code>each</code> is <code>true</code>, a <code>for each</code>/<code>in</code> statement.</p> + +<div class="note"><strong>メモ:</strong> The <code>for each</code> form is SpiderMonkey-specific.</div> + +<pre class="notranslate">interface ForOfStatement <: Statement { + type: "ForOfStatement"; + left: VariableDeclaration | Expression; + right: Expression; + body: Statement; +}</pre> + +<p>A <code>for</code>/<code>of</code> statement.</p> + +<pre class="notranslate">interface LetStatement <: Statement { + type: "LetStatement"; + head: [ VariableDeclarator ]; + body: Statement; +} +</pre> + +<p>A <code>let</code> statement.</p> + +<div class="note"><strong>メモ:</strong> The <code>let</code> statement form is SpiderMonkey-specific.</div> + +<pre class="notranslate">interface DebuggerStatement <: Statement { + type: "DebuggerStatement"; +} +</pre> + +<p>A <code>debugger</code> statement.</p> + +<div class="note"><strong>メモ:</strong> The <code>debugger</code> statement is new in ECMAScript 5th edition, although SpiderMonkey has supported it for years.</div> + +<h3 id="宣言">宣言</h3> + +<pre class="notranslate">interface Declaration <: Statement { } +</pre> + +<p>Any declaration node. Note that 宣言 are considered statements; this is because 宣言 can appear in any statement context in the language recognized by the SpiderMonkey parser.</p> + +<div class="note"><strong>メモ:</strong> 宣言 in arbitrary nested scopes are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface FunctionDeclaration <: Function, Declaration { + type: "FunctionDeclaration"; + id: Identifier; + params: [ Pattern ]; + defaults: [ Expression ]; + rest: Identifier | null; + body: BlockStatement | Expression; + generator: boolean; + expression: boolean; +} +</pre> + +<p>A function declaration.</p> + +<div class="note"><strong>メモ:</strong> The <code>id</code> field cannot be <code>null</code>.</div> + +<pre class="notranslate">interface VariableDeclaration <: Declaration { + type: "VariableDeclaration"; + 宣言: [ VariableDeclarator ]; + kind: "var" | "let" | "const"; +} +</pre> + +<p>A variable declaration, via one of <code>var</code>, <code>let</code>, or <code>const</code>.</p> + +<pre class="notranslate">interface VariableDeclarator <: Node { + type: "VariableDeclarator"; + id: Pattern; + init: Expression | null; +} +</pre> + +<p>A variable declarator.</p> + +<div class="note"><strong>メモ:</strong> The <code>id</code> field cannot be <code>null</code>.</div> + +<div class="note"><strong>メモ:</strong> <code>let</code> and <code>const</code> are SpiderMonkey-specific.</div> + +<h3 id="Expressions">Expressions</h3> + +<pre class="notranslate">interface Expression <: Node, Pattern { }</pre> + +<p>Any expression node. Since the left-hand side of an assignment may be any expression in general, an expression can also be a pattern.</p> + +<pre class="notranslate">interface ThisExpression <: Expression { + type: "ThisExpression"; +} +</pre> + +<p>A <code>this</code> expression.</p> + +<pre class="notranslate">interface ArrayExpression <: Expression { + type: "ArrayExpression"; + elements: [ Expression | null ]; +}</pre> + +<p>An array expression.</p> + +<pre class="notranslate">interface ObjectExpression <: Expression { + type: "ObjectExpression"; + properties: [ Property ]; +}</pre> + +<p>An object expression.</p> + +<pre class="notranslate">interface Property <: Node { + type: "Property"; + key: Literal | Identifier; + value: Expression; + kind: "init" | "get" | "set"; +}</pre> + +<p>A literal property in an object expression can have either a string or number as its <code>value</code>. Ordinary property initializers have a <code>kind</code> value <code>"init"</code>; getters and setters have the <code>kind</code> values <code>"get"</code> and <code>"set"</code>, respectively.</p> + +<pre class="notranslate">interface FunctionExpression <: Function, Expression { + type: "FunctionExpression"; + id: Identifier | null; + params: [ Pattern ]; + defaults: [ Expression ]; + rest: Identifier | null; + body: BlockStatement | Expression; + generator: boolean; + expression: boolean; +} +</pre> + +<p>A function expression.</p> + +<pre class="notranslate">interface ArrowExpression <: Function, Expression { + type: "ArrowExpression"; + params: [ Pattern ]; + defaults: [ Expression ]; + rest: Identifier | null; + body: BlockStatement | Expression; + generator: boolean; + expression: boolean; +} +</pre> + +<p>A fat arrow function expression, i.e., `let foo = (bar) => { /* body */ }`.</p> + +<pre class="notranslate">interface SequenceExpression <: Expression { + type: "SequenceExpression"; + expressions: [ Expression ]; +}</pre> + +<p>A sequence expression, i.e., a comma-separated sequence of expressions.</p> + +<pre class="notranslate">interface UnaryExpression <: Expression { + type: "UnaryExpression"; + operator: UnaryOperator; + prefix: boolean; + argument: Expression; +}</pre> + +<p>A unary operator expression.</p> + +<pre class="notranslate">interface BinaryExpression <: Expression { + type: "BinaryExpression"; + operator: BinaryOperator; + left: Expression; + right: Expression; +}</pre> + +<p>A binary operator expression.</p> + +<pre class="notranslate">interface AssignmentExpression <: Expression { + type: "AssignmentExpression"; + operator: AssignmentOperator; + left: Pattern; + right: Expression; +}</pre> + +<p>An assignment operator expression.</p> + +<pre class="notranslate">interface UpdateExpression <: Expression { + type: "UpdateExpression"; + operator: UpdateOperator; + argument: Expression; + prefix: boolean; +}</pre> + +<p>An update (increment or decrement) operator expression.</p> + +<pre class="notranslate">interface LogicalExpression <: Expression { + type: "LogicalExpression"; + operator: LogicalOperator; + left: Expression; + right: Expression; +}</pre> + +<p>A logical operator expression.</p> + +<pre class="notranslate">interface ConditionalExpression <: Expression { + type: "ConditionalExpression"; + test: Expression; + alternate: Expression; + consequent: Expression; +}</pre> + +<p>A conditional expression, i.e., a ternary <code>?</code>/<code>:</code> expression.</p> + +<pre class="notranslate">interface NewExpression <: Expression { + type: "NewExpression"; + callee: Expression; + arguments: [ Expression ]; +}</pre> + +<p>A <code>new</code> expression.</p> + +<pre class="notranslate">interface CallExpression <: Expression { + type: "CallExpression"; + callee: Expression; + arguments: [ Expression ]; +}</pre> + +<p>A function or method call expression.</p> + +<pre class="notranslate">interface MemberExpression <: Expression { + type: "MemberExpression"; + object: Expression; + property: Identifier | Expression; + computed: boolean; +}</pre> + +<p>A member expression. If <code>computed === true</code>, the node corresponds to a computed <code>e1[e2]</code> expression and property is an <code>Expression</code>. If <code>computed === false</code>, the node corresponds to a static <code>e1.x</code> expression and property is an <code>Identifier</code>.</p> + +<pre class="notranslate">interface YieldExpression <: Expression { + type: "YieldExpression"; + argument: Expression | null; +} +</pre> + +<p>A <code>yield</code> expression.</p> + +<div class="note"><strong>メモ:</strong> <code>yield</code> expressions are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface ComprehensionExpression <: Expression { + type: "ComprehensionExpression"; + body: Expression; + blocks: [ ComprehensionBlock | ComprehensionIf ]; + filter: Expression | null; +} +</pre> + +<p>An <a href="/en/JavaScript/Guide/Obsolete_Pages/Working_with_Arrays#Array_comprehensions" title="https://developer.mozilla.org/en/Core_JavaScript_1.5_Guide/Working_with_Arrays#Array_comprehensions">array comprehension</a>. The <code>blocks</code> array corresponds to the sequence of <code>for</code> and <code>for each</code> blocks. The optional <code>filter</code> expression corresponds to the final <code>if</code> clause, if present.</p> + +<div class="note"><strong>メモ:</strong> Array comprehensions are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface GeneratorExpression <: Expression { + type: "GeneratorExpression"; + body: Expression; + blocks: [ ComprehensionBlock | ComprehensionIf ]; + filter: Expression | null; +} +</pre> + +<p>A <a href="/en/JavaScript/Guide/Iterators_and_Generators#Generator_expressions" title="https://developer.mozilla.org/en/Core_JavaScript_1.5_Guide/Iterators_and_Generators#Generator_expressions">generator expression</a>. As with array comprehensions, the <code>blocks</code> array corresponds to the sequence of <code>for</code> and <code>for each</code> blocks, and the optional <code>filter</code> expression corresponds to the final <code>if</code> clause, if present.</p> + +<div class="note"><strong>メモ:</strong> Generator expressions are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface GraphExpression <: Expression { + type: "GraphExpression"; + index: uint32; + expression: Literal; +} +</pre> + +<p>A <a href="/en/JavaScript/Sharp_variables_in_JavaScript" title="https://developer.mozilla.org/en/Sharp_variables_in_JavaScript">graph expression</a>, aka "sharp literal," such as <code>#1={ self: #1# }</code>.</p> + +<div class="note"><strong>メモ:</strong> Graph expressions are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface GraphIndexExpression <: Expression { + type: "GraphIndexExpression"; + index: uint32; +} +</pre> + +<p>A <a href="/en/JavaScript/Sharp_variables_in_JavaScript" title="https://developer.mozilla.org/en/Sharp_variables_in_JavaScript">graph index expression</a>, aka "sharp variable," such as <code>#1#</code>.</p> + +<div class="note"><strong>メモ:</strong> Graph index expressions are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface LetExpression <: Expression { + type: "LetExpression"; + head: [ VariableDeclarator ]; + body: Expression; +} +</pre> + +<p>A <code>let</code> expression.</p> + +<div class="note"><strong>メモ:</strong> The <code>let</code> expression form is SpiderMonkey-specific.</div> + +<h3 id="Patterns">Patterns</h3> + +<pre class="notranslate">interface Pattern <: Node { } +</pre> + +<p>JavaScript 1.7 introduced <a href="/en/JavaScript/New_in_JavaScript/1.7#Destructuring_assignment_%28Merge_into_own_page.2fsection%29" title="https://developer.mozilla.org/en/new_in_javascript_1.7#Destructuring_assignment_(Merge_into_own_page.2fsection)">destructuring assignment and binding</a> forms. All binding forms (such as function parameters, variable 宣言, and <code>catch</code> block headers) accept array and object destructuring patterns in addition to plain identifiers. The left-hand sides of assignment expressions can be arbitrary expressions, but in the case where the expression is an object or array literal, it is interpreted by SpiderMonkey as a destructuring pattern.</p> + +<p>Since the left-hand side of an assignment can in general be any expression, in an assignment context, a pattern can be any expression. In binding positions (such as function parameters, variable 宣言, and <code>catch</code> headers), patterns can only be identifiers in the base case, not arbitrary expressions.</p> + +<pre class="notranslate">interface ObjectPattern <: Pattern { + type: "ObjectPattern"; + properties: [ { key: Literal | Identifier, value: Pattern } ]; +} +</pre> + +<p>An object-destructuring pattern. A literal property in an object pattern can have either a string or number as its <code>value</code>.</p> + +<pre class="notranslate">interface ArrayPattern <: Pattern { + type: "ArrayPattern"; + elements: [ Pattern | null ]; +} +</pre> + +<p>An array-destructuring pattern.</p> + +<h3 id="Clauses">Clauses</h3> + +<pre class="notranslate">interface SwitchCase <: Node { + type: "SwitchCase"; + test: Expression | null; + consequent: [ Statement ]; +} +</pre> + +<p>A <code>case</code> (if <code>test</code> is an <code>Expression</code>) or <code>default</code> (if <code>test === null</code>) clause in the body of a <code>switch</code> statement.</p> + +<pre class="notranslate">interface CatchClause <: Node { + type: "CatchClause"; + param: Pattern; + guard: Expression | null; + body: BlockStatement; +} +</pre> + +<p>A <code>catch</code> clause following a <code>try</code> block. The optional <code>guard</code> property corresponds to the optional expression guard on the bound variable.</p> + +<div class="note"><strong>メモ:</strong> The guard expression is SpiderMonkey-specific.</div> + +<pre class="notranslate">interface ComprehensionBlock <: Node { + type: "ComprehensionBlock"; + left: Pattern; + right: Expression; + each: boolean; +} +</pre> + +<p>A <code>for</code> or <code>for each</code> block in an array comprehension or generator expression.</p> + +<pre class="notranslate">interface ComprehensionIf <: Node { + type: "ComprehensionIf"; + test: Expression; +}</pre> + +<p>An <code>if</code> filter in an array comprehension or generator filter.</p> + +<div class="note"><strong>メモ:</strong> Array comprehensions and generator expressions are SpiderMonkey-specific.</div> + +<h3 id="Miscellaneous">Miscellaneous</h3> + +<pre class="notranslate">interface Identifier <: Node, Expression, Pattern { + type: "Identifier"; + name: string; +} +</pre> + +<p>An identifier. Note that an identifier may be an expression or a destructuring pattern.</p> + +<pre class="notranslate">interface Literal <: Node, Expression { + type: "Literal"; + value: string | boolean | null | number | RegExp; +} +</pre> + +<p>A literal token. Note that a literal can be an expression.</p> + +<pre class="notranslate">enum UnaryOperator { + "-" | "+" | "!" | "~" | "typeof" | "void" | "delete" +} +</pre> + +<p>A unary operator token.</p> + +<pre class="notranslate">enum BinaryOperator { + "==" | "!=" | "===" | "!==" + | "<" | "<=" | ">" | ">=" + | "<<" | ">>" | ">>>" + | "+" | "-" | "*" | "/" | "%" + | "|" | "^" | "&" | "in" + | "instanceof" | ".." +} +</pre> + +<p>A binary operator token.</p> + +<div class="note"><strong>メモ:</strong> The <code>..</code> operator is E4X-specific.</div> + +<pre class="notranslate">enum LogicalOperator { + "||" | "&&" +} +</pre> + +<p>A logical operator token.</p> + +<pre class="notranslate">enum AssignmentOperator { + "=" | "+=" | "-=" | "*=" | "/=" | "%=" + | "<<=" | ">>=" | ">>>=" + | "|=" | "^=" | "&=" +} +</pre> + +<p>An assignment operator token.</p> + +<pre class="notranslate">enum UpdateOperator { + "++" | "--" +} +</pre> + +<p>An update (increment or decrement) operator token.</p> + +<h3 id="E4X">E4X</h3> + +<p>This section describes node types that are provided for E4X support. E4X has since been removed as of Gecko 21.</p> + +<p>{{ Obsolete_header() }}</p> + +<div class="note"><strong>メモ:</strong> E4X is not part of the ECMAScript standard (<a class="external" href="http://www.ecma-international.org/publications/standards/Ecma-262.htm" title="http://www.ecma-international.org/publications/standards/Ecma-262.htm">ECMA-262</a>), but is a separate standard of its own (<a class="external" href="http://www.ecma-international.org/publications/standards/Ecma-357.htm" title="http://www.ecma-international.org/publications/standards/Ecma-357.htm">ECMA-357</a>).</div> + +<h4 id="宣言_2">宣言</h4> + +<pre class="notranslate">interface XMLDefaultDeclaration <: Declaration { + type: "XMLDefaultDeclaration"; + namespace: Expression; +} +</pre> + +<p>A <code>default xml namespace</code> declaration.</p> + +<h4 id="Expressions_2">Expressions</h4> + +<pre class="notranslate">interface XMLAnyName <: Expression { + type: "XMLAnyName"; +} +</pre> + +<p>The special E4X wildcard pseudo-identifier <code>*</code>.</p> + +<pre class="notranslate">interface XMLQualifiedIdentifier <: Expression { + type: "XMLQualifiedIdentifier"; + left: Identifier | XMLAnyName; + right: Identifier | Expression; + computed: boolean; +} +</pre> + +<p>An E4X qualified identifier, i.e., a pseudo-identifier using the namespace separator <code>::</code>. If the qualified identifier has a computed name (i.e., the <code>id::[expr]</code> form), then <code>computed</code> is <code>true</code> and the <code>right</code> property is an expression.</p> + +<pre class="notranslate">interface XMLFunctionQualifiedIdentifier <: Expression { + type: "XMLFunctionQualifiedIdentifier"; + right: Identifier | Expression; + computed: boolean; +} +</pre> + +<p>An E4X identifier qualified by the <code>function</code> keyword, e.g., <code>function::id</code>.</p> + +<div class="note"><strong>メモ:</strong> <code>function</code>-qualified identifiers are SpiderMonkey-specific.</div> + +<pre class="notranslate">interface XMLAttributeSelector <: Expression { + type: "XMLAttributeSelector"; + attribute: Expression; +} +</pre> + +<p>An E4X attribute selector expression, i.e., an <code>@</code> expression.</p> + +<pre class="notranslate">interface XMLFilterExpression <: Expression { + type: "XMLFilterExpression"; + left: Expression; + right: Expression; +} +</pre> + +<p>An E4X list filter expression, i.e., an expression of the form <code>expr.(expr)</code>.</p> + +<pre class="notranslate">interface XMLElement <: XML, Expression { + type: "XMLElement"; + contents: [ XML ]; +} +</pre> + +<p>An E4X literal representing a single XML element.</p> + +<pre class="notranslate">interface XMLList <: XML, Expression { + type: "XMLList"; + contents: [ XML ]; +} +</pre> + +<p>An E4X literal representing a list of XML elements.</p> + +<h4 id="XML">XML</h4> + +<pre class="notranslate">interface XML <: Node { } +</pre> + +<p>XML data.</p> + +<pre class="notranslate">interface XMLEscape <: XML { + type: "XMLEscape"; + expression: Expression; +} +</pre> + +<p>XML data with an escaped JavaScript expression.</p> + +<pre class="notranslate">interface XMLText <: XML { + type: "XMLText"; + text: string; +} +</pre> + +<p>Literal XML text.</p> + +<pre class="notranslate">interface XMLStartTag <: XML { + type: "XMLStartTag"; + contents: [ XML ]; +} +</pre> + +<p>An XML start tag.</p> + +<pre class="notranslate">interface XMLEndTag <: XML { + type: "XMLEndTag"; + contents: [ XML ]; +} +</pre> + +<p>An XML end tag.</p> + +<pre class="notranslate">interface XMLPointTag <: XML { + type: "XMLPointTag"; + contents: [ XML ]; +} +</pre> + +<p>An XML point tag.</p> + +<pre class="notranslate">interface XMLName <: XML { + type: "XMLName"; + contents: string | [ XML ]; +} +</pre> + +<p>An XML name.</p> + +<pre class="notranslate">interface XMLAttribute <: XML { + type: "XMLAttribute"; + value: string; +} +</pre> + +<p>An XML attribute value.</p> + +<pre class="notranslate">interface XMLCdata <: XML { + type: "XMLCdata"; + contents: string; +} +</pre> + +<p>An XML CDATA node.</p> + +<pre class="notranslate">interface XMLComment <: XML { + type: "XMLComment"; + contents: string; +} +</pre> + +<p>An XML comment.</p> + +<pre class="notranslate">interface XMLProcessingInstruction <: XML { + type: "XMLProcessingInstruction"; + target: string; + contents: string | null; +} +</pre> + +<p>An XML processing instruction.</p> + +<h2 id="ビルダーオブジェクト">ビルダーオブジェクト</h2> + +<p>The optional <strong><code>builder</code></strong> parameter to <code>Reflect.parse()</code> makes it possible to construct user-specified data from the parser, rather than the default <code>Node</code> objects. Builder objects may contain any of the callback methods described in this section.</p> + +<p>Each callback can produce any custom, user-defined datatype; these are referred to below as <code>CustomExpression</code>, <code>CustomStatement</code>, etc.</p> + +<div class="note"><strong>メモ:</strong> Because this library uses <code>null</code> for optional nodes, it is recommended that user-defined datatypes <strong>not</strong> use <code>null</code> as a representation of an AST node.</div> + +<p>If the <strong><code>loc</code></strong> option is enabled (see the <a href="/en/SpiderMonkey/Parser_API#Reflect.parse(src.5b.2c_options.5d)" title="en/SpiderMonkey/Parser API#Reflect.parse(src.5b.2c options.5d)">Reflect.parse() options</a> above), then each callback is provided with the source location information of the parsed node as an extra parameter.</p> + +<p>All builder callbacks are optional. When a callback is missing, the default format is used, but the provided builder methods are still used recursively for sub-nodes.</p> + +<h3 id="Programs_2">Programs</h3> + +<h5 id="programbody_loc"><code>program(body[, loc])</code></h5> + +<pre class="notranslate">body: [ CustomStatement ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomProgram</p> + +<p>Callback to produce a custom program node.</p> + +<h3 id="Statements_2">Statements</h3> + +<h5 id="emptyStatementloc"><code>emptyStatement([loc])</code></h5> + +<pre class="notranslate">loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom empty statement node.</p> + +<h5 id="blockStatementbody_loc"><code>blockStatement(body[, loc])</code></h5> + +<pre class="notranslate">body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom block statement node.</p> + +<h5 id="expressionStatementexpr_loc"><code>expressionStatement(expr[, loc])</code></h5> + +<pre class="notranslate">expr: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom expression statement node.</p> + +<h5 id="labeledStatementlabel_body_loc"><code>labeledStatement(label, body[, loc])</code></h5> + +<pre class="notranslate">label: CustomIdentifier +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom labeled statement node.</p> + +<h5 id="ifStatementtest_cons_alt_loc"><code>ifStatement(test, cons, alt[, loc])</code></h5> + +<pre class="notranslate">test: CustomExpression +cons: CustomStatement +alt: CustomStatement | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>if</code> statement node.</p> + +<h5 id="switchStatementdisc_cases_isLexical_loc"><code>switchStatement(disc, cases, isLexical[, loc])</code></h5> + +<pre class="notranslate">disc: CustomExpression +cases: [ CustomSwitchCase ] +isLexical: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>switch</code> statement node. The <strong><code>isLexical</code></strong> flag is metadata indicating whether the <code>switch</code> statement contains any unnested <code>let</code> 宣言 (and therefore introduces a new lexical scope).</p> + +<h5 id="whileStatementtest_body_loc"><code>whileStatement(test, body[, loc])</code></h5> + +<pre class="notranslate">test: CustomExpression +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>while</code> statement node.</p> + +<h5 id="doWhileStatementbody_test_loc"><code>doWhileStatement(body, test[, loc])</code></h5> + +<pre class="notranslate">body: CustomStatement +test: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>do</code>-<code>while</code> statement node.</p> + +<h5 id="forStatementinit_test_update_body_loc"><code>forStatement(init, test, update, body[, loc])</code></h5> + +<pre class="notranslate">init: CustomVariableDeclaration | CustomExpression | null +test: CustomExpression | null +update: CustomExpression | null +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>for</code> statement node.</p> + +<h5 id="forInStatementleft_right_body_isForEach_loc"><code>forInStatement(left, right, body, isForEach[, loc])</code></h5> + +<pre class="notranslate">left: CustomVariableDeclaration | CustomExpression +right: CustomExpression +body: CustomStatement +isForEach: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>for</code>-<code>in</code> statement node. The <strong><code>isForEach</code></strong> flag indicates whether the node is a <code>for each</code> statement.</p> + +<h5 id="breakStatementlabel_loc"><code>breakStatement(label[, loc])</code></h5> + +<pre class="notranslate">label: CustomIdentifier | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>break</code> statement node.</p> + +<h5 id="continueStatementlabel_loc"><code>continueStatement(label[, loc])</code></h5> + +<pre class="notranslate">label: CustomIdentifier | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>continue</code> statement node.</p> + +<h5 id="withStatementobj_body_loc"><code>withStatement(obj, body[, loc])</code></h5> + +<pre class="notranslate">obj: CustomExpression +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>with</code> statement node.</p> + +<h5 id="returnStatementarg_loc"><code>returnStatement(arg[, loc])</code></h5> + +<pre class="notranslate">arg: CustomExpression | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>return</code> statement node.</p> + +<h5 id="tryStatementbody_handlers_fin_loc"><code>tryStatement(body, handlers, fin[, loc])</code></h5> + +<pre class="notranslate">body: CustomStatement +handlers: [ CustomCatchClause ] +fin: CustomStatement | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>try</code> statement node.</p> + +<h5 id="throwStatementarg_loc"><code>throwStatement(arg[, loc])</code></h5> + +<pre class="notranslate">arg: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>throw</code> statement node.</p> + +<h5 id="debuggerStatementloc"><code>debuggerStatement([loc])</code></h5> + +<pre class="notranslate">loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>debugger</code> statement node.</p> + +<h5 id="letStatementhead_body_loc"><code>letStatement(head, body[, loc])</code></h5> + +<pre class="notranslate">head: [ CustomDeclarator ] +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomStatement</p> + +<p>Callback to produce a custom <code>let</code> statement node.</p> + +<h3 id="宣言_3">宣言</h3> + +<h5 id="functionDeclarationname_args_body_isGenerator_isExpression_loc"><code>functionDeclaration(name, args, body, isGenerator, isExpression[, loc])</code></h5> + +<pre class="notranslate">name: string +args: [ CustomPattern ] +body: CustomStatement | CustomExpression +isGenerator: boolean +isExpression: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomDeclaration</p> + +<p>Callback to produce a custom function declaration node.</p> + +<h5 id="variableDeclarationkind_dtors_loc"><code>variableDeclaration(kind, dtors[, loc])</code></h5> + +<pre class="notranslate">kind: "const" | "let" | "var" +dtors: [ CustomDeclarator ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomDeclaration</p> + +<p>Callback to produce a custom variable declaration node.</p> + +<h5 id="variableDeclaratorpatt_init_loc"><code>variableDeclarator(patt, init[, loc])</code></h5> + +<pre class="notranslate">patt: CustomPattern +init: CustomExpression | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomDeclarator</p> + +<p>Callback to produce a custom variable declarator node.</p> + +<h3 id="Expressions_3">Expressions</h3> + +<h5 id="sequenceExpressionexprs_loc"><code>sequenceExpression(exprs[, loc])</code></h5> + +<pre class="notranslate">exprs: [ CustomExpression ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom sequence expression node.</p> + +<h5 id="conditionalExpressiontest_cons_alt_loc"><code>conditionalExpression(test, cons, alt[, loc])</code></h5> + +<pre class="notranslate">test: CustomExpression +cons: CustomExpression +alt: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom conditional expression node.</p> + +<h5 id="unaryExpressionop_arg_isPrefix_loc"><code>unaryExpression(op, arg, isPrefix[, loc])</code></h5> + +<pre class="notranslate">op: UnaryOperator +arg: CustomExpression +isPrefix: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom unary expression node.</p> + +<h5 id="binaryExpressionop_left_right_loc"><code>binaryExpression(op, left, right[, loc])</code></h5> + +<pre class="notranslate">op: BinaryOperator +left: CustomExpression +right: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom binary expression node.</p> + +<h5 id="assignmentExpressionop_left_right_loc"><code>assignmentExpression(op, left, right[, loc])</code></h5> + +<pre class="notranslate">op: AssignmentOperator +left: CustomExpression +right: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom assignment expression node.</p> + +<h5 id="logicalExpressionop_left_right_loc"><code>logicalExpression(op, left, right[, loc])</code></h5> + +<pre class="notranslate">op: LogicalOperator +left: CustomExpression +right: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom logical expression node.</p> + +<h5 id="updateExpressionop_arg_isPrefix_loc"><code>updateExpression(op, arg, isPrefix[, loc])</code></h5> + +<pre class="notranslate">op: UpdateOperator +arg: CustomExpression +isPrefix: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom update expression node.</p> + +<h5 id="newExpressioncallee_args_loc"><code>newExpression(callee, args[, loc])</code></h5> + +<pre class="notranslate">callee: CustomExpression +args: [ CustomExpression ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>new</code>-expression node.</p> + +<h5 id="callExpressioncallee_args_loc"><code>callExpression(callee, args[, loc])</code></h5> + +<pre class="notranslate">callee: CustomExpression +args: [ CustomExpression ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom function call node.</p> + +<h5 id="memberExpressionobj_prop_isComputed_loc"><code>memberExpression(obj, prop, isComputed[, loc])</code></h5> + +<pre class="notranslate">obj: CustomExpression +prop: CustomIdentifier | CustomExpression +isComputed: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom member expression node.</p> + +<h5 id="functionExpressionname_args_body_isGenerator_isExpression_loc"><code>functionExpression(name, args, body, isGenerator, isExpression[, loc])</code></h5> + +<pre class="notranslate">name: CustomIdentifier | null +args: [ CustomPattern ] +body: CustomStatement | CustomExpression +isGenerator: boolean +isExpression: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom function expression node.</p> + +<h5 id="arrayExpressionelts_loc"><code>arrayExpression(elts[, loc])</code></h5> + +<pre class="notranslate">elts: [ CustomExpression | null ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom array expression node.</p> + +<h5 id="objectExpressionprops_loc"><code>objectExpression(props[, loc])</code></h5> + +<pre class="notranslate">props: [ CustomObjectProperty ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom object expression node.</p> + +<h5 id="thisExpressionloc"><code>thisExpression([loc])</code></h5> + +<pre class="notranslate">loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>this</code> expression node.</p> + +<h5 id="graphExpressionindex_expr_loc"><code>graphExpression(index, expr[, loc])</code></h5> + +<pre class="notranslate">index: uint32 >= 1 +expr: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>graph</code> expression node.</p> + +<h5 id="graphIndexExpressionindex_loc"><code>graphIndexExpression(index[, loc])</code></h5> + +<pre class="notranslate">index: uint32 >= 1 +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>graph index</code> expression node.</p> + +<h5 id="comprehensionExpressionbody_blocks_filter_loc"><code>comprehensionExpression(body, blocks, filter[, loc])</code></h5> + +<pre class="notranslate">body: CustomExpression +blocks: [ CustomComprehensionBlock | CustomComprehensionIf ] +filter: CustomExpression | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>comprehension</code> expression node.</p> + +<h5 id="generatorExpressionbody_blocks_filter_loc"><code>generatorExpression(body, blocks, filter[, loc])</code></h5> + +<pre class="notranslate">body: CustomExpression +blocks: [ CustomComprehensionBlock | CustomComprehensionIf ] +filter: CustomExpression | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>generator</code> expression node.</p> + +<h5 id="yieldExpressionarg_loc"><code>yieldExpression(arg[, loc])</code></h5> + +<pre class="notranslate">arg: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>yield</code> expression node.</p> + +<h5 id="letExpressionhead_body_loc"><code>letExpression(head, body[, loc])</code></h5> + +<pre class="notranslate">head: [ CustomDeclarator ] +body: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomExpression</p> + +<p>Callback to produce a custom <code>let</code> expression node.</p> + +<h3 id="Patterns_2">Patterns</h3> + +<h5 id="arrayPatternelts_loc"><code>arrayPattern(elts[, loc])</code></h5> + +<pre class="notranslate">elts: [ CustomPattern | null ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomPattern</p> + +<p>Callback to produce a custom array destructuring pattern node.</p> + +<h5 id="objectPatternprops_loc"><code>objectPattern(props[, loc])</code></h5> + +<pre class="notranslate">props: [ CustomPropertyPattern ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomPattern</p> + +<p>Callback to produce a custom object destructuring pattern node.</p> + +<h5 id="propertyPatternkey_patt_loc"><code>propertyPattern(key, patt[, loc])</code></h5> + +<pre class="notranslate">key: CustomLiteral | CustomIdentifier +patt: CustomPattern +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomPropertyPattern</p> + +<p>Callback to produce a custom object property destructuring pattern node.</p> + +<h3 id="Clauses_2">Clauses</h3> + +<h5 id="switchCasetest_cons_loc"><code>switchCase(test, cons[, loc])</code></h5> + +<pre class="notranslate">test: CustomExpression | null +cons: [ CustomStatement ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomSwitchCase</p> + +<p>Callback to produce a custom <code>case</code> or <code>default</code> clause node. The <strong><code>test</code></strong> argument is <code>null</code> if and only if the node is a <code>default</code> clause.</p> + +<h5 id="catchClausearg_guard_body_loc"><code>catchClause(arg, guard, body[, loc])</code></h5> + +<pre class="notranslate">arg: CustomPattern +guard: CustomExpression +body: CustomStatement +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomCatchClause</p> + +<p>Callback to produce a custom <code>catch</code> clause node.</p> + +<h5 id="comprehensionBlockleft_right_isForEach_loc"><code>comprehensionBlock(left, right, isForEach[, loc])</code></h5> + +<pre class="notranslate">left: CustomPattern +right: CustomExpression +isForEach: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomComprehensionBlock</p> + +<p>Callback to produce a custom comprehension block node. The <strong><code>isForEach</code></strong> flag indicates whether the node is a <code>for each</code> block.</p> + +<p><strong><code>comprehensionIf(test[, loc])</code></strong></p> + +<pre class="notranslate">test: CustomExpression +loc: SourceLocation</pre> + +<p>戻り値: CustomComprehensionIf</p> + +<p>Callback to produce a custom comprehension if node.</p> + +<h3 id="Miscellaneous_2">Miscellaneous</h3> + +<h5 id="identifiername_loc"><code>identifier(name[, loc])</code></h5> + +<pre class="notranslate">name: string +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomIdentifier/CustomPattern/CustomExpression</p> + +<p>Callback to produce a custom identifier node.</p> + +<h5 id="literalval_loc"><code>literal(val[, loc])</code></h5> + +<pre class="notranslate">val: string | boolean | null | number | RegExp +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomLiteral / CustomExpression</p> + +<p>Callback to produce a custom literal node.</p> + +<h5 id="propertykind_key_val_loc"><code>property(kind, key, val[, loc])</code></h5> + +<pre class="notranslate">kind: "init" | "get" | "set" +key: CustomLiteral | CustomIdentifier +val: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomObjectProperty</p> + +<p>Callback to produce a custom object property initializer node.</p> + +<h3 id="E4X_2">E4X</h3> + +<h4 id="宣言_4">宣言</h4> + +<h5 id="xmlDefaultDeclarationns_loc"><code>xmlDefaultDeclaration(ns[, loc])</code></h5> + +<pre class="notranslate">loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomDeclaration</p> + +<p>Callback to produce a custom XML default namespace declaration node.</p> + +<h4 id="Expressions_4">Expressions</h4> + +<h5 id="xmlAnyNameloc"><code>xmlAnyName([loc])</code></h5> + +<pre class="notranslate">loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXMLAnyName/CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML node for the wildcard pseudo-identifier <code>*</code>.</p> + +<h5 id="xmlAttributeSelectorexpr_loc"><code>xmlAttributeSelector(expr[, loc])</code></h5> + +<pre class="notranslate">expr: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML attribute selector node.</p> + +<h5 id="xmlFilterExpressionleft_right_loc"><code>xmlFilterExpression(left, right[, loc])</code></h5> + +<pre class="notranslate">left: CustomExpression +right: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML filter expression node.</p> + +<h5 id="xmlQualifiedIdentifierleft_right_isComputed_loc"><code>xmlQualifiedIdentifier(left, right, isComputed[, loc])</code></h5> + +<pre class="notranslate">left: CustomIdentifier | CustomXMLAnyName +right: CustomIdentifier | CustomExpression +isComputed: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom qualified identifier node.</p> + +<h5 id="xmlFunctionQualifiedIdentifierright_isComputed_loc"><code>xmlFunctionQualifiedIdentifier(right, isComputed[, loc])</code></h5> + +<pre class="notranslate">right: CustomIdentifier | CustomExpression +isComputed: boolean +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML <code>function</code>-qualified identifier node.</p> + +<h5 id="xmlElementcontents_loc"><code>xmlElement(contents[, loc])</code></h5> + +<pre class="notranslate">contents: [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML element node.</p> + +<h5 id="xmlListcontents_loc"><code>xmlList(contents[, loc])</code></h5> + +<pre class="notranslate">contents: [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML/CustomExpression</p> + +<p>Callback to produce a custom XML list node.</p> + +<h4 id="XML_2">XML</h4> + +<h5 id="xmlEscapeexpr_loc"><code>xmlEscape(expr[, loc])</code></h5> + +<pre class="notranslate">expr: CustomExpression +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML escape node.</p> + +<h5 id="xmlTexttext_loc"><code>xmlText(text[, loc])</code></h5> + +<pre class="notranslate">text: string +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML text node.</p> + +<h5 id="xmlStartTagcontents_loc"><code>xmlStartTag(contents[, loc])</code></h5> + +<pre class="notranslate">contents: [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML start-tag node.</p> + +<h5 id="xmlEndTagcontents_loc"><code>xmlEndTag(contents[, loc])</code></h5> + +<pre class="notranslate">contents: [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML end-tag node.</p> + +<h5 id="xmlPointTagcontents_loc"><code>xmlPointTag(contents[, loc])</code></h5> + +<pre class="notranslate">contents: [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML point tag node.</p> + +<h5 id="xmlNamecontents_loc"><code>xmlName(contents[, loc])</code></h5> + +<pre class="notranslate">contents: string | [ CustomXML ] +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML name node.</p> + +<h5 id="xmlAttributevalue_loc"><code>xmlAttribute(value[, loc])</code></h5> + +<pre class="notranslate">value: string +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML attribute node.</p> + +<h5 id="xmlCdatacontents_loc"><code>xmlCdata(contents[, loc])</code></h5> + +<pre class="notranslate">contents: string +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML <code>CDATA</code> node.</p> + +<h5 id="xmlCommentcontents_loc"><code>xmlComment(contents[, loc])</code></h5> + +<pre class="notranslate">contents: string +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML comment node.</p> + +<h5 id="xmlProcessingInstructiontarget_contents_loc"><code>xmlProcessingInstruction(target, contents[, loc])</code></h5> + +<pre class="notranslate">target: string +contents: string | null +loc: SourceLocation +</pre> + +<p><strong>戻り値:</strong> CustomXML</p> + +<p>Callback to produce a custom XML processing instruction node.</p> diff --git a/files/ja/mozilla/projects/spidermonkey/releases/52/index.html b/files/ja/mozilla/projects/spidermonkey/releases/52/index.html new file mode 100644 index 0000000000..d3ddc2bdb5 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/releases/52/index.html @@ -0,0 +1,30 @@ +--- +title: SpiderMonkey 52 +slug: Mozilla/Projects/SpiderMonkey/Releases/52 +translation_of: Mozilla/Projects/SpiderMonkey/Releases/52 +--- +<p>{{SpiderMonkeySidebar("Releases")}}</p> + +<div class="note" style="color: black;"> +<p><strong>これらのリリースノートは不完全です。</strong></p> + +<p>Mozilla JavaScript チームは <strong>SpiderMonkey 52</strong> のリリースを発表しました。treeherder から完全なソースコードをダウンロードするには、<a href="https://treeherder.mozilla.org/#/jobs?repo=mozilla-esr52&filter-searchStr=spidermonkey-sm-package">mozilla-esr52 リポジトリ</a>にアクセスし、表示される最初の SM(pkg) リンクをクリックします。それは、左下の小さなウィンドウに "artifact uploaded:mozjs-52.x.y.tar.bz2" のような行が表示されます。</p> + +<p>SpiderMonkey 52は、Firefox 52 に搭載された JavaScript エンジンです。以前の SpiderMonkey リリースよりもパフォーマンスが向上しています。また、以下で詳しく説明する新しい言語と API の機能も含まれています。</p> + +<p><a href="news://news.mozilla.org/mozilla.dev.tech.js-engine">mozilla.dev.tech.js-engineニュースグループ</a> に投稿することで、このリリースに関するご意見をお聞かせください。また、<a class="link-https" href="https://bugzilla.mozilla.org/">bugzilla.mozilla.org</a> の Product: Core、Component: JavaScript engine のバグを報告してください。 バグを bug 837921 ("sm.embedding"のエイリアス) にすることをお勧めします。</p> +</div> + +<h2 id="プラットフォームサポート"> プラットフォームサポート</h2> + +<h2 id="SpiderMonkey_52_への移行">SpiderMonkey 52 への移行</h2> + +<h2 id="新しい_JavaScript_言語機能">新しい JavaScript 言語機能</h2> + +<h2 id="新しい_C_API">新しい C++ API</h2> + +<h2 id="削除された_API">削除された API</h2> + +<h2 id="API_の変更">API の変更</h2> + +<h2 id="既知の問題">既知の問題</h2> diff --git a/files/ja/mozilla/projects/spidermonkey/releases/index.html b/files/ja/mozilla/projects/spidermonkey/releases/index.html new file mode 100644 index 0000000000..f074c9aeb9 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/releases/index.html @@ -0,0 +1,34 @@ +--- +title: SpiderMonkey リリースノート +slug: Mozilla/Projects/SpiderMonkey/Releases +translation_of: Mozilla/Projects/SpiderMonkey/Releases +--- +<div>{{SpiderMonkeySidebar("Releases")}}</div> + +<div class="summary"> +<p>ここでは <a href="/docs/Mozilla/Projects/SpiderMonkey">SpiderMonkey</a> のリリースノートを一覧で表示しています。</p> +</div> + +<h2 id="現在のリリース">現在のリリース</h2> + +<ul> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/38">SpiderMonkey 38</a></li> +</ul> + +<h2 id="次のリリース">次のリリース</h2> + +<ul> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/45">SpiderMonkey 45</a></li> +</ul> + +<h2 id="過去のリリース">過去のリリース</h2> + +<ul> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/31">SpiderMonkey 31</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/24">SpiderMonkey 24</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/17">SpiderMonkey 17</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/1.8.8">SpiderMonkey 1.8.8</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/1.8.7">SpiderMonkey 1.8.7</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/1.8.5">SpiderMonkey 1.8.5</a></li> + <li><a href="/en-US/docs/Mozilla/Projects/SpiderMonkey/Releases/1.8">SpiderMonkey 1.8</a></li> +</ul> diff --git a/files/ja/mozilla/projects/spidermonkey/shell_global_objects/index.html b/files/ja/mozilla/projects/spidermonkey/shell_global_objects/index.html new file mode 100644 index 0000000000..b560b3e934 --- /dev/null +++ b/files/ja/mozilla/projects/spidermonkey/shell_global_objects/index.html @@ -0,0 +1,662 @@ +--- +title: Shell のグローバルオブジェクト +slug: Mozilla/Projects/SpiderMonkey/Shell_global_objects +tags: + - JavaScript + - NeedsContent + - SpiderMonkey +translation_of: Mozilla/Projects/SpiderMonkey/Shell_global_objects +--- +<p>これらは、プログラムを起動したときに SpiderMonkey <code>js</code> コマンドラインインタプリタによって自動的に設定される<strong>グローバルオブジェクト</strong>です。</p> + +<p><strong>メモ</strong>: このリストは、<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell">JavaScript シェルの紹介</a>の「<a href="/ja/docs/Mozilla/Projects/SpiderMonkey/Introduction_to_the_JavaScript_shell#Built-in_functions">組み込み関数</a>」と重複しているため、おそらく完全ではありません。詳しくは <code>js/src/shell/js.cpp</code> (<code>shell_functions</code> 周辺) をご覧ください。</p> + +<p>このページには SpiderMonkey 53 で利用可能な変数と関数がリストされています。各バージョン間には多少の違いがあるかもしれません。js シェルの <code>help()</code> 関数で関数の一覧を見ることができます。</p> + +<h2 id="変数">変数</h2> + +<dl> + <dt><code>scriptArgs</code></dt> + <dd>js シェルに渡された引数を含む配列。</dd> + <dt><code>scriptPath</code></dt> + <dd>スクリプトのパスである文字列。</dd> + <dt><code>console</code></dt> + <dd>以下のプロパティを持つオブジェクト: + <dl> + <dt><code>log</code></dt> + <dd>式を評価して <code>stdout</code> に出力します。この関数は <code>print()</code> 関数のエイリアスです。</dd> + </dl> + </dd> + <dt><code>timesAccessed</code></dt> + <dd>この変数が何回アクセスされたかを示す数を返します</dd> + <dt>PerfMeasurement</dt> + <dd><a href="/ja/docs/Mozilla/JavaScript_code_modules/PerfMeasurement.jsm">PerfMeasurement.jsm</a> を参照してください。</dd> +</dl> + +<h2 id="シェルのみの関数">シェルのみの関数</h2> + +<h3 id="Functions_always_available">Functions always available</h3> + +<dl> + <dt><code>version([number])</code></dt> + <dd>Get or force a script compilation version number.</dd> + <dt><code>options([option ...])</code></dt> + <dd>Get or toggle JavaScript options.</dd> + <dt><code>load(['foo.js' ...])</code></dt> + <dd>Load files named by string arguments. Filename is relative to the current working directory.</dd> + <dt><code>loadRelativeToScript(['foo.js' ...])</code></dt> + <dd>Load files named by string arguments. Filename is relative to the calling script.</dd> + <dt><code>evaluate(code[, options])</code></dt> + <dd>Evaluate code as though it were the contents of a file. <code>options</code> is an optional object that may have these properties: + <dl> + <dt><code>isRunOnce</code></dt> + <dd>use the <code>isRunOnce</code> compiler option (default: <code>false</code>)</dd> + <dt><code>noScriptRval</code></dt> + <dd>use the no-script-rval compiler option (default: <code>false</code>)</dd> + <dt><code>fileName</code></dt> + <dd>filename for error messages and debug info</dd> + <dt><code>lineNumber</code></dt> + <dd>starting line number for error messages and debug info</dd> + <dt><code>columnNumber</code></dt> + <dd>starting column number for error messages and debug info</dd> + <dt><code>global</code></dt> + <dd>global in which to execute the code</dd> + <dt><code>newContext</code></dt> + <dd>if <code>true</code>, create and use a new <code>cx</code> (default: <code>false</code>)</dd> + <dt><code>catchTermination</code></dt> + <dd>if <code>true</code>, catch termination (failure without an exception value, as for slow scripts or out-of-memory) and return <code>'terminated'</code></dd> + <dt><code>element</code></dt> + <dd>if present with value <code>v</code>, convert <code>v</code> to an object <code>o</code> and mark the source as being attached to the DOM element <code>o</code>. If the property is omitted or <code>v</code> is <code>null</code>, don't attribute the source to any DOM element.</dd> + <dt><code>elementAttributeName</code></dt> + <dd>if present and not <code>undefined</code>, the name of property of <code>element</code> that holds this code. This is what <code>Debugger.Source.prototype.elementAttributeName</code> returns.</dd> + <dt><code>sourceMapURL</code></dt> + <dd>if present with value <code>v</code>, convert <code>v</code> to a string, and provide that as the code's source map URL. If omitted, attach no source map URL to the code (although the code may provide one itself, via a <code>//#sourceMappingURL</code> comment).</dd> + <dt><code>sourceIsLazy</code></dt> + <dd>if present and <code>true</code>, indicates that, after compilation, script source should not be cached by the JS engine and should be lazily loaded from the embedding as-needed.</dd> + <dt><code>loadBytecode</code></dt> + <dd>if <code>true</code>, and if the source is a <code>CacheEntryObject</code>, the bytecode would be loaded and decoded from the cache entry instead of being parsed, then it would be executed as usual.</dd> + <dt><code>saveBytecode</code></dt> + <dd>if <code>true</code>, and if the source is a <code>CacheEntryObject</code>, the bytecode would be encoded and saved into the cache entry after the script execution.</dd> + <dt><code>assertEqBytecode</code></dt> + <dd>if <code>true</code>, and if both <code>loadBytecode</code> and <code>saveBytecode</code> are <code>true</code>, then the loaded bytecode and the encoded bytecode are compared. and an assertion is raised if they differ.</dd> + </dl> + </dd> + <dt><code>run('foo.js')</code></dt> + <dd>Run the file named by the first argument, returning the number of of milliseconds spent compiling and executing it.</dd> +</dl> + +<dl> + <dt><code>read('bar.js')</code></dt> + <dd>Reads the file named by the first argument, returning the content of the file as string.</dd> +</dl> + +<dl> + <dt><code>readline()</code></dt> + <dd>Read a single line from <code>stdin</code>.</dd> + <dt><code>readlineBuf([ buf ])</code></dt> + <dd>Emulate <code>readline()</code> on the specified string. The first call with a string argument sets the source buffer. Subsequent calls without an argument then read from this buffer line by line.</dd> + <dt><code>print([exp ...])</code></dt> + <dd>Evaluate and print expressions to <code>stdout</code>.</dd> + <dt><code>printErr([exp ...])</code></dt> + <dd>Evaluate and print expressions to <code>stderr</code>.</dd> + <dt><code>putstr([exp])</code></dt> + <dd>Evaluate and print expression without newline.</dd> + <dt><code>dateNow()</code></dt> + <dd>Return the current time with sub-ms precision.</dd> + <dt><code>help([name ...])</code></dt> + <dd>Display usage and help messages.</dd> + <dt><code>quit()</code></dt> + <dd>Quit the shell.</dd> + <dt><code>assertEq(actual, expected[, msg])</code></dt> + <dd>Throw if the first two arguments are not the same (both <code>+0</code> or both <code>-0</code>, both <code>NaN</code>, or non-zero and <code>===</code>).</dd> + <dt><code>startTimingMutator()</code></dt> + <dd>Start accounting time to mutator vs GC.</dd> + <dt><code>stopTimingMutator()</code></dt> + <dd>Stop accounting time to mutator vs GC and dump the results.</dd> + <dt><code>throwError()</code></dt> + <dd>Throw an error from <code>JS_ReportError</code>.</dd> + <dt><code>intern(str)</code></dt> + <dd>Internalize <code>str</code> in the atom table.</dd> + <dt><code>getslx(obj)</code></dt> + <dd>Get script line extent.</dd> + <dt><code>evalcx(s[, o])</code></dt> + <dd>Evaluate <code>s</code> in optional sandbox object <code>o</code>. if <code>(s == '' && !o)</code> return new <code>o</code> with eager standard classes, if <code>(s == 'lazy' && !o)</code> return new <code>o</code> with lazy standard classes</dd> + <dt><code>evalInWorker(str)</code></dt> + <dd>Evaluate <code>str</code> in a separate thread with its own runtime.</dd> + <dt><code>getSharedArrayBuffer()</code></dt> + <dd>Retrieve the <code>SharedArrayBuffer</code> object from the cross-worker mailbox. The object retrieved may not be identical to the object that was installed, but it references the same shared memory. <code>getSharedArrayBuffer</code> performs an ordering memory barrier.</dd> + <dt><code>setSharedArrayBuffer()</code></dt> + <dd>Install the <code>SharedArrayBuffer</code> object in the cross-worker mailbox. <code>setSharedArrayBuffer</code> performs an ordering memory barrier.</dd> + <dt><code>shapeOf(obj)</code></dt> + <dd>Get the shape of <code>obj</code> (an implementation detail).</dd> + <dt><code>groupOf(obj)</code></dt> + <dd>Get the group of <code>obj</code> (an implementation detail).</dd> + <dt><code>unwrappedObjectsHaveSameShape(obj1, obj2)</code></dt> + <dd>Returns <code>true</code> iff <code>obj1</code> and <code>obj2</code> have the same shape, <code>false</code> otherwise. Both objects are unwrapped first, so this can be used on objects from different globals.</dd> + <dt><code>sleep(dt)</code></dt> + <dd>Sleep for <code>dt</code> seconds.</dd> + <dt><code>compile(code)</code></dt> + <dd>Compiles a string to bytecode, potentially throwing.</dd> + <dt><code>parseModule(code)</code></dt> + <dd>Parses source text as a module and returns a <code>Module</code> object.</dd> + <dt><code>setModuleResolveHook(function(module, specifier) {})</code></dt> + <dd>Set the <code>HostResolveImportedModule</code> hook to <code>function</code>. This hook is used to look up a previously loaded module object. It should be implemented by the module loader.</dd> + <dt><code>getModuleLoadPath()</code></dt> + <dd>Return any <code>--module-load-path</code> argument passed to the shell. Used by the module loader.</dd> + <dt><code>parse(code)</code></dt> + <dd>Parses a string, potentially throwing.</dd> + <dt><code>syntaxParse(code)</code></dt> + <dd>Check the syntax of a string, returning success value</dd> + <dt><code>offThreadCompileScript(code[, options])</code></dt> + <dd>Compile <code>code</code> on a helper thread. To wait for the compilation to finish and run the code, call <code>runOffThreadScript</code>. If present, <code>options</code> may have properties saying how the code should be compiled: + <dl> + <dt><code>noScriptRval</code></dt> + <dd>use the no-script-rval compiler option (default: <code>false</code>)</dd> + <dt><code>fileName</code></dt> + <dd>filename for error messages and debug info</dd> + <dt><code>lineNumber</code></dt> + <dd>starting line number for error messages and debug info</dd> + <dt><code>columnNumber</code></dt> + <dd>starting column number for error messages and debug info</dd> + <dt><code>element</code></dt> + <dd>if present with value <code>v</code>, convert <code>v</code> to an object <code>o</code> and mark the source as being attached to the DOM element <code>o</code>. If the property is omitted or <code>v</code> is <code>null</code>, don't attribute the source to any DOM element.</dd> + <dt><code>elementAttributeName</code></dt> + <dd>if present and not <code>undefined</code>, the name of property of <code>element</code> that holds this code. This is what <code>Debugger.Source.prototype.elementAttributeName</code> returns.</dd> + </dl> + </dd> + <dt><code>runOffThreadScript()</code></dt> + <dd>Wait for off-thread compilation to complete. If an error occurred, throw the appropriate exception; otherwise, run the script and return its value.</dd> + <dt><code>offThreadCompileModule(code)</code></dt> + <dd>Compile <code>code</code> on a helper thread. To wait for the compilation to finish and get the module object, call <code>finishOffThreadModule</code>.</dd> + <dt><code>finishOffThreadModule()</code></dt> + <dd>Wait for off-thread compilation to complete. If an error occurred, throw the appropriate exception; otherwise, return the module object</dd> + <dt><code>timeout([seconds], [func])</code></dt> + <dd>Get/Set the limit in seconds for the execution time for the current context. A negative value (default) means that the execution time is unlimited. If a second argument is provided, it will be invoked when the timer elapses. Calling this function will replace any callback set by <code>setInterruptCallback</code>.</dd> + <dt><code>interruptIf(cond)</code></dt> + <dd>Requests interrupt callback if cond is <code>true</code>. If a callback function is set via <code>timeout</code> or <code>setInterruptCallback</code>, it will be called. No-op otherwise.</dd> + <dt><code>invokeInterruptCallback(fun)</code></dt> + <dd>Forcefully set the interrupt flag and invoke the interrupt handler. If a callback function is set via <code>timeout</code> or <code>setInterruptCallback</code>, it will be called. Before returning, fun is called with the return value of the interrupt handler.</dd> + <dt><code>setInterruptCallback(func)</code></dt> + <dd>Sets <code>func</code> as the interrupt callback function. Calling this function will replace any callback set by <code>timeout</code>.</dd> + <dt><code>enableLastWarning()</code></dt> + <dd>Enable storing the last warning.</dd> + <dt><code>disableLastWarning()</code></dt> + <dd>Disable storing the last warning.</dd> + <dt><code>getLastWarning()</code></dt> + <dd>Returns an object that represents the last warning.</dd> + <dt><code>clearLastWarning()</code></dt> + <dd>Clear the last warning.</dd> + <dt><code>elapsed()</code></dt> + <dd>Execution time elapsed for the current thread.</dd> + <dt><code>decompileFunction(func)</code></dt> + <dd>Decompile a function.</dd> + <dt><code>decompileThis()</code></dt> + <dd>Decompile the currently executing script.</dd> + <dt><code>thisFilename()</code></dt> + <dd>Return the filename of the current script</dd> + <dt><code>newGlobal([options])</code></dt> + <dd>Return a new global object in a new compartment. If options is given, it may have any of the following properties: + <dl> + <dt><code>sameZoneAs</code></dt> + <dd>the compartment will be in the same zone as the given object (defaults to a new zone)</dd> + <dt><code>invisibleToDebugger</code></dt> + <dd>the global will be invisible to the debugger (default <code>false</code>)</dd> + <dt><code>principal</code></dt> + <dd>if present, its value converted to a number must be an integer that fits in 32 bits; use that as the new compartment's principal. Shell principals are toys, meant only for testing; one shell principal subsumes another if its set bits are a superset of the other's. Thus, a principal of <code>0</code> subsumes nothing, while a principals of <code>~0</code> subsumes all other principals. The absence of a principal is treated as if its bits were <code>0xffff</code>, for subsumption purposes. If this property is omitted, supply no principal.</dd> + </dl> + </dd> + <dt><code>createMappedArrayBuffer(filename, [offset, [size]])</code></dt> + <dd>Create an array buffer that mmaps the given file.</dd> + <dt><code>addPromiseReactions(promise, onResolve, onReject)</code></dt> + <dd>Calls the <code>JS::AddPromiseReactions</code> JSAPI function with the given arguments.</dd> + <dt><code>getMaxArgs()</code></dt> + <dd>Return the maximum number of supported args for a call.</dd> + <dt><code>objectEmulatingUndefined()</code></dt> + <dd>Return a new object <code>obj</code> for which <code>typeof obj === "undefined"</code>, <code>obj == null</code> and <code>obj == undefined</code> (and vice versa for <code>!=</code>), and <code>ToBoolean(obj) === false</code>.</dd> + <dt><code>isCachingEnabled()</code></dt> + <dd>Return whether JS caching is enabled.</dd> + <dt><code>setCachingEnabled(b)</code></dt> + <dd>Enable or disable JS caching.</dd> + <dt><code>cacheEntry(code)</code></dt> + <dd>Return a new opaque object which emulates a cache entry of a script. This object encapsulates the code and its cached content. The cache entry is filled and read by the <code>evaluate</code> function by using it in place of the source, and by setting <code>saveBytecode</code> and <code>loadBytecode</code> options.</dd> + <dt><code>printProfilerEvents()</code></dt> + <dd>Register a callback with the profiler that prints javascript profiler events to <code>stderr</code>. Callback is only registered if profiling is enabled.</dd> + <dt><code>enableSingleStepProfiling()</code></dt> + <dd>This function will fail on platforms that don't support single-step profiling (currently everything but ARM-simulator). When enabled, at every instruction a backtrace will be recorded and stored in an array. Adjacent duplicate backtraces are discarded.</dd> + <dt><code>disableSingleStepProfiling()</code></dt> + <dd>Return the array of backtraces recorded by <code>enableSingleStepProfiling</code>.</dd> + <dt><code>enableSPSProfiling()</code></dt> + <dd>Enables SPS instrumentation and corresponding assertions, with slow assertions disabled.</dd> + <dt><code>enableSPSProfilingWithSlowAssertions()</code></dt> + <dd>Enables SPS instrumentation and corresponding assertions, with slow assertions enabled.</dd> + <dt><code>disableSPSProfiling()</code></dt> + <dd>Disables SPS instrumentation</dd> + <dt><code>isLatin1(s)</code></dt> + <dd>Return true iff the string's characters are stored as Latin1.</dd> + <dt><code>stackPointerInfo()</code></dt> + <dd>Return an <code>int32</code> value which corresponds to the offset of the latest stack pointer, such that one can take the differences of 2 to estimate a frame-size.</dd> + <dt><code>entryPoints(params)</code></dt> + <dd>Carry out some JSAPI operation as directed by <code>params</code>, and return an array of objects describing which JavaScript entry points were invoked as a result. <code>params</code> is an object whose properties indicate what operation to perform. Here are the recognized groups of properties: + <dl> + <dt><code>{ function }</code></dt> + <dd>Call the object <code>params.function</code> with no arguments.</dd> + <dt><code>{ object, property }</code></dt> + <dd>Fetch the property named <code>params.property</code> of <code>params.object</code>.</dd> + <dt><code>{ ToString }</code></dt> + <dd>Apply <code>JS::ToString</code> to <code>params.toString</code>.</dd> + <dt><code>{ ToNumber }</code></dt> + <dd>Apply <code>JS::ToNumber</code> to <code>params.toNumber</code>.</dd> + <dt><code>{ eval }</code></dt> + <dd>Apply <code>JS::Evaluate</code> to <code>params.eval</code>.</dd> + </dl> + The return value is an array of strings, with one element for each JavaScript invocation that occurred as a result of the given operation. Each element is the name of the function invoked, or the string <code>'eval:FILENAME'</code> if the code was invoked by <code>eval</code> or something similar.</dd> + <dt><code>drainJobQueue()</code></dt> + <dd>Take jobs from the shell's job queue in FIFO order and run them until the queue is empty.</dd> + <dt><code>setPromiseRejectionTrackerCallback()</code></dt> + <dd>Sets the callback to be invoked whenever a Promise rejection is unhandled or a previously-unhandled rejection becomes handled.</dd> +</dl> + +<h3 id="Functions_available_only_in_DEBUG_build">Functions available only in DEBUG build</h3> + +<dl> + <dt><code>disassemble([fun/code])</code></dt> + <dd>Return the disassembly for the given function or code. All disassembly functions take these options as leading string arguments: + <dl> + <dt><code>-r</code></dt> + <dd>disassemble recursively</dd> + <dt><code>-l</code></dt> + <dd>show line numbers</dd> + <dt><code>-S</code></dt> + <dd>omit source notes</dd> + </dl> + </dd> + <dt><code>dis([fun/code])</code></dt> + <dd>Disassemble functions into bytecodes.</dd> + <dt><code>disfile('foo.js')</code></dt> + <dd>Disassemble script file into bytecodes.</dd> + <dt><code>dissrc([fun/code])</code></dt> + <dd>Disassemble functions with source lines.</dd> + <dt><code>notes([fun])</code></dt> + <dd>Show source notes for functions.</dd> + <dt><code>stackDump(showArgs, showLocals, showThisProps)</code></dt> + <dd>Tries to print a lot of information about the current stack. Similar to the <code>DumpJSStack()</code> function in the browser.</dd> + <dt><code>arrayInfo(a1, a2, ...)</code></dt> + <dd>Report statistics about arrays.</dd> +</dl> + +<h3 id="Functions_available_only_if_ENABLE_INTL_API_is_defined">Functions available only if ENABLE_INTL_API is defined</h3> + +<dl> + <dt><code>addIntlExtras(obj)</code></dt> + <dd>Adds various not-yet-standardized Intl functions as properties on the provided object (this should generally be <code>Intl</code> itself). The added functions and their behavior are experimental: don't depend upon them unless you're willing to update your code if these experimental APIs change underneath you.</dd> +</dl> + +<h3 id="Functions_available_if_--fuzzing-safe_is_not_specified">Functions available if <code>--fuzzing-safe</code> is not specified</h3> + +<dl> + <dt><code>clone(fun[, scope])</code></dt> + <dd>Clone function object.</dd> + <dt><code>getSelfHostedValue()</code></dt> + <dd>Get a self-hosted value by its name. Note that these values don't get cached, so repeatedly getting the same value creates multiple distinct clones.</dd> + <dt><code>line2pc([fun,] line)</code></dt> + <dd>Map line number to PC.</dd> + <dt><code>pc2line(fun[, pc])</code></dt> + <dd>Map PC to line number.</dd> + <dt><code>nestedShell(shellArgs...)</code></dt> + <dd>Execute the given code in a new JS shell process, passing this nested shell the arguments passed to <code>nestedShell</code>. <code>argv[0]</code> of the nested shell will be <code>argv[0]</code> of the current shell (which is assumed to be the actual path to the shell. <code>arguments[0]</code> (of the call to <code>nestedShell</code>) will be <code>argv[1]</code>, <code>arguments[1]</code> will be <code>argv[2]</code>, etc.</dd> + <dt><code>assertFloat32(value, isFloat32)</code></dt> + <dd>In IonMonkey only, asserts that <code>value</code> has (resp. hasn't) the <code>MIRType::Float32</code> if <code>isFloat32</code> is <code>true</code> (resp. <code>false</code>).</dd> + <dt><code>assertRecoveredOnBailout(var)</code></dt> + <dd>In IonMonkey only, asserts that variable has <code>RecoveredOnBailout</code> flag.</dd> + <dt><code>withSourceHook(hook, fun)</code></dt> + <dd>Set this JS runtime's lazy source retrieval hook (that is, the hook used to find sources compiled with <code>CompileOptions::LAZY_SOURCE</code>) to <code>hook</code>; call <code>fun</code> with no arguments; and then restore the runtime's original hook. Return or throw whatever <code>fun</code> did. <code>hook</code> gets passed the requested code's URL, and should return a string. + <p>Notes:</p> + + <ol> + <li>SpiderMonkey may assert if the returned code isn't close enough to the script's real code, so this function is not fuzzer-safe.</li> + <li>The runtime can have only one source retrieval hook active at a time. If <code>fun</code> is not careful, <code>hook</code> could be asked to retrieve the source code for compilations that occurred long before it was set, and that it knows nothing about. The reverse applies as well: the original hook, that we reinstate after the call to <code>fun</code> completes, might be asked for the source code of compilations that <code>fun</code> performed, and which, presumably, only <code>hook</code> knows how to find.</li> + </ol> + </dd> + <dt><code>wrapWithProto(obj)</code></dt> + <dd>Wrap an object into a noop wrapper with prototype semantics. Note: This is not fuzzing safe because it can be used to construct deeply nested wrapper chains that cannot exist in the wild.</dd> + <dt><code>trackedOpts(fun)</code></dt> + <dd>Returns an object describing the tracked optimizations of <code>fun</code>, if any. If <code>fun</code> is not a scripted function or has not been compiled by Ion, <code>null</code> is returned.</dd> + <dt><code>dumpScopeChain(obj)</code></dt> + <dd>Prints the scope chain of an interpreted function or a module.</dd> + <dt><code>crash([message])</code></dt> + <dd>Crashes the process with a <code>MOZ_CRASH</code>.</dd> + <dt><code>setARMHwCapFlags("flag1,flag2 flag3")</code></dt> + <dd>On non-ARM, no-op. On ARM, set the hardware capabilities. The list of flags is available by calling this function with <code>help</code> as the flag's name</dd> + <dt><code>wasmLoop(filename, imports)</code></dt> + <dd>Performs an AFL-style persistent loop reading data from the given file and passing it to the<code>wasmEval</code> function together with the specified imports object.</dd> +</dl> + +<h2 id="テスト用関数">テスト用関数</h2> + +<p>Testing functions are available also on Firefox via <code>Components.utils.getJSTestingFunctions()</code></p> + +<h3 id="Functions_always_available_2">Functions always available</h3> + +<dl> + <dt><code>gc([obj] | 'zone' [, 'shrinking'])</code></dt> + <dd>Run the garbage collector. When obj is given, GC only its zone. If <code>zone</code> is given, GC any zones that were scheduled for GC via schedulegc. If <code>shrinking</code> is passed as the optional second argument, perform a shrinking GC rather than a normal GC.</dd> + <dt><code>minorgc([aboutToOverflow])</code></dt> + <dd>Run a minor collector on the Nursery. When <code>aboutToOverflow</code> is true, marks the store buffer as about-to-overflow before collecting.</dd> + <dt><code>gcparam(name [, value])</code></dt> + <dd>Wrapper for <code>JS_[GS]etGCParameter</code>. The name is one of: + <ul> + <li>maxBytes</li> + <li>maxMallocBytes</li> + <li>gcBytes</li> + <li>gcNumber</li> + <li>mode</li> + <li>unusedChunks</li> + <li>totalChunks</li> + <li>sliceTimeBudget</li> + <li>markStackLimit</li> + <li>highFrequencyTimeLimit</li> + <li>highFrequencyLowLimit</li> + <li>highFrequencyHighLimit</li> + <li>highFrequencyHeapGrowthMax</li> + <li>highFrequencyHeapGrowthMin</li> + <li>lowFrequencyHeapGrowth</li> + <li>dynamicHeapGrowth</li> + <li>dynamicMarkSlice</li> + <li>allocationThreshold</li> + <li>minEmptyChunkCount</li> + <li>maxEmptyChunkCount</li> + <li>compactingEnabled</li> + <li>refreshFrameSlicesEnabled</li> + </ul> + </dd> + <dt><code>relazifyFunctions(...)</code></dt> + <dd>Perform a GC and allow relazification of functions. Accepts the same arguments as <code>gc()</code>.</dd> + <dt><code>getBuildConfiguration()</code></dt> + <dd>Return an object describing some of the configuration options SpiderMonkey was built with.</dd> + <dt><code>hasChild(parent, child)</code></dt> + <dd>Return <code>true</code> if <code>child</code> is a child of <code>parent</code>, as determined by a call to <code>TraceChildren</code></dd> + <dt><code>setSavedStacksRNGState(seed)</code></dt> + <dd>Set this compartment's <code>SavedStacks</code>' RNG state.</dd> + <dt><code>getSavedFrameCount()</code></dt> + <dd>Return the number of <code>SavedFrame</code> instances stored in this compartment's <code>SavedStacks</code> cache.</dd> + <dt><code>saveStack([maxDepth [, compartment]])</code></dt> + <dd>Capture a stack. If <code>maxDepth</code> is given, capture at most <code>maxDepth</code> number of frames. If <code>compartment</code> is given, allocate the <code>js::SavedFrame</code> instances with the given object's compartment.</dd> + <dt><code>saveStack(object [, shouldIgnoreSelfHosted = true]])</code></dt> + <dd>Capture a stack back to the first frame whose principals are subsumed by the object's compartment's principals. If <code>shouldIgnoreSelfHosted</code> is given, control whether self-hosted frames are considered when checking principals.</dd> + <dt><code>callFunctionFromNativeFrame(function)</code></dt> + <dd>Call <code>function</code> with a (C++-)native frame on stack. Required for testing that <code>SaveStack</code> properly handles native frames.</dd> + <dt><code>callFunctionWithAsyncStack(function, stack, asyncCause)</code></dt> + <dd>Call <code>function</code>, using the provided stack as the async stack responsible for the call, and propagate its return value or the exception it throws. The function is called with no arguments, and <code>this</code> is <code>undefined</code>. The specified <code>asyncCause</code> is attached to the provided stack frame.</dd> + <dt><code>enableTrackAllocations()</code></dt> + <dd>Start capturing the JS stack at every allocation. Note that this sets an object metadata callback that will override any other object metadata callback that may be set.</dd> + <dt><code>disableTrackAllocations()</code></dt> + <dd>Stop capturing the JS stack at every allocation.</dd> + <dt><code>makeFinalizeObserver()</code></dt> + <dd>Get a special object whose finalization increases the counter returned by the <code>finalizeCount</code> function.</dd> + <dt><code>finalizeCount()</code></dt> + <dd>Return the current value of the finalization counter that is incremented each time an object returned by the <code>makeFinalizeObserver</code> is finalized.</dd> + <dt><code>resetFinalizeCount()</code></dt> + <dd>Reset the value returned by <code>finalizeCount()</code>.</dd> + <dt><code>gcPreserveCode()</code></dt> + <dd>Preserve JIT code during garbage collections.</dd> + <dt><code>startgc([n [, 'shrinking']])</code></dt> + <dd>Start an incremental GC and run a slice that processes about <code>n</code> objects. If <code>shrinking</code> is passesd as the optional second argument, perform a shrinking GC rather than a normal GC.</dd> + <dt><code>gcslice([n])</code></dt> + <dd>Start or continue an an incremental GC, running a slice that processes about <code>n</code> objects.</dd> + <dt><code>abortgc()</code></dt> + <dd>Abort the current incremental GC.</dd> + <dt><code>fullcompartmentchecks(true|false)</code></dt> + <dd>If <code>true</code>, check for compartment mismatches before every GC.</dd> + <dt><code>nondeterministicGetWeakMapKeys(weakmap)</code></dt> + <dd>Return an array of the keys in the given WeakMap.</dd> + <dt><code>internalConst(name)</code></dt> + <dd>Query an internal constant for the engine. See <code>InternalConst</code> source for the list of constant names.</dd> + <dt><code>isProxy(obj)</code></dt> + <dd>If <code>true</code>, <code>obj</code> is a proxy of some sort</dd> + <dt><code>dumpHeap(['collectNurseryBeforeDump'], [filename])</code></dt> + <dd>Dump reachable and unreachable objects to the named file, or to <code>stdout</code>. If <code>collectNurseryBeforeDump</code> is specified, a minor GC is performed first, otherwise objects in the nursery are ignored.</dd> + <dt><code>terminate()</code></dt> + <dd>Terminate JavaScript execution, as if we had run out of memory or been terminated by the slow script dialog.</dd> + <dt><code>readSPSProfilingStack()</code></dt> + <dd>Reads the jit stack using <code>ProfilingFrameIterator</code>.</dd> + <dt><code>enableOsiPointRegisterChecks()</code></dt> + <dd>Emit extra code to verify live regs at the start of a VM call are not modified before its <code>OsiPoint</code>.</dd> + <dt><code>displayName(fn)</code></dt> + <dd>Gets the display name for a function, which can possibly be a guessed or inferred name based on where the function was defined. This can be different from the <code>name</code> property on the function.</dd> + <dt><code>isAsmJSCompilationAvailable</code></dt> + <dd>Returns whether asm.js compilation is currently available or whether it is disabled (e.g., by the debugger).</dd> + <dt><code>isSimdAvailable</code></dt> + <dd>Returns <code>true</code> if SIMD extensions are supported on this platform.</dd> + <dt><code>getCompilerOptions()</code></dt> + <dd>Return an object describing some of the JIT compiler options.</dd> + <dt><code>isAsmJSModule(fn)</code></dt> + <dd>Returns whether the given value is a function containing <code>"use asm"</code> that has been validated according to the asm.js spec.</dd> + <dt><code>isAsmJSModuleLoadedFromCache(fn)</code></dt> + <dd>Return whether the given asm.js module function has been loaded directly from the cache. This function throws an error if fn is not a validated asm.js module.</dd> + <dt><code>isAsmJSFunction(fn)</code></dt> + <dd>Returns whether the given value is a nested function in an asm.js module that has been both compile- and link-time validated.</dd> + <dt><code>wasmIsSupported()</code></dt> + <dd>Returns a boolean indicating whether WebAssembly is supported on the current device.</dd> + <dt><code>wasmTextToBinary(str)</code></dt> + <dd>Translates the given text wasm module into its binary encoding.</dd> + <dt><code>wasmBinaryToText(bin)</code></dt> + <dd>Translates binary encoding to text format</dd> + <dt><code>wasmExtractCode(module)</code></dt> + <dd>Extracts generated machine code from WebAssembly.Module.</dd> + <dt><code>isLazyFunction(fun)</code></dt> + <dd><code>True</code> if fun is a lazy <code>JSFunction</code>.</dd> + <dt><code>isRelazifiableFunction(fun)</code></dt> + <dd><code>Ture</code> if fun is a <code>JSFunction</code> with a relazifiable <code>JSScript</code>.</dd> + <dt><code>enableShellAllocationMetadataBuilder()</code></dt> + <dd>Use <code>ShellAllocationMetadataBuilder</code> to supply metadata for all newly created objects.</dd> + <dt><code>getAllocationMetadata(obj)</code></dt> + <dd>Get the metadata for an object.</dd> + <dt><code>bailout()</code></dt> + <dd>Force a bailout out of ionmonkey (if running in ionmonkey).</dd> + <dt><code>bailAfter(number)</code></dt> + <dd>Start a counter to bail once after passing the given amount of possible bailout positions in ionmonkey.</dd> + <dt><code>inJit()</code></dt> + <dd>Returns <code>true</code> when called within (jit-)compiled code. When jit compilation is disabled this function returns an error string. This function returns <code>false</code> in all other cases. Depending on truthiness, you should continue to wait for compilation to happen or stop execution.</dd> + <dt><code>inIon()</code></dt> + <dd>Returns <code>true</code> when called within ion. When ion is disabled or when compilation is abnormally slow to start, this function returns an error string. Otherwise, this function returns <code>false</code>. This behaviour ensures that a falsy value means that we are not in ion, but expect a compilation to occur in the future. Conversely, a truthy value means that we are either in ion or that there is litle or no chance of ion ever compiling the current script.</dd> + <dt><code>assertJitStackInvariants()</code></dt> + <dd>Iterates the Jit stack and check that stack invariants hold.</dd> + <dt><code>setCompilerOption(option, number)</code></dt> + <dd>Set a compiler option indexed in JSCompileOption enum to a number.</dd> + <dt><code>setIonCheckGraphCoherency(bool)</code></dt> + <dd>Set whether Ion should perform graph consistency (DEBUG-only) assertions. These assertions are valuable and should be generally enabled, however they can be very expensive for large (wasm) programs.</dd> + <dt><code>serialize(data, [transferables, [policy]])</code></dt> + <dd>Serialize <code>data</code> using <code>JS_WriteStructuredClone</code>. Returns a structured clone buffer object. <code>policy</code> must be an object. The following keys' string values will be used to determine whether the corresponding types may be serialized (value <code>allow</code>, the default) or not (value <code>deny</code>). If denied types are encountered a TypeError will be thrown during cloning. Valid keys: <code>SharedArrayBuffer</code>.</dd> + <dt><code>deserialize(clonebuffer)</code></dt> + <dd>Deserialize data generated by serialize.</dd> + <dt><code>detachArrayBuffer(buffer)</code></dt> + <dd>Detach the given <code>ArrayBuffer</code> object from its memory, i.e. as if it had been transferred to a WebWorker.</dd> + <dt><code>helperThreadCount()</code></dt> + <dd>Returns the number of helper threads available for off-main-thread tasks.</dd> + <dt><code>reportOutOfMemory()</code></dt> + <dd>Report OOM, then clear the exception and return undefined. For crash testing.</dd> + <dt><code>throwOutOfMemory()</code></dt> + <dd>Throw out of memory exception, for OOM handling testing.</dd> + <dt><code>reportLargeAllocationFailure()</code></dt> + <dd>Call the large allocation failure callback, as though a large malloc call failed, then return undefined. In Gecko, this sends a memory pressure notification, which can free up some memory.</dd> + <dt><code>findPath(start, target)</code></dt> + <dd>Return an array describing one of the shortest paths of GC heap edges from <code>start</code> to <code>target</code>, or <code>undefined</code> if <code>target</code> is unreachable from <code>start</code>. Each element of the array is either of the form: <code>{ node: {object or string}, edge: {string describing edge from node} }</code> , if the node is a JavaScript object or value; or of the form: <code>{ type: {string describing node}, edge: {string describing edge} }</code> , if the node is some internal thing that is not a proper JavaScript value (like a shape or a scope chain element). The destination of the i'th array element's edge is the node of the i+1'th array element; the destination of the last array element is implicitly <code>target</code>.</dd> + <dt><code>shortestPaths(start, targets, maxNumPaths)</code></dt> + <dd>Return an array of arrays of shortest retaining paths. There is an array of shortest retaining paths for each object in <code>targets</code>. The maximum number of paths in each of those arrays is bounded by <code>maxNumPaths</code>. Each element in a path is of the form <code>{ predecessor, edge }</code>.</dd> + <dt><code>sharedMemoryEnabled()</code></dt> + <dd>Return true if <code>SharedArrayBuffer</code> and Atomics are enabled</dd> + <dt><code>evalReturningScope(scriptStr, [global])</code></dt> + <dd>Evaluate the script in a new scope and return the scope. If <code>global</code> is present, clone the script to <code>global</code> before executing.</dd> + <dt><code>cloneAndExecuteScript(source, global)</code></dt> + <dd>Compile <code>source</code> in the current compartment, clone it into <code>global</code>'s compartment, and run it there.</dd> + <dt><code>backtrace()</code></dt> + <dd>Dump out a brief backtrace.</dd> + <dt><code>getBacktrace([options])</code></dt> + <dd>Return the current stack as a string. Takes an optional options object, which may contain any or all of the boolean properties <code>options.args</code> - show arguments to each function <code>options.locals</code> - show local variables in each frame <code>options.thisprops</code> - show the properties of the <code>this</code> object of each frame</dd> + <dt><code>byteSize(value)</code></dt> + <dd>Return the size in bytes occupied by <code>value</code>, or <code>undefined</code> if value is not allocated in memory.</dd> + <dt><code>byteSizeOfScript(f)</code></dt> + <dd>Return the size in bytes occupied by the function <code>f</code>'s JSScript.</dd> + <dt><code>setImmutablePrototype(obj)</code></dt> + <dd>Try to make obj's <code>[[Prototype]]</code> immutable, such that subsequent attempts to change it will fail. Return <code>true</code> if obj's <code>[[Prototype]]</code> was successfully made immutable (or if it already was immutable), <code>false</code> otherwise. Throws in case of internal error, or if the operation doesn't even make sense (for example, because the object is a revoked proxy).</dd> + <dt><code>setLazyParsingDisabled(bool)</code></dt> + <dd>Explicitly disable lazy parsing in the current compartment. The default is that lazy parsing is not explicitly disabled.</dd> + <dt><code>setDiscardSource(bool)</code></dt> + <dd>Explicitly enable source discarding in the current compartment. The default is that source discarding is not explicitly enabled.</dd> + <dt><code>getConstructorName(object)</code></dt> + <dd>If the given object was created with <code>new Ctor</code>, return the constructor's display name. Otherwise, return <code>null</code>.</dd> + <dt><code>allocationMarker([options])</code></dt> + <dd>Return a freshly allocated object whose <code>[[Class]]</code> name is <code>AllocationMarker</code>. Such objects are allocated only by calls to this function, never implicitly by the system, making them suitable for use in allocation tooling tests. Takes an optional options object which may contain the following properties: * nursery: bool, whether to allocate the object in the nursery</dd> + <dt><code>setGCCallback({action:"...", options...})</code></dt> + <dd>Set the GC callback. action may be: + <dl> + <dt><code>minorGC</code></dt> + <dd>run a nursery collection</dd> + <dt><code>majorGC</code></dt> + <dd>run a major collection, nesting up to a given <code>depth</code></dd> + </dl> + </dd> + <dt><code>getLcovInfo(global)</code></dt> + <dd>Generate LCOV tracefile for the given compartment. If no global are provided then the current global is used as the default one.</dd> + <dt><code>getModuleEnvironmentNames(module)</code></dt> + <dd>Get the list of a module environment's bound names for a specified module.</dd> + <dt><code>getModuleEnvironmentValue(module, name)</code></dt> + <dd>Get the value of a bound name in a module environment.</dd> + <dt><code>enableForEach()</code></dt> + <dd>Enables the deprecated, non-standard for-each.</dd> + <dt><code>disableForEach()</code></dt> + <dd>Disables the deprecated, non-standard for-each.</dd> +</dl> + +<h3 id="Functions_available_only_if_SPIDERMONKEY_PROMISE_is_defined">Functions available only if SPIDERMONKEY_PROMISE is defined</h3> + +<dl> + <dt><code>settlePromiseNow(promise)</code></dt> + <dd>'Settle' a <code>promise</code> immediately. This just marks the promise as resolved with a value of <code>undefined</code> and causes the firing of any <code>onPromiseSettled</code> hooks set on <code>Debugger</code> instances that are observing the given promise's global as a debuggee.</dd> + <dt><code>getWaitForAllPromise(densePromisesArray)</code></dt> + <dd>Calls the <code>GetWaitForAllPromise</code> JSAPI function and returns the result Promise.</dd> + <dt><code>resolvePromise(promise, resolution)</code></dt> + <dd>Resolve a <code>Promise</code> by calling the JSAPI function <code>JS::ResolvePromise</code>.</dd> + <dt><code>rejectPromise(promise, reason)</code></dt> + <dd>Reject a <code>Promise</code> by calling the JSAPI function <code>JS::RejectPromise</code>.</dd> +</dl> + +<h3 id="Functions_available_only_if_SPIDERMONKEY_PROMISE_is_not_defined">Functions available only if SPIDERMONKEY_PROMISE is not defined</h3> + +<dl> + <dt><code>makeFakePromise()</code></dt> + <dd>Create an object whose <code>[[Class]]</code> name is <code>'Promise'</code> and call <code>JS::dbg::onNewPromise</code> on it before returning it. It doesn't actually have any of the other behavior associated with promises.</dd> + <dt><code>settleFakePromise(promise)</code></dt> + <dd>'Settle' a <code>promise</code> created by <code>makeFakePromise()</code>. This doesn't have any observable effects outside of firing any <code>onPromiseSettled</code> hooks set on <code>Debugger</code> instances that are observing the given promise's global as a debuggee.</dd> +</dl> + +<h3 id="Functions_available_only_if_JS_GC_ZEAL_is_defined">Functions available only if JS_GC_ZEAL is defined</h3> + +<dl> + <dt><code>gczeal(level, [N])</code></dt> + <dd>Specifies how zealous the garbage collector should be. Some of these modes can be set simultaneously, by passing multiple level options, e.g. <code>"2;4"</code> will activate both modes 2 and 4. Modes can be specified by name or number. + <p>Values:</p> + + <dl> + <dt><code>0: (None)</code></dt> + <dd>Normal amount of collection (resets all modes)</dd> + <dt><code>1: (Poke)</code></dt> + <dd>Collect when roots are added or removed</dd> + <dt><code>2: (Alloc)</code></dt> + <dd>Collect when every <code>N</code> allocations (default: 100)</dd> + <dt><code>3: (FrameGC)</code></dt> + <dd>Collect when the window paints (browser only)</dd> + <dt><code>4: (VerifierPre)</code></dt> + <dd>Verify pre write barriers between instructions</dd> + <dt><code>5: (FrameVerifierPre)</code></dt> + <dd>Verify pre write barriers between paints</dd> + <dt><code>6: (StackRooting)</code></dt> + <dd>Verify stack rooting</dd> + <dt><code>7: (GenerationalGC)</code></dt> + <dd>Collect the nursery every <code>N</code> nursery allocations</dd> + <dt><code>8: (IncrementalRootsThenFinish)</code></dt> + <dd>Incremental GC in two slices: 1) mark roots 2) finish collection</dd> + <dt><code>9: (IncrementalMarkAllThenFinish)</code></dt> + <dd>Incremental GC in two slices: 1) mark all 2) new marking and finish</dd> + <dt><code>10: (IncrementalMultipleSlices)</code></dt> + <dd>Incremental GC in multiple slices</dd> + <dt><code>11: (IncrementalMarkingValidator)</code></dt> + <dd>Verify incremental marking</dd> + <dt><code>12: (ElementsBarrier)</code></dt> + <dd>Always use the individual element post-write barrier, regardless of elements size</dd> + <dt><code>13: (CheckHashTablesOnMinorGC)</code></dt> + <dd>Check internal hashtables on minor GC</dd> + <dt><code>14: (Compact)</code></dt> + <dd>Perform a shrinking collection every N allocations</dd> + <dt><code>15: (CheckHeapAfterGC)</code></dt> + <dd>Walk the heap to check its integrity after every GC</dd> + <dt><code>16: (CheckNursery)</code></dt> + <dd>Check nursery integrity on minor GC</dd> + </dl> + </dd> + <dt><code>schedulegc([num | obj])</code></dt> + <dd>If num is given, schedule a GC after num allocations. If obj is given, schedule a GC of obj's zone. Returns the number of allocations before the next trigger.</dd> + <dt><code>selectforgc(obj1, obj2, ...)</code></dt> + <dd>Schedule the given objects to be marked in the next GC slice.</dd> + <dt><code>verifyprebarriers()</code></dt> + <dd>Start or end a run of the pre-write barrier verifier.</dd> + <dt><code>verifypostbarriers()</code></dt> + <dd>Does nothing (the post-write barrier verifier has been remove).</dd> + <dt><code>gcstate()</code></dt> + <dd>Report the global GC state.</dd> + <dt><code>deterministicgc(true|false)</code></dt> + <dd>If <code>true</code>, only allow determinstic GCs to run.</dd> +</dl> + +<h3 id="Functions_available_only_if_JS_TRACE_LOGGING_is_defined">Functions available only if JS_TRACE_LOGGING is defined</h3> + +<dl> + <dt><code>startTraceLogger()</code></dt> + <dd>Start logging the mainThread. Note: tracelogging starts automatically. Disable it by setting environment variable <code>TLOPTIONS=disableMainThread</code></dd> + <dt><code>stopTraceLogger()</code></dt> + <dd>Stop logging the mainThread.</dd> +</dl> + +<h3 id="Functions_available_only_in_nightly_build">Functions available only in nightly build</h3> + +<dl> + <dt><code>objectAddress(obj)</code></dt> + <dd>Return the current address of the object. For debugging only--this address may change during a moving GC.</dd> + <dt><code>sharedAddress(obj)</code></dt> + <dd>Return the address of the shared storage of a <code>SharedArrayBuffer</code>.</dd> +</dl> + +<h3 id="Functions_available_only_in_DEBUG_build_2">Functions available only in DEBUG build</h3> + +<dl> + <dt><code>dumpObject()</code></dt> + <dd>Dump an internal representation of an object.</dd> + <dt><code>dumpStringRepresentation(str)</code></dt> + <dd>Print a human-readable description of how the string <code>str</code> is represented.</dd> + <dt><code>setRNGState(seed0, seed1)</code></dt> + <dd>Set this compartment's RNG state.</dd> +</dl> + +<h3 id="Functions_available_only_in_DEBUG_build_or_JS_OOM_BREAKPOINT_is_defined">Functions available only in DEBUG build or JS_OOM_BREAKPOINT is defined</h3> + +<dl> + <dt><code>oomThreadTypes()</code></dt> + <dd>Get the number of thread types that can be used as an argument for <code>oomAfterAllocations()</code> and <code>oomAtAllocation()</code>.</dd> + <dt><code>oomAfterAllocations(count [,threadType])</code></dt> + <dd>After <code>count</code> <code>js_malloc</code> memory allocations, fail every following allocation (return <code>nullptr</code>). The optional thread type limits the effect to the specified type of helper thread.</dd> + <dt><code>oomAtAllocation(count [,threadType])</code></dt> + <dd>After <code>count</code> <code>js_malloc</code> memory allocations, fail the next allocation (return <code>nullptr</code>). The optional thread type limits the effect to the specified type of helper thread.</dd> + <dt><code>resetOOMFailure()</code></dt> + <dd>Remove the allocation failure scheduled by either <code>oomAfterAllocations()</code> or <code>oomAtAllocation()</code> and return whether any allocation had been caused to fail.</dd> + <dt><code>oomTest(function, [expectExceptionOnFailure = true])</code></dt> + <dd>Test that the passed function behaves correctly under OOM conditions by repeatedly executing it and simulating allocation failure at successive allocations until the function completes without seeing a failure. By default this tests that an exception is raised if execution fails, but this can be disabled by passing false as the optional second parameter. This is also disabled when <code>--fuzzing-safe</code> is specified.</dd> +</dl> + +<h3 id="Functions_available_only_in_DEBUG_build_if_--fuzzing-safe_is_not_specified_and">Functions available only in DEBUG build if <code>--fuzzing-safe</code> is not specified and</h3> + +<dl> + <dt><code>parseRegExp(pattern[, flags[, match_only])</code></dt> + <dd>Parses a <code>RegExp</code> pattern and returns a tree, potentially throwing.</dd> + <dt><code>disRegExp(regexp[, match_only[, input]])</code></dt> + <dd>Dumps <code>RegExp</code> bytecode.</dd> +</dl> |