与 AI 共舞 · 享 AI 时代
Model Context Protocol — 由 Anthropic 提出的开放协议
flowchart LR
A["🤖 AI 助手
(Claude / CodeArts)"]
M["🔌 MCP Server
(工具网关)"]
C["🔧 Delphi 编译器"]
K["📚 源码知识库
30万函数"]
F["🎨 pasfmt 格式化"]
A -->|MCP 协议| M
M --> C
M --> K
M --> F
类比:AI 的"USB 接口"——插上什么工具,AI 就会用什么
✖ 传统模式
用户: 帮我编译项目
AI: 请打开命令行运行:
msbuild Project.dproj
用户: 报错了
AI: 错误是 X,建议你 Y
—— 只给建议,不执行
✔ MCP 模式
用户: 帮我编译项目
AI: 正在编译...
[调用 compile_project]
✅ 编译成功 (0 errors, 0 warnings)
用户: 修复这个错误
AI: 搜索 KB → 分析根因 →
修改代码 → 重编译 → ✅ 通过
—— 你提需求,它落地实现
用户只需一句话:
AI 自动完成:
全程在 AI 对话中完成,无需打开终端或编辑 JSON
install.ps1 自动检测,无需手动配置
| 方式 | 用法 | 示例 |
|---|---|---|
| 🎯 精确搜索 | 已知类名 / 函数名 | TStringList / Split |
| 🔍 语义搜索 | 自然语言描述需求 | "JSON 深度比较" |
| 🔗 引用查询 | 查谁引用了某单元 | Vcl.Forms 被谁 uses |
搜索策略:先精确猜名 → 再语义兜底
你不知道 API 叫什么?自然语言描述即可
⚠️ 需提前构建 embedding 索引:delphi_kb(action="build_embedding")
用户: Delphi 有没有可以比较两个 JSON 对象
是否结构相同的功能?
不是字符串 == 比较,要忽略键顺序。
AI 语义搜索 30 万函数 →
📌 TJSONObject — 继承链 TJSONAncestor > TJSONValue
📌 TJSONObject 未重写 Equals,默认引用比较
AI 分析: 标准库没有直接的深层比较函数,
但可以与你一同生成递归比较工具代码。
| 能力 | 说明 |
|---|---|
| 项目编译 | .dproj / .dpr → exe / dll,支持 MSBuild |
| 语法检查 | 单个 .pas 文件快速检查 |
| 批量编译 | .groupproj → 按 BuildOrder 自动排序 |
| 多平台 | Win32 / Win64 / OSX / iOS / Android / Linux |
| 多配置 | Debug / Release + 自定义条件编译 |
// E2511 — Type parameter must have a comparer
TDictionary<TCustomKey, string>.Create;
// ^^^^^^^^^^
// 错误: record 类型做 TKey 需要 IEqualityComparer
AI 不是只看错误行——它搜索 KB 理解根因:
flowchart LR
E["❌ 编译错误
E2511"] --> S1["🔍 搜 KB
TDictionary 类定义"]
S1 -->|发现泛型约束| S2["🔍 搜 KB
TEqualityComparer"]
S2 -->|了解实现方式| R["💡 根因分析
record 无默认比较器"]
R --> F["✏️ 生成比较器
TCustomKeyComparer"]
F --> P["✅ 修复 → 编译通过"]
一句话编译整个解决方案:
flowchart TD
G["📁 ProjectGroup.groupproj"] --> LIB["📁 LibProject"]
G --> APP["📁 AppProject"]
LIB --> L["LibUtils.dproj"]
APP --> M["MainApp.dproj"]
L -. 先编译 .-> M
classDef lib fill:#e8f8f0,stroke:#34c759
classDef app fill:#e8f4ff,stroke:#007aff
class L lib
class M app
用户: Release Win64 编译全部
AI:
① LibUtils.dproj → ✅
② MainApp.dproj → ✅
全部编译成功!
自动解析 BuildOrder,按依赖顺序编译
📁 格式化前自动备份
DataProcessor.pas
↓ file_tool(action="write", backup=true)
__history/
├── DataProcessor.pas.~1~
├── DataProcessor.pas.~2~ (版本递增)
└── DataProcessor.pas.~3~
🔄 备份管理
与 Delphi IDE 的 __history 机制完全兼容
同一需求,不同编码规则 → 风格截然不同的代码
📖 现代规范
type
TStringUtils = class
public
class function Join(
const AStrings: TArray<string>;
const ASeparator: string): string;
end;
📘 旧项目规范
type
StringUtils = class
public
class function join(
const arrStrings: array of string;
const separator: string): string;
end;
| 维度 | 现代规范 | 旧项目规范 |
|---|---|---|
| 类型命名 | TStringUtils | StringUtils |
| 方法命名 | Join, Split | join, split |
| 参数命名 | AStrings (A+大驼峰) | arrStrings (匈牙利) |
| 缩进 | 2 空格 | 4 空格 |
| begin 位置 | 另起一行 | 行尾 |
| 异常处理 | 具体异常类型 | except Exception 兜底 |
| 文件头 | XML Doc 注释 | 无强制要求 |
规则不仅是被查询的——它是被执行、被遵守的
📋 审计维度
| 🔴 严重 | 无 try/finally 保护 |
| 🔴 严重 | 循环内 Delete 跳项 |
| 🟡 警告 | 魔法数值未定义常量 |
| 🟡 警告 | finally 后取值的脆弱逻辑 |
| 🔵 建议 | 未使用变量 / 函数过长 |
📦 审计 → Issue 自动流转 (MCP 内置 Gitea 工具)
# Issue: LegacyData.pas 代码质量
## 🔴 严重
1. 资源泄漏 — ExportData:26
TStringList 无 try/finally
2. 循环删除跳项 — ProcessItems:82
## 🟡 警告
3. 魔法数值 — CalculateTotal:62,64,66,68
✅ 已创建: github.com/.../issues/42
AI 自动完成从规范到报告的完整审计链路
审计报告 → 工单,一键直达代码托管平台
📦 调用方式
code_hosting(
platform="gitea",
action="create_issue",
repo="owner/project",
title="审计: LegacyData.pas",
body="## 严重问题\n...",
label_names=["bug"]
)
🔄 完整闭环
需求:FireDAC + SQLite 数据库管理单元
场景:TStringList ➡ TArray<String>
构建 16 万页 CHM 索引后,自然语言即搜即得:
用户: TCanvas.Draw 的参数说明,
特别是 DrawOpacity 的作用
Result:
procedure Draw(X, Y: Integer;
const Graphic: TGraphic;
DrawOpacity: Byte = 255);
// DrawOpacity: 绘制不透明度
// 0 = 完全透明
// 255 = 完全不透明 (默认)
比翻 CHM 帮助文件快两个数量级
故事线:JSON 配置文件管理单元
flowchart LR
S1["① 获取规范"] --> S2["② 搜索 API"]
S2 --> S3["③ 写入代码
(自动备份)"]
S3 --> S4["④ 格式化"]
S4 --> S5["⑤ 编译验证"]
S5 --> S6["⑥ 代码审计"]
S6 --> S7["⑦ 清理 & 验证"]
classDef step1 fill:#e8f8f0,stroke:#34c759
classDef step2 fill:#e8f4ff,stroke:#007aff
classDef step3 fill:#fff3e6,stroke:#ff9500
classDef step4 fill:#fff0f0,stroke:#ff3b30
classDef step5 fill:#e8f8f0,stroke:#34c759
classDef step6 fill:#e8f4ff,stroke:#007aff
classDef step7 fill:#f3ecff,stroke:#8b5cf6
class S1 step1
class S2 step2
class S3 step3
class S4 step4
class S5 step5
class S6 step6
class S7 step7
共执笔,同成章
| 能力 | 一句话 |
|---|---|
| ⚙ 编译 | 项目 + 语法 + 批量 + 多平台,一句话完成 |
| 📚 知识库 | 17 万类 / 33 万函数 / 16 万文档,三模式搜索 |
| 🎨 格式化 | pasfmt + __history 备份,改不坏 |
| 📋 编码规范 | 驱动代码生成 + 审计,真实控制 AI 行为 |
| 🐛 诊断 | KB 驱动的复杂错误分析,从根因修复 |
| 🔄 重构 | 引用 → 修改 → 编译,全自动 |
| 📦 组件 | 编译 + 注册 .dpk 到 IDE |
| 🤖 自动化 | 审计报告 → 一键 Gitea 工单(MCP 内置) |
GitHub
github.com/chinawsb/daofy
MIT 许可证 Python 3.10+ Delphi 2005-13
交流方式:GitHub Issues
⭐ 如果觉得有用,请给项目点个 Star!
不止于此——这些能力让 AI 如虎添翼
感谢观看!
完整演示脚本见 docs/tutorial/tutorial_script.md