感谢你对 BitFun 的兴趣!BitFun 是一个由 Rust 与 TypeScript 驱动的多端 AI 编程环境,桌面端/CLI/Server 共享核心逻辑。本指南说明如何高效参与贡献。
请保持尊重、友善与建设性沟通。我们欢迎不同背景与经验的贡献者。
- Node.js(建议 LTS 版本)
- pnpm
- Rust toolchain(通过 rustup 安装)
- 桌面端开发需准备 Tauri 依赖
桌面端包含 SSH 远程功能,会链接 OpenSSL。Windows 上不使用 OpenSSL 源码编译(vendored),需使用预编译库。
- 默认:Windows 下
pnpm run desktop:dev会调用ensure-openssl-windows.mjs;所有desktop:build*均通过scripts/desktop-tauri-build.mjs执行,在tauri build前做相同引导(首次下载到.bitfun/cache/,之后走缓存)。额外参数:pnpm run desktop:build -- <tauri build 参数>。 - 手动 / CI:下载 FireDaemon ZIP,解压后将
OPENSSL_DIR指向x64,并设OPENSSL_STATIC=1,或运行scripts/ci/setup-openssl-windows.ps1。 - 关闭自动下载:设置
BITFUN_SKIP_OPENSSL_BOOTSTRAP=1并自行配置OPENSSL_DIR。 desktop:dev:raw不经过dev.cjs(无 OpenSSL 引导);请自行设置OPENSSL_DIR、运行scripts/ci/setup-openssl-windows.ps1,或执行node scripts/ensure-openssl-windows.mjs(会预热.bitfun/cache/并打印可在 PowerShell 中粘贴的OPENSSL_*命令)。
pnpm install# Desktop
pnpm run desktop:dev
pnpm run desktop:build
# E2E
pnpm run e2e:test说明:仓库提供更细粒度的脚本(例如
dev:web、cli:dev、website:dev),详情见package.json。
- 仅使用英文日志,避免冗长输出
- 前端:
createLogger('ModuleName') - 后端:
log::{info, debug, warn, error}宏
core 中禁止引入平台相关依赖:
- ❌
tauri::AppHandle - ✅
bitfun_events::EventEmitter
- 命令名使用
snake_case - Rust 与 TypeScript 命名保持一致
- 必须使用结构化请求格式:
#[tauri::command]
pub async fn your_command(
state: State<'_, AppState>,
request: YourRequest,
) -> Result<YourResponse, String>await api.invoke("your_command", { request: { /* ... */ } });- 贡献好的想法/创意(功能、交互、视觉等),提交问题
欢迎产品经理、UI设计师通过PI快速提交创意,我们会帮助完善开发
- 优化Agent系统和效果
- 对提升系统稳定性和完善基础能力
- 扩展生态(SKill、MCP、LSP插件,或者对某些垂域开发场景的更好支持)
我们欢迎不仅限于功能或修复的 PR。示例包括:
| 贡献方向 | 位置/文件 | 示例说明 |
|---|---|---|
| Prompts | src/crates/core/src/agentic/agents/prompts/ |
新增或优化提示词,并按需更新相关逻辑 |
| Tools | src/crates/core/src/agentic/tools/implementations/、src/crates/core/src/agentic/tools/registry.rs |
新增工具实现,并在工具注册表中注册 |
| Subagents | src/crates/core/src/agentic/agents/custom_subagents/、src/crates/core/src/agentic/agents/registry.rs |
新增子代理实现,并在子代理注册表中注册 |
| 模式贡献 | src/crates/core/src/agentic/agents/*_mode.rs、src/crates/core/src/agentic/agents/prompts/*_mode.md、src/web-ui/src/locales/*/settings/modes.json |
新增/优化 Agent 模式(例如 Plan/Debug/Agentic 或自定义模式)的逻辑与提示词,并同步前端模式文案 |
| Code Agent 与 AIIde 场景指南 | website/src/docs/ |
补充流程、playbook 与真实场景说明(或从 README.md 链接) |
- 先开 Issue 说明问题或方案,尤其是较大改动,以避免重复与设计冲突
- 新功能或 UI 变更建议先讨论设计方向,确保符合产品体验
建议使用 Conventional Commits 风格,便于维护版本记录与自动化流程:
feat:新功能fix:修复问题docs:文档变更chore:维护/依赖refactor:重构且不改行为test:测试相关
UI 改动请附前后对比截图或短录屏,方便快速评审。
如为 AI 辅助产出,请在 PR 中注明并说明测试程度(未测/轻测/已测),便于评审风险。
master分支用于稳定特性,不接受特性合入,本仓库欢迎各大产品经理、开发者使用AI生成代码以做快速穿刺或提交想法,因此所有PR请提交合入dev分支,我们会定期从dev分支审视和完善后回合至master
保持 PR 小而聚焦,避免混杂无关改动。
按改动范围运行相关测试:
# Rust
cargo test --workspace
# E2E
pnpm run e2e:test如暂时无法运行测试,请在 PR 描述中说明原因,并提供手动验证步骤。
- 不要提交密钥、Token、证书或任何敏感信息
- 新增依赖请确认许可证兼容并说明用途
每一份贡献都很重要,欢迎提交 Issue、PR 或建议!