# ARK JS Runtime Module - [ARK JS Runtime Module](#ark-js-runtime-module) - [Introduction](#introduction) - [Directory Structure](#directory-structure) - [Constraints](#constraints) - [Build](#build) - [Available APIs](#available-apis) - [Usage Guidelines](#usage-guidelines) - [Repositories Involved](#repositories-involved) ### Introduction ARK JS Runtime is the runtime used by JavaScript \(JS\) applications on OpenHarmony. It consists of the JS object allocator, garbage collector \(GC\), a standard library compliant with ECMAScript specifications, ARK bytecode interpreter, inline caches that store hidden classes, and the ARK Foreign Function Interface \(AFFI\). For more infomation, see: [ARK Runtime Subsystem](https://gitee.com/openharmony/docs/blob/master/en/readme/ARK-Runtime-Subsystem.md). **ARK JS runtime architecture** ![](docs/figures/en-us_image_0000001149439242.png) ## Directory Structure ``` /ark/js_runtime ├─ ecmascript # JS object definition │ ├─ base # Base helper class │ ├─ builtins # ECMAScript library │ ├─ class_linker # Bytecode pre-processing module │ ├─ compiler # JS compiler │ ├─ containers # Non-ECMAScript container library │ ├─ cpu_profiler # CPU Performance Analyzer │ ├─ hprof # Memory analysis utility class │ ├─ ic # Inline cache module │ ├─ interpreter # JS interpreter │ ├─ jobs # Queue of jobs │ ├─ js_vm # ARK command line tool │ ├─ mem # Memory management module │ ├─ napi # External native interface │ ├─ regexp # Regular expression engine module │ ├─ snapshot/mem # Snapshot module │ ├─ tests # Unit test cases │ ├─ thread # Thread pool │ ├─ tooling # JS debugger │ └─ vmstat # Runtime status utility classes └─ test # Module test cases ``` ## Constraints * Only the bytecode file generated by the ARK JS frontend can be run. * Only support ES2015 standard and strict mode ("use strict"). * Don't support dynamically create functions via string (e.g., new Function("console.log(1))). ## Build ``` ./build.sh --product-name Hi3516DV300 --build-target ark_js_runtime ``` ### Available APIs For details, see [NAPI](https://gitee.com/openharmony/ace_napi/blob/master/README.md). ### Usage Guidelines For details about how to generate JS bytecodes, see [Using the Toolchain](docs/using-the-toolchain.md). To run bytecodes: ``` $ cd out/release $ export LD_LIBRARY_PATH=clang_x64/ark/ark_js_runtime:clang_x64/ark/ark:clang_x64/global/i18n:../../prebuilts/clang/ohos/linux-x86_64/llvm/lib/ $ ./clang_x64/ark/ark_js_runtime/ark_js_vm helloworld.abc ``` For more infomation, please see: [ARK-Runtime-Usage-Guide](https://gitee.com/openharmony/ark_js_runtime/blob/master/docs/ARK-Runtime-Usage-Guide.md). ## Repositories Involved [ark\_runtime\_core](https://gitee.com/openharmony/ark_runtime_core) **[ark\_js\_runtime](https://gitee.com/openharmony/ark_js_runtime)** [ark\_ts2abc](https://gitee.com/openharmony/ark_ts2abc)