42_发布crate

1. 创建账号

  • 发布crate.io前,需要在<crates.io>创建账号并获得API Token
  • 运行命令cargo login $API_TOKEN
    • 将会通知cargo,把你的API token存储在本地 ~/.cargo/credentials.toml
    • API Token可以在<crates.io>上进行撤销。

2. crate添加元数据

在发布crate之前,需要在Cargo.toml[package]区域为crate添加一些元数据:

  • name: crate需要指定位于的名称
  • description: 一两句话即可,会出现在crate搜索的结果里
  • license: 需要提供许可证的表示值,可以到spdx.org/licenses/查找,可以指定多个许可,使用OR隔开
  • version: 版本号
  • author: 作者

更多的原数据可以参考doc.rust-lang.org/cargo/refer...

下面是一个示例的原数据:

ini 复制代码
[package]
name = "first_crate_yinuo"
version = "0.1.0"
author = ["kotlindev"]
edition = "2021"
description = "A Rust tutorials"
license = "MIT"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]

3. 发布crate

未提交代码使用cargo publish --allow-dirty测试。 使用cargo pushlish进行发布。要注意的是,如果发布失败,原因可能是因为你的<crates.io>的账号还没绑定验证的邮箱,或者你的crate的元信息缺失,需要根据错误提示补充即可。

crate一旦发布,就是永久性的:该版本无法覆盖,代码无法删除。因为<crates.io>希望成为永久的代码托管服务器,并且依赖于该版本的项目可以继续正常工作。如果允许开发者删除已经发布的代码,那么将无法达到这个目的。

4. 发布已存在的crate新版本

在修改crate的代码之后,当我们需要发布新版本时,需要先修改Cargo.toml里面的version值。可以参考语义化版本控制规范semver.org来定义你的语意版本。最后执行cargo publish进行发布。

5. 使用cargo yank从crates.io撤回版本

我们不可以删除之前的版本,不会删除任何代码,但可以防止其他项目把某个版本最为新的依赖,使用yank可撤回一个crate版本即可。该操作防止新项目依赖于该版本,但已经存在的项目可以继续将其作为依赖并可以下载。

yank意味着:所有已经产生Cargo.lock的项目不会中断,同时任何将来新生成的Cargo.lock文件都不会使用被yank的版本。

撤回命令如下示例:

bash 复制代码
cargo yank --version 1.0.1

取消撤回如下命令

bash 复制代码
cargo yank --version 1.0.1 --undo
相关推荐
晚霞的不甘10 分钟前
Flutter for OpenHarmony天气卡片应用:用枚举与动画打造沉浸式多城市天气浏览体验
前端·flutter·云原生·前端框架
xkxnq24 分钟前
第五阶段:Vue3核心深度深挖(第74天)(Vue3计算属性进阶)
前端·javascript·vue.js
三小河30 分钟前
Agent Skill与Rules的区别——以Cursor为例
前端·javascript·后端
Hilaku37 分钟前
不要在简历上写精通 Vue3?来自面试官的真实劝退
前端·javascript·vue.js
三小河43 分钟前
前端视角详解 Agent Skill
前端·javascript·后端
Aniugel1 小时前
单点登录(SSO)系统
前端
鹏多多1 小时前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
serioyaoyao1 小时前
上万级文件一起可视化,怎么办?答案是基于 ParaView 的远程可视化
前端
万少1 小时前
端云一体 一天开发的元服务-奇趣故事匣经验分享
前端·ai编程·harmonyos
WindrunnerMax1 小时前
从零实现富文本编辑器#11-Immutable状态维护与增量渲染
前端·架构·前端框架