diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-06-25 12:03:02 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-06-25 12:03:02 -0700 |
commit | c410d93d3af9813f889b4011f964d4becf43bc27 (patch) | |
tree | e6f3f330d5dd44755ab065a552403c957f96583c /test/example/c-api-kitchen-sink.c | |
parent | a88f8f275e068d6cdfb8879dc3bab1fe3201efbc (diff) | |
download | binaryen-c410d93d3af9813f889b4011f964d4becf43bc27.tar.gz binaryen-c410d93d3af9813f889b4011f964d4becf43bc27.tar.bz2 binaryen-c410d93d3af9813f889b4011f964d4becf43bc27.zip |
add c api method to interpret a module, calling its start method (#601)
Diffstat (limited to 'test/example/c-api-kitchen-sink.c')
-rw-r--r-- | test/example/c-api-kitchen-sink.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/test/example/c-api-kitchen-sink.c b/test/example/c-api-kitchen-sink.c index 84f04b45a..feffc9d4c 100644 --- a/test/example/c-api-kitchen-sink.c +++ b/test/example/c-api-kitchen-sink.c @@ -433,8 +433,29 @@ void test_binaries() { BinaryenModuleDispose(module); } +void test_interpret() { + // create a simple module with a start method that prints a number, and interpret it, printing that number. + BinaryenModuleRef module = BinaryenModuleCreate(); + + BinaryenType iparams[2] = { BinaryenInt32() }; + BinaryenFunctionTypeRef vi = BinaryenAddFunctionType(module, "vi", BinaryenNone(), iparams, 1); + BinaryenAddImport(module, "print-i32", "spectest", "print", vi); + + BinaryenFunctionTypeRef v = BinaryenAddFunctionType(module, "v", BinaryenNone(), NULL, 0); + BinaryenExpressionRef callOperands[] = { makeInt32(module, 1234) }; + BinaryenExpressionRef call = BinaryenCallImport(module, "print-i32", callOperands, 1, BinaryenNone()); + BinaryenFunctionRef starter = BinaryenAddFunction(module, "starter", v, NULL, 0, call); + BinaryenSetStart(module, starter); + + BinaryenModulePrint(module); + assert(BinaryenModuleValidate(module)); + BinaryenModuleInterpret(module); + BinaryenModuleDispose(module); +} + int main() { test_core(); test_relooper(); test_binaries(); + test_interpret(); } |