@f-o-t/cli 0.1.0 → 1.0.1

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.
Files changed (3) hide show
  1. package/README.md +8 -7
  2. package/dist/index.js +111 -108
  3. package/package.json +31 -29
package/README.md CHANGED
@@ -7,7 +7,7 @@ CLI tool for managing FOT (Factories of Tomorrow) libraries in monorepo workspac
7
7
  - **Build** - Compile TypeScript libraries with optimized bundling
8
8
  - **Dev Mode** - Watch mode for rapid development with automatic rebuilds
9
9
  - **Test** - Run tests with optional coverage and watch mode
10
- - **Check** - Run all checks (typecheck + test) in one command
10
+ - **Check** - Format and lint code with Biome
11
11
  - **Typecheck** - TypeScript type checking without builds
12
12
  - **Generate** - Generate configuration files from `fot.config.ts`
13
13
  - **Create** - Scaffold new libraries with complete boilerplate
@@ -102,17 +102,18 @@ fot test --coverage
102
102
 
103
103
  ### `fot check`
104
104
 
105
- Run all checks (typecheck + test) in sequence.
105
+ Format and lint code with Biome.
106
106
 
107
107
  ```bash
108
108
  fot check
109
109
  ```
110
110
 
111
111
  **What it does:**
112
- - First runs TypeScript type checking
113
- - Then runs the full test suite
114
- - Exits with error if either check fails
115
- - Perfect for CI/CD pipelines
112
+ - Runs Biome code formatter on all source files
113
+ - Performs linting checks with Biome
114
+ - Ensures code style consistency across the codebase
115
+ - Exits with error if formatting or linting issues are found
116
+ - Perfect for pre-commit hooks and CI/CD pipelines
116
117
 
117
118
  ---
118
119
 
@@ -308,7 +309,7 @@ jobs:
308
309
  ```
309
310
 
310
311
  **Pipeline best practices:**
311
- - Use `fot check` to run both typechecking and tests
312
+ - Use `fot check` to ensure code formatting and linting standards
312
313
  - Run `fot test --coverage` to track code coverage
313
314
  - Build after tests pass with `fot build`
314
315
  - Cache `node_modules` for faster CI runs
package/dist/index.js CHANGED
@@ -1,10 +1,19 @@
1
1
  #!/usr/bin/env bun
2
2
  // @bun
3
+ var __require = import.meta.require;
4
+
5
+ // src/index.ts
6
+ import { Command } from "commander";
7
+ import { readFileSync } from "fs";
8
+ import { join as join5, dirname } from "path";
9
+ import { fileURLToPath } from "url";
3
10
 
4
11
  // src/builder.ts
5
12
  import { join as join2 } from "path";
13
+ import { writeFileSync } from "fs";
6
14
  var {build: bunBuild } = globalThis.Bun;
7
15
  var {$ } = globalThis.Bun;
16
+ import { generateTSConfig } from "@f-o-t/config";
8
17
 
9
18
  // src/config-loader.ts
10
19
  import { existsSync } from "fs";
@@ -38,6 +47,9 @@ async function buildLibrary(options = {}) {
38
47
  const watch = options.watch || false;
39
48
  console.log("Loading fot.config.ts...");
40
49
  const config = await loadFotConfig(cwd);
50
+ const tsconfig = generateTSConfig(config);
51
+ writeFileSync(join2(cwd, "tsconfig.json"), JSON.stringify(tsconfig, null, 2) + `
52
+ `);
41
53
  const entryPoints = [];
42
54
  const mainEntry = join2(cwd, "src", "index.ts");
43
55
  entryPoints.push(mainEntry);
@@ -80,14 +92,70 @@ ${errors}`);
80
92
  if (config.typescript.declaration) {
81
93
  console.log("Generating TypeScript declarations...");
82
94
  try {
83
- await $`cd ${cwd} && bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();
95
+ if (config.typescript.maxMemory) {
96
+ await $`cd ${cwd} && NODE_OPTIONS='--max-old-space-size=${config.typescript.maxMemory}' bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();
97
+ } else {
98
+ await $`cd ${cwd} && bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();
99
+ }
84
100
  console.log("\u2713 TypeScript declarations generated");
85
101
  } catch (error) {
86
102
  throw new Error(`Declaration generation failed: ${error instanceof Error ? error.message : String(error)}`);
87
103
  }
88
104
  }
89
105
  if (watch) {
90
- console.log("Watching for changes...");
106
+ const { watch: fsWatch } = await import("fs");
107
+ const srcDir = join2(cwd, "src");
108
+ const configFile = join2(cwd, "fot.config.ts");
109
+ console.log(`Watching ${srcDir} and fot.config.ts for changes...`);
110
+ let debounceTimer = null;
111
+ let isBuilding = false;
112
+ const watchers = [];
113
+ const handleChange = (filename) => {
114
+ if (!filename)
115
+ return;
116
+ const isTypeScript = filename.endsWith(".ts") || filename.endsWith(".tsx");
117
+ const isConfig = filename === "fot.config.ts";
118
+ if (!isTypeScript && !isConfig)
119
+ return;
120
+ if (debounceTimer)
121
+ clearTimeout(debounceTimer);
122
+ debounceTimer = setTimeout(async () => {
123
+ if (isBuilding) {
124
+ console.log("Build in progress, skipping...");
125
+ return;
126
+ }
127
+ isBuilding = true;
128
+ const timestamp = new Date().toLocaleTimeString();
129
+ console.log(`
130
+ [${timestamp}] File changed: ${filename}`);
131
+ console.log("Rebuilding...");
132
+ try {
133
+ await buildLibrary({ cwd, watch: false });
134
+ console.log("\u2713 Rebuild successful");
135
+ } catch (error) {
136
+ console.error("\u2717 Rebuild failed:", error instanceof Error ? error.message : String(error));
137
+ } finally {
138
+ isBuilding = false;
139
+ }
140
+ }, 300);
141
+ };
142
+ watchers.push(fsWatch(srcDir, { recursive: true }, (_event, filename) => {
143
+ handleChange(filename);
144
+ }));
145
+ watchers.push(fsWatch(configFile, (_event, filename) => {
146
+ handleChange(filename);
147
+ }));
148
+ const cleanup = () => {
149
+ console.log(`
150
+ Stopping watch mode...`);
151
+ watchers.forEach((w) => w.close());
152
+ if (debounceTimer)
153
+ clearTimeout(debounceTimer);
154
+ process.exit(0);
155
+ };
156
+ process.on("SIGINT", cleanup);
157
+ process.on("SIGTERM", cleanup);
158
+ await new Promise(() => {});
91
159
  }
92
160
  }
93
161
 
@@ -149,7 +217,7 @@ var {spawn: spawn3 } = globalThis.Bun;
149
217
  async function typecheckCommand() {
150
218
  console.log("Running TypeScript type checking...");
151
219
  const proc = spawn3({
152
- cmd: ["bunx", "tsc"],
220
+ cmd: ["bunx", "tsc", "--noEmit"],
153
221
  stdio: ["inherit", "inherit", "inherit"]
154
222
  });
155
223
  const exitCode = await proc.exited;
@@ -161,11 +229,11 @@ async function typecheckCommand() {
161
229
  process.exit(exitCode);
162
230
  }
163
231
  // src/commands/generate.ts
164
- import { writeFileSync } from "fs";
232
+ import { writeFileSync as writeFileSync2 } from "fs";
165
233
  import { join as join3 } from "path";
166
234
  import {
167
235
  generatePackageJson,
168
- generateTSConfig,
236
+ generateTSConfig as generateTSConfig2,
169
237
  generateBiomeConfig
170
238
  } from "@f-o-t/config";
171
239
  async function generateConfigFiles(cwd) {
@@ -175,25 +243,25 @@ async function generateConfigFiles(cwd) {
175
243
  const libraryName = cwd.split("/").pop() || "library";
176
244
  const packageJson = generatePackageJson(libraryName, "0.1.0", config);
177
245
  const packageJsonPath = join3(cwd, "package.json");
178
- writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + `
246
+ writeFileSync2(packageJsonPath, JSON.stringify(packageJson, null, 2) + `
179
247
  `);
180
248
  console.log(`\u2713 Generated ${packageJsonPath}`);
181
249
  console.log("Generating tsconfig.json...");
182
- const tsconfig = generateTSConfig(config);
250
+ const tsconfig = generateTSConfig2(config);
183
251
  const tsconfigPath = join3(cwd, "tsconfig.json");
184
- writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2) + `
252
+ writeFileSync2(tsconfigPath, JSON.stringify(tsconfig, null, 2) + `
185
253
  `);
186
254
  console.log(`\u2713 Generated ${tsconfigPath}`);
187
255
  console.log("Generating biome.json...");
188
256
  const biomeConfig = generateBiomeConfig(config);
189
257
  const biomeConfigPath = join3(cwd, "biome.json");
190
- writeFileSync(biomeConfigPath, JSON.stringify(biomeConfig, null, 2) + `
258
+ writeFileSync2(biomeConfigPath, JSON.stringify(biomeConfig, null, 2) + `
191
259
  `);
192
260
  console.log(`\u2713 Generated ${biomeConfigPath}`);
193
261
  console.log("All configuration files generated successfully!");
194
262
  }
195
263
  // src/commands/create.ts
196
- import { existsSync as existsSync2, mkdirSync, writeFileSync as writeFileSync2 } from "fs";
264
+ import { existsSync as existsSync2, mkdirSync, writeFileSync as writeFileSync3 } from "fs";
197
265
  import { join as join4 } from "path";
198
266
  var {spawn: spawn4 } = globalThis.Bun;
199
267
 
@@ -307,16 +375,16 @@ Creating directory structure...`);
307
375
  Generating template files...`);
308
376
  const templates = getLibraryTemplate(name, description);
309
377
  const fotConfigPath = join4(libraryPath, "fot.config.ts");
310
- writeFileSync2(fotConfigPath, templates.fotConfig);
378
+ writeFileSync3(fotConfigPath, templates.fotConfig);
311
379
  console.log(`\u2713 Created ${fotConfigPath}`);
312
380
  const indexTsPath = join4(srcPath, "index.ts");
313
- writeFileSync2(indexTsPath, templates.indexTs);
381
+ writeFileSync3(indexTsPath, templates.indexTs);
314
382
  console.log(`\u2713 Created ${indexTsPath}`);
315
383
  const indexTestTsPath = join4(srcPath, "index.test.ts");
316
- writeFileSync2(indexTestTsPath, templates.indexTestTs);
384
+ writeFileSync3(indexTestTsPath, templates.indexTestTs);
317
385
  console.log(`\u2713 Created ${indexTestTsPath}`);
318
386
  const readmePath = join4(libraryPath, "README.md");
319
- writeFileSync2(readmePath, templates.readme);
387
+ writeFileSync3(readmePath, templates.readme);
320
388
  console.log(`\u2713 Created ${readmePath}`);
321
389
  console.log(`
322
390
  Generating configuration files...`);
@@ -349,98 +417,33 @@ Next steps:`);
349
417
  Happy coding! \uD83D\uDE80`);
350
418
  }
351
419
  // src/index.ts
352
- function printHelp() {
353
- console.log(`
354
- FOT CLI - Build tools for monorepo libraries
355
-
356
- Usage: fot <command> [options]
357
-
358
- Commands:
359
- build Build the current library
360
- dev Start development mode with watch
361
- test Run tests
362
- --watch Run tests in watch mode
363
- --coverage Run tests with coverage
364
- check Run all checks (typecheck + test)
365
- typecheck Run TypeScript type checking
366
- generate Generate configuration files
367
- create <name> Create a new library
368
- [description] Optional description for the library
369
- help, --help, -h Show this help message
370
- version, --version, -v Show version number
371
-
372
- Examples:
373
- fot build
374
- fot dev
375
- fot test --coverage
376
- fot test --watch
377
- fot create my-lib "A new library"
378
- fot generate
379
- fot check
380
- `);
381
- }
382
- async function main() {
383
- const args = process.argv.slice(2);
384
- const command = args[0];
385
- try {
386
- switch (command) {
387
- case "build":
388
- await buildCommand();
389
- break;
390
- case "dev":
391
- await devCommand();
392
- break;
393
- case "test": {
394
- const options = {
395
- coverage: args.includes("--coverage"),
396
- watch: args.includes("--watch")
397
- };
398
- await testCommand(options);
399
- break;
400
- }
401
- case "check":
402
- await checkCommand();
403
- break;
404
- case "typecheck":
405
- await typecheckCommand();
406
- break;
407
- case "generate":
408
- await generateConfigFiles(process.cwd());
409
- break;
410
- case "create": {
411
- const name = args[1];
412
- const description = args[2] || `A new FOT library: ${name}`;
413
- const options = {
414
- name,
415
- description
416
- };
417
- await createCommand(options);
418
- break;
419
- }
420
- case "help":
421
- case "--help":
422
- case "-h":
423
- printHelp();
424
- break;
425
- case "version":
426
- case "--version":
427
- case "-v":
428
- console.log("fot v0.1.0");
429
- break;
430
- case undefined:
431
- printHelp();
432
- break;
433
- default:
434
- console.error(`Unknown command: ${command}`);
435
- console.log('Run "fot --help" for usage information');
436
- process.exit(1);
437
- }
438
- } catch (error) {
439
- console.error("Error:", error instanceof Error ? error.message : error);
440
- process.exit(1);
441
- }
442
- }
443
- main();
420
+ var __dirname2 = dirname(fileURLToPath(import.meta.url));
421
+ var pkg = JSON.parse(readFileSync(join5(__dirname2, "..", "package.json"), "utf-8"));
422
+ var program = new Command;
423
+ program.name("fot").description("Build tools for FOT monorepo libraries").version(pkg.version);
424
+ program.command("build").description("Build the current library").action(async () => {
425
+ await buildCommand();
426
+ });
427
+ program.command("dev").description("Start development mode with file watching").action(async () => {
428
+ await devCommand();
429
+ });
430
+ program.command("test").description("Run tests").option("--watch", "Run tests in watch mode").option("--coverage", "Run tests with coverage").action(async (options) => {
431
+ await testCommand(options);
432
+ });
433
+ program.command("check").description("Format and lint code with Biome").action(async () => {
434
+ await checkCommand();
435
+ });
436
+ program.command("typecheck").description("Run TypeScript type checking").action(async () => {
437
+ await typecheckCommand();
438
+ });
439
+ program.command("generate").description("Generate config files from fot.config.ts").action(async () => {
440
+ await generateConfigFiles(process.cwd());
441
+ });
442
+ program.command("create <name>").description("Scaffold a new library").argument("[description]", "Description for the library", "A new FOT library").action(async (name, description) => {
443
+ const options = { name, description };
444
+ await createCommand(options);
445
+ });
446
+ program.parse();
444
447
  export {
445
448
  loadFotConfig,
446
449
  hasFotConfig,
@@ -449,5 +452,5 @@ export {
449
452
  buildCommand
450
453
  };
451
454
 
452
- //# debugId=3D1BC492518C26A964756E2164756E21
453
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/builder.ts", "src/config-loader.ts", "src/commands/build.ts", "src/commands/dev.ts", "src/commands/test.ts", "src/commands/check.ts", "src/commands/typecheck.ts", "src/commands/generate.ts", "src/commands/create.ts", "src/templates/library.ts", "src/index.ts"],
  "sourcesContent": [
    "import { join } from \"node:path\";\nimport { build as bunBuild } from \"bun\";\nimport { $ } from \"bun\";\nimport type { BuildFormat } from \"@f-o-t/config\";\nimport { loadFotConfig } from \"./config-loader\";\n\n/**\n * Options for building a library\n */\nexport interface BuildOptions {\n  /**\n   * The working directory containing the fot.config.ts file\n   * @default process.cwd()\n   */\n  cwd?: string;\n  /**\n   * Whether to watch for changes and rebuild\n   * @default false\n   */\n  watch?: boolean;\n}\n\n/**\n * Build a library using Bun's bundler\n *\n * @param options - Build options\n * @throws {Error} If the build fails\n */\nexport async function buildLibrary(options: BuildOptions = {}): Promise<void> {\n  const cwd = options.cwd || process.cwd();\n  const watch = options.watch || false;\n\n  console.log(\"Loading fot.config.ts...\");\n  const config = await loadFotConfig(cwd);\n\n  // Collect all entry points (main + plugins)\n  const entryPoints: string[] = [];\n\n  // Main entry point\n  const mainEntry = join(cwd, \"src\", \"index.ts\");\n  entryPoints.push(mainEntry);\n\n  // Plugin entry points\n  for (const plugin of config.plugins) {\n    if (plugin.enabled !== false) {\n      const pluginEntry = join(cwd, \"src\", \"plugins\", plugin.name, \"index.ts\");\n      entryPoints.push(pluginEntry);\n    }\n  }\n\n  console.log(`Building ${entryPoints.length} entry point(s)...`);\n\n  // Iterate over formats and build each\n  for (const format of config.formats) {\n    console.log(`Building ${format} format...`);\n\n    try {\n      const result = await bunBuild({\n        entrypoints: entryPoints,\n        outdir: join(cwd, \"dist\"),\n        target: \"bun\",\n        format: format === \"esm\" ? \"esm\" : \"cjs\",\n        splitting: format === \"esm\",\n        minify: false,\n        sourcemap: \"external\",\n        external: config.external,\n        naming: {\n          entry: \"[dir]/[name].js\",\n          chunk: \"[name]-[hash].js\",\n        },\n      });\n\n      if (!result.success) {\n        const errors = result.logs.map((log) => log.message).join(\"\\n\");\n        throw new Error(`Build failed for ${format} format:\\n${errors}`);\n      }\n\n      console.log(`✓ ${format} format built successfully`);\n    } catch (error) {\n      throw new Error(\n        `Build failed for ${format} format: ${error instanceof Error ? error.message : String(error)}`\n      );\n    }\n  }\n\n  console.log(\"Build completed successfully!\");\n\n  // Generate TypeScript declarations if enabled\n  if (config.typescript.declaration) {\n    console.log(\"Generating TypeScript declarations...\");\n    try {\n      await $`cd ${cwd} && bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();\n      console.log(\"✓ TypeScript declarations generated\");\n    } catch (error) {\n      throw new Error(\n        `Declaration generation failed: ${error instanceof Error ? error.message : String(error)}`\n      );\n    }\n  }\n\n  if (watch) {\n    console.log(\"Watching for changes...\");\n    // TODO: Implement watch mode in future\n  }\n}\n",
    "import { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport type { ResolvedFotConfig } from \"@f-o-t/config\";\n\n/**\n * Checks if a fot.config.ts file exists in the given directory\n *\n * @param cwd - The directory to check\n * @returns True if fot.config.ts exists, false otherwise\n */\nexport function hasFotConfig(cwd: string): boolean {\n  const configPath = join(cwd, \"fot.config.ts\");\n  return existsSync(configPath);\n}\n\n/**\n * Loads and validates a fot.config.ts file from the given directory\n *\n * @param cwd - The directory containing the fot.config.ts file\n * @returns The resolved FOT configuration\n * @throws {Error} If the config file is not found or has no default export\n */\nexport async function loadFotConfig(cwd: string): Promise<ResolvedFotConfig> {\n  const configPath = join(cwd, \"fot.config.ts\");\n\n  if (!existsSync(configPath)) {\n    throw new Error(\n      `fot.config.ts not found in ${cwd}. Please create a fot.config.ts file.`\n    );\n  }\n\n  try {\n    // Dynamic import to load the config file\n    const configModule = await import(configPath);\n\n    if (!configModule.default) {\n      throw new Error(\n        `fot.config.ts in ${cwd} must have a default export. Use 'export default defineFotConfig({ ... })'.`\n      );\n    }\n\n    return configModule.default as ResolvedFotConfig;\n  } catch (error) {\n    // If it's already our custom error, re-throw it\n    if (error instanceof Error && error.message.includes(\"fot.config.ts\")) {\n      throw error;\n    }\n\n    // Otherwise, wrap the error with more context\n    throw new Error(\n      `Failed to load fot.config.ts from ${cwd}: ${error instanceof Error ? error.message : String(error)}`\n    );\n  }\n}\n",
    "import { buildLibrary, type BuildOptions } from \"../builder\";\n\n/**\n * Execute the build command\n *\n * @param options - Build options\n */\nexport async function buildCommand(options: BuildOptions = {}): Promise<void> {\n  try {\n    await buildLibrary(options);\n  } catch (error) {\n    console.error(\n      \"Build failed:\",\n      error instanceof Error ? error.message : String(error)\n    );\n    process.exit(1);\n  }\n}\n",
    "import { buildLibrary } from \"../builder\";\n\n/**\n * Execute the dev command\n * Runs the build in watch mode for development\n */\nexport async function devCommand(): Promise<void> {\n  try {\n    console.log(\"Starting development mode...\");\n    await buildLibrary({ watch: true });\n  } catch (error) {\n    console.error(\n      \"Development mode failed:\",\n      error instanceof Error ? error.message : String(error)\n    );\n    process.exit(1);\n  }\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Options for the test command\n */\nexport interface TestOptions {\n  /**\n   * Whether to generate coverage reports\n   * @default false\n   */\n  coverage?: boolean;\n  /**\n   * Whether to watch for changes and re-run tests\n   * @default false\n   */\n  watch?: boolean;\n}\n\n/**\n * Execute the test command\n *\n * @param options - Test options\n */\nexport async function testCommand(options: TestOptions = {}): Promise<void> {\n  const args = [\"test\"];\n\n  if (options.coverage) {\n    args.push(\"--coverage\");\n  }\n\n  if (options.watch) {\n    args.push(\"--watch\");\n  }\n\n  console.log(`Running: bun ${args.join(\" \")}`);\n\n  const proc = spawn({\n    cmd: [\"bun\", ...args],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n  process.exit(exitCode);\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Execute the check command\n * Runs Biome to check and fix code style issues\n */\nexport async function checkCommand(): Promise<void> {\n  console.log(\"Running Biome check with auto-fix...\");\n\n  const proc = spawn({\n    cmd: [\"bunx\", \"biome\", \"check\", \"--write\", \".\"],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n\n  if (exitCode === 0) {\n    console.log(\"✓ Check completed successfully\");\n  } else {\n    console.error(\"Check failed\");\n  }\n\n  process.exit(exitCode);\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Execute the typecheck command\n * Runs TypeScript compiler to check for type errors\n */\nexport async function typecheckCommand(): Promise<void> {\n  console.log(\"Running TypeScript type checking...\");\n\n  const proc = spawn({\n    cmd: [\"bunx\", \"tsc\"],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n\n  if (exitCode === 0) {\n    console.log(\"✓ Type checking completed successfully\");\n  } else {\n    console.error(\"Type checking failed\");\n  }\n\n  process.exit(exitCode);\n}\n",
    "import { writeFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport {\n  generatePackageJson,\n  generateTSConfig,\n  generateBiomeConfig,\n} from \"@f-o-t/config\";\nimport { loadFotConfig } from \"../config-loader\";\n\n/**\n * Generate configuration files (package.json, tsconfig.json, biome.json) from fot.config.ts\n *\n * @param cwd - The directory containing the fot.config.ts file\n */\nexport async function generateConfigFiles(cwd: string): Promise<void> {\n  console.log(\"Loading fot.config.ts...\");\n  const config = await loadFotConfig(cwd);\n\n  console.log(\"Generating package.json...\");\n  // Extract library name from directory name or use a default\n  const libraryName = cwd.split(\"/\").pop() || \"library\";\n  const packageJson = generatePackageJson(libraryName, \"0.1.0\", config);\n  const packageJsonPath = join(cwd, \"package.json\");\n  writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${packageJsonPath}`);\n\n  console.log(\"Generating tsconfig.json...\");\n  const tsconfig = generateTSConfig(config);\n  const tsconfigPath = join(cwd, \"tsconfig.json\");\n  writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${tsconfigPath}`);\n\n  console.log(\"Generating biome.json...\");\n  const biomeConfig = generateBiomeConfig(config);\n  const biomeConfigPath = join(cwd, \"biome.json\");\n  writeFileSync(biomeConfigPath, JSON.stringify(biomeConfig, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${biomeConfigPath}`);\n\n  console.log(\"All configuration files generated successfully!\");\n}\n",
    "import { existsSync, mkdirSync, writeFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport { spawn } from \"bun\";\nimport { getLibraryTemplate } from \"../templates/library\";\nimport { generateConfigFiles } from \"./generate\";\n\n/**\n * Options for creating a new library\n */\nexport interface CreateOptions {\n  /**\n   * Name of the library (e.g., \"my-library\")\n   */\n  name: string;\n  /**\n   * Brief description of the library\n   */\n  description: string;\n  /**\n   * Working directory (defaults to process.cwd())\n   */\n  cwd?: string;\n}\n\n/**\n * Create a new library with scaffolded files\n *\n * @param options - Create options\n */\nexport async function createCommand(options: CreateOptions): Promise<void> {\n  const { name, description, cwd = process.cwd() } = options;\n\n  console.log(`Creating library: @f-o-t/${name}`);\n  console.log(`Description: ${description}`);\n\n  // Determine library path\n  const libraryPath = join(cwd, \"libraries\", name);\n\n  // Check if library already exists\n  if (existsSync(libraryPath)) {\n    console.error(`Error: Library already exists at ${libraryPath}`);\n    process.exit(1);\n  }\n\n  // Create directory structure\n  console.log(\"\\nCreating directory structure...\");\n  const srcPath = join(libraryPath, \"src\");\n  mkdirSync(srcPath, { recursive: true });\n  console.log(`✓ Created ${srcPath}`);\n\n  // Get templates\n  console.log(\"\\nGenerating template files...\");\n  const templates = getLibraryTemplate(name, description);\n\n  // Write fot.config.ts\n  const fotConfigPath = join(libraryPath, \"fot.config.ts\");\n  writeFileSync(fotConfigPath, templates.fotConfig);\n  console.log(`✓ Created ${fotConfigPath}`);\n\n  // Write src/index.ts\n  const indexTsPath = join(srcPath, \"index.ts\");\n  writeFileSync(indexTsPath, templates.indexTs);\n  console.log(`✓ Created ${indexTsPath}`);\n\n  // Write src/index.test.ts\n  const indexTestTsPath = join(srcPath, \"index.test.ts\");\n  writeFileSync(indexTestTsPath, templates.indexTestTs);\n  console.log(`✓ Created ${indexTestTsPath}`);\n\n  // Write README.md\n  const readmePath = join(libraryPath, \"README.md\");\n  writeFileSync(readmePath, templates.readme);\n  console.log(`✓ Created ${readmePath}`);\n\n  // Generate configuration files\n  console.log(\"\\nGenerating configuration files...\");\n  await generateConfigFiles(libraryPath);\n\n  // Run bun install\n  console.log(\"\\nInstalling dependencies...\");\n  const installProc = spawn({\n    cmd: [\"bun\", \"install\"],\n    cwd: libraryPath,\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await installProc.exited;\n\n  if (exitCode !== 0) {\n    console.error(\"Failed to install dependencies\");\n    process.exit(exitCode);\n  }\n\n  console.log(\"✓ Dependencies installed\");\n\n  // Show next steps\n  console.log(\"\\n\" + \"=\".repeat(60));\n  console.log(\"✓ Library created successfully!\");\n  console.log(\"=\".repeat(60));\n  console.log(\"\\nNext steps:\");\n  console.log(`  1. cd libraries/${name}`);\n  console.log(\"  2. Edit src/index.ts to implement your library\");\n  console.log(\"  3. Add tests in src/index.test.ts\");\n  console.log(\"  4. Run 'bun test' to verify tests pass\");\n  console.log(\"  5. Run 'bun run build' to build the library\");\n  console.log(\"\\nHappy coding! 🚀\");\n}\n",
    "/**\n * Templates for scaffolding new libraries\n */\n\nexport interface LibraryTemplates {\n  fotConfig: string;\n  indexTs: string;\n  indexTestTs: string;\n  readme: string;\n}\n\n/**\n * Get templates for a new library\n *\n * @param name - Library name (e.g., \"my-library\")\n * @param description - Brief description of the library\n * @returns Object containing all template files\n */\nexport function getLibraryTemplate(\n  name: string,\n  description: string\n): LibraryTemplates {\n  const packageName = `@f-o-t/${name}`;\n\n  const fotConfig = `import { defineFotConfig } from \"@f-o-t/config\";\n\nexport default defineFotConfig({\n  formats: [\"esm\", \"cjs\"],\n  external: [],\n  typescript: {\n    declaration: true,\n  },\n});\n`;\n\n  const indexTs = `/**\n * ${packageName}\n * ${description}\n */\n\nexport function hello(): string {\n  return \"Hello from ${packageName}!\";\n}\n`;\n\n  const indexTestTs = `import { describe, expect, test as it } from \"bun:test\";\nimport { hello } from \"./index\";\n\ndescribe(\"${packageName}\", () => {\n  it(\"should export hello function\", () => {\n    expect(hello()).toBe(\"Hello from ${packageName}!\");\n  });\n});\n`;\n\n  const readme = `# ${packageName}\n\n${description}\n\n## Installation\n\n\\`\\`\\`bash\n# bun\nbun add ${packageName}\n\n# npm\nnpm install ${packageName}\n\n# yarn\nyarn add ${packageName}\n\n# pnpm\npnpm add ${packageName}\n\\`\\`\\`\n\n## Quick Start\n\n\\`\\`\\`typescript\nimport { hello } from \"${packageName}\";\n\nconsole.log(hello());\n\\`\\`\\`\n\n## API Reference\n\n### \\`hello()\\`\n\nReturns a greeting string.\n\n\\`\\`\\`typescript\nconst greeting = hello();\nconsole.log(greeting); // \"Hello from ${packageName}!\"\n\\`\\`\\`\n\n## Contributing\n\nContributions are welcome! Please check the repository for guidelines.\n\n## License\n\nMIT License - see [LICENSE](./LICENSE) file for details.\n\n## Links\n\n- [GitHub Repository](https://github.com/F-O-T/libraries)\n- [Issue Tracker](https://github.com/F-O-T/libraries/issues)\n`;\n\n  return {\n    fotConfig,\n    indexTs,\n    indexTestTs,\n    readme,\n  };\n}\n",
    "#!/usr/bin/env bun\n\nimport {\n  buildCommand,\n  devCommand,\n  testCommand,\n  checkCommand,\n  typecheckCommand,\n  generateConfigFiles,\n  createCommand,\n  type TestOptions,\n  type CreateOptions,\n} from \"./commands/index\";\n\n// Export all commands and utilities\nexport { generateConfigFiles } from \"./commands/generate\";\nexport { buildCommand } from \"./commands/build\";\nexport { buildLibrary, type BuildOptions } from \"./builder\";\nexport { loadFotConfig, hasFotConfig } from \"./config-loader\";\n\nfunction printHelp() {\n  console.log(`\nFOT CLI - Build tools for monorepo libraries\n\nUsage: fot <command> [options]\n\nCommands:\n  build              Build the current library\n  dev                Start development mode with watch\n  test               Run tests\n    --watch          Run tests in watch mode\n    --coverage       Run tests with coverage\n  check              Run all checks (typecheck + test)\n  typecheck          Run TypeScript type checking\n  generate           Generate configuration files\n  create <name>      Create a new library\n    [description]    Optional description for the library\n  help, --help, -h   Show this help message\n  version, --version, -v  Show version number\n\nExamples:\n  fot build\n  fot dev\n  fot test --coverage\n  fot test --watch\n  fot create my-lib \"A new library\"\n  fot generate\n  fot check\n`);\n}\n\nasync function main() {\n  const args = process.argv.slice(2);\n  const command = args[0];\n\n  try {\n    switch (command) {\n      case \"build\":\n        await buildCommand();\n        break;\n\n      case \"dev\":\n        await devCommand();\n        break;\n\n      case \"test\": {\n        const options: TestOptions = {\n          coverage: args.includes(\"--coverage\"),\n          watch: args.includes(\"--watch\"),\n        };\n        await testCommand(options);\n        break;\n      }\n\n      case \"check\":\n        await checkCommand();\n        break;\n\n      case \"typecheck\":\n        await typecheckCommand();\n        break;\n\n      case \"generate\":\n        await generateConfigFiles(process.cwd());\n        break;\n\n      case \"create\": {\n        const name = args[1];\n        const description = args[2] || `A new FOT library: ${name}`;\n        const options: CreateOptions = {\n          name,\n          description,\n        };\n        await createCommand(options);\n        break;\n      }\n\n      case \"help\":\n      case \"--help\":\n      case \"-h\":\n        printHelp();\n        break;\n\n      case \"version\":\n      case \"--version\":\n      case \"-v\":\n        console.log(\"fot v0.1.0\");\n        break;\n\n      case undefined:\n        printHelp();\n        break;\n\n      default:\n        console.error(`Unknown command: ${command}`);\n        console.log('Run \"fot --help\" for usage information');\n        process.exit(1);\n    }\n  } catch (error) {\n    console.error(\"Error:\", error instanceof Error ? error.message : error);\n    process.exit(1);\n  }\n}\n\nmain();\n"
  ],
  "mappings": "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",
  "debugId": "3D1BC492518C26A964756E2164756E21",
  "names": []
}
455
+ //# debugId=9EBFF578F67EF15964756E2164756E21
456
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/index.ts", "src/builder.ts", "src/config-loader.ts", "src/commands/build.ts", "src/commands/dev.ts", "src/commands/test.ts", "src/commands/check.ts", "src/commands/typecheck.ts", "src/commands/generate.ts", "src/commands/create.ts", "src/templates/library.ts"],
  "sourcesContent": [
    "#!/usr/bin/env bun\n\nimport { Command } from \"commander\";\nimport { readFileSync } from \"node:fs\";\nimport { join, dirname } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport {\n  buildCommand,\n  devCommand,\n  testCommand,\n  checkCommand,\n  typecheckCommand,\n  generateConfigFiles,\n  createCommand,\n  type TestOptions,\n  type CreateOptions,\n} from \"./commands/index\";\n\n// Re-export public API\nexport { generateConfigFiles } from \"./commands/generate\";\nexport { buildCommand } from \"./commands/build\";\nexport { buildLibrary, type BuildOptions } from \"./builder\";\nexport { loadFotConfig, hasFotConfig } from \"./config-loader\";\n\n// Read version from package.json\nconst __dirname = dirname(fileURLToPath(import.meta.url));\nconst pkg = JSON.parse(readFileSync(join(__dirname, \"..\", \"package.json\"), \"utf-8\"));\n\nconst program = new Command();\n\nprogram\n  .name(\"fot\")\n  .description(\"Build tools for FOT monorepo libraries\")\n  .version(pkg.version);\n\nprogram\n  .command(\"build\")\n  .description(\"Build the current library\")\n  .action(async () => {\n    await buildCommand();\n  });\n\nprogram\n  .command(\"dev\")\n  .description(\"Start development mode with file watching\")\n  .action(async () => {\n    await devCommand();\n  });\n\nprogram\n  .command(\"test\")\n  .description(\"Run tests\")\n  .option(\"--watch\", \"Run tests in watch mode\")\n  .option(\"--coverage\", \"Run tests with coverage\")\n  .action(async (options: TestOptions) => {\n    await testCommand(options);\n  });\n\nprogram\n  .command(\"check\")\n  .description(\"Format and lint code with Biome\")\n  .action(async () => {\n    await checkCommand();\n  });\n\nprogram\n  .command(\"typecheck\")\n  .description(\"Run TypeScript type checking\")\n  .action(async () => {\n    await typecheckCommand();\n  });\n\nprogram\n  .command(\"generate\")\n  .description(\"Generate config files from fot.config.ts\")\n  .action(async () => {\n    await generateConfigFiles(process.cwd());\n  });\n\nprogram\n  .command(\"create <name>\")\n  .description(\"Scaffold a new library\")\n  .argument(\"[description]\", \"Description for the library\", \"A new FOT library\")\n  .action(async (name: string, description: string) => {\n    const options: CreateOptions = { name, description };\n    await createCommand(options);\n  });\n\nprogram.parse();\n",
    "import { join } from \"node:path\";\nimport { writeFileSync } from \"node:fs\";\nimport { build as bunBuild } from \"bun\";\nimport { $ } from \"bun\";\nimport type { BuildFormat } from \"@f-o-t/config\";\nimport { generateTSConfig } from \"@f-o-t/config\";\nimport { loadFotConfig } from \"./config-loader\";\n\n/**\n * Options for building a library\n */\nexport interface BuildOptions {\n  /**\n   * The working directory containing the fot.config.ts file\n   * @default process.cwd()\n   */\n  cwd?: string;\n  /**\n   * Whether to watch for changes and rebuild\n   * @default false\n   */\n  watch?: boolean;\n}\n\n/**\n * Build a library using Bun's bundler\n *\n * @param options - Build options\n * @throws {Error} If the build fails\n */\nexport async function buildLibrary(options: BuildOptions = {}): Promise<void> {\n  const cwd = options.cwd || process.cwd();\n  const watch = options.watch || false;\n\n  console.log(\"Loading fot.config.ts...\");\n  const config = await loadFotConfig(cwd);\n\n  // Generate tsconfig.json from config to keep it in sync\n  const tsconfig = generateTSConfig(config);\n  writeFileSync(\n    join(cwd, \"tsconfig.json\"),\n    JSON.stringify(tsconfig, null, 2) + \"\\n\"\n  );\n\n  // Collect all entry points (main + plugins)\n  const entryPoints: string[] = [];\n\n  // Main entry point\n  const mainEntry = join(cwd, \"src\", \"index.ts\");\n  entryPoints.push(mainEntry);\n\n  // Plugin entry points\n  for (const plugin of config.plugins) {\n    if (plugin.enabled !== false) {\n      const pluginEntry = join(cwd, \"src\", \"plugins\", plugin.name, \"index.ts\");\n      entryPoints.push(pluginEntry);\n    }\n  }\n\n  console.log(`Building ${entryPoints.length} entry point(s)...`);\n\n  // Iterate over formats and build each\n  for (const format of config.formats) {\n    console.log(`Building ${format} format...`);\n\n    try {\n      const result = await bunBuild({\n        entrypoints: entryPoints,\n        outdir: join(cwd, \"dist\"),\n        target: \"bun\",\n        format: format === \"esm\" ? \"esm\" : \"cjs\",\n        splitting: format === \"esm\",\n        minify: false,\n        sourcemap: \"external\",\n        external: config.external,\n        naming: {\n          entry: \"[dir]/[name].js\",\n          chunk: \"[name]-[hash].js\",\n        },\n      });\n\n      if (!result.success) {\n        const errors = result.logs.map((log) => log.message).join(\"\\n\");\n        throw new Error(`Build failed for ${format} format:\\n${errors}`);\n      }\n\n      console.log(`✓ ${format} format built successfully`);\n    } catch (error) {\n      throw new Error(\n        `Build failed for ${format} format: ${error instanceof Error ? error.message : String(error)}`\n      );\n    }\n  }\n\n  console.log(\"Build completed successfully!\");\n\n  // Generate TypeScript declarations if enabled\n  if (config.typescript.declaration) {\n    console.log(\"Generating TypeScript declarations...\");\n    try {\n      // Configure Node memory limit if specified in config\n      if (config.typescript.maxMemory) {\n        await $`cd ${cwd} && NODE_OPTIONS='--max-old-space-size=${config.typescript.maxMemory}' bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();\n      } else {\n        await $`cd ${cwd} && bun tsc --emitDeclarationOnly --declaration --declarationMap --outDir dist --noEmit false`.quiet();\n      }\n      console.log(\"✓ TypeScript declarations generated\");\n    } catch (error) {\n      throw new Error(\n        `Declaration generation failed: ${error instanceof Error ? error.message : String(error)}`\n      );\n    }\n  }\n\n  if (watch) {\n    const { watch: fsWatch } = await import(\"node:fs\");\n    const srcDir = join(cwd, \"src\");\n    const configFile = join(cwd, \"fot.config.ts\");\n\n    console.log(`Watching ${srcDir} and fot.config.ts for changes...`);\n\n    let debounceTimer: ReturnType<typeof setTimeout> | null = null;\n    let isBuilding = false;\n    const watchers: ReturnType<typeof fsWatch>[] = [];\n\n    const handleChange = (filename: string | null) => {\n      if (!filename) return;\n      \n      const isTypeScript = filename.endsWith(\".ts\") || filename.endsWith(\".tsx\");\n      const isConfig = filename === \"fot.config.ts\";\n      \n      if (!isTypeScript && !isConfig) return;\n\n      if (debounceTimer) clearTimeout(debounceTimer);\n\n      debounceTimer = setTimeout(async () => {\n        if (isBuilding) {\n          console.log(\"Build in progress, skipping...\");\n          return;\n        }\n        \n        isBuilding = true;\n        const timestamp = new Date().toLocaleTimeString();\n        \n        console.log(`\\n[${timestamp}] File changed: ${filename}`);\n        console.log(\"Rebuilding...\");\n        \n        try {\n          await buildLibrary({ cwd, watch: false });\n          console.log(\"✓ Rebuild successful\");\n        } catch (error) {\n          console.error(\n            \"✗ Rebuild failed:\",\n            error instanceof Error ? error.message : String(error)\n          );\n        } finally {\n          isBuilding = false;\n        }\n      }, 300);\n    };\n\n    // Watch src directory\n    watchers.push(fsWatch(srcDir, { recursive: true }, (_event, filename) => {\n      handleChange(filename);\n    }));\n\n    // Watch config file\n    watchers.push(fsWatch(configFile, (_event, filename) => {\n      handleChange(filename);\n    }));\n\n    // Cleanup on exit\n    const cleanup = () => {\n      console.log(\"\\nStopping watch mode...\");\n      watchers.forEach(w => w.close());\n      if (debounceTimer) clearTimeout(debounceTimer);\n      process.exit(0);\n    };\n\n    process.on(\"SIGINT\", cleanup);\n    process.on(\"SIGTERM\", cleanup);\n\n    // Keep process alive\n    await new Promise(() => {});\n  }\n}\n",
    "import { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport type { ResolvedFotConfig } from \"@f-o-t/config\";\n\n/**\n * Checks if a fot.config.ts file exists in the given directory\n *\n * @param cwd - The directory to check\n * @returns True if fot.config.ts exists, false otherwise\n */\nexport function hasFotConfig(cwd: string): boolean {\n  const configPath = join(cwd, \"fot.config.ts\");\n  return existsSync(configPath);\n}\n\n/**\n * Loads and validates a fot.config.ts file from the given directory\n *\n * @param cwd - The directory containing the fot.config.ts file\n * @returns The resolved FOT configuration\n * @throws {Error} If the config file is not found or has no default export\n */\nexport async function loadFotConfig(cwd: string): Promise<ResolvedFotConfig> {\n  const configPath = join(cwd, \"fot.config.ts\");\n\n  if (!existsSync(configPath)) {\n    throw new Error(\n      `fot.config.ts not found in ${cwd}. Please create a fot.config.ts file.`\n    );\n  }\n\n  try {\n    // Dynamic import to load the config file\n    const configModule = await import(configPath);\n\n    if (!configModule.default) {\n      throw new Error(\n        `fot.config.ts in ${cwd} must have a default export. Use 'export default defineFotConfig({ ... })'.`\n      );\n    }\n\n    return configModule.default as ResolvedFotConfig;\n  } catch (error) {\n    // If it's already our custom error, re-throw it\n    if (error instanceof Error && error.message.includes(\"fot.config.ts\")) {\n      throw error;\n    }\n\n    // Otherwise, wrap the error with more context\n    throw new Error(\n      `Failed to load fot.config.ts from ${cwd}: ${error instanceof Error ? error.message : String(error)}`\n    );\n  }\n}\n",
    "import { buildLibrary, type BuildOptions } from \"../builder\";\n\n/**\n * Execute the build command\n *\n * @param options - Build options\n */\nexport async function buildCommand(options: BuildOptions = {}): Promise<void> {\n  try {\n    await buildLibrary(options);\n  } catch (error) {\n    console.error(\n      \"Build failed:\",\n      error instanceof Error ? error.message : String(error)\n    );\n    process.exit(1);\n  }\n}\n",
    "import { buildLibrary } from \"../builder\";\n\n/**\n * Execute the dev command\n * Runs the build in watch mode for development\n */\nexport async function devCommand(): Promise<void> {\n  try {\n    console.log(\"Starting development mode...\");\n    await buildLibrary({ watch: true });\n  } catch (error) {\n    console.error(\n      \"Development mode failed:\",\n      error instanceof Error ? error.message : String(error)\n    );\n    process.exit(1);\n  }\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Options for the test command\n */\nexport interface TestOptions {\n  /**\n   * Whether to generate coverage reports\n   * @default false\n   */\n  coverage?: boolean;\n  /**\n   * Whether to watch for changes and re-run tests\n   * @default false\n   */\n  watch?: boolean;\n}\n\n/**\n * Execute the test command\n *\n * @param options - Test options\n */\nexport async function testCommand(options: TestOptions = {}): Promise<void> {\n  const args = [\"test\"];\n\n  if (options.coverage) {\n    args.push(\"--coverage\");\n  }\n\n  if (options.watch) {\n    args.push(\"--watch\");\n  }\n\n  console.log(`Running: bun ${args.join(\" \")}`);\n\n  const proc = spawn({\n    cmd: [\"bun\", ...args],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n  process.exit(exitCode);\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Execute the check command\n * Runs Biome to check and fix code style issues\n */\nexport async function checkCommand(): Promise<void> {\n  console.log(\"Running Biome check with auto-fix...\");\n\n  const proc = spawn({\n    cmd: [\"bunx\", \"biome\", \"check\", \"--write\", \".\"],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n\n  if (exitCode === 0) {\n    console.log(\"✓ Check completed successfully\");\n  } else {\n    console.error(\"Check failed\");\n  }\n\n  process.exit(exitCode);\n}\n",
    "import { spawn } from \"bun\";\n\n/**\n * Execute the typecheck command\n * Runs TypeScript compiler to check for type errors\n */\nexport async function typecheckCommand(): Promise<void> {\n  console.log(\"Running TypeScript type checking...\");\n\n  const proc = spawn({\n    cmd: [\"bunx\", \"tsc\", \"--noEmit\"],\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await proc.exited;\n\n  if (exitCode === 0) {\n    console.log(\"✓ Type checking completed successfully\");\n  } else {\n    console.error(\"Type checking failed\");\n  }\n\n  process.exit(exitCode);\n}\n",
    "import { writeFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport {\n  generatePackageJson,\n  generateTSConfig,\n  generateBiomeConfig,\n} from \"@f-o-t/config\";\nimport { loadFotConfig } from \"../config-loader\";\n\n/**\n * Generate configuration files (package.json, tsconfig.json, biome.json) from fot.config.ts\n *\n * @param cwd - The directory containing the fot.config.ts file\n */\nexport async function generateConfigFiles(cwd: string): Promise<void> {\n  console.log(\"Loading fot.config.ts...\");\n  const config = await loadFotConfig(cwd);\n\n  console.log(\"Generating package.json...\");\n  // Extract library name from directory name or use a default\n  const libraryName = cwd.split(\"/\").pop() || \"library\";\n  const packageJson = generatePackageJson(libraryName, \"0.1.0\", config);\n  const packageJsonPath = join(cwd, \"package.json\");\n  writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${packageJsonPath}`);\n\n  console.log(\"Generating tsconfig.json...\");\n  const tsconfig = generateTSConfig(config);\n  const tsconfigPath = join(cwd, \"tsconfig.json\");\n  writeFileSync(tsconfigPath, JSON.stringify(tsconfig, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${tsconfigPath}`);\n\n  console.log(\"Generating biome.json...\");\n  const biomeConfig = generateBiomeConfig(config);\n  const biomeConfigPath = join(cwd, \"biome.json\");\n  writeFileSync(biomeConfigPath, JSON.stringify(biomeConfig, null, 2) + \"\\n\");\n  console.log(`✓ Generated ${biomeConfigPath}`);\n\n  console.log(\"All configuration files generated successfully!\");\n}\n",
    "import { existsSync, mkdirSync, writeFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport { spawn } from \"bun\";\nimport { getLibraryTemplate } from \"../templates/library\";\nimport { generateConfigFiles } from \"./generate\";\n\n/**\n * Options for creating a new library\n */\nexport interface CreateOptions {\n  /**\n   * Name of the library (e.g., \"my-library\")\n   */\n  name: string;\n  /**\n   * Brief description of the library\n   */\n  description: string;\n  /**\n   * Working directory (defaults to process.cwd())\n   */\n  cwd?: string;\n}\n\n/**\n * Create a new library with scaffolded files\n *\n * @param options - Create options\n */\nexport async function createCommand(options: CreateOptions): Promise<void> {\n  const { name, description, cwd = process.cwd() } = options;\n\n  console.log(`Creating library: @f-o-t/${name}`);\n  console.log(`Description: ${description}`);\n\n  // Determine library path\n  const libraryPath = join(cwd, \"libraries\", name);\n\n  // Check if library already exists\n  if (existsSync(libraryPath)) {\n    console.error(`Error: Library already exists at ${libraryPath}`);\n    process.exit(1);\n  }\n\n  // Create directory structure\n  console.log(\"\\nCreating directory structure...\");\n  const srcPath = join(libraryPath, \"src\");\n  mkdirSync(srcPath, { recursive: true });\n  console.log(`✓ Created ${srcPath}`);\n\n  // Get templates\n  console.log(\"\\nGenerating template files...\");\n  const templates = getLibraryTemplate(name, description);\n\n  // Write fot.config.ts\n  const fotConfigPath = join(libraryPath, \"fot.config.ts\");\n  writeFileSync(fotConfigPath, templates.fotConfig);\n  console.log(`✓ Created ${fotConfigPath}`);\n\n  // Write src/index.ts\n  const indexTsPath = join(srcPath, \"index.ts\");\n  writeFileSync(indexTsPath, templates.indexTs);\n  console.log(`✓ Created ${indexTsPath}`);\n\n  // Write src/index.test.ts\n  const indexTestTsPath = join(srcPath, \"index.test.ts\");\n  writeFileSync(indexTestTsPath, templates.indexTestTs);\n  console.log(`✓ Created ${indexTestTsPath}`);\n\n  // Write README.md\n  const readmePath = join(libraryPath, \"README.md\");\n  writeFileSync(readmePath, templates.readme);\n  console.log(`✓ Created ${readmePath}`);\n\n  // Generate configuration files\n  console.log(\"\\nGenerating configuration files...\");\n  await generateConfigFiles(libraryPath);\n\n  // Run bun install\n  console.log(\"\\nInstalling dependencies...\");\n  const installProc = spawn({\n    cmd: [\"bun\", \"install\"],\n    cwd: libraryPath,\n    stdio: [\"inherit\", \"inherit\", \"inherit\"],\n  });\n\n  const exitCode = await installProc.exited;\n\n  if (exitCode !== 0) {\n    console.error(\"Failed to install dependencies\");\n    process.exit(exitCode);\n  }\n\n  console.log(\"✓ Dependencies installed\");\n\n  // Show next steps\n  console.log(\"\\n\" + \"=\".repeat(60));\n  console.log(\"✓ Library created successfully!\");\n  console.log(\"=\".repeat(60));\n  console.log(\"\\nNext steps:\");\n  console.log(`  1. cd libraries/${name}`);\n  console.log(\"  2. Edit src/index.ts to implement your library\");\n  console.log(\"  3. Add tests in src/index.test.ts\");\n  console.log(\"  4. Run 'bun test' to verify tests pass\");\n  console.log(\"  5. Run 'bun run build' to build the library\");\n  console.log(\"\\nHappy coding! 🚀\");\n}\n",
    "/**\n * Templates for scaffolding new libraries\n */\n\nexport interface LibraryTemplates {\n  fotConfig: string;\n  indexTs: string;\n  indexTestTs: string;\n  readme: string;\n}\n\n/**\n * Get templates for a new library\n *\n * @param name - Library name (e.g., \"my-library\")\n * @param description - Brief description of the library\n * @returns Object containing all template files\n */\nexport function getLibraryTemplate(\n  name: string,\n  description: string\n): LibraryTemplates {\n  const packageName = `@f-o-t/${name}`;\n\n  const fotConfig = `import { defineFotConfig } from \"@f-o-t/config\";\n\nexport default defineFotConfig({\n  formats: [\"esm\", \"cjs\"],\n  external: [],\n  typescript: {\n    declaration: true,\n  },\n});\n`;\n\n  const indexTs = `/**\n * ${packageName}\n * ${description}\n */\n\nexport function hello(): string {\n  return \"Hello from ${packageName}!\";\n}\n`;\n\n  const indexTestTs = `import { describe, expect, test as it } from \"bun:test\";\nimport { hello } from \"./index\";\n\ndescribe(\"${packageName}\", () => {\n  it(\"should export hello function\", () => {\n    expect(hello()).toBe(\"Hello from ${packageName}!\");\n  });\n});\n`;\n\n  const readme = `# ${packageName}\n\n${description}\n\n## Installation\n\n\\`\\`\\`bash\n# bun\nbun add ${packageName}\n\n# npm\nnpm install ${packageName}\n\n# yarn\nyarn add ${packageName}\n\n# pnpm\npnpm add ${packageName}\n\\`\\`\\`\n\n## Quick Start\n\n\\`\\`\\`typescript\nimport { hello } from \"${packageName}\";\n\nconsole.log(hello());\n\\`\\`\\`\n\n## API Reference\n\n### \\`hello()\\`\n\nReturns a greeting string.\n\n\\`\\`\\`typescript\nconst greeting = hello();\nconsole.log(greeting); // \"Hello from ${packageName}!\"\n\\`\\`\\`\n\n## Contributing\n\nContributions are welcome! Please check the repository for guidelines.\n\n## License\n\nMIT License - see [LICENSE](./LICENSE) file for details.\n\n## Links\n\n- [GitHub Repository](https://github.com/F-O-T/libraries)\n- [Issue Tracker](https://github.com/F-O-T/libraries/issues)\n`;\n\n  return {\n    fotConfig,\n    indexTs,\n    indexTestTs,\n    readme,\n  };\n}\n"
  ],
  "mappings": "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",
  "debugId": "9EBFF578F67EF15964756E2164756E21",
  "names": []
}
package/package.json CHANGED
@@ -1,31 +1,33 @@
1
1
  {
2
- "name": "@f-o-t/cli",
3
- "version": "0.1.0",
4
- "description": "CLI tool for managing FOT libraries",
5
- "type": "module",
6
- "bin": {
7
- "fot": "./dist/index.js"
8
- },
9
- "main": "./dist/index.js",
10
- "types": "./dist/index.d.ts",
11
- "files": [
12
- "dist"
13
- ],
14
- "scripts": {
15
- "build": "bunup",
16
- "dev": "bunup --watch",
17
- "test": "bun test"
18
- },
19
- "dependencies": {
20
- "@f-o-t/config": "workspace:*",
21
- "commander": "^12.1.0"
22
- },
23
- "devDependencies": {
24
- "@types/bun": "latest",
25
- "bunup": "^0.16.20",
26
- "typescript": "^5.7.3"
27
- },
28
- "peerDependencies": {
29
- "typescript": ">=5.0.0"
30
- }
2
+ "name": "@f-o-t/cli",
3
+ "version": "1.0.1",
4
+ "description": "CLI tool for managing FOT libraries",
5
+ "type": "module",
6
+ "bin": {
7
+ "fot": "./dist/index.js"
8
+ },
9
+ "main": "./dist/index.js",
10
+ "types": "./dist/index.d.ts",
11
+ "files": [
12
+ "dist"
13
+ ],
14
+ "scripts": {
15
+ "build": "bunup",
16
+ "postbuild": "chmod +x dist/index.js",
17
+ "dev": "bunup --watch",
18
+ "test": "bun test",
19
+ "typecheck": "tsc --noEmit"
20
+ },
21
+ "dependencies": {
22
+ "@f-o-t/config": "^1.0.0",
23
+ "commander": "^12.1.0"
24
+ },
25
+ "devDependencies": {
26
+ "@types/bun": "latest",
27
+ "bunup": "^0.16.20",
28
+ "typescript": "^5.7.3"
29
+ },
30
+ "peerDependencies": {
31
+ "typescript": ">=5.0.0"
32
+ }
31
33
  }