jpskill.com
✍️ ライティング コミュニティ

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本体の挙動とは独立した参考情報です。

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
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
🪟 Windows (PowerShell)
$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. 1. 下の青いボタンを押して code-self-describe.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → code-self-describe フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

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 を同期的に更新

参考資料

📜 原文 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` | <职责描述> |

源文件头部注释格式

多语言示例见 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

参考资料