插件依赖解析器Skill plugin-dependency-resolver

该技能用于生成插件依赖解析逻辑,核心是使用拓扑排序算法解决插件间的依赖关系,确保加载顺序正确并检测循环依赖。关键词:插件依赖、拓扑排序、循环依赖检测、架构设计、软件模块化。

架构设计 0 次安装 0 次浏览 更新于 2/23/2026

name: plugin-dependency-resolver description: 生成基于拓扑排序的插件依赖解析逻辑。 allowed-tools: Read, Write, Edit, Bash, Glob, Grep

插件依赖解析器

生成插件依赖解析逻辑。

生成模式

interface PluginNode {
  name: string;
  dependencies: string[];
}

export function resolveDependencies(plugins: PluginNode[]): string[] {
  const graph = new Map<string, string[]>();
  const inDegree = new Map<string, number>();

  for (const plugin of plugins) {
    graph.set(plugin.name, plugin.dependencies);
    inDegree.set(plugin.name, 0);
  }

  for (const [, deps] of graph) {
    for (const dep of deps) {
      inDegree.set(dep, (inDegree.get(dep) || 0) + 1);
    }
  }

  const queue = [...inDegree.entries()].filter(([, d]) => d === 0).map(([n]) => n);
  const result: string[] = [];

  while (queue.length > 0) {
    const node = queue.shift()!;
    result.push(node);
    for (const dep of graph.get(node) || []) {
      inDegree.set(dep, inDegree.get(dep)! - 1);
      if (inDegree.get(dep) === 0) queue.push(dep);
    }
  }

  if (result.length !== plugins.length) {
    throw new Error('检测到循环依赖');
  }

  return result.reverse();
}

目标流程

  • plugin-architecture-implementation