Foundry v1.0.0 正式发布:区块链开发工具的重大升级
Foundry 是区块链生态系统中广受欢迎的智能合约开发工具套件,它提供了一整套命令行工具,包括 Forge(测试框架)、Cast(交互工具)、Anvil(本地节点)和 Chisel(REPL 环境)。经过长时间的开发和社区贡献,Foundry 终于迎来了 1.0.0 正式版本,这标志着该项目已经达到了生产就绪的稳定状态。
重大变更与迁移指南
Foundry v1.0.0 引入了一些重要的破坏性变更,开发者需要特别注意:
-
Solidity 优化器默认关闭:现在需要显式配置 optimizer 和 optimizer_runs 来启用优化器功能,这有助于减少合约部署和交互的 gas 成本。
-
testFail 测试模式移除*:旧版中通过 testFail* 前缀来测试预期失败用例的方式已被移除,推荐使用更现代的 expectRevert 断言方式。
-
内部调用异常检测变更:expectRevert 作弊码现在默认不会检测内部调用中的异常,这更符合实际 EVM 行为。
-
控制台日志签名更新:移除了对旧版 console.sol 签名的支持,确保与最新 Solidity 版本兼容。
-
冲突重映射处理:当检测到重映射冲突时,新版本会忽略这些冲突而不是报错,提高了配置的灵活性。
核心功能增强
Anvil 本地节点改进
Anvil 新增了 anvil_rollback 功能,允许开发者将链状态回滚到之前的某个区块,极大方便了测试场景。同时修复了 IPC 通信和 gas limit 设置等关键问题。
Cast 工具升级
Cast 工具现在支持更美观的交易收据打印格式,增加了对 ink 和 ink-sepolia 链的支持,并改进了 cast source 命令(原 cast etherscan-source)以支持更多区块链浏览器。
Forge 测试框架优化
Forge 现在支持在覆盖率报告中过滤特定 profile,改进了私有依赖项的安装流程,并允许对 Solidity 文件进行重映射。测试输出也更加详细,当设置 verbose>=4 时会显示广播的交易信息。
性能与稳定性提升
-
覆盖率分析优化:使用 u32 类型替代原有 ID 系统,显著提升了覆盖率分析性能。
-
错误处理改进:增强了错误信息的展示方式,提供了更清晰的错误上下文。
-
配置加载优化:改进了配置文件的加载逻辑,能够更好地处理配置错误。
-
状态差异记录优化:现在只在余额变化时记录状态差异,减少了不必要的计算开销。
开发者体验改进
-
Foundryup 工具增强:现在默认安装稳定版本,增加了自更新功能,并会检查运行中的进程以避免冲突。
-
Docker 支持:新增了 ARM64 架构的 Docker 镜像,方便在不同平台上部署使用。
-
版本管理:改进了自定义版本的构建和管理方式,为开发者提供了更多灵活性。
-
交互式调试:移除了单独的
forge debug子命令,将其功能整合到forge test和forge script的--debug参数中,简化了调试流程。
向后兼容性说明
虽然 v1.0.0 带来了许多改进,但也引入了一些破坏性变更。项目团队提供了详细的迁移指南,建议开发者仔细阅读并测试现有项目在新版本下的行为。特别是那些依赖旧版特性的项目,可能需要相应的调整才能完全兼容。
Foundry v1.0.0 的发布标志着该项目已经成熟,为区块链开发者提供了一个更加稳定、高效的开发环境。无论是智能合约测试、部署还是交互,新版本都带来了显著的改进和优化,值得所有区块链开发者升级体验。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0131
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00