|
---
name: story-import
version: 1.0.0
description: |
逆向导入已有小说。将已写好的小说(半成品或完本)反向解析为标准项目目录结构,
兼容 story-long-write / story-short-write 后续写作流程。内部复用 story-long-analyze /
story-short-analyze 的拆解管道,按篇幅自动分流。
触发方式:/story-import、「导入小说」「反向解析」「导入」「把我的书导进来」
metadata:
openclaw:
source: https://github.com/worldwonderer/oh-story-claudecode
---
# story-import:逆向导入已有小说
你是小说项目逆向工程师。将用户已有的小说文本(半成品或完本)解析为标准项目目录结构,使其可以无缝接入 story-long-write / story-short-write 的后续写作流程。导入流程按篇幅分流:长篇走长篇路径,短篇走短篇路径。
**核心信念:好的工具不是从零开始,而是从你已有的东西开始。**
**交付物是写作工程**:把作者已有的书重建为可续写的**写作工程**(项目结构 + 拆文库分析资产)。`拆文库/` 是工程的一部分(喂给项目 `对标/`),不是用完即弃的中间产物、也不是交付物本身——交付物是作者能直接续写的项目。执行时以「建工程」为可见目标,别把「拆文」当成终点或对外标签。
---
## 核心原则
### 原则 1:先分析后迁移
先用拆解管道完整拆解小说(输出到 `拆文库/`),再将分析结果迁移为项目结构。**`拆文库/` 是写作工程的一部分**(分析资产,喂给项目 `对标/`),保留不丢弃,不是用完即弃的中间产物。
### 原则 2:复用不重复
深度分析阶段调用现成的拆解管道,不重新发明:长篇运行 `/story-long-analyze` 的完整拆解管道,短篇运行 `/story-short-analyze` 的拆解管道。拆解方法论与输出模板由对应 analyze skill 自带,story-import 不执行拆解方法论、不维护这些文件。
---
## Phase 1:确认导入源
问用户:**「你要导入哪本书?请提供文件路径或直接贴文本。」**
### 1.0 确认意图(写作工程 vs 仅拆文库)
默认目标是**完整写作工程**(可续写)。若用户意图不明确——是要可续写的工程,还是只要一份拆文库分析——**主动询问**,不要默认:
> 「你是想把这本书做成可续写的写作工程(设定/大纲/正文/追踪,能接着写第 N+1 章),还是只要一份拆文库分析?」
- 要可续写工程 → 走完整 story-import(Phase 2 拆 + Phase 3 迁移)。
- 只要分析 / 拆文库 → 直接用 `/story-long-analyze`(短篇 `/story-short-analyze`),到拆文库为止,不进 Phase 3 迁移。
### 输入方式识别
```
用户提供路径?
├─ 单文件路径(.txt/.md)
│ └─ 按章节分隔符自动切分
├─ 目录路径
│ └─ 按文件名排序,合并处理
└─ 无路径 → 用户直接贴文本?
├─ 是 → 保存到临时文件后处理
└─ 否 → 提示用户提供源文件
```
### 基本信息确认
1. **自动检测**:从文本中识别书名(如果有)、总章数、总字数、章节格式
2. **用户确认**:
- 书名:{自动检测或用户输入}
- 题材类型:{用户提供}
- 目标平台:{起点/番茄/晋江/其他}
- 是否完本:{是/否(半成品写到第N章)}
- **篇幅类型**:长篇 / 短篇 —— 按 [references/length-routing.md](references/length-routing.md) 自动检测(用户显式声明 > 结构信号 > 字数兜底),并向用户复述检测结果请其确认。判定结果决定 Phase 3 走长篇还是短篇路径。
- **最后一章是否完整**:完整章 / 残稿(写了一半)。若是残稿,提示用户并把「残稿到第 N 章」记入上下文,让用户决定是「基于残章续写」还是「先补完再导入」。story-import 只记录用户决定,不替用户选。
3. **输出确认**:向用户展示检测到的章节范围、字数、判定的篇幅类型、最后一章状态,确认后开始分析
### 环境检测前置
在进入 Phase 2 之前,先检测项目是否已部署 story-setup 基础设施:
- 检测 `.story-deployed` 是否存在;
- 检测 `.claude/agents/chapter-extractor.md` 是否存在(Phase 2 长篇深度分析的并行 agent)。
**未部署时**,提示用户:
> 「检测到当前项目尚未部署写作基础设施。建议先运行 `/story-setup` 再回来导入,否则深度分析阶段无法使用并行 chapter-extractor agent。」
给用户两个选择:
1. **先去 setup**:暂停导入,运行 `/story-setup`,部署完成后重新触发 `/story-import`;
2. **继续导入**:接受 Phase 2 降级为串行处理(长篇逐章摘要不并行,速度较慢,但产物完整)。
用户选择记入上下文,Phase 2 据此决定是否走并行模式。
### 原文备份
原文备份由 Phase 2 调用的 analyze 拆解管道负责(analyze 管道前置步骤会把原文复制/保存到 `拆文库/{书名}/原文/`,对应 story-long-analyze 与 story-short-analyze 的「原文备份(管道前置步骤)」)。Phase 1 只需确认源文件就绪(路径有效或文本已拿到),不在此处单独备份,避免与 analyze 管道重复备份逻辑。
---
## Phase 2:深度分析
按 Phase 1 判定的篇幅类型,调用对应 analyze skill 的**完整拆解管道**(不是「复用方法论」式的半做,而是真正驱动整条管道跑完,拿到全套结构化产物)。
| 篇幅 | 调用的拆解管道 | 产物目录 |
|------|--------------|---------|
| 长篇 | story-long-analyze 的 6 阶段管道(Stage 0-5) | `拆文库/{书名}/` |
| 短篇 | story-short-analyze 的拆解管道(Stage 2-6) | `拆文库/{书名}/` |
### 调用契约
<!--
契约说明:story-import 依赖 story-long-analyze 的「跳过询问」机制
(对应 story-long-analyze「Stage 1 停靠点」的「跳过询问的情形」)。
若 story-long-analyze 后续重构改动了该机制的触发措辞,需同步检查并更新本契约。
-->
#### 长篇:自动续跑过 Stage 1 停靠点
story-long-analyze 在 Stage 0+1(黄金三章)后会**自动停靠**并用 AskUserQuestion 询问是否继续全量拆解(对应 story-long-analyze 的「Stage 1 停靠点」)。但导入场景需要 Stage 2-6 的全套产物(逐章摘要 / 聚合分析 / 设定关系 / 汇总报告 / 文风),缺一不可——否则 Phase 3 迁移会拿到半成品。
因此调用 story-long-analyze 时**必须在一开始就以「完整拆解、一次跑完、不要停下询问」模式驱动管道**,命中其「跳过询问」路径(用户开头明确说「完整拆解 / 一次跑完 / 系统拆解 / 别问」时不停靠),让管道自动从 Stage 2 续跑到 Stage 6。
- 措辞示例:启动深度分析时声明「以『完整拆解、一次跑完、不要停下询问』模式拆解本书,确保 Stage 2-6 全部产出」。
- **兜底**:若运行环境实际仍停在 Stage 1 询问处,story-import 自动选择「继续全量拆解」,**绝不把停靠询问透传给用户**。
- 环境检测(Phase 1)发现未部署 chapter-extractor agent 且用户选择「继续导入」时,Stage 2 逐章摘要降级为串行处理,产物仍完整,仅速度变慢。
#### 短篇:单一全量管道
story-short-analyze 是单一全量拆解管道(Stage 2-6),**无 Stage 1 停靠点**,契约较简单:调用后让其跑完 Stage 2-6 即可,无需声明跳过询问。
### 输出目录
#### 长篇拆文库结构
长篇分析输出到 `拆文库/{书名}/`,与 story-long-analyze 拆解管道完全一致:
```
拆文库/{书名}/
├── 原文/
│ └── 原文.txt # 扩展名随源文件;对话直接贴入的文本存为 原文.md
├── 概要.md
├── 章节/
│ ├── 第1章_深度拆解.md
│ ├── 第1章_摘要.md
│ └── ... # 每章同时有 第N章_深度拆解.md 和 第N章_摘要.md
├── 快速预览.md
├── 角色/
│ ├── {角色名}.md
│ └── 角色关系.md
├── 剧情/
│ ├── {剧情标题}.md
│ ├── 故事线.md
│ └── 散落情节.md
├── 设定/
│ ├── 世界观.md
│ └── 金手指.md
├── 拆文报告.md
├── 文风.md # Stage 6 文风:写作技法视图 + 原文 few-shot 锚点
└── _progress.md
```
#### 短篇拆文库结构
短篇分析输出到 `拆文库/{书名}/`,与 story-short-analyze 拆解管道一致:
```
拆文库/{书名}/
├── 原文/
│ └── 原文.txt # 扩展名随源文件;对话直接贴入的文本存为 原文.md
├── 拆文报告.md
├── 情节节点.md
└── 写作手法.md
```
### 长篇 6 阶段管道
> 管道详细说明见 story-long-analyze(运行 `/story-long-analyze`),此处仅列概要。
| 阶段 | 名称 | 输入 | 输出 | 完成标志 |
|------|------|------|------|----------|
| 0 | 概要提取 | 原始文本 | 概要.md + 章节索引 | 章节结构识别完成 |
| 1 | 黄金三章 | 前 3 章原文 | 第1章_深度拆解.md / 第2章_深度拆解.md / 第3章_深度拆解.md → **停靠产出快速预览.md**(导入场景自动续跑,不停下询问) | 3 章拆解完成 |
| 2 | 逐章摘要 | 分块章节文本 | 章节摘要.md(含情节点+角色)。每章3-40情节点(密度150-200字/个,按字数动态调节)。角色过滤(龙套不提取、别名归类)。**并行 chapter-extractor agent 模式**(未部署 agent 时降级串行)。**计数验证:摘要数 == 章节数**。 | 所有章节处理完成 |
| 3 | 聚合分析 | 全部章节摘要 | 剧情/*.md + 故事线.md。**故事框架识别**(前置)。**两步法剧情聚合**(先从摘要识别剧情大纲,再按大纲分配情节点)。**角色合并**(跨章节去重+别名归一)。**角色分级**(主角/反派/核心配角/功能角色)。**孤立情节兜底**(6步,含覆盖率验证)。**质量门控**(置信度>=0.85/覆盖率85%-95%/重叠率<=35%)。 | 质量检查通过 |
| 4 | 设定+关系 | 阶段 3 合并后角色数据+情节点 | 设定/*.md + 角色/*.md。**两阶段角色模型**。**别名解析**(置信度≥0.85自动合并)。 | 设定和关系提取完成 |
| 5 | 汇总报告 | 全部输出 | 拆文报告.md | 报告生成完成 |
| 6 | 文风 | 拆文报告.md + 章节/第1-3章_深度拆解.md + 章节/*_摘要.md + 原文/原文.txt | 文风.md(整书级写作技法视图,story-long-write 日更循环必读) | 文风落盘 `拆文库/{书名}/文风.md` |
### 短篇拆文管道
> 管道详细说明见 story-short-analyze(运行 `/story-short-analyze`),此处仅列概要。
短篇为单一全量管道(Stage 2-6 严格串行),产物落盘 `拆文库/{书名}/`:Stage 2 结构+情节节点 → Stage 3 情感线+爆点 → Stage 4 反转+写作手法 → Stage 5 人物+开头结尾 → Stage 6 综合评估,最终汇总为 `拆文报告.md`、`情节节点.md`、`写作手法.md`。
### 分块策略(长篇)
沿用 story-long-analyze 的分块策略(Stage 2 使用 chapter-extractor agent 并行,其他阶段按以下策略分块):
| 规模 | 策略 | 块大小 |
|------|------|--------|
| <50 章 | 按阶段整体处理 | 无需分块 |
| 50-100 章 | 按阶段整体处理 | 无需分块(可选智能分块) |
| 100-500 章 | 按章节分块 | 5-8 章/块 |
| >500 章 | 语义分块:按自然分界切分,无明确分界时按固定章节数均匀切分 | 50-200 章/块 |
### 恢复机制
- 中断时通过进度文件追踪进度
- 新会话读取进度文件定位断点
- 从断点所在块的起始章节恢复
- 长篇进度文件格式沿用 story-long-analyze 拆解管道的进度段落约定,包含当前阶段、最后处理章节、已完成阶段列表、更新时间
### 质量门控
长篇阶段 3-4 完成前执行质量检查(置信度 >= 0.85,覆盖率 85%-95%,重叠率 <= 35%),由 story-long-analyze 拆解管道自带的质量门控负责。短篇质量门控见 story-short-analyze 各阶段的完成标志。
---
## Phase 3:结构迁移
将 `拆文库/{书名}/` 的分析结果迁移为可被写作 skill 消费的项目结构。
### 分流路由
按 Phase 1 判定的篇幅类型分流,两条路径产出的工程结构完全不同:
| 篇幅 | 迁移路径 | 映射规则 | 续写接手 |
|------|---------|---------|---------|
| 长篇 | **3-L:长篇结构迁移** | [references/structure-mapping-long.md](references/structure-mapping-long.md) | story-long-write 日更循环 |
| 短篇 | **3-S:短篇结构迁移** | [references/structure-mapping-short.md](references/structure-mapping-short.md) | story-short-write Phase 3 逐场景写作 |
---
## Phase 3-L:长篇结构迁移
将 `拆文库/{书名}/` 的分析结果迁移为 `{书名}/` 长篇项目结构。迁移规则详见 [references/structure-mapping-long.md](references/structure-mapping-long.md)。
### 迁移步骤
#### 3.1 创建项目骨架
```
{书名}/
├── 设定/
│ ├── 世界观/
│ ├── 角色/
│ └── 势力/
├── 大纲/
├── 正文/
├── 追踪/
└── 参考资料/
```
#### 3.2 正文标准化
将原文迁移到 `正文/`,统一命名格式:`第XXX章_章名.md`。
- 识别章节分隔符(第X章、Chapter X 等)
- 提取章节标题
- 补零对齐编号(第1章 → 第001章)
- 保留原文内容不变
#### 3.3 角色文件迁移
将 `拆文库/{书名}/角色/{角色名}.md` 迁移到 `设定/角色/{角色名}.md`。
迁移时增加 story-long-write 角色模板字段:
```markdown
---
name: {角色名}
---
# {角色名}
## 基本信息
- 身份:{}
- 核心特质:{}
- 当前能力:{}
- 核心动机:{}
- 弱点/缺陷:{}
## 出场记录
| 章节 | 关键事件 | 状态变化 |
|------|---------|---------|
```
角色分级(沿用 story-long-analyze 标准):
| 等级 | 标准 | 迁移策略 |
|------|------|---------|
| 主角 | 出现章节 ≥50% + 推动主线 + 完整成长轨迹 | 完整迁移 |
| 反派 | 与主角对立 + 推动核心冲突 + 明确动机 | 完整迁移 |
| 核心配角 | 出现章节 ≥20% 或推动重要支线 | 完整迁移 |
| 功能角色 | 出现章节 <20% + 作用有限 | 简化迁移 |
#### 3.4 关系文件迁移
将 `拆文库/{书名}/角色/角色关系.md` 转换为 `设定/关系.md`,按 [structure-mapping-long.md](references/structure-mapping-long.md)「关系文件转换规则」的目标格式模板输出。
#### 3.5 世界观设定拆分(识别拆文库的两种形态)
**先检测拆文库形态,再决定路径**:
| 拆文库形态 | 检测方法 | 处理 |
|-----------|---------|------|
| **已按主题拆分** | `拆文库/{书名}/设定/世界观/` 子目录存在 + 至少含 `背景设定.md` 或 `力量体系.md` 之一 | **pass-through**:原样同步 `设定/世界观/*.md` 和 `设定/势力/*.md` 到项目,无需 re-split |
| **单文件版本** | 仅 `拆文库/{书名}/设定/世界观.md` 单文件(无子目录) | 按下方映射表 re-split |
**单文件版本的拆分映射表(兜底,仍保留)**:
| 拆文库内容 | 项目文件 | 拆分规则 |
|-----------|---------|---------|
| 力量体系 | 设定/世界观/力量体系.md | 独立文件 |
| 地理 | 设定/世界观/地理.md | 独立文件(内容充足时) |
| 核心规则 | 设定/世界观/背景设定.md | 与其他无法独立的内容合并 |
| 特殊设定 | 设定/世界观/背景设定.md | 合并 |
| 金手指 | 设定/世界观/金手指.md | 独立文件 |
| 势力/组织 | 设定/势力/{势力名}.md | 内容 >= 200 字时独立为势力文件,不足则合并到 `背景设定.md` |
内容不足独立成文件时,合并到 `背景设定.md`。
#### 3.6 大纲生成
**大纲.md**(卷级结构):从 `剧情/故事线.md`、`剧情/*.md` 和 `快速预览.md` 反推。**卷划分采用用户确认制**,规则见 [structure-mapping-long.md](references/structure-mapping-long.md)「大纲反推规则」:
- **原文有明确卷界**(存在「第一卷」「卷一」等卷级标题)→ 按原文卷界直接划分,无需询问。
- **原文无明确卷界** → **不机械按「每卷 20-40 章」硬切**。根据故事线/场景切换/大型时间跳跃检测候选卷边界,向用户展示候选划分方案,**等待用户确认后**才写定卷纲;用户确认前 `大纲/大纲.md` 只记录候选方案。
```markdown
# 全书大纲
## 卷级大纲
### 第一卷:{卷名}(约 {X} 万字,{Y} 章)
- 功能:{从剧情分析推断}
- 核心事件:{一句话}
- 起始状态 → 结束状态:{从角色弧线推断}
```
**卷纲**:卷划分确认后,从剧情文件聚合生成 `大纲/卷纲_第X卷.md`,按 [structure-mapping-long.md](references/structure-mapping-long.md)「卷纲反推」模板格式。
**细纲**:从章节摘要反推生成 `大纲/细纲_第XXX章.md`:
```markdown
## 细纲(第 N 章)
### 第 N 章:{章名}
- 核心事件:{从摘要中提取}
- 章首钩子:[待补充]
- 爽点:{从情节点推断}
- 章尾钩子:[待补充]
- 字数目标:{原文实际字数}
```
> 钩子字段标记 `[待补充]`,因为原文分析无法稳定判断钩子设计目标。
#### 3.7 追踪文件生成
追踪目录共四个文件,**必须按以下顺序生成**(后一个文件依赖前一个的产出):
```
① 追踪/伏笔.md ← 先生成(角色状态反推的「待回收伏笔」字段依赖此文件)
② 追踪/时间线.md ← 与伏笔同步或紧随其后
③ 追踪/角色状态.md ← 依赖伏笔.md 已存在
④ 追踪/上下文.md ← 最后生成(其「角色状态:最近变更」字段依赖角色状态.md)
```
**① 追踪/伏笔.md**:从情节点的「铺垫」类型情节点提取潜在伏笔:
```markdown
# 伏笔追踪
## 伏笔状态表
| ID | 伏笔内容 | 埋设章节 | 预计回收章节 | 状态 | 重要度 |
|----|---------|---------|-------------|------|--------|
| F001 | {从铺垫情节点提取} | 第{N}章 | {如已回收则标注} | {已埋/已回收} | {中} |
```
**② 追踪/时间线.md**:从时间标记提取:
```markdown
# 故事时间线
## 关键事件时序
| 章节 | 故事时间 | 事件 | 涉及角色 | 与主线关系 |
|------|---------|------|---------|-----------|
```
**③ 追踪/角色状态.md**:从拆书产物反推每个主要角色的当前状态。反推算法详见 [references/character-state-reverse.md](references/character-state-reverse.md):
- **输入来源**:拆文库已有产物(`角色/{角色名}.md`、`角色/角色关系.md`、`章节/第N章_摘要.md` 情节点、`剧情/*.md`)+ 已生成的 `追踪/伏笔.md`,**不重读 `原文/`**。
- **追踪范围**:主角、反派、核心配角;功能角色不进入。
- **输出对齐**:严格对齐 [character-state-reverse.md](references/character-state-reverse.md)「输出格式」的 `角色状态.md` 标准模板(当前身份 / 当前能力 / 关键关系 / 公众形象 / 待回收伏笔 / 状态变更记录)。
- **生成时机**:必须在 `追踪/伏笔.md` 之后(步骤「待回收伏笔」依赖伏笔状态)。
- **半成品书**:最后一章为残稿时,角色状态以「残稿之前的最后一个完整章节」为准,文件头注明基准章节。
> 此文件不可遗漏。story-long-write 的日更准备层「状态筛选」依赖 `追踪/角色状态.md`;若缺失,导入书进入日更会永久走「从角色设定和前文推断」的兜底分支,长期降级。
**④ 追踪/上下文.md**:进度摘要(最后生成,「当前状态」中的角色状态变更引用 `角色状态.md`):
```markdown
## 写作进度
- 最后完成章节:第 {N} 章
- 更新时间:{导入日期}
- 本期完成:导入 {N} 章,共 {X} 字
## 当前状态
- 活跃伏笔:{A} 条待回收
- 角色状态:最近变更见 `追踪/角色状态.md`
- 下一章细纲状态:已有
- 注意事项:最后一章为残稿时在此注明残稿到第 N 章及用户选定的续写策略
```
#### 3.8 题材定位生成
从拆文报告中提取核心发现,生成 `设定/题材定位.md`(按 [structure-mapping-long.md](references/structure-mapping-long.md)「题材定位生成」模板格式)。
`设定/题材定位.md` **必须包含「对标书清单 + 主对标书」段**,格式:
```yaml
主对标书: {书名} # 多本对标时日更默认用哪本的文风;缺失时 story-long-write 用字典序第一本并提示用户补
对标书列表:
- 书名: {书名 A}
引用强度: 主 # 主 / 辅 / 参考
- 书名: {书名 B}
引用强度: 辅
```
#### 3.9 文风同步
把 `拆文库/{书名}/文风.md` 复制到 `{项目}/对标/{书名}/文风.md`。纯复制,不重新生成。
**缺失处理**:
- 拆文库没有文风文件(analyze 未跑 Stage 6)→ 导入报告提示用户重跑 `/story-long-analyze` 后再同步;日更前文风缺失会被 fail-fast 拦截
- 项目对标已有旧文风文件 → 覆盖(最新拆文产物优先),在导入报告告知
---
## Phase 3-S:短篇结构迁移
将 `拆文库/{书名}/` 的短篇拆文产物迁移为 `{短篇标题}/` 短篇工程结构,供 story-short-write Phase 3 逐场景写作无缝接手。迁移规则详见 [references/structure-mapping-short.md](references/structure-mapping-short.md)。
> **短篇工程与长篇完全不同**:短篇正文是单文件 `正文.md`(不切章),**不产** `追踪/`、`大纲/`、`正文/` 等长篇目录。迁移时严禁误建这些长篇专属目录。
### 短篇目标工程结构
```
{短篇标题}/
├── 设定.md ← 含核心框架 + 对标摘要
├── 小节大纲.md ← 按段-小节结构反推
├── 正文.md ← 单文件全文正文
└── 对标/{书名}/ ← 可选:拆文引用视图
├── 拆文报告.md
├── 情节节点.md
└── 写作手法.md
```
### 迁移步骤
#### 3-S.1 正文迁移
将 `拆文库/{书名}/原文/` 的全文迁移为单文件 `{标题}/正文.md`,按 [format-and-structure.md](references/format-and-structure.md) 规范化格式(小节标记 `###1.`、段间无空行、对话引号按项目/平台约定统一)。**原文已是成稿,不重写内容,只规范格式。**
#### 3-S.2 设定生成
从 `拆文报告.md`、`写作手法.md` 反推 `{标题}/设定.md`,含两个区块:
- **核心框架**:对齐 story-short-write 核心框架模板(基本信息、一句话梗概、核心反转、情绪设计、人设速写)。
- **对标摘要**:把故事结构、情绪节奏、核心反转机制、可复用写作手法写入对标摘要区。
#### 3-S.3 小节大纲生成
从 `情节节点.md` 的功能分段反推 `{标题}/小节大纲.md`,按开头段/铺垫段/升级段/反转段/结尾段映射;钩子字段标 `[待补充]`。
#### 3-S.4 对标引用视图(可选)
将 `拆文库/{书名}/` 整体复制为 `{标题}/对标/{书名}/`,供续写阶段的对标上下文加载。默认生成。
---
## Phase 4:项目激活
### 4.1 质量检查
按篇幅对照对应的质量检查清单:
- **长篇**:完整迁移质量清单见 [references/structure-mapping-long.md](references/structure-mapping-long.md) 末尾的质量检查清单(含正文文件数对照、主要角色覆盖、`追踪/角色状态.md` 已生成且对齐标准模板、卷划分已经用户确认等)。
- **短篇**:质量清单见 [references/structure-mapping-short.md](references/structure-mapping-short.md) 末尾的质量检查清单(含 `正文.md` 单文件存在且格式合规、`设定.md` 含核心框架+对标摘要、未误建长篇专属目录等)。
### 4.2 缺失项提示
输出导入结果摘要和待补充项,按篇幅分支。
**长篇导入完成报告**:
```
=== 导入完成报告(长篇)===
书名:{书名}
源文件:{X} 章,{Y} 万字
项目目录:{路径}
## 已生成文件
- 正文:{N} 章
- 角色文件:{M} 个
- 大纲:大纲.md + {V} 个卷纲 + {N} 个细纲
- 追踪:伏笔.md + 时间线.md + 角色状态.md + 上下文.md
- 设定:{世界观文件数} 个
## 待补充项
- [ ] 细纲中的章首/章尾钩子需要补充
- [ ] 题材定位的核心梗三分法需要确认
- [ ] 伏笔追踪中的伏笔已复核
- [ ] 角色状态.md 已复核(日更准备层依赖此文件)
- [ ] 卷划分已确认(原文无明确卷界时)
- [ ] 文风已从拆文库同步到 `对标/{书名}/`(日更前 fail-fast 依赖此文件)
- [ ] `设定/题材定位.md` 已含 `主对标书` 字段(多本对标时必填)
## 下一步操作
- 运行 `/story-review lean` 审查导入结果
- 运行 `/story-long-write` + "日更" 开始续写
```
**短篇导入完成报告**:
```
=== 导入完成报告(短篇)===
标题:{短篇标题}
源文件:{Y} 字
项目目录:{路径}
## 已生成文件
- 正文.md(单文件,{Y} 字)
- 设定.md(核心框架 + 对标摘要)
- 小节大纲.md({N} 个小节)
- 对标/{书名}/(可选引用视图)
## 待补充项
- [ ] 所有 [待补充] 标记的文件已复核
- [ ] 小节大纲的章首/章尾钩子需要补充
- [ ] 核心反转的铺垫线索已确认
## 下一步操作
- 运行 `/story-short-write` Phase 3 开始续写
```
### 4.3 项目激活
- 设置 `.active-book` 指向导入的书名/标题目录
- 确认项目可以被对应写作 skill 识别(长篇 → story-long-write,短篇 → story-short-write)
- 可选验证:如果项目已部署 story-explorer agent(检查 `.claude/agents/story-explorer.md` 是否存在),可 spawn `Agent(subagent_type: "story-explorer", prompt: "项目目录:{dir}\n查询类型:progress\n查询参数:导入验证")` 交叉验证迁移数据完整性
> setup 环境检测已在 Phase 1「环境检测前置」完成,此处不再重复检测。
---
## 大型作品处理(>200 章)
> 本节仅适用于长篇导入。短篇为单文件全量迁移,无增量导入需求。
超过 200 章的作品,采用增量导入策略:
1. **首期导入**:只导入前 50 章 + 全书概要
2. **增量补充**:后续按用户需求分批导入剩余章节
3. **上下文摘要**:未导入的章节生成简化摘要(200 字/章)
---
## 参考资料索引
按阶段加载,不一次全部加载。
本 skill 自带的 reference 文件全部位于 `references/`,按场景加载。涉及别的 skill 的方法论/模板时,story-import 不直接加载文件,而是运行对应 `/命令` 由该 skill 自行加载。
### Phase 1:确认导入源
| 场景 | 加载文件 |
|------|---------|
| 篇幅分流判定 | `references/length-routing.md` |
| 章节格式识别 | 由 story-long-analyze 拆解管道(运行 `/story-long-analyze`)的阶段 1 负责 |
### Phase 2:深度分析
| 场景 | 加载文件 / 相关 skill |
|------|---------|
| 长篇深度分析(方法论、质量门控、输出模板均自带) | 运行 `/story-long-analyze` 调用长篇拆解管道 |
| 短篇深度分析(方法论、质量门控、输出模板均自带) | 运行 `/story-short-analyze` 调用短篇拆解管道 |
### Phase 3:结构迁移
| 场景 | 加载文件 |
|------|---------|
| 长篇迁移映射规则 | `references/structure-mapping-long.md` |
| 短篇迁移映射规则 | `references/structure-mapping-short.md` |
| 角色状态反推规则(长篇) | `references/character-state-reverse.md` |
| 角色状态规则(character-state-reverse.md 依赖) | `references/state-tracking.md` |
| 短篇正文格式规范 | `references/format-and-structure.md` |
> 长篇细纲模板格式参见 story-long-write(Phase 3 细纲部分);短篇核心框架模板参见 story-short-write(核心框架部分)。这两项为纯文本指引,story-import 不加载对应 skill 的文件。
### Phase 4:项目激活
| 场景 | 说明 |
|------|---------|
| 长篇项目结构规范 | 参见 story-long-write(Phase 4 项目文件结构) |
| 短篇项目结构规范 | 参见 story-short-write(Phase 3 项目结构) |
| 环境部署 | 部署模板由 `/story-setup` 提供,story-import 不负责部署 |
---
## 流程衔接
**流水线:** 长篇 / 短篇
**位置:** 导入(在开书之前)
| 时机 | 跳转到 | 命令 |
|---|---|---|
| 导入完想继续写(长篇) | story-long-write | `/story-long-write` + "日更" |
| 导入完想继续写(短篇) | story-short-write | `/story-short-write` |
| 导入完想审查质量 | story-review | `/story-review` |
| 想深入分析对标(长篇) | story-long-analyze | `/story-long-analyze` |
| 想深入分析对标(短篇) | story-short-analyze | `/story-short-analyze` |
| 从零开新书(长篇) | story-long-write | `/story-long-write` + "开书" |
| 从零开新书(短篇) | story-short-write | `/story-short-write` |
| 项目未部署环境 | story-setup | `/story-setup` |
---
## 语言
- 跟随用户的语言回复,用户用什么语言就用什么语言回复
- 中文回复遵循《中文文案排版指北》
Creator's repository · worldwonderer/oh-story-claudecode