#run-time #solana #labs #version #llvm #stable #check

waffles-solana-program-runtime

由Waffle Labs维护的Solana程序运行时

17个版本 (3个稳定版)

1.16.0 2023年2月21日
1.16.0-alpha.112023年5月30日
1.16.0-alpha.102023年3月24日
1.16.0-alpha.52023年2月27日
1.15.0 2023年1月7日

#64 in #labs

Download history 143/week @ 2024-03-12 110/week @ 2024-03-19 175/week @ 2024-03-26 162/week @ 2024-04-02 92/week @ 2024-04-09 110/week @ 2024-04-16 329/week @ 2024-04-23 107/week @ 2024-04-30 113/week @ 2024-05-07 126/week @ 2024-05-14 110/week @ 2024-05-21 121/week @ 2024-05-28 88/week @ 2024-06-04 76/week @ 2024-06-11 139/week @ 2024-06-18 95/week @ 2024-06-25

423 monthly downloads
用于 52 个crate(12个直接使用)

Apache-2.0

1MB
18K SLoC

Rust 16K SLoC // 0.0% comments Bitbake 1K SLoC // 0.1% comments Shell 651 SLoC // 0.1% comments Python 155 SLoC // 0.0% comments INI 9 SLoC

Solana

Solana crate Solana documentation Build status codecov

构建

1. 安装rustc,cargo和rustfmt。

$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt

当构建master分支时,请确保您正在使用最新的稳定版rust,通过运行

$ rustup update

当构建特定的发布分支时,您应该在 ci/rust-version.sh 中检查rust版本,并在必要时通过运行来安装该版本

$ rustup install VERSION

请注意,如果这不是您机器上最新的rust版本,则可能需要在cargo命令中使用覆盖以使用正确的版本。

在Linux系统上,您可能需要安装libssl-dev,pkg-config,zlib1g-dev,protobuf等。

在Ubuntu上

$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang cmake make libprotobuf-dev protobuf-compiler

在Fedora上

$ sudo dnf install openssl-devel systemd-devel pkg-config zlib-devel llvm clang cmake make protobuf-devel protobuf-compiler perl-core

2. 下载源代码。

$ git clone https://github.com/solana-labs/solana.git
$ cd solana

3. 构建。

$ ./cargo build

测试

运行测试套件

$ ./cargo test

启动本地测试网

在本地启动自己的测试网,请参阅在线文档中的说明。

访问远程开发集群

  • devnet - 通过devnet.solana.com可访问的稳定公共集群,用于开发。每天24小时运行。了解更多关于公共集群的信息

基准测试

首先,安装rustc的nightly构建。 cargo bench 需要使用仅在nightly构建中可用的不稳定功能。

$ rustup install nightly

运行基准测试

$ cargo +nightly bench

发布过程

本项目的发布过程在此描述

代码覆盖率

要生成代码覆盖率统计信息

$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html

为什么是覆盖率?虽然大多数人认为覆盖率是代码质量指标,但我们主要将其视为开发者生产力指标。当开发者对代码库进行更改时,这通常被认为是对某些问题的解决方案。我们的单元测试套件是我们编码代码库解决的一组问题。运行测试套件应表明您的更改没有侵犯其他人的解决方案。添加测试可以保护您的解决方案免受未来更改的影响。比如说您不明白为什么存在一行代码,试着删除它并运行单元测试。最近的测试失败应该会告诉您该代码解决了什么问题。如果没有测试失败,请提交一个Pull Request,询问“这段代码解决了什么问题?”另一方面,如果测试失败并且您能想到更好的解决方案,您的解决方案Pull Request一定会受欢迎!同样,如果重写测试可以更好地传达受保护的代码,请发送给我们这个补丁!

免责声明

本项目中描述的所有主张、内容、设计、算法、估算、路线图、规范和性能测量都是基于Solana Labs, Inc.(“SL”)的善意努力。读者有责任核实其准确性和真实性。此外,本项目中没有任何内容构成投资邀请。

SL或开发者资源生产的任何内容仅用于教育和启发目的。SL不鼓励、诱导或批准在违反适用法律或法规的情况下部署、集成或使用任何此类应用程序(包括构成Solana区块链协议的代码),并禁止此类部署、集成或使用。这包括读者使用任何此类应用程序(a)违反美国或任何其他适用司法管辖区的出口控制或制裁法律,(b)如果读者位于或通常居住在美国国务院外国资产管理办公室(OFAC)管理的全面制裁的国家或地区,或(c)如果读者是或代表特别指定国家(SDN)或受类似封锁或拒绝方禁令限制的人。

读者应意识到,美国的出口控制和制裁法律禁止美国个人(以及受此类法律约束的其他个人)与某些国家或地区的个人进行交易或在SDN名单上。因此,其他人使用本存储库中包含的任何代码或其衍生品存在风险,并且与这些人员的交易可能违反美国的出口控制和制裁法律。

依赖项

~20–35MB
~616K SLoC