DependencyMCP Server

local-only server

The server can only run on the client’s local machine because it depends on local resources.

Integrations

  • Analyzes JavaScript codebases to generate dependency graphs, extract file metadata, and evaluate architectural patterns and dependencies.

  • Analyzes Python codebases to generate dependency graphs, extract file metadata, and evaluate architectural patterns and dependencies.

  • Analyzes TypeScript codebases to generate dependency graphs, extract imports/exports, and evaluate code against architectural rules and patterns.

DependencyMCP サーバー

コードベースを分析し、依存関係グラフとアーキテクチャに関する洞察を生成するモデルコンテキストプロトコル(MCP)サーバー。このサーバーは、複数のプログラミング言語にまたがるコード構造、依存関係、アーキテクチャパターンの理解に役立ちます。

特徴

  • 多言語サポート: TypeScript、JavaScript、C#、Pythonなどの依存関係を分析
  • 依存関係グラフ生成: JSONまたはDOT形式で詳細な依存関係グラフを作成します。
  • アーキテクチャ分析: アーキテクチャのレイヤーを推測し、ルールに基づいて検証します
  • ファイルメタデータ: ソースファイルからインポート、エクスポート、その他のメタデータを抽出します
  • スコアリングシステム: アーキテクチャのルールとパターンに照らしてコードベースを評価する

インストール

  1. リポジトリをクローンする
  2. 依存関係をインストールします:
npm install
  1. プロジェクトをビルドします。
npm run build

構成

MCP 設定ファイル (通常は ~/.config/cline/mcp_settings.json または同等の場所にあります) に以下を追加します。

json { mcpServers: { \DependencyMCP: { \command: \node, \args: [\path/to/dependency-mcp/dist/index.js], \env: { \MAX_LINES_TO_READ: \1000, \CACHE_DIR: \path/to/dependency-mcp/.dependency-cache, \CACHE_TTL: \3600000 } } }

環境変数:

  • MAX_LINES_TO_READ: 各ファイルから読み取る行の最大数(デフォルト: 1000)
  • CACHE_DIR: 依存関係キャッシュファイルを保存するディレクトリ (デフォルト: .dependency-cache)
  • CACHE_TTL: キャッシュの有効期間(ミリ秒)(デフォルト: 1 時間 = 3600000)

利用可能なツール

依存関係を分析する

コードベース内の依存関係を分析し、依存関係グラフを生成します。

const result = await client.callTool("DependencyMCP", "analyze_dependencies", { path: "/path/to/project", excludePatterns: ["node_modules", "dist"], // optional maxDepth: 10, // optional fileTypes: [".ts", ".js", ".cs"] // optional });

依存関係グラフを取得する

コードベースの依存関係グラフを JSON または DOT 形式で取得します。

const result = await client.callTool("DependencyMCP", "get_dependency_graph", { path: "/path/to/project", format: "dot" // or "json" (default) });

get_file_metadata

特定のファイルに関する詳細なメタデータを取得します。

const result = await client.callTool("DependencyMCP", "get_file_metadata", { path: "/path/to/file.ts" });

建築スコアを取得する

アーキテクチャのルールとパターンに照らしてコードベースにスコアを付けます。

const result = await client.callTool("DependencyMCP", "get_architectural_score", { path: "/path/to/project", rules: [ { pattern: "src/domain/**/*", allowed: ["src/domain/**/*"], forbidden: ["src/infrastructure/**/*"] } ] });

出力例

依存関係グラフ (JSON)

{ "src/index.ts": { "path": "src/index.ts", "imports": ["./utils", "./services/parser"], "exports": ["analyze", "generateGraph"], "namespaces": [], "architecturalLayer": "Infrastructure", "dependencies": ["src/utils.ts", "src/services/parser.ts"], "dependents": [] } }

建築スコア

{ "score": 85, "violations": [ "src/domain/user.ts -> src/infrastructure/database.ts violates architectural rules" ], "details": "Score starts at 100 and deducts 5 points per violation" }

発達

サーバーは TypeScript で構築されており、以下を使用します。

  • スキーマ検証のためのZod
  • ファイル比較のためのdiff
  • globパターンマッチングのためのminimatch

プロジェクト構造

dependency-mcp/ ├── src/ │ └── index.mts # Main server implementation ├── package.json ├── tsconfig.json └── README.md

新しい言語のサポートの追加

新しいプログラミング言語のサポートを追加するには:

  1. デフォルトのfileTypes配列にファイル拡張子を追加する
  2. parseFileImportsparseFileExportsで言語固有の正規表現パターンを実装する
  3. 言語固有のアーキテクチャパターンをinferArchitecturalLayerに追加する

ライセンス

マサチューセッツ工科大学

-
security - not tested
F
license - not found
-
quality - not tested

コードベースを分析して、複数のプログラミング言語にわたる依存関係グラフとアーキテクチャの洞察を生成し、開発者がコード構造を理解し、アーキテクチャ ルールに照らして検証できるようにします。

  1. Features
    1. Installation
      1. Configuration
        1. Available Tools
          1. analyze_dependencies
          2. get_dependency_graph
          3. get_file_metadata
          4. get_architectural_score
        2. Example Output
          1. Dependency Graph (JSON)
          2. Architectural Score
        3. Development
          1. Project Structure
          2. Adding Support for New Languages
        4. License
          ID: 4ndnq31gxp