Name | componentize-py JSON |
Version |
0.16.0
JSON |
| download |
home_page | None |
Summary | Tool to package Python applications as WebAssembly components |
upload_time | 2024-11-27 21:36:31 |
maintainer | None |
docs_url | None |
author | None |
requires_python | None |
license | None |
keywords |
webassembly
wasm
component
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# componentize-py
**A [Bytecode Alliance](https://bytecodealliance.org/) project**
This is a tool to convert a Python application to a [WebAssembly
component](https://github.com/WebAssembly/component-model). It takes the
following as input:
- a [WIT](https://github.com/WebAssembly/component-model/blob/main/design/mvp/WIT.md) file or directory
- the name of a [WIT world](https://github.com/WebAssembly/component-model/blob/main/design/mvp/WIT.md#wit-worlds) defined in the above file or directory
- the name of a Python module which targets said world
- a list of directories in which to find the Python module and its dependencies
The output is a component which may be run using
e.g. [`wasmtime`](https://github.com/bytecodealliance/wasmtime).
## Getting Started
First, install [Python 3.10 or later](https://www.python.org/) and
[pip](https://pypi.org/project/pip/) if you don't already have them. Then,
install `componentize-py`:
```shell
pip install componentize-py
```
Next, create or download the WIT world you'd like to target, e.g.:
```shell
cat >hello.wit <<EOF
package example:hello;
world hello {
export hello: func() -> string;
}
EOF
```
If you're using an IDE or just want to examine the bindings produced for the WIT
world, you can generate them using the `bindings` subcommand:
```shell
componentize-py -d hello.wit -w hello bindings hello_guest
```
Then, use the `hello` module produced by the command above to write your app:
```shell
cat >app.py <<EOF
import hello
class Hello(hello.Hello):
def hello(self) -> str:
return "Hello, World!"
EOF
```
And finally generate the component:
```shell
componentize-py -d hello.wit -w hello componentize --stub-wasi app -o app.wasm
```
To test it, you can install `wasmtime-py` and use it to generate host-side
bindings for the component:
```shell
pip install wasmtime
python3 -m wasmtime.bindgen app.wasm --out-dir hello_host
```
Now we can write a simple host app using those bindings:
```shell
cat >host.py <<EOF
from hello_host import Root
from wasmtime import Config, Engine, Store
config = Config()
config.cache = True
engine = Engine(config)
store = Store(engine)
hello = Root(store)
print(f"component says: {hello.hello(store)}")
EOF
```
And finally run it:
```shell
$ python3 host.py
component says: Hello, World!
```
See the
[examples](https://github.com/bytecodealliance/componentize-py/tree/main/examples)
directories for more examples, including various ways to run the components you've
created.
## Known Limitations
Currently, the application can only import dependencies during build time, which
means any imports used at runtime must be resolved at the top level of the
application module. For example, if `x` is a module with a submodule named `y`
the following may not work:
```python
import x
class Hello(hello.Hello):
def hello(self) -> str:
return x.y.foo()
```
That's because importing `x` does not necessarily resolve `y`. This can be
addressed by modifying the code to import `y` at the top level of the file:
```python
from x import y
class Hello(hello.Hello):
def hello(self) -> str:
return y.foo()
```
This limitation is being tracked as [issue
#23](https://github.com/bytecodealliance/componentize-py/issues/23).
See [the issue tracker](https://github.com/bytecodealliance/componentize-py/issues) for other known issues.
## Contributing
See
[CONTRIBUTING.md](https://github.com/bytecodealliance/componentize-py/tree/main/CONTRIBUTING.md)
for details on how to contribute to the project and build it from source.
Raw data
{
"_id": null,
"home_page": null,
"name": "componentize-py",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": "Fermyon Engineering <engineering@fermyon.com>",
"keywords": "webassembly, wasm, component",
"author": null,
"author_email": "Fermyon Engineering <engineering@fermyon.com>",
"download_url": "https://files.pythonhosted.org/packages/d1/64/d64b0cbf596b4624f941199c943cf4547612807f125c25d26d6c7dfa7e03/componentize_py-0.16.0.tar.gz",
"platform": null,
"description": "# componentize-py\n\n**A [Bytecode Alliance](https://bytecodealliance.org/) project**\n\nThis is a tool to convert a Python application to a [WebAssembly\ncomponent](https://github.com/WebAssembly/component-model). It takes the\nfollowing as input:\n\n- a [WIT](https://github.com/WebAssembly/component-model/blob/main/design/mvp/WIT.md) file or directory\n- the name of a [WIT world](https://github.com/WebAssembly/component-model/blob/main/design/mvp/WIT.md#wit-worlds) defined in the above file or directory\n- the name of a Python module which targets said world\n- a list of directories in which to find the Python module and its dependencies\n\nThe output is a component which may be run using\ne.g. [`wasmtime`](https://github.com/bytecodealliance/wasmtime).\n\n## Getting Started\n\nFirst, install [Python 3.10 or later](https://www.python.org/) and\n[pip](https://pypi.org/project/pip/) if you don't already have them. Then,\ninstall `componentize-py`:\n\n```shell\npip install componentize-py\n```\n\nNext, create or download the WIT world you'd like to target, e.g.:\n\n```shell\ncat >hello.wit <<EOF\npackage example:hello;\nworld hello {\n export hello: func() -> string;\n}\nEOF\n```\n\nIf you're using an IDE or just want to examine the bindings produced for the WIT\nworld, you can generate them using the `bindings` subcommand:\n\n```shell\ncomponentize-py -d hello.wit -w hello bindings hello_guest\n```\n\nThen, use the `hello` module produced by the command above to write your app:\n\n```shell\ncat >app.py <<EOF\nimport hello\nclass Hello(hello.Hello):\n def hello(self) -> str:\n return \"Hello, World!\"\nEOF\n```\n\nAnd finally generate the component:\n\n```shell\ncomponentize-py -d hello.wit -w hello componentize --stub-wasi app -o app.wasm\n```\n\nTo test it, you can install `wasmtime-py` and use it to generate host-side\nbindings for the component:\n\n```shell\npip install wasmtime\npython3 -m wasmtime.bindgen app.wasm --out-dir hello_host\n```\n\nNow we can write a simple host app using those bindings:\n\n```shell\ncat >host.py <<EOF\nfrom hello_host import Root\nfrom wasmtime import Config, Engine, Store\n\nconfig = Config()\nconfig.cache = True\nengine = Engine(config)\nstore = Store(engine)\nhello = Root(store)\nprint(f\"component says: {hello.hello(store)}\")\nEOF\n```\n\nAnd finally run it:\n\n```shell\n $ python3 host.py\ncomponent says: Hello, World!\n```\n\nSee the\n[examples](https://github.com/bytecodealliance/componentize-py/tree/main/examples)\ndirectories for more examples, including various ways to run the components you've\ncreated.\n\n## Known Limitations\n\nCurrently, the application can only import dependencies during build time, which\nmeans any imports used at runtime must be resolved at the top level of the\napplication module. For example, if `x` is a module with a submodule named `y`\nthe following may not work:\n\n```python\nimport x\n\nclass Hello(hello.Hello):\n def hello(self) -> str:\n return x.y.foo()\n```\n\nThat's because importing `x` does not necessarily resolve `y`. This can be\naddressed by modifying the code to import `y` at the top level of the file:\n\n```python\nfrom x import y\n\nclass Hello(hello.Hello):\n def hello(self) -> str:\n return y.foo()\n```\n\nThis limitation is being tracked as [issue\n#23](https://github.com/bytecodealliance/componentize-py/issues/23).\n\nSee [the issue tracker](https://github.com/bytecodealliance/componentize-py/issues) for other known issues.\n\n## Contributing\n\nSee\n[CONTRIBUTING.md](https://github.com/bytecodealliance/componentize-py/tree/main/CONTRIBUTING.md)\nfor details on how to contribute to the project and build it from source.\n\n",
"bugtrack_url": null,
"license": null,
"summary": "Tool to package Python applications as WebAssembly components",
"version": "0.16.0",
"project_urls": {
"repository": "https://github.com/bytecodealliance/componentize-py"
},
"split_keywords": [
"webassembly",
" wasm",
" component"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "c13955db339c8d2a3de3f9b57e94763308eaa1ea4691b671606b90595cbcef3f",
"md5": "277f8fdc04d245690f23cc7cf1620231",
"sha256": "a67f378aada7d4652c14abfb922be915c6383192416d0fe75aef33c4fd8ed6f0"
},
"downloads": -1,
"filename": "componentize_py-0.16.0-cp39-abi3-macosx_10_12_x86_64.whl",
"has_sig": false,
"md5_digest": "277f8fdc04d245690f23cc7cf1620231",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 18121079,
"upload_time": "2024-11-27T21:35:49",
"upload_time_iso_8601": "2024-11-27T21:35:49.379797Z",
"url": "https://files.pythonhosted.org/packages/c1/39/55db339c8d2a3de3f9b57e94763308eaa1ea4691b671606b90595cbcef3f/componentize_py-0.16.0-cp39-abi3-macosx_10_12_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "59c07721d5d3f8e6d716309fc0da466856695b699a6a55d557dfcc841b088730",
"md5": "b687860ae40bdc1226073d384ecd0dc7",
"sha256": "0728eb5c584651a21c7fde39e9c4c21d0b469b37e07e5e32b2d72e7ac5047083"
},
"downloads": -1,
"filename": "componentize_py-0.16.0-cp39-abi3-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "b687860ae40bdc1226073d384ecd0dc7",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 17763273,
"upload_time": "2024-11-27T21:36:00",
"upload_time_iso_8601": "2024-11-27T21:36:00.471236Z",
"url": "https://files.pythonhosted.org/packages/59/c0/7721d5d3f8e6d716309fc0da466856695b699a6a55d557dfcc841b088730/componentize_py-0.16.0-cp39-abi3-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "474b8e70d5526073825a791dc2a4a1d02ef255034203d3fb4ff6450b06c927f5",
"md5": "d194094c37519f64cefe2743a0e86476",
"sha256": "46bc31b4d3e93d556174827aeef326f644e7de4b85f3c1f8e05769aa3f522a08"
},
"downloads": -1,
"filename": "componentize_py-0.16.0-cp39-abi3-manylinux_2_28_aarch64.whl",
"has_sig": false,
"md5_digest": "d194094c37519f64cefe2743a0e86476",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 18544158,
"upload_time": "2024-11-27T21:36:09",
"upload_time_iso_8601": "2024-11-27T21:36:09.726467Z",
"url": "https://files.pythonhosted.org/packages/47/4b/8e70d5526073825a791dc2a4a1d02ef255034203d3fb4ff6450b06c927f5/componentize_py-0.16.0-cp39-abi3-manylinux_2_28_aarch64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "dc78368da5fdc97e8c56ee5d59a1c3f452233aa91f6c2e89fc8cde532612c6a3",
"md5": "3ab12785a616557a25c48bcf4c0a851a",
"sha256": "95644bf551b8e93f56049a623307bbc1d982ebfa3ebb1ef45b3e631bfd65b798"
},
"downloads": -1,
"filename": "componentize_py-0.16.0-cp39-abi3-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "3ab12785a616557a25c48bcf4c0a851a",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 19050720,
"upload_time": "2024-11-27T21:36:19",
"upload_time_iso_8601": "2024-11-27T21:36:19.633497Z",
"url": "https://files.pythonhosted.org/packages/dc/78/368da5fdc97e8c56ee5d59a1c3f452233aa91f6c2e89fc8cde532612c6a3/componentize_py-0.16.0-cp39-abi3-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "124755d85805686da60018b1f3d32c1025e46f9c2fe18a9c7e369912fa65998b",
"md5": "ad237f3dfceb36d0cd2bfc99d3bf30d4",
"sha256": "8b0571f7a081dac86c9ab1b7ed0e0a5b5d5c9107f3d33db29f0764f261d7c1b8"
},
"downloads": -1,
"filename": "componentize_py-0.16.0-cp39-abi3-win_amd64.whl",
"has_sig": false,
"md5_digest": "ad237f3dfceb36d0cd2bfc99d3bf30d4",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 17282010,
"upload_time": "2024-11-27T21:36:28",
"upload_time_iso_8601": "2024-11-27T21:36:28.530188Z",
"url": "https://files.pythonhosted.org/packages/12/47/55d85805686da60018b1f3d32c1025e46f9c2fe18a9c7e369912fa65998b/componentize_py-0.16.0-cp39-abi3-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d164d64b0cbf596b4624f941199c943cf4547612807f125c25d26d6c7dfa7e03",
"md5": "d98459d76c7301f9693d044e6278ea45",
"sha256": "2823e5f3abf7a4eaf993d0841d8e7888f13d3b46a8e42230e044d64b49311e57"
},
"downloads": -1,
"filename": "componentize_py-0.16.0.tar.gz",
"has_sig": false,
"md5_digest": "d98459d76c7301f9693d044e6278ea45",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 156307,
"upload_time": "2024-11-27T21:36:31",
"upload_time_iso_8601": "2024-11-27T21:36:31.329919Z",
"url": "https://files.pythonhosted.org/packages/d1/64/d64b0cbf596b4624f941199c943cf4547612807f125c25d26d6c7dfa7e03/componentize_py-0.16.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-27 21:36:31",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "bytecodealliance",
"github_project": "componentize-py",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "componentize-py"
}