#ethereum #classic #patch #virtual-machine #sputnik-vm #deprecated #fork

no-std ethereumvm-network-classic

Ethereum Classic 对 EthereumVM 的补丁。已弃用,将在未来版本中删除:请使用 ethereumvm-network 代替

1 个不稳定版本

0.11.0 2019年7月1日

#31 in #sputnik-vm

Download history 18/week @ 2024-03-29 7/week @ 2024-04-05

73 每月下载量
用于 ethereumvm-stateful

Apache-2.0 和可能 GPL-3.0

270KB
6K SLoC

SputnikVM:Rust 实现的以太坊虚拟机

Build Status License

名称 描述 Crates.io 文档
evm 以太坊虚拟机的核心库 crates.io Documentation
evm-stateful SputnikVM 的 Merkle Trie 状态包装器 crates.io Documentation

功能

  • 独立 - 可以作为独立进程启动或集成到其他应用程序中
  • 通用 - 支持不同的以太坊链,例如 ETC、ETH 或私有链
  • 无状态 - 仅提供一个与独立状态存储连接的执行环境
  • 快速 - 主要关注性能
  • IoT 兼容 - 设计用于支持嵌入式设备中使用的硬件
  • 用 Rust 编写,可以作为二进制文件、cargo crate 或共享库使用

支持的网络

支持的网络

网络 Crates.io 文档
任何网络 crates.io Documentation
Ethereum Classic crates.io Documentation
Ethereum crates.io Documentation
Ellaism crates.io Documentation
Ubiq crates.io Documentation
Expanse crates.io Documentation
Musicoin crates.io Documentation

预编译合约

核心库嵌入初始四个预编译合约。要使用拜占庭硬分叉引入的 bn128 和 modexp 预编译合约,请拉取以下 crate。

名称 描述 Crates.io 文档
evm-precompiled-bn128 bn128 预编译合约 crates.io Documentation
evm-precompiled-modexp 预编译的modexp合约 crates.io Documentation

依赖项

请确保您至少有 rustc 1.33.0 (2aa4c46cf 2019-02-28). Rust 1.32.0及以前版本不受支持。

文档

从源代码构建

SputnikVM是用Rust编写的。如果您不熟悉Rust,请参阅入门指南

构建

要开始使用SputnikVM,您需要安装rustup,然后您可以执行以下操作

$ git clone [email protected]:ethereumproject/evm-rs.git
$ cd evm-rs
$ cargo build --release --all

测试

我们目前使用两种方式来测试SputnikVM并确保其执行与其他以太坊虚拟机实现相一致

  • jsontests:这部分使用了以太坊的测试。这些测试目前对系统操作操作码的覆盖良好。此外,一些测试是错误的,因此已禁用。
  • regtests:在以太坊经典主网上从创世区块到第400万区块进行完全回归测试。一些之前失败的测试也被集成到Rust的测试系统中。

要运行所有测试,请在克隆的存储库中执行以下命令

$ cargo test --all

贡献

格式化策略在GUIDE.md中描述,推荐的自动化格式化技术可以在FORMATTING.md中找到

许可证

Apache 2.0

依赖项

~6MB
~50K SLoC