Files
PromptX/prompt/domain/role-designer/execution/resource-best-practice.execution.md

4.7 KiB
Raw Blame History

# 资源模式设计流程
```mermaid
flowchart TD
  A[明确资源需求] --> B[设计资源路径结构]
  B --> C[定义查询参数]
  C --> D[建立资源注册表]
  D --> E[验证资源协议]
  E -->|通过| F[完成资源定义]
  E -->|不通过| G[调整修正]
  G --> B
```

## 核心步骤详解

1. **明确资源需求**
   - 确定资源类型和用途
   - 定义资源的生命周期和作用域
   - 规划资源的访问模式

2. **设计资源路径结构**
   - 使用`<location>`标签定义路径规则
   - 通过EBNF形式描述路径结构
   - 提供清晰的路径示例

3. **定义查询参数**
   - 使用`<params>`标签定义参数
   - 明确参数名称、类型和作用
   - 设计参数组合规则和优先级

4. **建立资源注册表**
   - 使用`<registry>`标签建立映射
   - 将抽象ID映射到具体资源路径
   - 确保映射关系清晰且无冲突

5. **验证资源协议**
   - 测试资源引用的解析正确性
   - 验证资源加载语义(@、@!、@?
   - 检查嵌套引用和查询参数功能
### 资源路径设计指南
- **简洁明确**:路径应当简洁但足够明确,避免歧义
- **分层结构**:使用层级结构组织资源,增强可读性
- **命名规范**:使用一致的命名规则
- **通配符合理使用**:适当使用通配符提升灵活性

### 查询参数设计指南

- **参数命名**:使用描述性名称,遵循常见约定
- **参数分组**:相关参数应使用一致的前缀
- **默认值处理**:明确指定参数的默认行为

### 注册表设计指南

- **ID命名**使用有意义的ID体现资源内容
- **路径模板**:对于相似资源,使用一致的路径模板
- **分类组织**:按功能或领域对注册表条目分组
  
### 资源引用指南

- **加载语义选择**
  - `@`:一般资源,非关键,可延迟加载
  - `@!`:关键资源,必须立即加载
  - `@?`:大型资源,仅在需要时加载

- **嵌套引用建议**
  - 简单情况使用简写形式:`@execution:file://path.md`
  - 复杂情况使用完整形式:`@execution:@file://path.md`
  - 多重嵌套不超过3层`@outer:middle:inner://path`
1. **路径格式一致性** - 资源路径必须遵循EBNF中定义的语法规则 2. **三要素完整性** - 自定义协议必须包含location、params和registry三个核心组件 3. **加载语义明确性** - 资源引用必须明确其加载语义(@、@!、@?)的使用场景 4. **查询参数规范化** - 参数名称和值格式必须明确规范 5. **注册表唯一性** - 注册表中的ID必须唯一不允许重复 6. **资源获取主动性** - AI必须主动使用工具调用获取资源特别是@!前缀的资源 7. **路径解析完整性** - 必须正确处理嵌套引用,从内向外解析 8. **资源验证必要性** - 必须验证资源是否成功加载,并妥善处理加载失败情况 1. **路径长度限制** - 资源路径不应过长建议不超过255字符 2. **嵌套深度限制** - 嵌套引用不应超过3层以保持可读性 3. **查询参数复杂度限制** - 单个资源引用的查询参数不宜过多 4. **注册表大小限制** - 单个注册表条目数量应控制在可管理范围内 5. **资源访问权限限制** - 需考虑环境对资源访问的权限限制 6. **解析环境限制** - 资源路径和参数需考虑在不同解析环境中的兼容性 | 指标 | 通过标准 | 不通过标准 | |------|---------|-----------| | 路径清晰度 | 路径结构直观易懂 | 路径结构混乱或难以理解 | | 参数设计合理性 | 参数命名明确,功能清晰 | 参数命名模糊,功能重叠 | | 注册表组织性 | 注册表条目分类合理ID有意义 | 注册表混乱ID无意义 | | 加载语义正确性 | 正确使用@、@!、@?前缀 | 加载语义使用不当 | | 嵌套引用可读性 | 嵌套结构清晰,不过度复杂 | 嵌套过深或结构混乱 | | 资源获取可靠性 | 资源加载有验证和错误处理 | 缺少验证或错误处理 | | 通配符使用合理性 | 通配符模式精确且高效 | 过于宽泛或低效的模式 | | 整体一致性 | 资源协议设计风格统一 | 设计风格不一致或混乱 |