Go to file
openharmony_ci f90507e628
!7886 OOM dump don't report appfreeze.
Merge pull request !7886 from hhl/master
2024-06-26 15:41:59 +00:00
.gitee add the jit workload to the checklist 2024-06-07 15:46:29 +08:00
compiler_service Modify the fork function to syscall starter 2024-06-26 17:48:42 +08:00
docs Remove TSManager and TSTypes 2024-04-18 19:02:45 +08:00
ecmascript !7886 OOM dump don't report appfreeze. 2024-06-26 15:41:59 +00:00
etc support jit log skip 2024-06-18 09:11:18 +08:00
script Added DateNow builtin 2024-04-20 12:30:39 +08:00
test !7910 Add Fast Path For ToLocaleUpperCase 2024-06-26 11:34:14 +00:00
tools/circuit_viewer fix warning of security 2024-06-14 15:19:49 +08:00
.gitignore Add TS Aot Test Framework 2022-04-25 21:28:10 +08:00
BUILD.gn !7782 适配Linux arm host openharmony编译 2024-06-24 09:12:04 +00:00
bundle.json merge aot and jit white list 2024-06-20 20:45:32 +08:00
hisysevent.yaml add jit event 2024-05-14 14:38:56 +08:00
js_runtime_config.gni !7782 适配Linux arm host openharmony编译 2024-06-24 09:12:04 +00:00
libark_jsruntime.map OOM dump don't report appfreeze. 2024-06-24 16:36:15 +08:00
LICENSE add ark js_runtime 2021-09-05 16:05:06 +08:00
OAT.xml 静态告警fix 2024-06-06 11:23:53 +08:00
README_zh.md Update Dead-link in docs 2023-11-01 11:24:56 +08:00
README.md Modify ets_runtime readme.md 2023-05-09 15:05:35 +08:00

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.

ArkCompiler JS Runtime architecture

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.

Usage

For details about how to generate JS bytecodes, see Using the Toolchain.

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

arkcompiler_ets_runtime

arkcompiler_ets_frontend