コンテンツにスキップ

contextlint-init Skill

contextlint-initリポジトリへ contextlint を初期セットアップする ための Skill です。AI が「contextlint を設定して」「lint 環境整えて」のような依頼を受け取ったときに自動で起動します。

contextlint には 21 個のルールが 7 カテゴリにまたがって存在します。人間が初見で全部読んで「自分のリポジトリに何を有効化すべきか」を判断するのは負担が大きく、結果として導入を諦めるケースに繋がります。

contextlint-initリポジトリの構造を実際に scan してから構成を提案する ことで、この壁を取り払います。人間が手で 21 個から選ぶのではなく、AI が文書の配置・スタイル・参照パターンを見て、プロジェクトに合うルールセットを推論します。

ユーザーが次のような依頼をしたときに起動します。Skill 名を明示する必要はありません。

  • 「contextlint を設定して」「contextlint 入れて」
  • 「Markdown のリンターを入れたい」「ドキュメントの整合性チェックを導入して」
  • 「lint 環境整えて」「lint setup」

contextlint という名前を出さずに「ドキュメントの整合性チェック」のような文脈だけが渡されても起動します。

Skill は以下の手順を順に実行します。

リポジトリ直下や親ディレクトリに contextlint.config.json がないかを最初に確認します。見つかった場合は、ユーザーに次の選択肢を提示します。

選択肢動作
overwrite一から再生成
add既存設定を保持しつつ、新しいスキャン結果に基づいてルール追加を提案
skip何もしない

既存設定を勝手に上書きしないのは、過去にチューニングされた設定や CI を通っている前提を壊さないためです。

2. パッケージマネージャー検出

Section titled “2. パッケージマネージャー検出”

ロックファイルから優先順位付きで判定します。

ロックファイルマネージャー
bun.lock / bun.lockbbun
pnpm-lock.yamlpnpm
yarn.lockyarn
package-lock.jsonnpm
(なし)npm にフォールバック

docs/ を決め打ちにせず、documentation/specs/adr/decisions/requirements/architecture/notes/ などの典型的な配置を実際に walk して確認します。3 ファイル以上の Markdown が集まっているディレクトリを「doc クラスタ」候補として抽出し、ディレクトリ名がドキュメント文脈とマッチするものを優先します。README.mdCHANGELOG.md などのプロジェクトメタは検出するものの、デフォルトでは lint 対象に含めません。

monorepo の場合は packages/*/docs/ のような配置も検出して、すべて include に含めます。

4. ドキュメント内容のサンプリング

Section titled “4. ドキュメント内容のサンプリング”

検出された各クラスタから 3〜5 ファイルを抜粋して内容を読み、以下のシグナルを探します。コンテキストを浪費しないよう、全ファイル読みはしません。

観察されたパターン提案ルール
[link](file.md#anchor) 形式の相互参照REF-001
ID カラムを持つテーブルTBL-001 + TBL-002
同じ見出しトリプレット(例: ## Context / ## Decision / ## ConsequencesSEC-001
多用されるチェックリストCHK-001
TODOTBD<pending> などの placeholderCTX-001
ファイル間の双方向参照が多いGRP-002

REF-001 と GRP-002 は 常時オン のベースラインとして提案します。リンク切れ検出と循環参照検出はリポジトリの種類を問わず有用なためです。

抽出した構成を contextlint.config.json のドラフトとして提示し、各ルールに「なぜ提案したか」の 1 行根拠を添えます。「ADR ディレクトリで Context/Decision/Consequences の繰り返しを観測したので SEC-001 を提案」のように、観察に基づく具体的な説明を行います。

設定を勝手に書き込むのではなく、必ずユーザーの確認を取ります。AI が観察を間違えていた場合や、ユーザーが特定ルールを意図的に外したい場合に備えるためです。

6. インストールと初回 lint 実行

Section titled “6. インストールと初回 lint 実行”

ユーザーが承認したら、検出済みのパッケージマネージャーで @contextlint/cli を install し、contextlint.config.json を書き込みます。続けて npx contextlint を 1 回走らせて、現状の違反を可視化します。インストールが終わった瞬間に「現状どこに何があるか」が分かる流れにしています。

CI と README は変更がチーム全体に影響するため、それぞれ別個に許可を取って書き込みます。

  • GitHub Actions ワークフロー.github/workflows/contextlint.yml を生成(pull_request トリガー、npx contextlint 実行)
  • README セクション — 「contextlint を使っている」ことを示す短いブロックを追記

それぞれは任意で、確認なしには実行しません。

  • README.md しかないリポジトリ — contextlint の真価は cross-file 整合性にあるため、構造化ドキュメントが揃ってから導入するよう案内します。
  • 複数のロックファイルが共存 — 最終更新が新しい方を採用するか、ユーザーに確認します。
  • 親ディレクトリに既に設定が存在する — monorepo を想定し、上位の設定を尊重して同階層に重複作成しません。
  • GitHub Actions 以外の CI — GitLab CI、CircleCI などでは .github/workflows/ を生成せず、「npx contextlint で同等の検証を任意の CI に組み込める」旨だけを伝えます。