SkillAgentSearch skills...

Openbrep

OpenBrep: 用自然语言驱动 ArchiCAD GDL 库对象的创建、修改与编译

Install / Use

/learn @byewind1/Openbrep
About this skill

Quality Score

0/100

Category

Design

Supported Platforms

Universal

README

<p align="center"> <img src="assets/logo.png" width="1525" alt="logo"> </p>

OpenBrep

快速开始

  1. 克隆项目
  2. 运行 bash install.sh 安装依赖
  3. 双击 start.command 启动

简体中文 | English

用自然语言驱动 ArchiCAD GDL 库对象的创建、修改与编译。

OpenBrep: Code Your Boundaries

正式发布版本 v0.6.0 — Runtime Phase 1 主骨架已经完成收口,代码、UI、说明文档与发布说明现已统一,可作为正式版本成立。


问题与解法

你用 AI 写了一段 GDL 代码,想在 ArchiCAD 里测试。传统路径:

打开库对象编辑器 → 手动填参数 → 切 5 个 Script 窗口 → 粘代码 → 编译

openbrep 把这个流程压缩到:

描述需求(中文/英文皆可)→ AI 生成并填入脚本框 → 一键编译 → .gsm 拖入 ArchiCAD

或者导入已有 .gsm 文件,让 AI 帮你 debug、重构、加参数。


安装与启动

首次安装

git clone https://github.com/byewind1/gdl-agent.git
cd gdl-agent
bash install.sh
obr

如果 obr 不可用,重开终端或运行 source ~/.zshrc

升级

cd gdl-agent
git pull origin main
bash install.sh   # 有新依赖时重跑,无害
obr

个人配置(config.toml / API Key)升级后保持不变,无需重新配置。

需要 Python 3.10+。真实编译(.gsm 输出)需要安装 ArchiCAD 28/29。


CLI 模式

面向 GDL 开发者的终端工作流。

pip install -e "."

# 创建对象
openbrep create "做一个宽600mm深400mm的书架,4个层板" --output ./my_shelf

# 修改对象(基于磁盘上的 HSF 项目目录)
openbrep modify ./my_shelf "把层板改成6个,间距均匀分布"

# 查看帮助
openbrep --help

每次修改都读取完整项目状态,精确修改而非重写,自动编译验证。


功能一览

编辑器栏(左侧)

| 功能 | 说明 | |---|---| | 📂 导入 | 拖入 .gdl / .txt / .gsm 文件;.gsm 经 LP_XMLConverter 解包为 HSF | | 🔧 编译 GSM | HSF → .gsm,支持 Mock 模式(无需 ArchiCAD)和真实 LP_XMLConverter 编译 | | 📥 提取 | 从 AI 对话中扫描代码块,自动识别脚本类型(3D/2D/Param...)并写入编辑器 | | 脚本标签页 | 6 个独立脚本框(3D / 2D / Master / Param / UI / Properties),每个均支持 streamlit-ace 语法高亮和全屏编辑 | | 参数表 | 查看、手动添加参数;AI 生成的 paramlist.xml 可一键写入 | | 🔍 语法检查 | IF/ENDIF、FOR/NEXT、ADD/DEL 匹配,3D 末尾 END,2D 必须有 PROJECT2 |

AI 对话栏(右侧)

| 功能 | 说明 | |---|---| | 🖼️ 图片即意图 | 上传建筑构件图片 → AI 识别几何、提取参数化维度 → 直接生成 GDL 脚本,无需文字描述 | | 自然语言创建 | "做一个宽 600mm 深 400mm 的书架,4 个层板" → 自动生成全部脚本和参数 | | 自然语言修改 | 已有项目时:"把层板改成 5 个,材质加一个 shelfMat 参数" → AI 理解上下文按需修改 | | Debug 模式 | 包含 "为什么"/"检查"/"修复" 等词时,自动注入全部脚本上下文;AI 可以给出分析文字 + 代码修复 | | 确认写入 | 已有项目的 AI 修改不会自动覆盖,消息下方出现 [✅ 写入] [❌ 忽略] 按钮 | | 对话操作栏 | 每条 AI 消息下方:👍 👎 📋 🔄(好评/差评/复制/重新生成) | | 多模型支持 | Claude / GLM / GPT / DeepSeek / Gemini / Ollama 本地,侧边栏切换 |


支持的 LLM

| 提供商 | 模型 | 说明 | |---|---|---| | Anthropic | claude-haiku / sonnet / opus | 推荐首选 | | 智谱 | glm-5 / glm-4-flash | 国内可用,性价比高 | | OpenAI | gpt-4o / gpt-4o-mini / o3-mini | | | DeepSeek | deepseek-chat / deepseek-reasoner | | | Google | gemini-2.5-flash / pro | | | Ollama | qwen2.5 / qwen3 / deepseek-coder | 本地,无需 API Key |


GSM 导入(AC29 支持)

侧边栏选择 LP_XMLConverter 模式,配置路径后可导入 .gsm 文件进行修改:

# ArchiCAD 29 路径(LP_XMLConverter 内嵌于 app bundle)
/Applications/GRAPHISOFT/Archicad 29/Archicad 29.app/Contents/MacOS/
  LP_XMLConverter.app/Contents/MacOS/LP_XMLConverter

也可直接在 config.toml 中写入,启动后自动读取。


HSF 格式简介

.gsm 文件解压后是这样的目录结构(HSF):

MyBookshelf/
├── libpartdata.xml     ← 对象身份(GUID、版本)
├── paramlist.xml       ← 参数定义(强类型)
├── ancestry.xml        ← 对象分类
└── scripts/
    ├── 1d.gdl          ← Master Script
    ├── 2d.gdl          ← 2D 平面符号
    ├── 3d.gdl          ← 3D 几何模型
    ├── vl.gdl          ← 参数逻辑(VALUES/LOCK)
    └── ui.gdl          ← 自定义界面

openbrep 以 HSF 为原生格式,每个脚本独立处理,AI 只读取与当前任务相关的脚本(减少 context 占用)。


项目结构

openbrep/
├── openbrep/
│   ├── hsf_project.py       # HSF 数据模型
│   ├── paramlist_builder.py # paramlist.xml 强类型生成
│   ├── gdl_parser.py        # .gdl → HSFProject
│   ├── compiler.py          # LP_XMLConverter 封装
│   ├── core.py              # Agent 主循环 + generate_only
│   ├── llm.py               # 多模型统一接口
│   ├── knowledge.py         # 知识库加载
│   └── skills_loader.py     # 任务策略加载
├── ui/
│   └── app.py               # Streamlit Web 界面
├── knowledge/               # GDL 参考文档(可自行扩充)
├── skills/                  # 任务策略(可自行扩充)
├── docs/
│   └── manual.md            # 详细用户手册
├── tests/                   # 单元测试
├── config.example.toml
└── pyproject.toml

配置

复制 config.example.tomlconfig.toml(已 .gitignore),按需填写:

[llm]
model = "glm-4-flash"

[llm.provider_keys]
zhipu     = "your-zhipu-key"
anthropic = "your-claude-key"
openai    = "your-openai-key"
deepseek  = "your-deepseek-key"

[compiler]
path = "/Applications/GRAPHISOFT/Archicad 29/..."

文档

  • 用户手册 → — UI 每个功能的详细说明、工作流、常见问题

版本历史

| 版本 | 主要内容 | |---|---| | v0.6.0 | Runtime Phase 1 主骨架正式发布收尾:统一 create / modify / repair / chat 主链路;repair 独立 intent 闭合;CLI/UI/runtime 版本与发布口径统一(见 docs/releases/v0.6.0.md) | | v0.5.7 | CLI 模式正式可用(create/modify 命令);生成过程支持用户取消;pipeline 改进解决越改越差问题;参数路由修复(见 docs/releases/v0.5.7.md) | | v0.5.6 | 图片上传不再卡死;cross-script / static checker 误报减少;AI 助手设置支持长期保存并注入系统提示;自定义代理与官方供应商分层选择,并优先显示代理名(见 docs/releases/v0.5.6.md) | | v0.5.5 | UI重构为四栏布局:左栏操作+预览、中栏脚本+参数表、右栏AI对话(见 docs/releases/v0.5.5.md) | | v0.5.4 | validator 分层重构:error/warning 分开,硬错误白名单收紧;跨脚本检查器;debug 最小改动;生成过程实时显示;生成中禁用 widget(见 docs/releases/v0.5.4.md) | | v0.5.3 | 知识库升级与文档品牌增强:整合拆书增量(含 2D 高级与可编译示例)、新增命令索引与命令级精准路由、README 顶部加入 logo(见 docs/releases/v0.5.3.md)。 | | v0.5.2 | 版本标注与发布归档规范化:UI 版本号统一读取代码版本;README 标题去版本;新增发布说明文档(见 docs/releases/v0.5.2.md) | | v0.5.1 | 安装包发布准备:新增 macOS/Windows 打包脚本与 GitHub Actions 构建流程(PyInstaller) | | v0.5 | OpenBrep 品牌发布 — 项目更名为 OpenBrep;稳定版本发布;Gitee 镜像支持(国内用户快速访问) | | v0.5 pre | 统一编辑器 UI;图片即意图(上传图片 → AI 生成 GDL);AI 对话修改脚本;确认写入流程;paramlist.xml 自动注入;GSM 导入(AC29);streamlit-ace 语法高亮;全屏编辑;多模型支持 | | v0.4.0 | HSF-native 架构重构;Streamlit Web UI;强类型 paramlist;44 项单元测试 | | v0.3.x | GDL 解析器;Context surgery;Preflight | | v0.2.0 | Anti-hallucination;Golden snippets | | v0.1.0 | Core agent loop |


License

MIT — see LICENSE.

View on GitHub
GitHub Stars16
CategoryDesign
Updated6h ago
Forks3

Languages

Python

Security Score

95/100

Audited on Apr 8, 2026

No findings