Files
PromptX/docs/dpml-semantic-rendering-upgrade.md

9.0 KiB
Raw Blame History

DPML语义渲染升级方案

📋 文档信息

  • 版本: v1.0
  • 创建时间: 2025-06-11
  • 作者: Claude Code & Sean
  • 优先级: High
  • 类型: 架构升级

🎯 核心理念

@引用 = 语义占位符

DPML标签中的@引用不应该被视为"独立的资源",而应该被理解为"语义占位符",在渲染时在原始位置插入引用内容,保持标签的完整语义流程。

🔍 问题分析

当前实现的语义割裂

<personality>
  @!thought://remember
  
  # 网络杠精思维模式
  ## 核心思维特征
  - 挑刺思维:看到任何观点都先找问题和漏洞
  - 抬杠本能:天生反对派,习惯性质疑一切表述
  
  @!thought://recall
  
  ## 认知偏好模式
  - 逆向思考优先:遇到任何论点先想如何反驳
  - 细节放大镜效应:善于将小问题放大成大问题
</personality>

当前渲染结果(割裂的)

## ✅ 🧠 思维模式remember
[remember的内容 - 100行]
---

## ✅ 🧠 思维模式recall  
[recall的内容 - 80行]
---

## ✅ 🧠 思维模式internet-debater-personality
# 网络杠精思维模式
## 核心思维特征
- 挑刺思维:看到任何观点都先找问题和漏洞
- 抬杠本能:天生反对派,习惯性质疑一切表述

## 认知偏好模式
- 逆向思考优先:遇到任何论点先想如何反驳
- 细节放大镜效应:善于将小问题放大成大问题
---

问题

  1. 语义割裂完整的personality被分割成3个独立片段
  2. 位置语义丢失@引用的位置信息完全丢失
  3. 阅读体验差:用户无法获得连贯的角色理解
  4. 违背用户意图:用户精心设计的内容组织被破坏

💡 升级方案:语义占位符渲染

核心概念

@引用 = 占位符:在标签的原始位置插入引用内容,保持完整的语义流程。

理想渲染结果(完整的)

## ✅ 🧠 完整思维模式internet-debater

[remember的完整内容 - 100行记忆相关思维模式]

# 网络杠精思维模式
## 核心思维特征
- 挑刺思维:看到任何观点都先找问题和漏洞
- 抬杠本能:天生反对派,习惯性质疑一切表述

[recall的完整内容 - 80行回忆相关思维模式]

## 认知偏好模式
- 逆向思考优先:遇到任何论点先想如何反驳
- 细节放大镜效应:善于将小问题放大成大问题

---

优势

  1. 语义完整性用户看到完整连贯的personality
  2. 位置语义保持:内容按用户设计的顺序自然流淌
  3. 阅读体验优化:连贯的角色理解体验
  4. 用户意图忠实:完全按照用户的内容组织呈现

🔧 技术实现设计

1. 核心渲染算法

class SemanticRenderer {
  /**
   * 语义占位符渲染:将@引用替换为实际内容
   * @param {Object} tagSemantics - 标签语义结构
   * @param {ResourceManager} resourceManager - 资源管理器
   * @returns {string} 完整融合的语义内容
   */
  async renderSemanticContent(tagSemantics, resourceManager) {
    let content = tagSemantics.fullSemantics // 保持原始标签内容结构
    
    // 按出现顺序处理每个@引用(保持位置语义)
    for (const ref of tagSemantics.references) {
      try {
        // 解析引用内容
        const refContent = await resourceManager.resolveReference(ref)
        
        // 在原始位置替换@引用为实际内容
        content = content.replace(ref.fullMatch, refContent)
      } catch (error) {
        // 引用解析失败时的优雅降级
        content = content.replace(ref.fullMatch, `<!-- 引用解析失败: ${ref.fullMatch} -->`)
      }
    }
    
    return content.trim()
  }
}

2. DPMLContentParser扩展

class DPMLContentParser {
  // 现有方法保持不变...
  
  /**
   * 新增:获取引用的位置信息
   */
  extractReferencesWithPosition(content) {
    const resourceRegex = /@([!?]?)([a-zA-Z][a-zA-Z0-9_-]*):\/\/([a-zA-Z0-9_\/.,-]+?)(?=[\s\)\],]|$)/g
    const matches = []
    let match
    
    while ((match = resourceRegex.exec(content)) !== null) {
      matches.push({
        fullMatch: match[0],
        priority: match[1],
        protocol: match[2],
        resource: match[3],
        position: match.index, // 位置信息
        isRequired: match[1] === '!',
        isOptional: match[1] === '?'
      })
    }
    
    return matches.sort((a, b) => a.position - b.position) // 按位置排序
  }
}

3. ActionCommand升级

class ActionCommand {
  /**
   * 升级:生成语义完整的学习计划
   */
  async generateSemanticLearningPlan(roleId, dependencies) {
    const { roleSemantics } = dependencies
    const renderer = new SemanticRenderer()
    
    let content = `🎭 **角色激活完成:${roleId}** - 语义完整加载\n`
    
    // 渲染完整的personality语义
    if (roleSemantics.personality) {
      content += `# 🧠 完整思维模式:${roleId}\n`
      const personalityContent = await renderer.renderSemanticContent(
        roleSemantics.personality, 
        this.resourceManager
      )
      content += `${personalityContent}\n---\n`
    }
    
    // 渲染完整的principle语义
    if (roleSemantics.principle) {
      content += `# ⚡ 完整执行模式:${roleId}\n`
      const principleContent = await renderer.renderSemanticContent(
        roleSemantics.principle, 
        this.resourceManager
      )
      content += `${principleContent}\n---\n`
    }
    
    // 渲染完整的knowledge语义
    if (roleSemantics.knowledge) {
      content += `# 📚 完整知识体系:${roleId}\n`
      const knowledgeContent = await renderer.renderSemanticContent(
        roleSemantics.knowledge, 
        this.resourceManager
      )
      content += `${knowledgeContent}\n---\n`
    }
    
    return content
  }
}

📊 语义保障对比

升级前:语义割裂

独立片段1: remember内容 (100行)
独立片段2: recall内容 (80行)  
独立片段3: 杠精思维 (50行)

问题: 用户无法理解这些片段的组织关系

升级后:语义完整

完整personality: remember内容 + 杠精思维 + recall内容 (230行)

优势: 用户获得完整连贯的角色理解

🎯 用户体验提升

1. 内容组织忠实性

用户精心设计的内容组织得到完全保持:

  • 引言 → @引用基础能力 → 核心特征 → @引用扩展能力 → 总结

2. 阅读连贯性

从分离的技术片段转变为连贯的角色叙述:

  • "这个角色有3个独立的思维片段"
  • "这个角色具有完整连贯的思维体系"

3. 角色理解深度

用户能够理解角色的完整图景,而不是零散的技能点。

🔧 实现阶段

阶段1SemanticRenderer实现

  • 创建语义渲染器核心类
  • 实现占位符替换算法
  • 支持引用解析失败的优雅降级

阶段2DPMLContentParser扩展

  • 添加位置信息提取
  • 增强引用解析能力
  • 保持向下兼容性

阶段3ActionCommand集成

  • 更新学习计划生成逻辑
  • 集成语义渲染器
  • 全面测试各种角色类型

阶段4全系统推广

  • 扩展到LearnCommand
  • 更新所有Protocol类
  • 建立统一的语义渲染标准

📝 测试策略

1. 语义完整性测试

test('应该保持@引用的位置语义', async () => {
  const content = `intro @!thought://A middle @!thought://B end`
  const rendered = await renderer.renderSemanticContent(semantics, rm)
  expect(rendered).toBe(`intro [A的内容] middle [B的内容] end`)
})

2. 复杂布局测试

test('应该处理复杂的@引用布局', async () => {
  const content = `
# 标题
@!thought://base

## 子标题  
- 列表项1
@!execution://action
- 列表项2
`
  // 验证内容在正确位置插入
})

3. 错误处理测试

test('应该优雅处理引用解析失败', async () => {
  // 验证失败时的降级策略
})

💡 长期价值

1. DPML协议语义标准

这个升级建立了DPML协议中@引用的语义标准:

  • @引用 = 占位符,不是独立资源
  • 位置语义优于类型语义
  • 用户意图优于技术实现

2. 可扩展的语义框架

为未来的DPML扩展奠定基础

  • 支持更复杂的引用类型
  • 支持条件渲染
  • 支持嵌套引用

3. 用户体验范式

从"技术驱动"转向"用户意图驱动"的设计范式。

🔗 相关文档

⚠️ 注意事项

  1. 性能考虑: 语义渲染涉及异步资源解析,需要考虑缓存策略
  2. 错误处理: 引用解析失败时的用户体验设计
  3. 兼容性: 确保现有角色的正常工作
  4. 文档更新: 用户需要了解新的语义渲染效果

这个升级将彻底解决DPML语义完整性问题为PromptX建立真正以用户意图为中心的语义框架。