code-self-describe
コードの構造を理解しやすいように、モジュールごとの説明ファイルやソースコードのヘッダーコメントを自動生成・更新し、AIがコードを理解しやすくしたり、コードのナビゲーションを改善したり、ドキュメントを維持したりするのを支援するSkill。
📜 元の英語説明(参考)
Generate and maintain self-describing code structure with module-level CLAUDE.md files and source file header comments (INPUT/OUTPUT/POS). Supports init, update, and audit modes. Use when users want to add AI-friendly code descriptions, improve code navigation, or maintain code documentation. Triggers on keywords like "self-describe", "code description", "CLAUDE.md", "自描述", "代码描述", "模块描述", "生成描述".
🇯🇵 日本人クリエイター向け解説
コードの構造を理解しやすいように、モジュールごとの説明ファイルやソースコードのヘッダーコメントを自動生成・更新し、AIがコードを理解しやすくしたり、コードのナビゲーションを改善したり、ドキュメントを維持したりするのを支援するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o code-self-describe.zip https://jpskill.com/download/8766.zip && unzip -o code-self-describe.zip && rm code-self-describe.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/8766.zip -OutFile "$d\code-self-describe.zip"; Expand-Archive "$d\code-self-describe.zip" -DestinationPath $d -Force; ri "$d\code-self-describe.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
code-self-describe.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
code-self-describeフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
コード自記述
コードリポジトリの自記述構造を生成および維持し、Claude Code の階層的ロードメカニズムを利用して段階的なコンテキスト理解を実現します。
言語規則
- 中国語と英語の質問をサポート
- 中国語での統一された回答
CLAUDE.mdファイルの内容は中国語を使用- ソースファイルのヘッダーコメントは中国語を使用
トリガー条件
- ユーザーはプロジェクトに AI フレンドリーなコード記述を追加する必要がある
- ユーザーはコード変更後に記述を更新する必要がある
- ユーザーは記述の網羅率と正確性を確認する必要がある
- キーワード:「自記述」、「モジュール記述」、「
CLAUDE.md生成」、「self-describe」
核心概念
自分形アーキテクチャ
Claude Code の階層的ロードメカニズム(ファイルを検索すると、そのディレクトリの CLAUDE.md が自動的にロードされる)を利用して、3層の自記述構造を通じて AI のコード理解を向上させます。
プロジェクトルート CLAUDE.md ← グローバルビュー
│
├── src/modules/auth/CLAUDE.md ← モジュールビュー
│ ├── auth.service.ts ← ファイルヘッダー INPUT/OUTPUT/POS
│ ├── auth.guard.ts
│ └── auth.controller.ts
│
└── src/modules/user/CLAUDE.md ← モジュールビュー
├── user.service.ts
└── user.repository.ts
AI が5層目のファイルを検索すると、すでに前の4層の CLAUDE.md が自動的にロードされており、モジュール全体の理解が非常に明確になります。
三層記述体系
| 層級 | 載体 | 内容 |
|---|---|---|
| プロジェクト級 | ルート CLAUDE.md |
モジュールリスト、グローバル制約 |
| モジュール級 | ディレクトリ CLAUDE.md |
地位、ロジック、制約、ビジネスドメインリスト |
| ファイル級 | ソースコードヘッダーコメント | INPUT、OUTPUT、POS |
コード追跡アノテーションとの関係
自記述と DevDocs 追跡アノテーションは異なる次元で機能し、両者は共存し補完し合います。
| 维度 | 自記述 (INPUT/OUTPUT/POS) | 追跡アノテーション (@requirement/@satisfies) |
|---|---|---|
| 目的 | AI がモジュール構造と依存関係を理解するのを助ける | 要件の実現状態を追跡する |
| 粒度 | ファイル級 | メソッド/関数級 |
| 维度 | アーキテクチャ理解(モジュールは何をするか) | 要件追跡(なぜそれをするのか) |
| 更新タイミング | コード構造が変更されたとき | 要件が実現/変更されたとき |
| 位置 | ファイルの先頭 | 特定のクラス/関数/メソッドの上 |
実行モード
/code-self-describe → インテリジェント検出モード
/code-self-describe --init → 初期化:プロジェクトの完全な自記述構造を生成
/code-self-describe --init src/modules/auth → 指定されたモジュールを初期化
/code-self-describe --update → 更新:コード変更に基づいて記述を更新
/code-self-describe --update src/user.ts → 指定されたファイルとそのモジュールを更新
/code-self-describe --audit → 監査:記述の鮮度と正確性を確認
モード比較
| モード | スキャン範囲 | CLAUDE.md 生成 |
ヘッダーコメント更新 | ユーザー確認 |
|---|---|---|---|---|
| init | 全プロジェクト/指定モジュール | ✅ 新規 | ✅ 新規追加 | ✅ モジュールごと |
| update | 変更されたファイル (git diff) |
✅ 既存のものを更新 | ✅ 変更を更新 | 低リスク自動 |
| audit | 全プロジェクト | ❌ レポートのみ | ❌ レポートのみ | ❌ |
インテリジェント検出フロー
プロジェクトにモジュールレベルの CLAUDE.md がすでに存在するかどうかを検出
│
├── 無 → 自動的に init モードに入る
│
└── 有 → コード変更があるかどうかを検出
│
├── 未同期の変更がある → update モードを推奨
└── 変更なし → audit モードを推奨
Init モード
ワークフロー
1. プロジェクト構造をスキャン
├── 言語/フレームワークを識別 (package.json, go.mod, Cargo.toml など)
├── ディレクトリ構造パターンを識別 (src/, lib/, modules/ など)
└── ビジネスモジュールの境界を識別
│
▼
2. プロジェクトルート CLAUDE.md を強化
├── 既存の場合:モジュール記述セクションを追加(既存の内容は上書きしない)
└── 存在しない場合:基本的な CLAUDE.md を生成
│
▼
3. モジュールごとに CLAUDE.md を生成
├── モジュール内のファイルのインポート/エクスポート関係を分析
├── モジュールの役割を識別(サービス層、データ層、インターフェース層など)
├── CLAUDE.md を生成(地位/ロジック/制約/ビジネスドメインリスト)
└── ユーザーが各モジュールの記述を確認
│
▼
4. ファイルごとにヘッダーコメントを生成
├── import/依存関係を分析 → INPUT
├── export/公開インターフェースを分析 → OUTPUT
├── ディレクトリの場所とモジュールの役割に基づいて → POS
└── ファイルのヘッダーコメントを挿入
│
▼
5. 記述リストレポートを生成
モジュールレベルの CLAUDE.md テンプレート
詳細なテンプレートと例は templates/claude-md-template.md を参照してください。
# <モジュール名>
## 地位
<システムにおける役割と位置、1〜2文>
## ロジック
<モジュールは何をするか、コア機能の説明、3〜5文>
## 制約
- <使用ルール>
- <依存関係の制限>
## ビジネスドメインリスト
| ファイル/サブモジュール | 职责 |
|-------------|------|
| `xxx.ts` | <职责描述> |
ソースファイルヘッダーコメント形式
多言語の例は templates/header-comment-examples.md を参照してください。
// INPUT: UserRepository (データアクセス), ValidatorService (検証)
// OUTPUT: createUser(), getUser(), updateUser() (ユーザー CRUD 操作)
// POS: ユーザーモジュールのコアサービス層、ユーザービジネスロジックを処理
コメントはファイルの先頭に配置する必要があり(import ステートメントの前)、AI がファイルのロードをヘッダーから開始するためです。
Update モード
ワークフロー
1. 変更範囲を検出
├── `git diff --name-only`(前回のコミットと比較)
├── またはユーザーが指定したファイル/ディレクトリ
└── 影響を受けるモジュールを識別
│
▼
2. 変更の影響を分析
├── ファイルレベル:INPUT/OUTPUT が変化したかどうか
├── モジュールレベル:モジュールの役割が変化したかどうか
└── モジュール間:モジュール間の依存関係が変化したかどうか
│
▼
3. ソースファイルのヘッダーコメントを更新
├── 変更されたファイルの INPUT/OUTPUT/POS を更新
└── 手動で追加された追加のコメントを保持
│
▼
4. モジュール CLAUDE.md を更新
├── ビジネスドメインリストを更新(ファイルの追加/削除)
├── ロジック記述を更新(モジュールの役割の変化など)
└── 制約を更新(新しい依存関係ルールなど)
│
▼
5. 更新を上位に伝播
├── サブモジュールの変更 → 親モジュールの CLAUDE.md を更新
└── プロジェクトルート CLAUDE.md まで
更新伝播ルール
詳細なルールは templates/update-rules.md を参照してください。
- パブリックインターフェースが変更された場合にのみ上位に伝播(内部リファクタリングはトリガーしない)
- 自動/手動コンテンツを区別するためにマーク(
<!-- auto-generated -->は自動生成された部分をマーク) - 手動で記述された記述は変更しない
Audit モード
監査内容
1. すべての CLAUDE.md とソースファイルのヘッダーコメントをスキャン
2. 実際のコード状態と比較
3. 監査レポートを生成:
├── 記述が欠落しているモジュール/ファイル
├── 古い記述(コードが変更されたが記述が更新されていない)
├── 不正確な記述(INPUT/OUTPUT が実際と一致しない)
└── 記述の網羅率統計
監査レポート形式(ターミナル出力)
📊 コード自記述監査レポート
網羅率:
モジュールレベル CLAUDE.md: 8/12 (67%)
ファイルヘッダーコメント: 45/62 (73%)
⚠️ 記述の欠落:
- src/modules/payment/CLAUDE.md (欠落)
- src/services/cache.ts (ヘッダーコメントなし)
🔄 古い記述:
- src/modules/user/CLAUDE.md (user.service.ts に deleteUser メソッドが追加されました)
- src/auth/auth.guard.ts (INPUT に RoleService 依存関係がありません)
制約
生成制約
- [ ]
CLAUDE.mdファイル名は大文字を使用する必要がある(Claude Code の規約) - [ ] 既存のプロジェクトルート
CLAUDE.mdを上書きしない(追加またはマージ) - [ ] モジュールレベルの
CLAUDE.mdは実際のコード分析に基づいて生成する必要がある - [ ] ヘッダーコメントは実際の
import/export分析に基づいて生成する必要がある - [ ] 空のディレクトリまたは構成ディレクトリに対して
CLAUDE.mdを生成しない - [ ] サードパーティの依存関係ディレクトリに対して記述を生成しない(node_modules, vendor など)
更新制約
- [ ] 実際に変更されたファイルのみを更新する
- [ ] 手動で記述された記述内容は変更しない(マークで区別)
- [ ] 上位への伝播はパブリックインターフェースが変更された場合にのみトリガーされる
- [ ] 更新前に既存の記述を読み取る必要がある
監査制約
- [ ] 監査モードではファイルを変更しない
- [ ] 網羅率統計を生成する必要がある
- [ ] 古い記述の具体的な理由を明記する必要がある
範囲制約
- [ ] 隠しディレクトリを無視する(.git, .vscode, .idea など)
- [ ] ビルド成果物を無視する(dist/, build/, pycache/ など)
- [ ] 依存関係ディレクトリを無視する(node_modules/, vendor/, Pods/ など)
- [ ] テストディレクトリの
CLAUDE.md生成を無視する(テストファイルはヘッダーコメントを生成) - [ ] パラメータでスキャン範囲を指定可能
Skill 連携
| 段階 | 連携 Skill | 説明 |
|---|---|---|
| 開発完了後 | /devdocs-dev-workflow |
呼び出される:チェックステップの完了時に --update をトリガー |
| リファクタリング後 | /refactor |
呼び出される:リファクタリング完了後に記述を更新 |
| プロジェクトコンテキスト | /devdocs-onboard |
相互補完:CLAUDE.md はモジュールレベルのコンテキストを提供する |
| コード追跡 | /devdocs-sync |
相互補完:異なる次元のコードアノテーション |
| ファイル操作 | /git-safety |
連携:モジュールの移動/名前変更時に CLAUDE.md を同期的に更新 |
参考資料
- claude-md-template.md - モジュールレベルの
CLAUDE.mdテンプレート - header-comment-examples.md - 多言語ヘッダーコメントの例
- update-rules.md - 階層更新伝播ルール
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
代码自描述
为代码库生成和维护自描述结构,利用 Claude Code 的层级加载机制实现渐进式上下文理解。
语言规则
- 支持中英文提问
- 统一中文回复
- CLAUDE.md 文件内容使用中文
- 源文件头部注释使用中文
触发条件
- 用户需要为项目添加 AI 友好的代码描述
- 用户需要在代码变更后更新描述
- 用户需要检查描述覆盖率和准确性
- 关键词:"自描述"、"模块描述"、"生成 CLAUDE.md"、"self-describe"
核心概念
自分形架构
利用 Claude Code 的分级加载机制(搜索到文件时自动加载所在目录的 CLAUDE.md),通过三层自描述结构提升 AI 的代码理解:
项目根 CLAUDE.md ← 全局视图
│
├── src/modules/auth/CLAUDE.md ← 模块视图
│ ├── auth.service.ts ← 文件头部 INPUT/OUTPUT/POS
│ ├── auth.guard.ts
│ └── auth.controller.ts
│
└── src/modules/user/CLAUDE.md ← 模块视图
├── user.service.ts
└── user.repository.ts
AI 搜索到第五层文件时,已自动加载前四层 CLAUDE.md,对整个模块的了解无比清晰。
三层描述体系
| 层级 | 载体 | 内容 |
|---|---|---|
| 项目级 | 根 CLAUDE.md | 模块列表、全局约束 |
| 模块级 | 目录 CLAUDE.md | 地位、逻辑、约束、业务域清单 |
| 文件级 | 源码头部注释 | INPUT、OUTPUT、POS |
与代码追溯标注的关系
自描述和 DevDocs 追溯标注服务于不同维度,两者共存互补:
| 维度 | 自描述 (INPUT/OUTPUT/POS) | 追溯标注 (@requirement/@satisfies) |
|---|---|---|
| 目的 | 帮助 AI 理解模块结构和依赖 | 追踪需求实现状态 |
| 粒度 | 文件级 | 方法/函数级 |
| 维度 | 架构理解(模块做什么) | 需求追溯(为什么做) |
| 更新时机 | 代码结构变更时 | 需求实现/变更时 |
| 位置 | 文件最开始 | 具体的类/函数/方法上方 |
运行模式
/code-self-describe → 智能检测模式
/code-self-describe --init → 初始化:为项目生成完整自描述结构
/code-self-describe --init src/modules/auth → 初始化指定模块
/code-self-describe --update → 更新:根据代码变更更新描述
/code-self-describe --update src/user.ts → 更新指定文件及其所在模块
/code-self-describe --audit → 审计:检查描述新鲜度和准确性
模式对比
| 模式 | 扫描范围 | 生成 CLAUDE.md | 更新头部注释 | 用户确认 |
|---|---|---|---|---|
| init | 全项目/指定模块 | ✅ 新建 | ✅ 新增 | ✅ 逐模块 |
| update | 变更文件 (git diff) | ✅ 更新现有 | ✅ 更新变更 | 低风险自动 |
| audit | 全项目 | ❌ 仅报告 | ❌ 仅报告 | ❌ |
智能检测流程
检测项目是否已有模块级 CLAUDE.md
│
├── 无 → 自动进入 init 模式
│
└── 有 → 检测是否有代码变更
│
├── 有未同步变更 → 建议 update 模式
└── 无变更 → 建议 audit 模式
Init 模式
工作流程
1. 扫描项目结构
├── 识别语言/框架(package.json, go.mod, Cargo.toml 等)
├── 识别目录结构模式(src/, lib/, modules/ 等)
└── 识别业务模块边界
│
▼
2. 增强项目根 CLAUDE.md
├── 已存在:追加模块描述章节(不覆盖现有内容)
└── 不存在:生成基础 CLAUDE.md
│
▼
3. 逐模块生成 CLAUDE.md
├── 分析模块内文件的导入/导出关系
├── 识别模块角色(服务层、数据层、接口层等)
├── 生成 CLAUDE.md(地位/逻辑/约束/业务域清单)
└── 用户确认每个模块的描述
│
▼
4. 逐文件生成头部注释
├── 分析 import/依赖关系 → INPUT
├── 分析 export/公开接口 → OUTPUT
├── 根据目录位置和模块角色 → POS
└── 插入文件头部注释
│
▼
5. 生成描述清单报告
模块级 CLAUDE.md 模板
详细模板和示例见 templates/claude-md-template.md
# <模块名>
## 地位
<在系统中的角色和位置,1-2 句话>
## 逻辑
<模块做什么,核心功能描述,3-5 句话>
## 约束
- <使用规则>
- <依赖限制>
## 业务域清单
| 文件/子模块 | 职责 |
|-------------|------|
| `xxx.ts` | <职责描述> |
源文件头部注释格式
// INPUT: UserRepository (数据访问), ValidatorService (校验)
// OUTPUT: createUser(), getUser(), updateUser() (用户 CRUD 操作)
// POS: 用户模块核心服务层,处理用户业务逻辑
注释必须放在文件最开始(在 import 语句之前),因为 AI 加载文件从头部开始。
Update 模式
工作流程
1. 检测变更范围
├── git diff --name-only(对比上次提交)
├── 或用户指定文件/目录
└── 识别受影响的模块
│
▼
2. 分析变更影响
├── 文件级:INPUT/OUTPUT 是否变化
├── 模块级:模块职责是否变化
└── 跨模块:模块间依赖是否变化
│
▼
3. 更新源文件头部注释
├── 更新变更文件的 INPUT/OUTPUT/POS
└── 保留手动添加的额外注释
│
▼
4. 更新模块 CLAUDE.md
├── 更新业务域清单(新增/删除文件)
├── 更新逻辑描述(如模块职责变化)
└── 更新约束(如新增依赖规则)
│
▼
5. 向上传播更新
├── 子模块变更 → 更新父模块 CLAUDE.md
└── 直到项目根 CLAUDE.md 为止
更新传播规则
- 仅在公共接口变化时向上传播(内部重构不触发)
- 标记区分自动/手动内容(
<!-- auto-generated -->标记自动生成部分) - 不修改手动编写的描述
Audit 模式
审计内容
1. 扫描所有 CLAUDE.md 和源文件头部注释
2. 对比实际代码状态
3. 生成审计报告:
├── 缺失描述的模块/文件
├── 过期描述(代码已变更但描述未更新)
├── 不准确描述(INPUT/OUTPUT 与实际不符)
└── 描述覆盖率统计
审计报告格式(终端输出)
📊 代码自描述审计报告
覆盖率:
模块级 CLAUDE.md: 8/12 (67%)
文件头部注释: 45/62 (73%)
⚠️ 缺失描述:
- src/modules/payment/CLAUDE.md (缺失)
- src/services/cache.ts (无头部注释)
🔄 过期描述:
- src/modules/user/CLAUDE.md (user.service.ts 新增了 deleteUser 方法)
- src/auth/auth.guard.ts (INPUT 缺少 RoleService 依赖)
约束
生成约束
- [ ] CLAUDE.md 文件名必须使用大写(Claude Code 约定)
- [ ] 不覆盖已有的项目根 CLAUDE.md(追加或合并)
- [ ] 模块级 CLAUDE.md 必须基于实际代码分析生成
- [ ] 头部注释必须基于实际 import/export 分析
- [ ] 不为空目录或配置目录生成 CLAUDE.md
- [ ] 不为第三方依赖目录生成描述(node_modules, vendor 等)
更新约束
- [ ] 只更新实际发生变化的文件
- [ ] 不修改手动编写的描述内容(通过标记区分)
- [ ] 向上传播仅在公共接口变化时触发
- [ ] 更新前必须读取现有描述
审计约束
- [ ] 审计模式不修改任何文件
- [ ] 必须生成覆盖率统计
- [ ] 必须标注过期描述的具体原因
范围约束
- [ ] 忽略隐藏目录(.git, .vscode, .idea 等)
- [ ] 忽略构建产物(dist/, build/, pycache/ 等)
- [ ] 忽略依赖目录(node_modules/, vendor/, Pods/ 等)
- [ ] 忽略测试目录的 CLAUDE.md 生成(测试文件仍生成头部注释)
- [ ] 可通过参数指定扫描范围
Skill 协作
| 阶段 | 协作 Skill | 说明 |
|---|---|---|
| 开发完成后 | /devdocs-dev-workflow |
被调用:完成检查步骤中触发 --update |
| 重构后 | /refactor |
被调用:重构完成后更新描述 |
| 项目上下文 | /devdocs-onboard |
互补:CLAUDE.md 提供模块级上下文 |
| 代码追溯 | /devdocs-sync |
互补:不同维度的代码标注 |
| 文件操作 | /git-safety |
配合:模块移动/重命名时同步更新 CLAUDE.md |
参考资料
- claude-md-template.md - 模块级 CLAUDE.md 模板
- header-comment-examples.md - 多语言头部注释示例
- update-rules.md - 层级更新传播规则