[翻译]Hello, wasm-pack - cargo.toml

简介: Hello, wasm-pack - cargo.toml 翻译

Cargo.toml

cargo.toml是Rust 包管理器 cargo 的清单文件。这个文件包 nameversion 和包的依赖,在 Rust 中,我们一般称之为 crate

在示例中给出了一系列信息,但是我们主要讨论如下三点:

  • crate-type
  • wasm-bindgen 依赖
  • [features]wee_allocconsole_error_panic_hook 依赖

1.crate-type

[lib]
crate-type = ["cdylib", "rlib"]

Rust-wasm 包与通常的 crate 有一点不同,作为 WebAssembly 项目, 我们需要在 cargo.toml 中加入该说明。

如果你熟悉其他的 Rust crate,那么你肯定知道,大多的 crate 的类型是 rlib(默认), 或者是二进制形式的 bin(这种形式不需要 crate-type 注解), 并且 [lib] 注解在普通的 Cargo 项目中并不需要指定。

crate-type = ["cdylib"] 指示你的工程将会被编译为动态系统库 [dynamic system library], 但是对于 WebAssembly,他将会编译为一个没有启动函数的 .wasm 文件,在 Linux 平台上,他将会创建.so 文件,在macOS 上将会创建.dylib文件,在 windows 平台上将会创建 *.dylib 文件。

我们通常指定 crate-type = ["rlib"] 来确保我们的库可以用 wasm-pack 来做单元测试(稍后会看到)。如果没有这个配置,我们将不能测试我们的库,因为 cdylib 包类型和 wasm-pack 的单元测试类型相冲突。

你可以使用此链接获取更多关于包类型的知识。

2. wasm-bindgen 依赖

wasm-bindgen 在WebAssembly 中是一个重要的依赖。 这个包允许我们使用 [wasm-bindgen] 为在 JavaScript 和 Rust 生成的 wasm 之间的代码打标签。以使我们使用它的属性可以导入 JS 并且导出 Rust。

wasm-bindgen = "0.2"

当我们讨论 lib.rs 生成什么内容的时候,将会看到更多关于怎么使用这个库。
如果你从 JavaScript 技术栈过来,你可能注意到了当我们添加依赖的时候并没有加 ^ 或者 ~ ,看起来像是我们只要 0.2 这个版本。然而,事实并非如此!在 Rust 里, ^ 是默认的,你可使用这个 链接查看更多信息

3. [features] 和 wee_alloc, console_error_panic_hook dependencies

作为我们设计模板的工作的一部分,该模板可帮助人们发现针对特定用例的有用包,该模板包括两个依赖项,这对于开发Rust-wasm包的人们可能非常有用:console_error_panic_hook 和 wee_alloc。

因为这些依赖关系主要在 Rust-wasm 包开发工作流程的特定部分中有用,所以我们还设置了一些粘合代码,使我们既可以将它们都包含为依赖关系,又可以选择将它们包含在内。

[features]
default = ["console_error_panic_hook"]

[dependencies]
wasm-bindgen = "0.2"

# The `console_error_panic_hook` crate provides better debugging of panics by
# logging them with `console.error`. This is great for development, but requires
# all the `std::fmt` and `std::panicking` infrastructure, so isn't great for
# code size when deploying.
console_error_panic_hook = { version = "0.1.1", optional = true }

# `wee_alloc` is a tiny allocator for wasm that is only ~1K in code size
# compared to the default allocator's ~10K. It is slower than the default
# allocator, however.
#
# Unfortunately, `wee_alloc` requires nightly Rust when targeting wasm for now.
wee_alloc = { version = "0.4.2", optional = true }

在我们的代码中,只有在启用某些 [features] 的情况下,我们才会将代码的某些部分标记为正在运行,特别是 console_error_panic_hook 和 wee_alloc。默认情况下,仅启用 console_error_panic_hook。要禁用或启用任一功能,默认情况下,我们可以在 [features] 下编辑 default 数组。

要了解有关这些功能的更多信息,我们将在 src/lib.rs 和 src/utils.rs 部分中深入讨论它们。
简要地,它们包括:

  • console_error_panic_hook ,用于将奔溃消息记录到开发人员控制台的功能。
  • wee_alloc,一个使代码量更小而优化的分配器。
目录
相关文章
|
4月前
|
Dart iOS开发 C++
Dart ffi 使用问题之在pubspec.yaml文件中,对plugin_ffi_sample插件的依赖如何配置
Dart ffi 使用问题之在pubspec.yaml文件中,对plugin_ffi_sample插件的依赖如何配置
|
区块链 Python
打包工具--pyinstaller
打包工具--pyinstaller
106 0
|
存储 缓存 Kubernetes
K8s源代码解读--plugin
K8s源代码解读--plugin
121 0
|
Rust Cloud Native IDE
Rust源码学习 - Lint 与 LintPass
- 时间:2022.8.19 - 作者:[黑怕](https://github.com/He1pa)@KusionStack开发组 --- ## 背景 KusionStack是我们团队对云原生开放协同技术探索与实践
Rust源码学习 - Lint 与 LintPass
|
Java API Maven
Gradle基础|自定义插件并上传到JitPack
每一个使用 Gradle 的同学,肯定都听过或者写过插件,因为其本身并不难,但碍于现在网上的文章千篇一律,大部分都比较老,新同学一上手反而是和我一样,花了大把时间在最基础的第一步如何写一个简单demo上。再者如果大家使用 AndroidStudio BumBlebee 去创建项目,那对照网上教程差别更大,甚是花费时间,而本篇就是帮你省掉这些时间。 本篇主要概括创建插件的三种方式,并如何上传到 JitPack 中。
215 0
Gradle基础|自定义插件并上传到JitPack
|
Java Linux Go
知识分享之Golang——在Goland中增加快速注释插件Goanno
知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。 知识分享系列目前包含Java、Golang、Linux、Docker等等。
1110 0
知识分享之Golang——在Goland中增加快速注释插件Goanno
|
Java Linux Go
知识分享之Golang——使用embed包实现静态资源打包至二进制文件中
知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。 知识分享系列目前包含Java、Golang、Linux、Docker等等。
979 0
知识分享之Golang——使用embed包实现静态资源打包至二进制文件中
|
Linux Shell
pkg-config 自动补全 C 编译库依赖
pkg-config 是一个在源代码编译时查询已安装的库的使用接口的计算机工具软件。
138 0
|
JavaScript
Nodejs pkg打包
nodejs打包
638 0
Nodejs pkg打包
pkg 打包
pkg 打包
246 0
下一篇
DataWorks