MCP HubMCP Hub
Volver a habilidades

analyze-codebase-for-mcp

pjt222
Actualizado Yesterday
6 vistas
17
2
17
Ver en GitHub
Desarrolloaiapimcp

Acerca de

Esta habilidad analiza cualquier base de código para identificar funciones, APIs y fuentes de datos aptas para exponer como herramientas MCP, generando especificaciones estructuradas de herramientas. Se utiliza al planificar un servidor MCP para un proyecto existente, al auditar una base de código antes de envolverla como una superficie de herramientas de IA, o al comparar las capacidades de la base de código con funciones MCP ya expuestas. La salida proporciona las especificaciones de herramientas necesarias para estructurar un servidor MCP.

Instalación rápida

Claude Code

Recomendado
Principal
npx skills add pjt222/agent-almanac -a claude-code
Comando PluginAlternativo
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativo
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/analyze-codebase-for-mcp

Copia y pega este comando en Claude Code para instalar esta habilidad

Documentación

MCP向けコードベース分析

コードベースをスキャンして、MCPツール公開の候補となる関数、RESTエンドポイント、CLIコマンド、データアクセスパターンを発見し、構造化されたツール仕様書を作成する。

使用タイミング

  • 既存プロジェクトのMCPサーバーを計画しており、何を公開すべきか知る必要がある時
  • AI対応ツールサーフェスとしてラップする前にコードベースを監査する時
  • コードベースの機能とMCP経由で既に公開されている機能を比較する時
  • scaffold-mcp-serverに渡すツール仕様書を生成する時
  • サードパーティライブラリをMCPツールとしてラップする価値があるか評価する時

入力

  • 必須: コードベースのルートディレクトリへのパス
  • 必須: コードベースの対象言語(例: TypeScript、Python、R、Go)
  • 任意: 比較対象の既存MCPサーバーコード(ギャップ分析)
  • 任意: ドメインフォーカス(例: 「データ分析」「ファイル操作」「API統合」)
  • 任意: 推奨ツールの最大数(デフォルト: 20)

手順

ステップ1: コードベース構造をスキャンする

1.1. Globを使用してディレクトリツリーをマッピングし、ソースディレクトリに焦点を当てる:

  • src/**/*.{ts,js,py,R,go,rs} ソースファイル用
  • **/routes/****/api/****/controllers/** エンドポイント定義用
  • **/cli/****/commands/** CLIエントリポイント用
  • **/package.json**/setup.py**/DESCRIPTION 依存関係メタデータ用

1.2. ファイルを役割別に分類する:

  • エントリポイント: メインファイル、ルートハンドラー、CLIコマンド
  • コアロジック: ビジネスロジック関数、アルゴリズム、データトランスフォーマー
  • データアクセス: データベースクエリ、ファイルI/O、APIクライアント
  • ユーティリティ: ヘルパー、フォーマッター、バリデーター

1.3. 総ファイル数、コード行数、エクスポートされたシンボルを数えてプロジェクトの規模を把握する。

期待結果: 役割アノテーション付きの分類されたファイルインベントリ。

失敗時: コードベースが大きすぎる場合(10,000ファイル以上)、ドメインフォーカス入力を使用して特定のディレクトリやモジュールにスキャンを絞る。ソースファイルが見つからない場合、ルートパスと言語パラメータを確認する。

ステップ2: 公開された関数とエンドポイントを特定する

2.1. Grepを使用してエクスポートされた関数とパブリックAPIを見つける:

  • TypeScript/JavaScript: export (async )?functionexport defaultmodule.exports
  • Python: _プレフィックスのない関数、@app.route@router
  • R: NAMESPACEにリストされた関数または#' @export roxygenタグ
  • Go: 大文字で始まる関数名(規約によりエクスポート)

2.2. 各候補関数について以下を抽出する:

  • 名前: 関数名またはエンドポイント名
  • シグネチャ: 型とデフォルト値を含むパラメータ
  • 戻り値型: 関数が生成するもの
  • ドキュメント: docstring、JSDoc、roxygen、godoc
  • 場所: ファイルパスと行番号

2.3. REST APIについては追加で以下を抽出する:

  • HTTPメソッドとルートパターン
  • リクエストボディスキーマ
  • レスポンスの形状
  • 認証要件

2.4. 潜在的な有用性でソートされた候補リストを構築する(パブリック、ドキュメント済み、型付き関数を優先)。

期待結果: 抽出されたメタデータ付きの20-100個の候補関数/エンドポイントのリスト。

失敗時: 候補が少ない場合、パブリックにできる内部関数も含めて検索を広げる。ドキュメントが不足している場合、出力にリスクとしてフラグを立てる。

ステップ3: MCP適合性を評価する

3.1. 各候補について、MCPツール基準に対して評価する:

  • 入力契約の明確さ: パラメータは適切に型付けされドキュメント化されているか? JSON Schemaで記述できるか?
  • 出力の予測可能性: 関数は構造化データ(JSONシリアライズ可能)を返すか? 戻り値の形状は一貫しているか?
  • 副作用: 関数は状態を変更するか(ファイル、データベース、外部サービス)? 副作用は明確にラベル付けが必要。
  • 冪等性: 操作は安全にリトライできるか? 非冪等ツールは明示的な警告が必要。
  • 実行時間: 合理的なタイムアウト内(30秒未満)で完了するか? 長時間実行操作は非同期パターンが必要。
  • エラーハンドリング: 構造化エラーをスローするか、サイレントに失敗するか?

3.2. 各候補を1-5のスケールでスコアリングする:

  • 5: 純粋関数、型付きI/O、ドキュメント済み、高速、副作用なし
  • 4: 適切に型付けされドキュメント済み、軽微な副作用(例: ロギング)
  • 3: 合理的なI/O契約だがラッピングが必要(例: 生オブジェクトを返す)
  • 2: 重大な副作用または不明確な契約、大幅な適応が必要
  • 1: 大規模なリファクタリングなしには不適切

3.3. スコア3以上の候補にフィルタリングする。スコア2の項目はリファクタリングが必要な「将来の候補」としてフラグを立てる。

期待結果: 各候補の適合性根拠付きのスコアリングおよびフィルタリングされた候補リスト。

失敗時: ほとんどの候補が3未満のスコアの場合、MCP公開前にコードベースのリファクタリングが必要な可能性がある。ギャップを文書化し、具体的な改善(型の追加、純粋関数の抽出、副作用のラッピング)を推奨する。

ステップ4: ツール仕様を設計する

4.1. 選択された各候補(スコア >= 3)について、ツール仕様を起草する:

- name: tool_name
  description: >
    One-line description of what the tool does.
  source_function: module.function_name
  source_file: src/path/to/file.ts:42
  parameters:
    param_name:
      type: string | number | boolean | object | array
      description: What this parameter controls
      required: true | false
      default: value_if_optional
  returns:
    type: string | object | array
    description: What the tool returns
  side_effects:
    - description of any side effect
  estimated_latency: fast | medium | slow
  suitability_score: 5

4.2. ツールを論理的なカテゴリにグループ化する(例: 「データクエリ」「ファイル操作」「分析」「設定」)。

4.3. ツール間の依存関係を特定する(例: 「list_datasets」は「query_dataset」の前に呼ぶべき)。

4.4. ラッパーが必要なツールがあるか判断する:

  • 複雑なパラメータオブジェクトをフラットな入力に簡素化する
  • 生の戻り値を構造化テキストまたはJSONに変換する
  • 安全ガードを追加する(例: データベース関数の読み取り専用ラッパー)

期待結果: カテゴリ、依存関係、ラッパーノート付きの完全なYAMLツール仕様。

失敗時: ツール仕様が曖昧な場合、ステップ2に戻ってソースコードからより多くの詳細を抽出する。パラメータ型が推論できない場合、手動レビュー用にフラグを立てる。

ステップ5: ツール仕様書を生成する

5.1. 以下のセクションを含む最終仕様書を作成する:

  • サマリー: コードベースの概要、言語、規模、分析日
  • 推奨ツール: ステップ4のフル仕様、カテゴリ別にグループ化
  • 将来の候補: リファクタリング推奨付きのスコア2項目
  • 除外項目: 除外根拠付きのスコア1項目
  • 依存関係: ツール依存関係グラフ
  • 実装ノート: ラッパー要件、認証ニーズ、トランスポート推奨

5.2. mcp-tool-spec.yml(機械可読)として保存し、オプションでmcp-tool-spec.md(人間可読のサマリー)も保存する。

5.3. 既存のMCPサーバーが提供された場合、ギャップ分析セクションを含める:

  • 仕様にあるが未実装のツール
  • 実装されているが仕様にないツール(古い可能性あり)
  • 仕様のドリフトがあるツール(実装が仕様から乖離)

期待結果: scaffold-mcp-serverで利用可能な完全なツール仕様書。

失敗時: ドキュメントが合理的なサイズを超える場合(200ツール以上)、クロスリファレンス付きのモジュールに分割する。コードベースに適切な候補がない場合、代わりにリファクタリング推奨付きの「準備状況評価」ドキュメントを作成する。

バリデーション

  • 対象コードベースのすべてのソースファイルがスキャンされた
  • 候補関数の名前、シグネチャ、戻り値型が抽出されている
  • 各候補に記述された根拠付きの適合性スコアがある
  • ツール仕様に型付きの完全なパラメータスキーマが含まれている
  • すべてのツールの副作用が明示的に文書化されている
  • 出力ドキュメントが有効なYAMLである(任意のYAMLライブラリでパース可能)
  • ツール名がMCP規約に従っている(snake_case、記述的、一意)
  • カテゴリと依存関係が一貫したツールサーフェスを形成している
  • 既存MCPサーバーが提供された場合、ギャップ分析が含まれている
  • 将来の候補セクションにスコア2項目に必要なリファクタリング手順がリストされている

よくある落とし穴

  • ツールを公開しすぎる: AIアシスタントは10-30の集中したツールで最もよく機能する。深さよりも機能の幅を優先する。すべてのパブリック関数を公開する誘惑に抵抗する。
  • 副作用を無視する: 「読み取りのみ」だがログやキャッシュにも書き込む関数にはまだ副作用がある。Grepでファイル書き込み、ネットワーク呼び出し、データベース変更を注意深く監査する。
  • 型安全性を仮定する: 動的言語(Python、R、JavaScript)には型アノテーションのない関数がある可能性がある。使用パターンとテストから型を推論するが、仕様に不確実性をフラグとして立てる。
  • 認証コンテキストの欠落: 認証されたWebリクエストで動作する関数は、セッションコンテキストなしにMCP経由で呼ばれると失敗する可能性がある。セッションCookie、JWTトークン、環境注入された認証情報などの暗黙的な認証依存をチェックする。
  • ラッパーの過剰設計: 関数がMCP互換にするために50行のラッパーを必要とする場合、良い候補ではない可能性がある。ツールインターフェースに自然にマッピングされる関数を優先する。
  • エラーパスの軽視: MCPツールは構造化エラーを返す必要がある。型なし例外をスローする関数にはエラーハンドリングラッパーが必要。
  • 内部APIと外部APIの混同: 他の内部コードから呼ばれる内部ヘルパー関数はMCP候補として不適切。外部利用向けに設計された関数や明確な境界APIに焦点を当てる。
  • ギャップ分析のスキップ: 既存のMCPサーバーが提供された場合、常に仕様を現在の実装と比較する。ギャップ分析なしでは、作業の重複や古いツールの見落としのリスクがある。

関連スキル

  • scaffold-mcp-server - 出力仕様を使用して動作するMCPサーバーを生成する
  • build-custom-mcp-server - 手動サーバー実装のリファレンス
  • configure-mcp-server - 結果のサーバーをClaude Code/Desktopに接続する
  • troubleshoot-mcp-connection - サーバーデプロイ後の接続性をデバッグする
  • review-software-architecture - ツールサーフェス設計のアーキテクチャレビュー
  • security-audit-codebase - 関数を外部に公開する前のセキュリティ監査

Repositorio GitHub

pjt222/agent-almanac
Ruta: i18n/ja/skills/analyze-codebase-for-mcp
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Habilidades relacionadas

qmd

Desarrollo

qmd es una herramienta CLI de búsqueda e indexación local que permite a los desarrolladores indexar y buscar en archivos locales mediante búsqueda híbrida que combina BM25, embeddings vectoriales y reranking. Es compatible tanto con uso desde la línea de comandos como con modo MCP (Model Context Protocol) para integración con Claude. La herramienta utiliza Ollama para los embeddings y almacena los índices localmente, lo que la hace ideal para buscar documentación o bases de código directamente desde la terminal.

Ver habilidad

subagent-driven-development

Desarrollo

Esta habilidad ejecuta planes de implementación asignando un nuevo subagente para cada tarea independiente, con revisión de código entre tareas. Permite una iteración rápida mientras mantiene controles de calidad a través de este proceso de revisión. Úsala cuando trabajes en tareas mayormente independientes dentro de la misma sesión para garantizar un progreso continuo con verificaciones de calidad integradas.

Ver habilidad

mcporter

Desarrollo

La habilidad mcporter permite a los desarrolladores gestionar y llamar servidores del Protocolo de Contexto de Modelo (MCP) directamente desde Claude. Proporciona comandos para listar servidores disponibles, llamar a sus herramientas con argumentos, y manejar la autenticación y el ciclo de vida del daemon. Utiliza esta habilidad para integrar y probar la funcionalidad de servidores MCP en tu flujo de trabajo de desarrollo.

Ver habilidad

adk-deployment-specialist

Desarrollo

Esta habilidad despliega y orquesta agentes Vertex AI ADK utilizando el protocolo A2A, gestionando el descubrimiento de AgentCard, el envío de tareas y soportando herramientas como el Sandbox de Ejecución de Código y el Banco de Memoria. Permite construir sistemas multiagente con patrones de orquestación secuencial, paralela o en bucle en Python, Java o Go. Úsela cuando se le solicite desplegar agentes ADK u orquestar flujos de trabajo de agentes en Google Cloud.

Ver habilidad