Foundry项目2025-04-02夜间版本更新解析
Foundry是区块链生态中广受欢迎的智能合约开发工具套件,由Rust语言编写,包含Forge、Cast、Anvil等多个组件,为开发者提供从合约测试到部署的全套解决方案。本次夜间版本更新带来了多项功能优化和问题修复,值得开发者关注。
核心组件Anvil的改进
Anvil作为本地区块链节点模拟器,在本次更新中获得了两个重要改进。首先是修复了--chain-id参数优先级问题,现在当开发者同时指定--chain-id和自定义创世配置时,命令行参数将优先于配置文件中的设置,这确保了开发环境的确定性配置。
另一个重要改进是优化了账户模拟功能。当开发者使用anvil进行账户模拟(impersonation)操作时,现在可以绕过sidecar服务的强制要求,简化了本地开发测试流程。这项改进特别适合需要频繁切换账户状态的测试场景。
Forge测试框架增强
Forge作为智能合约测试框架,本次新增了vm.setArbitraryStorage方法,并支持覆盖写入功能。这项特性允许测试者更灵活地操作合约存储,特别是对于需要模拟特定存储状态的复杂测试用例非常有用。开发者现在可以直接设置任意存储槽的值,包括覆盖已有数据,这大大增强了测试场景的构建能力。
密码学相关调整
项目移除了位于地址0x14的Odyssey P256预编译合约。P256是区块链考虑引入的新椭圆曲线标准,这次调整反映了项目与主网发展的同步。开发者需要注意,如果之前有测试依赖于这个特定地址的预编译合约,需要相应调整测试代码。
开发者工具优化
Cast工具新增了钱包公钥获取功能,通过简单的命令行即可提取指定地址的公钥信息。这对于需要处理签名验证或进行加密操作的开发场景特别有价值。
在代码质量方面,项目统一了十六进制字符串的处理方式,用更安全的宏替代了原有的from_str(...).unwrap()模式,减少了潜在的空指针异常风险。
绑定生成功能增强
Forge的绑定生成功能现在支持自定义crate的描述信息和许可证类型。当开发者需要将智能合约绑定到其他语言(如Rust)时,可以更灵活地配置生成的绑定包元数据,便于后续的发布和管理。
总结
本次Foundry夜间版本更新虽然规模不大,但包含了多个实用改进。从Anvil的确定性配置到Forge的存储操作增强,再到工具链的细节优化,都体现了项目对开发者体验的持续关注。特别是存储操作和账户模拟方面的改进,将显著提升复杂智能合约的测试效率。建议正在使用Foundry进行区块链开发的团队及时评估这些新特性,适时整合到自己的开发流程中。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0105
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。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.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
AgentCPM-Explore没有万亿参数的算力堆砌,没有百万级数据的暴力灌入,清华大学自然语言处理实验室、中国人民大学、面壁智能与 OpenBMB 开源社区联合研发的 AgentCPM-Explore 智能体模型基于仅 4B 参数的模型,在深度探索类任务上取得同尺寸模型 SOTA、越级赶上甚至超越 8B 级 SOTA 模型、比肩部分 30B 级以上和闭源大模型的效果,真正让大模型的长程任务处理能力有望部署于端侧。Jinja00