silgi 0.8.26 → 0.8.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- const version = "0.8.26";
1
+ const version = "0.8.27";
2
2
  const devDependencies = {
3
3
  "@antfu/eslint-config": "^4.2.0",
4
4
  "@fastify/deepmerge": "^2.0.2",
@@ -1054,6 +1054,17 @@ function createDependencyGraph(modules) {
1054
1054
  logger$1.debug(`Module registered: ${key}`);
1055
1055
  }
1056
1056
  });
1057
+ modules.forEach((module) => {
1058
+ const key = module.meta?.configKey;
1059
+ if (!key)
1060
+ return;
1061
+ const beforeDeps = module.meta?.beforeDependencies || [];
1062
+ const afterDeps = module.meta?.afterDependencies || [];
1063
+ const missingDeps = [...beforeDeps, ...afterDeps].filter((dep) => !graph.has(dep));
1064
+ if (missingDeps.length > 0) {
1065
+ logger$1.error(`Module ${key} has missing dependencies: ${missingDeps.join(", ")}`);
1066
+ }
1067
+ });
1057
1068
  modules.forEach((module) => {
1058
1069
  const key = module.meta?.configKey;
1059
1070
  if (!key)
@@ -1063,35 +1074,23 @@ function createDependencyGraph(modules) {
1063
1074
  logger$1.debug(`
1064
1075
  Analyzing dependencies for module ${key}:`);
1065
1076
  beforeDeps.forEach((dep) => {
1066
- if (!graph.has(dep)) {
1067
- logger$1.warn(`Warning: Module ${key} depends on non-existent module ${dep}`);
1068
- return;
1077
+ if (graph.has(dep)) {
1078
+ graph.get(dep)?.add(key);
1079
+ inDegree.set(key, (inDegree.get(key) || 0) + 1);
1080
+ logger$1.debug(` ${key} must run after ${dep}`);
1069
1081
  }
1070
- graph.get(dep)?.add(key);
1071
- inDegree.set(key, (inDegree.get(key) || 0) + 1);
1072
- dependencyRelations.get(key)?.before.push(dep);
1073
- logger$1.debug(` Must run after: ${dep}`);
1074
1082
  });
1075
1083
  afterDeps.forEach((dep) => {
1076
- if (!graph.has(key)) {
1077
- logger$1.warn(`Warning: Module ${dep} depends on non-existent module ${key}`);
1078
- return;
1084
+ if (graph.has(dep)) {
1085
+ graph.get(key)?.add(dep);
1086
+ inDegree.set(dep, (inDegree.get(dep) || 0) + 1);
1087
+ logger$1.debug(` ${key} must run before ${dep}`);
1079
1088
  }
1080
- graph.get(key)?.add(dep);
1081
- inDegree.set(dep, (inDegree.get(dep) || 0) + 1);
1082
- dependencyRelations.get(key)?.after.push(dep);
1083
- logger$1.debug(` Must run before: ${dep}`);
1084
1089
  });
1085
1090
  });
1086
- logger$1.debug("\nDependency Summary:");
1087
- for (const [key, relations] of dependencyRelations.entries()) {
1088
- if (relations.before.length || relations.after.length) {
1089
- logger$1.debug(`${key}:`);
1090
- if (relations.before.length)
1091
- logger$1.debug(` Must run after: ${relations.before.join(", ")}`);
1092
- if (relations.after.length)
1093
- logger$1.debug(` Must run before: ${relations.after.join(", ")}`);
1094
- }
1091
+ logger$1.debug("\nDependency Graph:");
1092
+ for (const [module, deps] of graph.entries()) {
1093
+ logger$1.debug(`${module} -> ${Array.from(deps).join(", ")} (in-degree: ${inDegree.get(module)})`);
1095
1094
  }
1096
1095
  return { graph, inDegree };
1097
1096
  }
@@ -1,4 +1,4 @@
1
- const version = "0.8.26";
1
+ const version = "0.8.27";
2
2
  const devDependencies = {
3
3
  "@antfu/eslint-config": "^4.2.0",
4
4
  "@fastify/deepmerge": "^2.0.2",
@@ -1,4 +1,4 @@
1
- const version = "0.8.26";
1
+ const version = "0.8.27";
2
2
  const devDependencies = {
3
3
  "@antfu/eslint-config": "^4.2.0",
4
4
  "@fastify/deepmerge": "^2.0.2",
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "silgi",
3
3
  "type": "module",
4
- "version": "0.8.26",
4
+ "version": "0.8.27",
5
5
  "private": false,
6
6
  "sideEffects": false,
7
7
  "exports": {