NAME
Wasm::Wasmtime::Linker - Wasmtime linker class
VERSION
version 0.23
SYNOPSIS
use Wasm::Wasmtime;
my $store = Wasm::Wasmtime::Store->new;
my $linker = Wasm::Wasmtime::Linker->new($store);
# Instanciate and define a WASI instance
my $wasi = Wasm::Wasmtime::WasiInstance->new(
$store,
"wasi_snapshot_preview1",
Wasm::Wasmtime::WasiConfig
->new
->inherit_stdout
);
$linker->define_wasi($wasi);
# Create a logger module + instance
my $logger = $linker->instantiate(
Wasm::Wasmtime::Module->new(
$store->engine,
wat => q{
(module
(type $fd_write_ty (func (param i32 i32 i32 i32) (result i32)))
(import "wasi_snapshot_preview1" "fd_write" (func $fd_write (type $fd_write_ty)))
(func (export "log") (param i32 i32)
;; store the pointer in the first iovec field
i32.const 4
local.get 0
i32.store
;; store the length in the first iovec field
i32.const 4
local.get 1
i32.store offset=4
;; call the `fd_write` import
i32.const 1 ;; stdout fd
i32.const 4 ;; iovs start
i32.const 1 ;; number of iovs
i32.const 0 ;; where to write nwritten bytes
call $fd_write
drop
)
(memory (export "memory") 2)
(global (export "memory_offset") i32 (i32.const 65536))
)
},
)
);
$linker->define_instance("logger", $logger);
# Create a caller module + instance
my $caller = $linker->instantiate(
Wasm::Wasmtime::Module->new(
$store->engine,
wat => q{
(module
(import "logger" "log" (func $log (param i32 i32)))
(import "logger" "memory" (memory 1))
(import "logger" "memory_offset" (global $offset i32))
(func (export "run")
;; Our `data` segment initialized our imported memory, so let's print the
;; string there now.
global.get $offset
i32.const 14
call $log
)
(data (global.get $offset) "Hello, world!\n")
)
},
),
);
$caller->exports->run->();
DESCRIPTION
WARNING: WebAssembly and Wasmtime are a moving target and the interface for these modules is under active development. Use with caution.
This class represents a WebAssembly linker.
CONSTRUCTOR
new
my $linker = Wasm::Wasmtime::Linker->new(
$store, # Wasm::Wasmtime::Store
);
Create a new WebAssembly linker object.
METHODS
allow_shadowing
$linker->allow_shadowing($bool);
Sets the allow shadowing property.
define
$linker->define(
$module,
$name,
$extern, # Wasm::Wasmtime::Extern
);
Define the given extern. You can use a func, global, table or memory object in its place and this method will get the extern for you.
define_wasi
$linker->define_wasi(
$wasi, # Wasm::Wasmtime::WasiInstance
);
Define WASI instance.
define_instance
$linker->define_instance(
$name, # string
$instance, # Wasm::Wasmtime::Instance
);
Define WebAssembly instance.
instantiate
my $instance = $linker->instantiate(
$module,
);
Instantiate the module using the linker. Returns the new Wasm::Wasmtime::Instance object.
get_one_by_name
my $extern = $linker->get_one_by_name($module,$name);
Returns the Wasm::Wasmtime::Extern for the given $module
and $name
. undef
is returned if there is no such extern with that $name
.
get_default
my $func = $linker->get_default($name);
Acquires the "default export" of the named module in this linker. Returns a Wasm::Wasmtime::Func.
store
my $store = $linker->store;
Returns the Wasm::Wasmtime::Store for the linker.
SEE ALSO
AUTHOR
Graham Ollis <plicease@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2020-2022 by Graham Ollis.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.