Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Extism Elixir Host SDK - easily run WebAssembly modules / plugins from Elixir applications

License

NotificationsYou must be signed in to change notification settings

extism/elixir-sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Extism Host SDK for Elixir

Docs

Read thedocs on hexdocs.pm.

Installation

You can find this package on hex.pmhex.pm

defdepsdo[{:extism,"1.0.0"}]end

Note: You do not need to install the Extism Runtime shared object, but you will need a rust toolchain installed to build this package. SeeInstall Rust to install for your platform.

Getting Started

This guide should walk you through some of the concepts in Extism and this Elixir library.

Note: You should be able to follow this guide by copy pasting the code intoiex usingiex -S mix.

Creating A Plug-in

The primary concept in Extism is theplug-in. You can think of a plug-in as a code module stored in a.wasm file.

Since you may not have an Extism plug-in on hand to test, let's load a demo plug-in from the web:

url="https://github.com/extism/plugins/releases/latest/download/count_vowels.wasm"manifest=%{wasm:[%{url:url}]}{:ok,plugin}=Extism.Plugin.new(manifest,false)

Note: Seethe Manifest docs as it has a rich schema and a lot of options.

Calling A Plug-in's Exports

This plug-in was written in Rust and it does one thing, it counts vowels in a string. As such, it exposes one "export" function:count_vowels. We can call exports usingExtism.Plugin#call/3:

{:ok,output}=Extism.Plugin.call(plugin,"count_vowels","Hello, World!")# => {"count": 3, "total": 3, "vowels": "aeiouAEIOU"}

All exports have a simple interface of bytes-in and bytes-out. This plug-in happens to take a string and return a JSON encoded string with a report of results.

Plug-in State

Plug-ins may be stateful or stateless. Plug-ins can maintain state b/w calls by the use of variables. Our count vowels plug-in remembers the total number of vowels it's ever counted in the "total" key in the result. You can see this by making subsequent calls to the export:

{:ok,output}=Extism.Plugin.call(plugin,"count_vowels","Hello, World!")# => {"count": 3, "total": 6, "vowels": "aeiouAEIOU"}{:ok,output}=Extism.Plugin.call(plugin,"count_vowels","Hello, World!")# => {"count": 3, "total": 9, "vowels": "aeiouAEIOU"}

These variables will persist until this plug-in is freed or you initialize a new one.

Configuration

TODO: Implement config

Plug-ins may optionally take a configuration object. This is a static way to configure the plug-in. Our count-vowels plugin takes an optional configuration to change out which characters are considered vowels. Example:

{:ok,output}=Extism.Plugin.call(plugin,"count_vowels","Yellow, World!")# => {"count": 3, "total": 3, "vowels": "aeiouAEIOU"}{:ok,plugin}=Extism.Plugin.new(manifest,false,%{"vowels":"aeiouyAEIOUY"}){:ok,output}=Extism.Plugin.call(plugin,"count_vowels","Yellow, World!")plugin.call("count_vowels","Yellow, World!")# => {"count": 4, "total": 4, "vowels": "aeiouAEIOUY"}

Host Functions

We don't offer host function support in this library yet. If it is something you need, pleasefile an issue!

About

Extism Elixir Host SDK - easily run WebAssembly modules / plugins from Elixir applications

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors3

  •  
  •  
  •  

[8]ページ先頭

©2009-2025 Movatter.jp