Skip to content

Duktape

INFO

このページおよび同じカテゴリーにあるすべてのページはDuktapeの公式サイトGithubリポジトリのドキュメント等を翻訳したものです。

Duktapeは移植性とコンパクトなフットプリントに重点を置いた、組み込み可能なJavascriptエンジンです。

DuktapeはC/C++プロジェクトに簡単に統合できます。ビルドにduktape.c、duktape.h、duk_config.hを追加し、Duktape APIを使ってCコードからECMAScriptの関数を呼び出したり、逆にECMAScriptからCコードに関数を呼び出したりすることができます。

特徴

  • 組み込み可能、ポータブル、コンパクト:160kB フラッシュと 64kB RAM のプラットフォームで実行可能。
  • ECMAScript E5/E5.1、一部のセマンティクスは ES2015+ から更新されています。
  • ECMAScript 2015 (E6)ECMAScript 2016 (E7) を部分的にサポート、Post-ES5 feature statuskangax/compat-table を参照してください。
  • ES2015 TypedArrayおよびNode.js Bufferバインディング
  • CBORバインディング
  • WHATWG Encoding Living Standardに基づくエンコーディングAPIバインディング
  • performance.now()
  • ビルトインデバッガ
  • ビルトイン正規表現エンジン
  • 内蔵のUnicodeサポート
  • 最小限の、再ターゲット可能なプラットフォーム依存性
  • 参照カウントとマーク&スイープ・ガベージコレクションの組み合わせとファイナリゼーション
  • コルーチン
  • ECMAScript ES2015 Proxy オブジェクトのサブセットを使用したプロパティの仮想化
  • コンパイルされた関数をキャッシュするためのバイトコードダンプ/ロード
  • 配布可能なものには、オプションでロギングフレームワーク、CommonJSベースのモジュールロード実装などがあります。
  • リベラルライセンス(MIT)

コードとRAMのフットプリント

Hello worldの:

ConfigCode footprint (kB)Startup RAM (kB)
thumb default14878
thumb lowmem9627
thumb full lowmem1191.5
x86 default18778
x86 lowmem12427
x86 full lowmem1481.5

コードのフットプリントを最小にするためのGCCオプションを参照してください。完全なローメモリでは、ポインタ圧縮とROMベースの文字列/オブジェクトを使用します。ROMベースの文字列/オブジェクトは、他のローメモリオプションなしで使うこともできます。

現在の状況

  • 安定版

サポート

Duktapeを使用したいくつかのプロジェクト

Duktapeを使用しているプロジェクトを参照してください。

もしあなたのプロジェクトでDuktapeを使っているなら、リストに追加するためにメールを送るか、GitHubのissuesを開いてください。

類似エンジン

少なくともDuktapeと同様のユースケースをターゲットにしたJavascriptエンジンは複数存在します。

ECMAScriptエンジンの一覧も参照してください。

1. ビルドに追加する

(詳しい紹介はGetting startedをご覧ください)

Duktape Cのソースとヘッダをビルドに追加します。どのようなビルドシステムでも使用できます。配布物には、参考までにMakefileの例が含まれています。最も単純なケースでは

$ gcc -std=c99 -otest test.c duktape.c -lm
$ ./test
1+2=3

Duktapeの設定をカスタマイズするには、ここでECMAScript 6 Proxyオブジェクトのサポートを無効にしてください。

$ python2 duktape-2.6.0/tools/configure.py --output-directory src-duktape \
      -UDUK_USE_ES6_PROXY
$ ls src-duktape/
duk_config.h  duk_source_meta.json  duktape.c  duktape.h
$ gcc -std=c99 -otest -Isrc-duktape \
      test.c src-duktape/duktape.c -lm
$ ./test
1+2=3

2 コンテキストを初期化する

プログラムのどこかでDuktapeを初期化し、使用する。

c
/* test.c */
#include <stdio.h>
#include "duktape.h"

int main(int argc, char *argv[]) {
  duk_context *ctx = duk_create_heap_default();
  duk_eval_string(ctx, "1+2");
  printf("1+2=%d\n", (int) duk_get_int(ctx, -1));
  duk_destroy_heap(ctx);
  return 0;
}

3. C関数バインディングの追加

ECMAScript のコードから C の関数を呼び出すには、まず C の関数を宣言します。

c
/* 組み込みエンジンであるDuktapeは、
 * デフォルトではI/Oバインディングを提供しません。
 * 以下は引数が1つの単純なprint()関数です。
 */

static duk_ret_t native_print(duk_context *ctx) {
  printf("%s\n", duk_to_string(ctx, 0));
  return 0;  /* no return value (= undefined) */
}

/* Adder: 引数の値を加算する。 */
static duk_ret_t native_adder(duk_context *ctx) {
  int i;
  int n = duk_get_top(ctx);  /* #args */
  double res = 0.0;

  for (i = 0; i < n; i++) {
    res += duk_to_number(ctx, i);
  }

  duk_push_number(ctx, res);
  return 1;  /* one return value */
}

作成した関数をグローバルオブジェクトに登録するなどしてください。

c
duk_push_c_function(ctx, native_print, 1 /*nargs*/);
duk_put_global_string(ctx, "print");
duk_push_c_function(ctx, native_adder, DUK_VARARGS);
duk_put_global_string(ctx, "adder");

そして、ECMAScriptのコードから関数を呼び出すことができます。

javascript
duk_eval_string_noresult(ctx, "print('2+3=' + adder(2, 3));");

Duktape is (C) by its authors and licensed under the MIT license.