@donkeylabs/cli 0.4.7 → 0.5.0

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@donkeylabs/cli",
3
- "version": "0.4.7",
3
+ "version": "0.5.0",
4
4
  "type": "module",
5
5
  "description": "CLI for @donkeylabs/server - project scaffolding and code generation",
6
6
  "main": "./src/index.ts",
@@ -8,19 +8,39 @@ const execAsync = promisify(exec);
8
8
 
9
9
  const serverDir = join(import.meta.dir, "..", "src", "server");
10
10
  let isGenerating = false;
11
- let pendingGenerate = false;
11
+ let lastGenerationTime = 0;
12
+
13
+ // Files/patterns we generate - ignore changes to these
14
+ const IGNORED_PATTERNS = [
15
+ /schema\.ts$/, // Generated schema files
16
+ /\.d\.ts$/, // Type declaration files
17
+ ];
18
+
19
+ // Cooldown period after generation (ms)
20
+ const COOLDOWN_MS = 2000;
21
+ const DEBOUNCE_MS = 500;
12
22
 
13
23
  // Handle signals for clean shutdown (from parent dev.ts)
14
24
  process.on("SIGTERM", () => process.exit(0));
15
25
  process.on("SIGINT", () => process.exit(0));
16
26
 
27
+ function shouldIgnoreFile(filename: string): boolean {
28
+ return IGNORED_PATTERNS.some(pattern => pattern.test(filename));
29
+ }
30
+
17
31
  async function regenerate() {
32
+ // Check cooldown
33
+ const now = Date.now();
34
+ if (now - lastGenerationTime < COOLDOWN_MS) {
35
+ return;
36
+ }
37
+
18
38
  if (isGenerating) {
19
- pendingGenerate = true;
20
39
  return;
21
40
  }
22
41
 
23
42
  isGenerating = true;
43
+ lastGenerationTime = now;
24
44
  console.log("\x1b[36m[watch]\x1b[0m Server files changed, regenerating types...");
25
45
 
26
46
  try {
@@ -30,10 +50,7 @@ async function regenerate() {
30
50
  console.error("\x1b[31m[watch]\x1b[0m Error regenerating types:", e.message);
31
51
  } finally {
32
52
  isGenerating = false;
33
- if (pendingGenerate) {
34
- pendingGenerate = false;
35
- await regenerate();
36
- }
53
+ lastGenerationTime = Date.now(); // Update after generation completes
37
54
  }
38
55
  }
39
56
 
@@ -42,7 +59,7 @@ let debounceTimer: Timer | null = null;
42
59
 
43
60
  function debouncedRegenerate() {
44
61
  if (debounceTimer) clearTimeout(debounceTimer);
45
- debounceTimer = setTimeout(regenerate, 300);
62
+ debounceTimer = setTimeout(regenerate, DEBOUNCE_MS);
46
63
  }
47
64
 
48
65
  // Watch server directory recursively
@@ -50,6 +67,9 @@ watch(serverDir, { recursive: true }, (eventType, filename) => {
50
67
  if (!filename) return;
51
68
  if (!filename.endsWith(".ts")) return;
52
69
 
70
+ // Ignore generated files
71
+ if (shouldIgnoreFile(filename)) return;
72
+
53
73
  debouncedRegenerate();
54
74
  });
55
75