# arkcompiler_ets_runtime **Repository Path**: li_yue1999/arkcompiler_ets_runtime ## Basic Information - **Project Name**: arkcompiler_ets_runtime - **Description**: 方舟ArkTS运行时(ARK TypeScript Runtime)是OpenHarmony上ArkTS应用使用的运行时。包含ArkTS/JS对象的分配器以及垃圾回收器(GC)、符合ECMAScript规范的标准库、用于运行ARK前端组件生成的方舟字节码(ARK Bytecode简称abc)的解释器、用于加速的内联缓存、静态类型编译器、运行时的C++/C函数接口(NAPI)等模块。 - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1082 - **Created**: 2023-11-01 - **Last Updated**: 2024-11-07 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # ArkCompiler JS Runtime ### Introduction ArkCompiler JS Runtime is the default JS runtime on OpenHarmony. It supports ECMAScript libraries and efficient container libraries. It also provides a set of native APIs for C++ and JS interaction and a variety of garbage collectors that features high performance. For more information, see [ArkCompiler JS Runtime](https://gitee.com/openharmony/docs/blob/master/en/readme/ARK-Runtime-Subsystem.md). **ArkCompiler JS Runtime architecture** ![](/docs/figures/en-us_image_ark-js-arch.png) ## Directory Structure ``` /arkcompiler/ets_runtime ├─ ecmascript # Implementation of ArkCompiler JS Runtime, including the ECMAScript library, interpreter, and memory management │ ├─ base # Base helper class │ ├─ builtins # ECMAScript libraries │ ├─ compiler # JS compiler │ ├─ containers # Non-ECMAScript containers │ ├─ dfx # Memory and profiling tool │ ├─ ic # Inline cache module │ ├─ interpreter # JS interpreter │ ├─ jobs # Queue of jobs │ ├─ js_vm # Command line tool │ ├─ jspandafile # abc file management module │ ├─ mem # Memory management module │ ├─ module # ECMAScript module │ ├─ napi # C++ API module │ ├─ taskpool # Task pool │ ├─ regexp # Regular expression engine module │ ├─ snapshot # Snapshot module │ ├─ stubs # Runtime stub functions │ ├─ tests # Unit test cases │ ├─ debugger # JS debugger │ ├─ trampoline # Trampoline function │ ├─ ts_type # TS type management module └─ test # Module test cases ``` ## Constraints * Only the ArkCompiler bytecode files generated by ts2abc, which is the ArkCompiler JS frontend toolchain, can be run. * Only the ES2021 standard and strict modes are supported. * Functions cannot be dynamically created using strings, such as new Function("console.log(1);")). ## Building ``` $./build.sh --product-name hispark_taurus_standard --build-target ark_js_host_linux_tools_packages ``` ### Available APIs See [NAPI](https://gitee.com/openharmony/arkui_napi/blob/master/README.md). ### Usage For details about how to generate JS bytecodes, see [Using the Toolchain](docs/using-the-toolchain.md). To run bytecodes: ``` LD_LIBRARY_PATH=out/hispark_taurus/clang_x64/arkcompiler/ets_runtime:out/hispark_taurus/clang_x64/thirdparty/icu:prebuilts/clang/ohos/linux-x86_64/llvm/lib ./out/hispark_taurus/clang_x64/arkcompiler/ets_runtime/ark_js_vm helloworld.abc ``` For more information, see [ARK Runtime Usage Guide](https://gitee.com/openharmony/arkcompiler_ets_runtime/blob/master/ docs/ARK-Runtime-Usage-Guide.md). ## Repositories Involved [arkcompiler\_runtime\_core](https://gitee.com/openharmony/arkcompiler_runtime_core) **[arkcompiler\_ets\_runtime](https://gitee.com/openharmony/arkcompiler_ets_runtime)** [arkcompiler\_ets\_frontend](https://gitee.com/openharmony/arkcompiler_ets_frontend)