build-ts 17.1.4 → 17.1.6
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/dist/index.js +2 -2
- package/package.json +2 -2
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import e from"node:fs";import o from"node:path";import{readAndApplyEnvironmentVariables as n,yargsOptionsBuilderForEnv as s,removeNpmAndYarnEnvironmentVariables as t}from"@willbooster/shared-lib-node";import i from"yargs";import{hideBin as r}from"yargs/helpers";import a from"chalk";import c from"date-time";import p from"pretty-ms";import{rollup as l,watch as d}from"rollup";import{onExit as u}from"signal-exit";import m from"node:url";import{babel as f}from"@rollup/plugin-babel";import*as y from"@rollup/plugin-commonjs";import*as h from"@rollup/plugin-json";import*as b from"@rollup/plugin-node-resolve";import*as j from"@rollup/plugin-replace";import*as g from"@rollup/plugin-terser";import*as v from"rollup-plugin-analyzer";import{keepImport as w}from"rollup-plugin-keep-import";import{nodeExternals as x}from"rollup-plugin-node-externals";import S from"rollup-plugin-preserve-directives";import{string as k}from"rollup-plugin-string";import $ from"node:process";import*as T from"node:child_process";import{createRequire as O}from"node:module";let D;function E(e,o){return D||(D=n(e,o),e.verbose&&console.info("Loaded env vars:",Object.keys(D))),D}function _(e,o){const n={},s=new Set([...(e.inline??[]).flatMap(e=>e.toString().split(",")),...e.autoInline?Object.keys(E(e,o)):[]]);for(const e of s)void 0!==process.env[e]&&(n[`process.env.${e}`]=JSON.stringify(process.env[e]));return e.verbose&&console.info("Inline env vars:",Object.keys(n)),n}const N=["app","functions","lib"];async function F(n){const s=o.join(n,"package.json");try{const o=await e.promises.readFile(s,"utf8");return[JSON.parse(o),s]}catch{}return[void 0,s]}const R={...s,silent:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"s"}},B={...R,input:{description:'Paths of source code files to be built. The first file is main. If no option is given, "src/index.{ts,tsx}" from package directory is targeted.',type:"array",alias:"i"},"core-js":{description:"Whether or not core-js is employed.",type:"boolean",default:!1},"core-js-proposals":{description:"Whether or not core-js with proposals support is employed.",type:"boolean",default:!1},minify:{description:"Whether or not minification is enabled.",type:"boolean",default:!0},sourcemap:{description:"Whether or not sourcemap is enabled.",type:"boolean",default:!0},external:{description:"Additional external dependencies.",type:"array"},inline:{description:"Environment variables to be inlined.",type:"array"},"auto-inline":{description:"Inline environment variables defined at env files.",type:"boolean",default:!1},watch:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"w"},keepImport:{description:"Identifiers to be kept as import statements.",type:"array"},bundleBuiltins:{description:"Module names same with builtins (e.g., undici) to be bundled.",type:"array"}},I={...B,moduleType:{description:"esm, cjs, or either (default).",type:"string",alias:"m"}},L={...I,onlyPackageJson:{description:"Whether to generate only package.json.",type:"boolean"}},A={...B,moduleType:{description:"esm, cjs, either, or both (default).",type:"string",alias:"m"},jsExtension:{description:"Whether to use .js in cjs and/or esm: either (default), both, or none.",type:"string",alias:"j"}};function U(n,s,t,i,r,a){const c=[...n.external??[]].map(e=>e.toString());if(t.dependencies?.["@prisma/client"]&&c.push("prisma-client"),c.push(...Object.keys(t.dependencies??{}),...Object.keys(t.peerDependencies??{}),...Object.keys(t.optionalDependencies??{})),e.existsSync(o.join("..","..","package.json"))){const n=e.readdirSync(o.join(".."),{withFileTypes:!0});for(const s of n){if(!s.isDirectory())continue;const n=o.join("..",s.name,"package.json");if(!e.existsSync(n))continue;const i=JSON.parse(e.readFileSync(n,"utf8"));t.dependencies?.[i.name??""]&&c.push(...Object.keys(i.dependencies??{}),...Object.keys(i.peerDependencies??{}),...Object.keys(i.optionalDependencies??{}))}}const p=[".cjs",".mjs",".js",".jsx",".json",".cts",".mts",".ts",".tsx"],l=o.join(m.fileURLToPath(o.dirname(o.dirname(import.meta.url))),"babel.config.mjs"),d=W(j),u=W(h),$=W(b),T=W(y),O=W(g),D=W(v),E=[d({delimiters:["",""],preventAssignment:!0,values:_(n,r)}),u(),x({deps:!0,devDeps:!1,peerDeps:!0,optDeps:!0,include:c.map(e=>new RegExp(`^${e}(?:\\/.+)?`)),exclude:i&&new RegExp(`^@?${i}(?:\\/.+)?`)}),$({extensions:p,preferBuiltins:e=>!n.bundleBuiltins?.includes(e)}),T(),w({moduleNames:n.keepImport?.map(e=>e.toString())??[]})],N="app-node"===s||"functions"===s||!c.includes("@babel/runtime");return process.env.BUILDTS_USE_BABLE_RUNTIME=N?"":"1",E.push(f({configFile:l,extensions:p,babelHelpers:N?"bundled":"runtime",exclude:/^(.+\/)?node_modules\/.+$/}),...a.some(e=>e.preserveModules)?[S()]:[],k({include:["**/*.csv","**/*.txt"]})),n.minify&&E.push(O({compress:{directives:!1}})),E.push(D({summaryOnly:!0})),E}function W(e){return e.default}const J=O(import.meta.url);async function P(n,s){const t=M(s);if(!t)throw new Error(`Failed to find tsconfig.json in ${s}.`);n.verbose&&console.info("Found tsconfig.json:",t);const i=[];let r=o.join("dist",o.basename(s),"src");if(e.existsSync(r)){const n=o.dirname(s),t=await e.promises.readdir(n,{withFileTypes:!0});s=o.resolve(s);for(const r of t){if(!r.isDirectory())continue;const t=o.resolve(n,r.name);if(t===s)continue;const a=M(t),c=o.join("dist",r.name,"src");a&&e.existsSync(c)&&i.push([t,a,c])}}else r="dist";i.push([s,t,r]);let a=!0;for(const[e,t,r]of i)a&&=await C(n,e,t,o.join(s,r));return a}async function C(n,s,t,i){n.verbose&&console.info("runTypeScriptNative()",s,t,i);const r=o.dirname(t),a=o.join(r,`.build-ts-tsgo.${process.pid}.${Date.now()}.json`);try{await e.promises.writeFile(a,JSON.stringify(await async function(n,s,t){const i={declaration:!0,emitDeclarationOnly:!0,module:"NodeNext",moduleResolution:"NodeNext",noEmit:!1,noEmitOnError:!0,outDir:t,rootDir:"src"};if(await H(o.join(n,"src"))){const s=await async function(o){try{return(await e.promises.readdir(o,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>e.name)}catch{return[]}}(o.join(n,"node_modules","@types"));s.includes("node")&&(i.types=s)}return{compilerOptions:i,extends:V(o.dirname(s),s),include:["src/**/*"]}}(s,t,i),void 0,2));const n=T.spawnSync(process.execPath,[G(),"-p",a],{cwd:s,stdio:"inherit"});if(n.error)throw n.error;return 0===n.status}finally{await e.promises.rm(a,{force:!0})}}function M(n){let s=o.resolve(n);for(;;){const n=o.join(s,"tsconfig.json");if(e.existsSync(n))return n;const t=o.dirname(s);if(t===s)return;s=t}}function G(){const e=J.resolve("@typescript/native-preview/package.json");return o.join(o.dirname(e),"bin","tsgo.js")}async function H(n){try{const s=await e.promises.readdir(n,{withFileTypes:!0});for(const t of s){const s=o.join(n,t.name);if(t.isDirectory()){if(await H(s))return!0}else if(/\.[cm]?tsx?$/.test(t.name)&&(await e.promises.readFile(s,"utf8")).includes("node:"))return!0}}catch{return!1}return!1}function V(e,n){const s=o.relative(e,n).replaceAll(o.sep,"/");return s.startsWith(".")?s:`./${s}`}const Y={command:"app [package]",describe:"Build an app",builder:I,handler:async e=>K(e,"app")},z={command:"functions [package]",describe:"Build a GCP/Firebase functions app",builder:L,async handler(e){if(!e.onlyPackageJson)return K(e,"functions");{const n=o.resolve(e.package?.toString()??"."),[s,t]=await F(n);s||(console.error(`Failed to parse package.json (${t}).`),process.exit(1)),await Q(n,s,e.moduleType)}}},q={command:"lib [package]",describe:"Build a Node.js / React library",builder:A,handler:async e=>K(e,"lib")};async function K(n,s){process.env.NODE_ENV||="production";const t=!n.silent&&n.verbose,i=process.cwd(),r=o.resolve(n.package?.toString()??"."),[m,f]=await F(r);m||(console.error(`Failed to parse package.json (${f}).`),process.exit(1)),E(n,r);const y=function(n,s,t){if(n.input&&n.input.length>0)return n.input.map(e=>o.resolve(s,e.toString()));const i=o.join(t,"src");for(const n of["ts","tsx","cts","mts"]){const s=o.join(i,`index.${n}`);if(e.existsSync(s))return[s]}console.error("Failed to detect input file."),process.exit(1)}(n,i,r),h=function(e,o){switch(e){case"app":return"app-node";case"functions":return"functions";case"lib":return o.some(e=>e.endsWith(".tsx"))?"lib-react":"lib";default:console.error("target option must be one of: "+N.join(", ")),process.exit(1)}}(s,y);t&&(console.info("argv:",n),console.info("packageJsonPath:",f),console.info("Target (Category):",`${h} (${s})`));const[b]=function(e){const o=e.name?.toString()??"",n=/@([^/]+)\/(.+)/.exec(o),[,s,t]=n??[];return[s,t]}(m),j="module"===m.type;n["core-js"]?process.env.BUILD_TS_COREJS="1":n["core-js-proposals"]&&(process.env.BUILD_TS_COREJS_WITH_PROPOSALS="1"),t&&(process.env.BUILD_TS_VERBOSE="1"),process.env.BUILD_TS_TARGET_CATEGORY=s,process.env.BUILD_TS_TARGET_DETAIL=h;const g=function(e,n,s,t){const i=o.join(s,"dist");if("app-node"===n||"functions"===n)return[{dir:i,format:X(t,e.moduleType)?"module":"commonjs",sourcemap:e.sourcemap&&"inline"}];const r=[],a=e.moduleType||"both",c=e.jsExtension||"either";("cjs"===a||"both"===a||"either"===a&&!t)&&r.push({dir:i,entryFileNames:"both"===c||"either"===c&&!t?"[name].js":"[name].cjs",format:"commonjs",preserveModules:!0,sourcemap:e.sourcemap});("esm"===a||"both"===a||"either"===a&&t)&&r.push({dir:i,entryFileNames:"both"===c||"either"===c&&t?"[name].js":"[name].mjs",format:"module",preserveModules:!0,sourcemap:e.sourcemap});return r}(n,h,r,j);t&&console.info("OutputOptions:",g),0===g.length&&(console.error("Failed to detect output files."),process.exit(1)),process.chdir(r),await e.promises.rm(o.join(r,"dist"),{recursive:!0,force:!0}),"functions"===h&&await Q(r,m,n.moduleType);const v={input:"functions"===h?Object.fromEntries(y.map((e,n)=>[0===n?"index":o.basename(e,o.extname(e)),e])):y,plugins:U(n,h,m,b,r,g),watch:n.watch?{clearScreen:!1}:void 0},w=e=>(Array.isArray(e)?e:[e]).map(e=>o.relative(r,e));if(n.watch)!function(e,o,n,s,t,i){const r=d({...s,output:t}),l=async e=>{process.removeListener("uncaughtException",l),process.stdin.removeListener("end",l),r&&await r.close(),e&&process.exit(e)};u(l),process.on("uncaughtException",l),process.stdin.isTTY||(process.stdin.on("end",l),process.stdin.resume());r.on("event",async s=>{switch(s.code){case"ERROR":!function(e,o=!1){const n=e.name||e.cause?.name,s=n?`${n}: `:"",t=`${e.plugin?`(plugin ${e.plugin}) `:""}${s}${e.message}`,i=[a.bold(a.red(`[!] ${a.bold(t.toString())}`))];e.url&&i.push(a.cyan(e.url)),e.loc?i.push(`${e.loc.file||e.id} (${e.loc.line}:${e.loc.column})`):e.id&&i.push(e.id),e.frame&&i.push(a.dim(e.frame)),e.stack&&i.push(a.dim(e.stack?.replace(`${s}${e.message}\n`,""))),i.push("",""),console.error(i.join("\n")),o||$.exit(1)}(s.error,!0);break;case"BUNDLE_START":{if(e.silent)break;const o=s.input,t=[];"string"==typeof o?t.push(o):t.push(...Array.isArray(o)?o:Object.values(o)),console.info(a.cyan(`Bundles ${a.bold(i(t).join(", "))} → ${a.bold(i(s.output).join(", "))}\non ${n} ...`));break}case"BUNDLE_END":if(e.silent)break;console.info(a.green(`Created ${a.bold(i(s.output).join(", "))} in ${a.bold(p(s.duration))}`)),"app-node"!==o&&"functions"!==o&&await P(e,n);break;case"END":if(e.silent)break;console.info(`\n[${c()}] waiting for changes...`)}"result"in s&&s.result&&s.result.close()})}(n,h,r,v,g,w);else{let e;n.silent||console.info(a.cyan(`Bundles ${a.bold(w(y).join(", "))} → ${a.bold(w(g.map(e=>e.file||e.dir||"")).join(", "))}\non ${r} ...`));let o=!1;try{const o=Date.now(),s=await l(v);e=s,await Promise.all(g.map(e=>s.write(e))),n.silent||console.info(a.green(`Created ${w(g.map(e=>e.file||e.dir||"")).join(", ")} in ${a.bold(p(Date.now()-o))}`))}catch(e){o=!0,console.error("Failed to build due to:",e)}await(e?.close()),o&&process.exit(1),"app-node"===h||"functions"===h||await P(n,r)||process.exit(1)}}async function Q(n,s,t){s.name+="-dist";const i="module"===s.type,r=X(i,t);s.main=i===r?"index.js":r?"index.mjs":"index.cjs",delete s.scripts,delete s.devDependencies,await e.promises.mkdir(o.join(n,"dist"),{recursive:!0}),await e.promises.writeFile(o.join(n,"dist","package.json"),JSON.stringify(s))}function X(e,o){return"esm"===o||(!o||"either"===o)&&e}const Z={command:"run <file>",describe:"Run script",builder:{...R,module:{description:"A module type: cjs or esm",type:"string",alias:"m"},watch:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"w"}},handler(e){E(e,process.cwd());const o=e.file?.toString()??"",n=process.versions.bun,s=n?"bun":"node",t=n?["--bun"]:["--no-warnings","--import","tsx"];e.watch&&t.push("--watch"),t.push(o);const[,...i]=e._,r=[...t,...i.map(e=>e.toString())];e.verbose&&console.info(`Running '${s} ${r.join(" ")}'`);const a=T.spawnSync(s,r,{stdio:"inherit",env:{...process.env}});process.exit(a.status??1)}};t(process.env),await i(r(process.argv)).scriptName("build-ts").options(R).command(Y).command(z).command(q).command(Z).demandCommand().strict().version(function(){let n=o.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(o.join(n,"package.json"));)n=o.dirname(n);return JSON.parse(e.readFileSync(o.join(n,"package.json"),"utf8")).version}()).help().argv;
|
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../src/env.ts","../src/types.ts","../src/utils.ts","../src/sharedOptionsBuilder.ts","../src/commands/build/builder.ts","../src/commands/build/plugin.ts","../src/commands/build/typeScript.ts","../src/commands/build/build.ts","../src/commands/build/rollupLogger.ts","../src/commands/run.ts","../src/index.ts"],"sourcesContent":["import { readAndApplyEnvironmentVariables } from '@willbooster/shared-lib-node';\n\nimport type { builder } from './commands/build/builder.js';\nimport type { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\nimport type { ArgumentsType } from './types.js';\n\nlet envVars: Record<string, string | undefined> | undefined;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariablesWithCache(\n  argv: ArgumentsType<typeof sharedOptionsBuilder>,\n  cwd: string\n): Record<string, string | undefined> {\n  if (!envVars) {\n    envVars = readAndApplyEnvironmentVariables(argv, cwd);\n    if (argv.verbose) {\n      console.info('Loaded env vars:', Object.keys(envVars));\n    }\n  }\n  return envVars;\n}\n\n/**\n * This function creates a definition of environment variables that will be injected into the build.\n * */\nexport function createEnvironmentVariablesDefinition(\n  argv: ArgumentsType<typeof builder>,\n  cwd: string\n): Record<string, string> {\n  const envVarsDef: Record<string, string> = {};\n  const envVarNames = new Set([\n    ...(argv.inline ?? []).flatMap((e) => e.toString().split(',')),\n    ...(argv.autoInline ? Object.keys(loadEnvironmentVariablesWithCache(argv, cwd)) : []),\n  ]);\n  for (const name of envVarNames) {\n    if (process.env[name] === undefined) continue;\n\n    envVarsDef[`process.env.${name}`] = JSON.stringify(process.env[name]);\n  }\n  if (argv.verbose) {\n    console.info('Inline env vars:', Object.keys(envVarsDef));\n  }\n  return envVarsDef;\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes, Options } from 'yargs';\n\nexport const allTargetCategories = ['app', 'functions', 'lib'] as const;\n\nexport type TargetCategory = (typeof allTargetCategories)[number];\n\nexport const allTargetDetails = ['app-node', 'functions', 'lib', 'lib-react'] as const;\n\nexport type TargetDetail = (typeof allTargetDetails)[number];\n\nexport type ArgumentsType<T extends Record<string, Options>> = ArgumentsCamelCase<InferredOptionTypes<T>>;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport url from 'node:url';\n\nimport type { PackageJson } from 'type-fest';\n\nexport async function readPackageJson(dirPath: string): Promise<[PackageJson | undefined, string]> {\n  const packageJsonPath = path.join(dirPath, 'package.json');\n  try {\n    const packageJsonText = await fs.promises.readFile(packageJsonPath, 'utf8');\n    return [JSON.parse(packageJsonText) as PackageJson, packageJsonPath];\n  } catch {\n    // do nothing\n  }\n  return [undefined, packageJsonPath];\n}\n\nexport function getBuildTsRootPath(): string {\n  return url.fileURLToPath(path.dirname(path.dirname(import.meta.url)));\n}\n\nexport function getNamespaceAndName(packageJson: PackageJson): [string | undefined, string | undefined] {\n  const packageName = packageJson.name?.toString() ?? '';\n  const match = /@([^/]+)\\/(.+)/.exec(packageName);\n  const [, namespace, name] = match ?? [];\n  return [namespace, name];\n}\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  silent: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 's',\n  },\n} as const;\n","import { sharedOptionsBuilder } from '../../sharedOptionsBuilder.js';\n\nexport const builder = {\n  ...sharedOptionsBuilder,\n  input: {\n    description:\n      'Paths of source code files to be built. The first file is main. If no option is given, \"src/index.{ts,tsx}\" from package directory is targeted.',\n    type: 'array',\n    alias: 'i',\n  },\n  'core-js': {\n    description: 'Whether or not core-js is employed.',\n    type: 'boolean',\n    default: false,\n  },\n  'core-js-proposals': {\n    description: 'Whether or not core-js with proposals support is employed.',\n    type: 'boolean',\n    default: false,\n  },\n  minify: {\n    description: 'Whether or not minification is enabled.',\n    type: 'boolean',\n    default: true,\n  },\n  sourcemap: {\n    description: 'Whether or not sourcemap is enabled.',\n    type: 'boolean',\n    default: true,\n  },\n  external: {\n    description: 'Additional external dependencies.',\n    type: 'array',\n  },\n  inline: {\n    description: 'Environment variables to be inlined.',\n    type: 'array',\n  },\n  'auto-inline': {\n    description: 'Inline environment variables defined at env files.',\n    type: 'boolean',\n    default: false,\n  },\n  watch: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 'w',\n  },\n  keepImport: {\n    description: 'Identifiers to be kept as import statements.',\n    type: 'array',\n  },\n  bundleBuiltins: {\n    description: 'Module names same with builtins (e.g., undici) to be bundled.',\n    type: 'array',\n  },\n} as const;\n\nexport const appBuilder = {\n  ...builder,\n  moduleType: {\n    description: 'esm, cjs, or either (default).',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const functionsBuilder = {\n  ...appBuilder,\n  onlyPackageJson: {\n    description: 'Whether to generate only package.json.',\n    type: 'boolean',\n  },\n} as const;\n\nexport const libBuilder = {\n  ...builder,\n  moduleType: {\n    description: 'esm, cjs, either, or both (default).',\n    type: 'string',\n    alias: 'm',\n  },\n  // .js files in a package with `\"type\": \"module\"` are treated as esm.\n  // However, we want to treat them as cjs in the case where a cjs project imports an esm package.\n  // To deal with the case, we use .cjs and .mjs extensions instead of .js extension.\n  jsExtension: {\n    description: 'Whether to use .js in cjs and/or esm: either (default), both, or none.',\n    type: 'string',\n    alias: 'j',\n  },\n} as const;\n\nexport type AnyBuilderType = typeof appBuilder | typeof functionsBuilder | typeof libBuilder;\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { babel } from '@rollup/plugin-babel';\nimport * as commonjs from '@rollup/plugin-commonjs';\nimport * as json from '@rollup/plugin-json';\nimport * as resolve from '@rollup/plugin-node-resolve';\nimport * as replace from '@rollup/plugin-replace';\nimport * as terser from '@rollup/plugin-terser';\nimport type { OutputOptions, Plugin } from 'rollup';\nimport * as analyze from 'rollup-plugin-analyzer';\nimport { keepImport } from 'rollup-plugin-keep-import';\nimport { nodeExternals } from 'rollup-plugin-node-externals';\nimport preserveDirectives from 'rollup-plugin-preserve-directives';\nimport { string } from 'rollup-plugin-string';\nimport type { PackageJson } from 'type-fest';\n\nimport { createEnvironmentVariablesDefinition } from '../../env.js';\nimport type { ArgumentsType, TargetDetail } from '../../types.js';\nimport { getBuildTsRootPath } from '../../utils.js';\n\nimport type { builder } from './builder.js';\n\nexport function setupPlugins(\n  argv: ArgumentsType<typeof builder>,\n  targetDetail: TargetDetail,\n  packageJson: PackageJson,\n  namespace: string | undefined,\n  packageDirPath: string,\n  outputOptionsList: OutputOptions[]\n): Plugin[] {\n  const externalDeps = [...(argv.external ?? [])].map((item) => item.toString());\n  if (packageJson.dependencies?.['@prisma/client']) {\n    externalDeps.push('prisma-client');\n  }\n  // Since `deps: true` does not work for `import chunk from 'lodash.chunk/index.js';`\n  externalDeps.push(\n    ...Object.keys(packageJson.dependencies ?? {}),\n    ...Object.keys(packageJson.peerDependencies ?? {}),\n    ...Object.keys(packageJson.optionalDependencies ?? {})\n  );\n  // Add external dependencies from sibling packages\n  if (fs.existsSync(path.join('..', '..', 'package.json'))) {\n    const packageDirs = fs.readdirSync(path.join('..'), { withFileTypes: true });\n    for (const packageDir of packageDirs) {\n      if (!packageDir.isDirectory()) continue;\n\n      const packageJsonPath = path.join('..', packageDir.name, 'package.json');\n      if (!fs.existsSync(packageJsonPath)) continue;\n\n      const otherPackageJson: PackageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));\n      if (packageJson.dependencies?.[otherPackageJson.name ?? '']) {\n        externalDeps.push(\n          ...Object.keys(otherPackageJson.dependencies ?? {}),\n          ...Object.keys(otherPackageJson.peerDependencies ?? {}),\n          ...Object.keys(otherPackageJson.optionalDependencies ?? {})\n        );\n      }\n    }\n  }\n\n  const extensions = ['.cjs', '.mjs', '.js', '.jsx', '.json', '.cts', '.mts', '.ts', '.tsx'];\n  const babelConfigPath = path.join(getBuildTsRootPath(), 'babel.config.mjs');\n  const replacePlugin = getDefaultPluginFactory(replace);\n  const jsonPlugin = getDefaultPluginFactory(json);\n  const resolvePlugin = getDefaultPluginFactory(resolve);\n  const commonjsPlugin = getDefaultPluginFactory(commonjs);\n  const terserPlugin = getDefaultPluginFactory(terser);\n  const analyzePlugin = getDefaultPluginFactory(analyze);\n  const plugins: Plugin[] = [\n    replacePlugin({\n      // Ignore word boundaries and replace every instance of the string.\n      // cf. https://github.com/rollup/plugins/tree/master/packages/replace#word-boundaries\n      delimiters: ['', ''],\n      preventAssignment: true,\n      values: createEnvironmentVariablesDefinition(argv, packageDirPath),\n    }),\n    jsonPlugin(),\n    nodeExternals({\n      deps: true,\n      devDeps: false,\n      peerDeps: true,\n      optDeps: true,\n      include: externalDeps.map((name) => new RegExp(`^${name}(?:\\\\/.+)?`)),\n      exclude: namespace && new RegExp(`^@?${namespace}(?:\\\\/.+)?`),\n    }),\n    resolvePlugin({\n      extensions,\n      preferBuiltins: (id: string) => !argv.bundleBuiltins?.includes(id),\n    }),\n    commonjsPlugin(),\n    keepImport({ moduleNames: argv.keepImport?.map((item) => item.toString()) ?? [] }),\n  ];\n  const isBabelHelpersBundled =\n    targetDetail === 'app-node' || targetDetail === 'functions' || !externalDeps.includes('@babel/runtime');\n  process.env.BUILDTS_USE_BABLE_RUNTIME = isBabelHelpersBundled ? '' : '1';\n  plugins.push(\n    babel({\n      configFile: babelConfigPath,\n      extensions,\n      // We need `runtime since `bundled` may break directory structure by creating _virtual directory.\n      babelHelpers: isBabelHelpersBundled ? 'bundled' : 'runtime',\n      exclude: /^(.+\\/)?node_modules\\/.+$/,\n    }),\n    ...(outputOptionsList.some((opts) => opts.preserveModules) ? [preserveDirectives()] : []),\n    string({ include: ['**/*.csv', '**/*.txt'] })\n  );\n  if (argv.minify) {\n    plugins.push(terserPlugin({ compress: { directives: false } }));\n  }\n  plugins.push(analyzePlugin({ summaryOnly: true }));\n  return plugins;\n}\n\ntype PluginFactory = (options?: unknown) => Plugin;\n\nfunction getDefaultPluginFactory(module: { default: unknown }): PluginFactory {\n  return module.default as PluginFactory;\n}\n","import * as child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\n\nimport type { ArgumentsType } from '../../types.js';\n\nimport type { AnyBuilderType } from './builder.js';\n\nconst require = createRequire(import.meta.url);\n\nexport async function generateDeclarationFiles(\n  argv: ArgumentsType<AnyBuilderType>,\n  coreProjectDirPath: string\n): Promise<boolean> {\n  const coreConfigFile = findConfigFile(coreProjectDirPath);\n  if (!coreConfigFile) throw new Error(`Failed to find tsconfig.json in ${coreProjectDirPath}.`);\n  if (argv.verbose) {\n    console.info('Found tsconfig.json:', coreConfigFile);\n  }\n\n  const projects: [string, string, string][] = [];\n  let outDir = path.join('dist', path.basename(coreProjectDirPath), 'src');\n  if (fs.existsSync(outDir)) {\n    const parentDirPath = path.dirname(coreProjectDirPath);\n    const dirents = await fs.promises.readdir(parentDirPath, { withFileTypes: true });\n    coreProjectDirPath = path.resolve(coreProjectDirPath);\n    for (const dirent of dirents) {\n      if (!dirent.isDirectory()) continue;\n\n      const projectDirPath = path.resolve(parentDirPath, dirent.name);\n      if (projectDirPath === coreProjectDirPath) continue;\n\n      const configFile = findConfigFile(projectDirPath);\n      const outDir = path.join('dist', dirent.name, 'src');\n      if (configFile && fs.existsSync(outDir)) {\n        projects.push([projectDirPath, configFile, outDir]);\n      }\n    }\n  } else {\n    outDir = 'dist';\n  }\n  projects.push([coreProjectDirPath, coreConfigFile, outDir]);\n\n  let allSucceeded = true;\n  for (const [projectDirPath, configFile, outDir] of projects) {\n    allSucceeded &&= await runTypeScriptNative(argv, projectDirPath, configFile, path.join(coreProjectDirPath, outDir));\n  }\n  return allSucceeded;\n}\n\nasync function runTypeScriptNative(\n  argv: ArgumentsType<AnyBuilderType>,\n  projectDirPath: string,\n  configFile: string,\n  outDir: string\n): Promise<boolean> {\n  if (argv.verbose) {\n    console.info('runTypeScriptNative()', projectDirPath, configFile, outDir);\n  }\n\n  const configFileDirPath = path.dirname(configFile);\n  const tempConfigFile = path.join(configFileDirPath, `.build-ts-tsgo.${process.pid}.${Date.now()}.json`);\n  try {\n    await fs.promises.writeFile(\n      tempConfigFile,\n      JSON.stringify(await createTypeScriptNativeConfig(projectDirPath, configFile, outDir), undefined, 2)\n    );\n    const ret = child_process.spawnSync(process.execPath, [getTypeScriptNativePath(), '-p', tempConfigFile], {\n      cwd: projectDirPath,\n      stdio: 'inherit',\n    });\n    if (ret.error) throw ret.error;\n    return ret.status === 0;\n  } finally {\n    await fs.promises.rm(tempConfigFile, { force: true });\n  }\n}\n\nasync function createTypeScriptNativeConfig(\n  projectDirPath: string,\n  configFile: string,\n  outDir: string\n): Promise<Record<string, unknown>> {\n  const compilerOptions: Record<string, unknown> = {\n    declaration: true,\n    emitDeclarationOnly: true,\n    module: 'NodeNext',\n    moduleResolution: 'NodeNext',\n    noEmit: false,\n    noEmitOnError: true,\n    outDir,\n    rootDir: 'src',\n  };\n  if (await usesNodeProtocolImport(path.join(projectDirPath, 'src'))) {\n    const types = await collectTypePackages(path.join(projectDirPath, 'node_modules', '@types'));\n    if (types.includes('node')) {\n      compilerOptions.types = types;\n    }\n  }\n  return {\n    compilerOptions,\n    extends: toRelativeConfigPath(path.dirname(configFile), configFile),\n    include: ['src/**/*'],\n  };\n}\n\nfunction findConfigFile(dirPath: string): string | undefined {\n  let currentDirPath = path.resolve(dirPath);\n  while (true) {\n    const configFile = path.join(currentDirPath, 'tsconfig.json');\n    if (fs.existsSync(configFile)) return configFile;\n\n    const parentDirPath = path.dirname(currentDirPath);\n    if (parentDirPath === currentDirPath) return undefined;\n    currentDirPath = parentDirPath;\n  }\n}\n\nfunction getTypeScriptNativePath(): string {\n  const packageJsonPath = require.resolve('@typescript/native-preview/package.json');\n  return path.join(path.dirname(packageJsonPath), 'bin', 'tsgo.js');\n}\n\nasync function usesNodeProtocolImport(dirPath: string): Promise<boolean> {\n  try {\n    const dirents = await fs.promises.readdir(dirPath, { withFileTypes: true });\n    for (const dirent of dirents) {\n      const childPath = path.join(dirPath, dirent.name);\n      if (dirent.isDirectory()) {\n        if (await usesNodeProtocolImport(childPath)) return true;\n      } else if (/\\.[cm]?tsx?$/.test(dirent.name) && (await fs.promises.readFile(childPath, 'utf8')).includes('node:')) {\n        return true;\n      }\n    }\n  } catch {\n    return false;\n  }\n  return false;\n}\n\nasync function collectTypePackages(typeRootsDirPath: string): Promise<string[]> {\n  try {\n    const dirents = await fs.promises.readdir(typeRootsDirPath, { withFileTypes: true });\n    return dirents.filter((dirent) => dirent.isDirectory()).map((dirent) => dirent.name);\n  } catch {\n    return [];\n  }\n}\n\nfunction toRelativeConfigPath(fromDirPath: string, toFilePath: string): string {\n  const relativePath = path.relative(fromDirPath, toFilePath).replaceAll(path.sep, '/');\n  return relativePath.startsWith('.') ? relativePath : `./${relativePath}`;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport dateTime from 'date-time';\nimport ms from 'pretty-ms';\nimport type { OutputOptions, RollupBuild, RollupOptions } from 'rollup';\nimport { rollup, watch } from 'rollup';\nimport type { Handler } from 'signal-exit';\nimport { onExit } from 'signal-exit';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule } from 'yargs';\n\nimport { loadEnvironmentVariablesWithCache } from '../../env.js';\nimport type { ArgumentsType, TargetCategory, TargetDetail } from '../../types.js';\nimport { allTargetCategories } from '../../types.js';\nimport { getNamespaceAndName, readPackageJson } from '../../utils.js';\n\nimport type { AnyBuilderType, builder } from './builder.js';\nimport { appBuilder, functionsBuilder, libBuilder } from './builder.js';\nimport { setupPlugins } from './plugin.js';\nimport { handleError } from './rollupLogger.js';\nimport { generateDeclarationFiles } from './typeScript.js';\n\nexport const app: CommandModule<unknown, ArgumentsType<typeof appBuilder>> = {\n  command: 'app [package]',\n  describe: 'Build an app',\n  builder: appBuilder,\n  async handler(argv) {\n    return build(argv, 'app');\n  },\n};\n\nexport const functions: CommandModule<unknown, ArgumentsType<typeof functionsBuilder>> = {\n  command: 'functions [package]',\n  describe: 'Build a GCP/Firebase functions app',\n  builder: functionsBuilder,\n  async handler(argv) {\n    if (argv.onlyPackageJson) {\n      const packageDirPath = path.resolve(argv.package?.toString() ?? '.');\n      const [packageJson, packageJsonPath] = await readPackageJson(packageDirPath);\n      if (!packageJson) {\n        console.error(`Failed to parse package.json (${packageJsonPath}).`);\n        process.exit(1);\n      }\n      await generatePackageJsonForFunctions(packageDirPath, packageJson, argv.moduleType);\n    } else {\n      return build(argv, 'functions');\n    }\n  },\n};\n\nexport const lib: CommandModule<unknown, ArgumentsType<typeof libBuilder>> = {\n  command: 'lib [package]',\n  describe: 'Build a Node.js / React library',\n  builder: libBuilder,\n  async handler(argv) {\n    return build(argv, 'lib');\n  },\n};\n\nexport async function build(argv: ArgumentsType<AnyBuilderType>, targetCategory: TargetCategory): Promise<void> {\n  process.env.NODE_ENV ||= 'production';\n\n  // `silent` is stronger than `verbose`.\n  const verbose = !argv.silent && argv.verbose;\n  const cwd = process.cwd();\n\n  const packageDirPath = path.resolve(argv.package?.toString() ?? '.');\n  const [packageJson, packageJsonPath] = await readPackageJson(packageDirPath);\n  if (!packageJson) {\n    console.error(`Failed to parse package.json (${packageJsonPath}).`);\n    process.exit(1);\n  }\n\n  loadEnvironmentVariablesWithCache(argv, packageDirPath);\n\n  const inputs = verifyInput(argv, cwd, packageDirPath);\n  const targetDetail = detectTargetDetail(targetCategory, inputs);\n\n  if (verbose) {\n    console.info('argv:', argv);\n    console.info('packageJsonPath:', packageJsonPath);\n    console.info('Target (Category):', `${targetDetail} (${targetCategory})`);\n  }\n\n  const [namespace] = getNamespaceAndName(packageJson);\n  const isEsmPackage = packageJson.type === 'module';\n\n  if (argv['core-js']) {\n    process.env.BUILD_TS_COREJS = '1';\n  } else if (argv['core-js-proposals']) {\n    process.env.BUILD_TS_COREJS_WITH_PROPOSALS = '1';\n  }\n\n  if (verbose) {\n    process.env.BUILD_TS_VERBOSE = '1';\n  }\n  process.env.BUILD_TS_TARGET_CATEGORY = targetCategory;\n  process.env.BUILD_TS_TARGET_DETAIL = targetDetail;\n\n  const outputOptionsList = getOutputOptionsList(argv, targetDetail, packageDirPath, isEsmPackage);\n  if (verbose) {\n    console.info('OutputOptions:', outputOptionsList);\n  }\n  if (outputOptionsList.length === 0) {\n    console.error('Failed to detect output files.');\n    process.exit(1);\n  }\n\n  process.chdir(packageDirPath);\n  await fs.promises.rm(path.join(packageDirPath, 'dist'), { recursive: true, force: true });\n  if (targetDetail === 'functions') {\n    await generatePackageJsonForFunctions(packageDirPath, packageJson, argv.moduleType);\n  }\n\n  const options: RollupOptions = {\n    input:\n      targetDetail === 'functions'\n        ? Object.fromEntries(\n            inputs.map((input, index) => [index === 0 ? 'index' : path.basename(input, path.extname(input)), input])\n          )\n        : inputs,\n    plugins: setupPlugins(argv, targetDetail, packageJson, namespace, packageDirPath, outputOptionsList),\n    watch: argv.watch ? { clearScreen: false } : undefined,\n  };\n\n  const pathToRelativePath = (paths: string | Readonly<string[]>): string[] =>\n    (Array.isArray(paths) ? paths : [paths]).map((p) => path.relative(packageDirPath, p));\n  if (argv.watch) {\n    watchRollup(argv, targetDetail, packageDirPath, options, outputOptionsList, pathToRelativePath);\n  } else {\n    if (!argv.silent) {\n      console.info(\n        chalk.cyan(\n          `Bundles ${chalk.bold(pathToRelativePath(inputs).join(', '))} → ${chalk.bold(\n            pathToRelativePath(outputOptionsList.map((opts) => opts.file || opts.dir || '')).join(', ')\n          )}\\non ${packageDirPath} ...`\n        )\n      );\n    }\n\n    let bundle: RollupBuild | undefined;\n    let buildFailed = false;\n    try {\n      const startTime = Date.now();\n      const _bundle = await rollup(options);\n      bundle = _bundle;\n      await Promise.all(outputOptionsList.map((opts) => _bundle.write(opts)));\n\n      if (!argv.silent) {\n        console.info(\n          chalk.green(\n            `Created ${pathToRelativePath(outputOptionsList.map((opts) => opts.file || opts.dir || '')).join(\n              ', '\n            )} in ${chalk.bold(ms(Date.now() - startTime))}`\n          )\n        );\n      }\n    } catch (error) {\n      buildFailed = true;\n      console.error('Failed to build due to:', error);\n    }\n    await bundle?.close();\n    if (buildFailed) process.exit(1);\n\n    if (\n      targetDetail !== 'app-node' &&\n      targetDetail !== 'functions' &&\n      !(await generateDeclarationFiles(argv, packageDirPath))\n    ) {\n      process.exit(1);\n    }\n  }\n}\n\nfunction watchRollup(\n  argv: ArgumentsType<AnyBuilderType>,\n  targetDetail: string,\n  packageDirPath: string,\n  options: RollupOptions,\n  outputOptionsList: OutputOptions[],\n  pathToRelativePath: (paths: string | Readonly<string[]>) => string[]\n): void {\n  const watcher = watch({ ...options, output: outputOptionsList });\n\n  const close = async (code: number | null | undefined): Promise<void> => {\n    process.removeListener('uncaughtException', close);\n    process.stdin.removeListener('end', close);\n    if (watcher) await watcher.close();\n    if (code) process.exit(code);\n  };\n  onExit(close as unknown as Handler);\n  process.on('uncaughtException', close);\n  if (!process.stdin.isTTY) {\n    process.stdin.on('end', close);\n    process.stdin.resume();\n  }\n\n  watcher.on('event', async (event) => {\n    switch (event.code) {\n      case 'ERROR': {\n        handleError(event.error, true);\n        break;\n      }\n      case 'BUNDLE_START': {\n        if (argv.silent) break;\n\n        const eventInput = event.input;\n        const inputFiles: string[] = [];\n        if (typeof eventInput === 'string') {\n          inputFiles.push(eventInput);\n        } else {\n          inputFiles.push(\n            ...(Array.isArray(eventInput) ? eventInput : Object.values(eventInput as Record<string, string>))\n          );\n        }\n        console.info(\n          chalk.cyan(\n            `Bundles ${chalk.bold(pathToRelativePath(inputFiles).join(', '))} → ${chalk.bold(\n              pathToRelativePath(event.output).join(', ')\n            )}\\non ${packageDirPath} ...`\n          )\n        );\n        break;\n      }\n      case 'BUNDLE_END': {\n        if (argv.silent) break;\n\n        console.info(\n          chalk.green(\n            `Created ${chalk.bold(pathToRelativePath(event.output).join(', '))} in ${chalk.bold(ms(event.duration))}`\n          )\n        );\n\n        if (targetDetail !== 'app-node' && targetDetail !== 'functions') {\n          await generateDeclarationFiles(argv, packageDirPath);\n        }\n        break;\n      }\n      case 'END': {\n        if (argv.silent) break;\n\n        console.info(`\\n[${dateTime()}] waiting for changes...`);\n        break;\n      }\n    }\n\n    if ('result' in event && event.result) {\n      void event.result.close();\n    }\n  });\n}\n\nfunction verifyInput(argv: ArgumentsType<typeof builder>, cwd: string, packageDirPath: string): string[] {\n  if (argv.input && argv.input.length > 0) return argv.input.map((p) => path.resolve(cwd, p.toString()));\n\n  const srcDirPath = path.join(packageDirPath, 'src');\n  for (const ext of ['ts', 'tsx', 'cts', 'mts']) {\n    const input = path.join(srcDirPath, `index.${ext}`);\n    if (fs.existsSync(input)) return [input];\n  }\n\n  console.error('Failed to detect input file.');\n  process.exit(1);\n}\n\nfunction detectTargetDetail(targetCategory: string, inputs: string[]): TargetDetail {\n  switch (targetCategory) {\n    case 'app': {\n      return 'app-node';\n    }\n    case 'functions': {\n      return 'functions';\n    }\n    case 'lib': {\n      if (inputs.some((input) => input.endsWith('.tsx'))) {\n        return 'lib-react';\n      }\n      return 'lib';\n    }\n    default: {\n      console.error('target option must be one of: ' + allTargetCategories.join(', '));\n      process.exit(1);\n    }\n  }\n}\n\nasync function generatePackageJsonForFunctions(\n  packageDirPath: string,\n  packageJson: PackageJson,\n  moduleType: string | undefined\n): Promise<void> {\n  packageJson.name += '-dist';\n  const esmPackage = packageJson.type === 'module';\n  const esmOutput = isEsmOutput(esmPackage, moduleType);\n  packageJson.main = esmPackage === esmOutput ? 'index.js' : esmOutput ? 'index.mjs' : 'index.cjs';\n\n  // Prevent Firebase Functions from running `build` script since we are building code before deploying.\n  delete packageJson.scripts;\n  // devDependencies are not required since we are building code before deploying.\n  delete packageJson.devDependencies;\n\n  await fs.promises.mkdir(path.join(packageDirPath, 'dist'), { recursive: true });\n  await fs.promises.writeFile(path.join(packageDirPath, 'dist', 'package.json'), JSON.stringify(packageJson));\n}\n\nfunction getOutputOptionsList(\n  argv: ArgumentsType<AnyBuilderType>,\n  targetDetail: TargetDetail,\n  packageDirPath: string,\n  isEsmPackage: boolean\n): OutputOptions[] {\n  const outDirPath = path.join(packageDirPath, 'dist');\n  if (targetDetail === 'app-node' || targetDetail === 'functions') {\n    return [\n      {\n        dir: outDirPath,\n        format: isEsmOutput(isEsmPackage, argv.moduleType) ? 'module' : 'commonjs',\n        sourcemap: argv.sourcemap && 'inline',\n      },\n    ];\n  }\n\n  // The following import statement in an esm module causes the following error:\n  // Statement:\n  //   import { usePrevious } from 'react-use';\n  // Error:\n  //   Named export 'usePrevious' not found. The requested module 'react-use' is a CommonJS module,\n  //   which may not support all module.exports as named exports.\n  // We need cjs modules for web apps to avoid the error.\n  // Also, splitting a library is useful in both modules, so preserveModules should be true.\n  const outputOptionsList: OutputOptions[] = [];\n  const moduleType = argv.moduleType || 'both';\n  const jsExt = argv.jsExtension || 'either';\n  if (moduleType === 'cjs' || moduleType === 'both' || (moduleType === 'either' && !isEsmPackage)) {\n    outputOptionsList.push({\n      dir: outDirPath,\n      entryFileNames: jsExt === 'both' || (jsExt === 'either' && !isEsmPackage) ? '[name].js' : '[name].cjs',\n      format: 'commonjs',\n      preserveModules: true,\n      sourcemap: argv.sourcemap,\n    });\n  }\n  if (moduleType === 'esm' || moduleType === 'both' || (moduleType === 'either' && isEsmPackage)) {\n    outputOptionsList.push({\n      dir: outDirPath,\n      entryFileNames: jsExt === 'both' || (jsExt === 'either' && isEsmPackage) ? '[name].js' : '[name].mjs',\n      format: 'module',\n      preserveModules: true,\n      sourcemap: argv.sourcemap,\n    });\n  }\n  return outputOptionsList;\n}\n\nfunction isEsmOutput(isEsmPackage: boolean, moduleType: string | undefined): boolean {\n  return moduleType === 'esm' || ((!moduleType || moduleType === 'either') && isEsmPackage);\n}\n","import process from 'node:process';\n\nimport chalk from 'chalk';\nimport type { RollupError } from 'rollup';\n\nexport function handleError(error: RollupError, recover = false): void {\n  const name = error.name || (error.cause as Error)?.name;\n  const nameSection = name ? `${name}: ` : '';\n  const pluginSection = error.plugin ? `(plugin ${error.plugin}) ` : '';\n  const message = `${pluginSection}${nameSection}${error.message}`;\n\n  const outputLines = [chalk.bold(chalk.red(`[!] ${chalk.bold(message.toString())}`))];\n\n  if (error.url) {\n    outputLines.push(chalk.cyan(error.url));\n  }\n\n  if (error.loc) {\n    outputLines.push(`${error.loc.file || error.id} (${error.loc.line}:${error.loc.column})`);\n  } else if (error.id) {\n    outputLines.push(error.id);\n  }\n\n  if (error.frame) {\n    outputLines.push(chalk.dim(error.frame));\n  }\n\n  if (error.stack) {\n    outputLines.push(chalk.dim(error.stack?.replace(`${nameSection}${error.message}\\n`, '')));\n  }\n\n  outputLines.push('', '');\n  console.error(outputLines.join('\\n'));\n\n  if (!recover) process.exit(1);\n}\n","import * as child_process from 'node:child_process';\n\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { loadEnvironmentVariablesWithCache } from '../env.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  ...sharedOptionsBuilder,\n  module: {\n    description: 'A module type: cjs or esm',\n    type: 'string',\n    alias: 'm',\n  },\n  watch: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 'w',\n  },\n} as const;\n\nexport const run: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'run <file>',\n  describe: 'Run script',\n  builder,\n  handler(argv) {\n    loadEnvironmentVariablesWithCache(argv, process.cwd());\n\n    const file = argv.file?.toString() ?? '';\n\n    // cf. https://bun.sh/guides/util/detect-bun\n    const isRunningOnBun = process.versions.bun;\n    const runtime = isRunningOnBun ? 'bun' : 'node';\n    const args = isRunningOnBun ? ['--bun'] : ['--no-warnings', '--import', 'tsx'];\n    if (argv.watch) {\n      args.push('--watch');\n    }\n    args.push(file);\n    const [, ...additionalArguments] = argv._;\n    const runtimeArgs = [...args, ...additionalArguments.map((arg) => arg.toString())];\n    if (argv.verbose) {\n      console.info(`Running '${runtime} ${runtimeArgs.join(' ')}'`);\n    }\n    const ret = child_process.spawnSync(runtime, runtimeArgs, {\n      stdio: 'inherit',\n      env: { ...process.env },\n    });\n    process.exit(ret.status ?? 1);\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { app, functions, lib } from './commands/build/build.js';\nimport { run } from './commands/run.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nremoveNpmAndYarnEnvironmentVariables(process.env);\n\nawait yargs(hideBin(process.argv))\n  .scriptName('build-ts')\n  .options(sharedOptionsBuilder)\n  .command(app)\n  .command(functions)\n  .command(lib)\n  .command(run)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n"],"names":["envVars","loadEnvironmentVariablesWithCache","argv","cwd","readAndApplyEnvironmentVariables","verbose","console","info","Object","keys","createEnvironmentVariablesDefinition","envVarsDef","envVarNames","Set","inline","flatMap","e","toString","split","autoInline","name","undefined","process","env","JSON","stringify","allTargetCategories","async","readPackageJson","dirPath","packageJsonPath","path","join","packageJsonText","fs","promises","readFile","parse","sharedOptionsBuilder","yargsOptionsBuilderForEnv","silent","description","type","alias","builder","input","default","minify","sourcemap","external","watch","keepImport","bundleBuiltins","appBuilder","moduleType","functionsBuilder","onlyPackageJson","libBuilder","jsExtension","setupPlugins","targetDetail","packageJson","namespace","packageDirPath","outputOptionsList","externalDeps","map","item","dependencies","push","peerDependencies","optionalDependencies","existsSync","packageDirs","readdirSync","withFileTypes","packageDir","isDirectory","otherPackageJson","readFileSync","extensions","babelConfigPath","url","fileURLToPath","dirname","replacePlugin","getDefaultPluginFactory","replace","jsonPlugin","json","resolvePlugin","resolve","commonjsPlugin","commonjs","terserPlugin","terser","analyzePlugin","analyze","plugins","delimiters","preventAssignment","values","nodeExternals","deps","devDeps","peerDeps","optDeps","include","RegExp","exclude","preferBuiltins","id","includes","moduleNames","isBabelHelpersBundled","BUILDTS_USE_BABLE_RUNTIME","babel","configFile","babelHelpers","some","opts","preserveModules","preserveDirectives","string","compress","directives","summaryOnly","module","require","createRequire","generateDeclarationFiles","coreProjectDirPath","coreConfigFile","findConfigFile","Error","projects","outDir","basename","parentDirPath","dirents","readdir","dirent","projectDirPath","allSucceeded","runTypeScriptNative","configFileDirPath","tempConfigFile","pid","Date","now","writeFile","compilerOptions","declaration","emitDeclarationOnly","moduleResolution","noEmit","noEmitOnError","rootDir","usesNodeProtocolImport","types","typeRootsDirPath","filter","collectTypePackages","extends","toRelativeConfigPath","createTypeScriptNativeConfig","ret","child_process","spawnSync","execPath","getTypeScriptNativePath","stdio","error","status","rm","force","currentDirPath","childPath","test","fromDirPath","toFilePath","relativePath","relative","replaceAll","sep","startsWith","app","command","describe","handler","build","functions","package","exit","generatePackageJsonForFunctions","lib","targetCategory","NODE_ENV","inputs","length","p","srcDirPath","ext","verifyInput","endsWith","detectTargetDetail","packageName","match","exec","getNamespaceAndName","isEsmPackage","BUILD_TS_COREJS","BUILD_TS_COREJS_WITH_PROPOSALS","BUILD_TS_VERBOSE","BUILD_TS_TARGET_CATEGORY","BUILD_TS_TARGET_DETAIL","outDirPath","dir","format","isEsmOutput","jsExt","entryFileNames","getOutputOptionsList","chdir","recursive","options","fromEntries","index","extname","clearScreen","pathToRelativePath","paths","Array","isArray","watcher","output","close","removeListener","stdin","code","onExit","on","isTTY","resume","event","recover","cause","nameSection","message","plugin","outputLines","chalk","bold","red","cyan","loc","file","line","column","frame","dim","stack","handleError","eventInput","inputFiles","green","ms","duration","dateTime","result","watchRollup","bundle","buildFailed","startTime","_bundle","rollup","Promise","all","write","esmPackage","esmOutput","main","scripts","devDependencies","mkdir","run","isRunningOnBun","versions","bun","runtime","args","additionalArguments","_","runtimeArgs","arg","removeNpmAndYarnEnvironmentVariables","yargs","hideBin","scriptName","demandCommand","strict","version","packageJsonDir","URL","pathname","getVersion","help"],"mappings":"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"}
|
|
1
|
+
import e from"node:fs";import n from"node:path";import{readAndApplyEnvironmentVariables as o,yargsOptionsBuilderForEnv as s,removeNpmAndYarnEnvironmentVariables as t}from"@willbooster/shared-lib-node";import i from"yargs";import{hideBin as r}from"yargs/helpers";import a from"chalk";import c from"date-time";import p from"pretty-ms";import{rollup as l,watch as d}from"rollup";import{onExit as u}from"signal-exit";import m from"node:url";import{babel as f}from"@rollup/plugin-babel";import*as y from"@rollup/plugin-commonjs";import*as h from"@rollup/plugin-json";import*as b from"@rollup/plugin-node-resolve";import*as j from"@rollup/plugin-replace";import*as g from"@rollup/plugin-terser";import*as v from"rollup-plugin-analyzer";import{keepImport as w}from"rollup-plugin-keep-import";import{nodeExternals as x}from"rollup-plugin-node-externals";import S from"rollup-plugin-preserve-directives";import{string as k}from"rollup-plugin-string";import $ from"node:process";import*as T from"node:child_process";import{createRequire as D}from"node:module";let O;function E(e,n){return O||(O=o(e,n),e.verbose&&console.info("Loaded env vars:",Object.keys(O))),O}function _(e,n){const o={},s=new Set([...(e.inline??[]).flatMap(e=>e.toString().split(",")),...e.autoInline?Object.keys(E(e,n)):[]]);for(const e of s)void 0!==process.env[e]&&(o[`process.env.${e}`]=JSON.stringify(process.env[e]));return e.verbose&&console.info("Inline env vars:",Object.keys(o)),o}const F=["app","functions","lib"];async function R(o){const s=n.join(o,"package.json");try{const n=await e.promises.readFile(s,"utf8");return[JSON.parse(n),s]}catch{}return[void 0,s]}const B={...s,silent:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"s"}},N={...B,input:{description:'Paths of source code files to be built. The first file is main. If no option is given, "src/index.{ts,tsx}" from package directory is targeted.',type:"array",alias:"i"},"core-js":{description:"Whether or not core-js is employed.",type:"boolean",default:!1},"core-js-proposals":{description:"Whether or not core-js with proposals support is employed.",type:"boolean",default:!1},minify:{description:"Whether or not minification is enabled.",type:"boolean",default:!0},sourcemap:{description:"Whether or not sourcemap is enabled.",type:"boolean",default:!0},external:{description:"Additional external dependencies.",type:"array"},inline:{description:"Environment variables to be inlined.",type:"array"},"auto-inline":{description:"Inline environment variables defined at env files.",type:"boolean",default:!1},watch:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"w"},keepImport:{description:"Identifiers to be kept as import statements.",type:"array"},bundleBuiltins:{description:"Module names same with builtins (e.g., undici) to be bundled.",type:"array"}},I={...N,moduleType:{description:"esm, cjs, or either (default).",type:"string",alias:"m"}},L={...I,onlyPackageJson:{description:"Whether to generate only package.json.",type:"boolean"}},A={...N,moduleType:{description:"esm, cjs, either, or both (default).",type:"string",alias:"m"},jsExtension:{description:"Whether to use .js in cjs and/or esm: either (default), both, or none.",type:"string",alias:"j"}};function W(o,s,t,i,r,a){const c=[...o.external??[]].map(e=>e.toString());if(t.dependencies?.["@prisma/client"]&&c.push("prisma-client"),c.push(...Object.keys(t.dependencies??{}),...Object.keys(t.peerDependencies??{}),...Object.keys(t.optionalDependencies??{})),e.existsSync(n.join("..","..","package.json"))){const o=e.readdirSync(n.join(".."),{withFileTypes:!0});for(const s of o){if(!s.isDirectory())continue;const o=n.join("..",s.name,"package.json");if(!e.existsSync(o))continue;const i=JSON.parse(e.readFileSync(o,"utf8"));t.dependencies?.[i.name??""]&&c.push(...Object.keys(i.dependencies??{}),...Object.keys(i.peerDependencies??{}),...Object.keys(i.optionalDependencies??{}))}}const p=[".cjs",".mjs",".js",".jsx",".json",".cts",".mts",".ts",".tsx"],l=n.join(m.fileURLToPath(n.dirname(n.dirname(import.meta.url))),"babel.config.mjs"),d=J(j),u=J(h),$=J(b),T=J(y),D=J(g),O=J(v),E=[d({delimiters:["",""],preventAssignment:!0,values:_(o,r)}),u(),x({deps:!0,devDeps:!1,peerDeps:!0,optDeps:!0,include:c.map(e=>new RegExp(`^${e}(?:\\/.+)?`)),exclude:U(s)&&i&&new RegExp(`^@?${i}(?:\\/.+)?`)}),$({extensions:p,preferBuiltins:e=>!o.bundleBuiltins?.includes(e)}),T(),w({moduleNames:o.keepImport?.map(e=>e.toString())??[]})],F="app-node"===s||"functions"===s||!c.includes("@babel/runtime");return process.env.BUILDTS_USE_BABLE_RUNTIME=F?"":"1",E.push(f({configFile:l,extensions:p,babelHelpers:F?"bundled":"runtime",exclude:/^(.+\/)?node_modules\/.+$/}),...a.some(e=>e.preserveModules)?[S()]:[],k({include:["**/*.csv","**/*.txt"]})),o.minify&&E.push(D({compress:{directives:!1}})),E.push(O({summaryOnly:!0})),E}function U(e){return"app-node"===e||"functions"===e}function J(e){return e.default}const P=D(import.meta.url);async function C(o,s){const t=G(s);if(!t)throw new Error(`Failed to find tsconfig.json in ${s}.`);o.verbose&&console.info("Found tsconfig.json:",t);const i=[];let r=n.join("dist",n.basename(s),"src");if(e.existsSync(r)){const o=n.dirname(s),t=await e.promises.readdir(o,{withFileTypes:!0});s=n.resolve(s);for(const r of t){if(!r.isDirectory())continue;const t=n.resolve(o,r.name);if(t===s)continue;const a=G(t),c=n.join("dist",r.name,"src");a&&e.existsSync(c)&&i.push([t,a,c])}}else r="dist";i.push([s,t,r]);let a=!0;for(const[e,t,r]of i)a&&=await M(o,e,t,n.join(s,r));return a}async function M(o,s,t,i){o.verbose&&console.info("runTypeScriptNative()",s,t,i);const r=n.dirname(t),a=n.join(r,`.build-ts-tsgo.${process.pid}.${Date.now()}.json`);try{await e.promises.writeFile(a,JSON.stringify(await async function(o,s,t){const i={declaration:!0,emitDeclarationOnly:!0,noEmit:!1,noEmitOnError:!0,outDir:t,rootDir:"src"};if(await V(n.join(o,"src"))){const s=await async function(n){try{return(await e.promises.readdir(n,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>e.name)}catch{return[]}}(n.join(o,"node_modules","@types"));s.includes("node")&&(i.types=s)}return{compilerOptions:i,extends:Y(n.dirname(s),s),include:["src/**/*"]}}(s,t,i),void 0,2));const o=T.spawnSync(process.execPath,[H(),"-p",a],{cwd:s,stdio:"inherit"});if(o.error)throw o.error;return 0===o.status}finally{await e.promises.rm(a,{force:!0})}}function G(o){let s=n.resolve(o);for(;;){const o=n.join(s,"tsconfig.json");if(e.existsSync(o))return o;const t=n.dirname(s);if(t===s)return;s=t}}function H(){const e=P.resolve("@typescript/native-preview/package.json");return n.join(n.dirname(e),"bin","tsgo.js")}async function V(o){try{const s=await e.promises.readdir(o,{withFileTypes:!0});for(const t of s){const s=n.join(o,t.name);if(t.isDirectory()){if(await V(s))return!0}else if(/\.[cm]?tsx?$/.test(t.name)&&(await e.promises.readFile(s,"utf8")).includes("node:"))return!0}}catch{return!1}return!1}function Y(e,o){const s=n.relative(e,o).replaceAll(n.sep,"/");return s.startsWith(".")?s:`./${s}`}const z={command:"app [package]",describe:"Build an app",builder:I,handler:async e=>Q(e,"app")},q={command:"functions [package]",describe:"Build a GCP/Firebase functions app",builder:L,async handler(e){if(!e.onlyPackageJson)return Q(e,"functions");{const o=n.resolve(e.package?.toString()??"."),[s,t]=await R(o);s||(console.error(`Failed to parse package.json (${t}).`),process.exit(1)),await Z(o,s,e.moduleType)}}},K={command:"lib [package]",describe:"Build a Node.js / React library",builder:A,handler:async e=>Q(e,"lib")};async function Q(o,s){process.env.NODE_ENV||="production";const t=!o.silent&&o.verbose,i=process.cwd(),r=n.resolve(o.package?.toString()??"."),[m,f]=await R(r);m||(console.error(`Failed to parse package.json (${f}).`),process.exit(1)),E(o,r);const y=function(o,s,t){if(o.input&&o.input.length>0)return o.input.map(e=>n.resolve(s,e.toString()));const i=n.join(t,"src");for(const o of["ts","tsx","cts","mts"]){const s=n.join(i,`index.${o}`);if(e.existsSync(s))return[s]}console.error("Failed to detect input file."),process.exit(1)}(o,i,r),h=function(e,o,s){switch(e){case"app":return"app-node";case"functions":return"functions";case"lib":return o.some(e=>e.endsWith(".tsx"))||function(e){const o=n.join(e,"src");return X(o)}(s)?"lib-react":"lib";default:console.error("target option must be one of: "+F.join(", ")),process.exit(1)}}(s,y,r);t&&(console.info("argv:",o),console.info("packageJsonPath:",f),console.info("Target (Category):",`${h} (${s})`));const[b]=function(e){const n=e.name?.toString()??"",o=/@([^/]+)\/(.+)/.exec(n),[,s,t]=o??[];return[s,t]}(m),j="module"===m.type;o["core-js"]?process.env.BUILD_TS_COREJS="1":o["core-js-proposals"]&&(process.env.BUILD_TS_COREJS_WITH_PROPOSALS="1"),t&&(process.env.BUILD_TS_VERBOSE="1"),process.env.BUILD_TS_TARGET_CATEGORY=s,process.env.BUILD_TS_TARGET_DETAIL=h;const g=function(e,o,s,t){const i=n.join(s,"dist");if("app-node"===o||"functions"===o)return[{dir:i,format:ee(t,e.moduleType)?"module":"commonjs",sourcemap:e.sourcemap&&"inline"}];const r=[],a=e.moduleType||"both",c=e.jsExtension||"either";("cjs"===a||"both"===a||"either"===a&&!t)&&r.push({dir:i,entryFileNames:"both"===c||"either"===c&&!t?"[name].js":"[name].cjs",format:"commonjs",preserveModules:!0,preserveModulesRoot:n.join(s,"src"),sourcemap:e.sourcemap});("esm"===a||"both"===a||"either"===a&&t)&&r.push({dir:i,entryFileNames:"both"===c||"either"===c&&t?"[name].js":"[name].mjs",format:"module",preserveModules:!0,preserveModulesRoot:n.join(s,"src"),sourcemap:e.sourcemap});return r}(o,h,r,j);t&&console.info("OutputOptions:",g),0===g.length&&(console.error("Failed to detect output files."),process.exit(1)),process.chdir(r),await e.promises.rm(n.join(r,"dist"),{recursive:!0,force:!0}),"functions"===h&&await Z(r,m,o.moduleType);const v={input:"functions"===h?Object.fromEntries(y.map((e,o)=>[0===o?"index":n.basename(e,n.extname(e)),e])):y,plugins:W(o,h,m,b,r,g),watch:o.watch?{clearScreen:!1}:void 0},w=e=>(Array.isArray(e)?e:[e]).map(e=>n.relative(r,e));if(o.watch)!function(e,n,o,s,t,i){const r=d({...s,output:t}),l=async e=>{process.removeListener("uncaughtException",l),process.stdin.removeListener("end",l),r&&await r.close(),e&&process.exit(e)};u(l),process.on("uncaughtException",l),process.stdin.isTTY||(process.stdin.on("end",l),process.stdin.resume());r.on("event",async s=>{switch(s.code){case"ERROR":!function(e,n=!1){const o=e.name||e.cause?.name,s=o?`${o}: `:"",t=`${e.plugin?`(plugin ${e.plugin}) `:""}${s}${e.message}`,i=[a.bold(a.red(`[!] ${a.bold(t.toString())}`))];e.url&&i.push(a.cyan(e.url)),e.loc?i.push(`${e.loc.file||e.id} (${e.loc.line}:${e.loc.column})`):e.id&&i.push(e.id),e.frame&&i.push(a.dim(e.frame)),e.stack&&i.push(a.dim(e.stack?.replace(`${s}${e.message}\n`,""))),i.push("",""),console.error(i.join("\n")),n||$.exit(1)}(s.error,!0);break;case"BUNDLE_START":{if(e.silent)break;const n=s.input,t=[];"string"==typeof n?t.push(n):t.push(...Array.isArray(n)?n:Object.values(n)),console.info(a.cyan(`Bundles ${a.bold(i(t).join(", "))} → ${a.bold(i(s.output).join(", "))}\non ${o} ...`));break}case"BUNDLE_END":if(e.silent)break;console.info(a.green(`Created ${a.bold(i(s.output).join(", "))} in ${a.bold(p(s.duration))}`)),"app-node"!==n&&"functions"!==n&&await C(e,o);break;case"END":if(e.silent)break;console.info(`\n[${c()}] waiting for changes...`)}"result"in s&&s.result&&s.result.close()})}(o,h,r,v,g,w);else{let e;o.silent||console.info(a.cyan(`Bundles ${a.bold(w(y).join(", "))} → ${a.bold(w(g.map(e=>e.file||e.dir||"")).join(", "))}\non ${r} ...`));let n=!1;try{const n=Date.now(),s=await l(v);e=s,await Promise.all(g.map(e=>s.write(e))),o.silent||console.info(a.green(`Created ${w(g.map(e=>e.file||e.dir||"")).join(", ")} in ${a.bold(p(Date.now()-n))}`))}catch(e){n=!0,console.error("Failed to build due to:",e)}await(e?.close()),n&&process.exit(1),"app-node"===h||"functions"===h||await C(o,r)||process.exit(1)}}function X(o){try{return e.readdirSync(o,{withFileTypes:!0}).some(e=>{const s=n.join(o,e.name);return e.isDirectory()?X(s):e.isFile()&&e.name.endsWith(".tsx")})}catch{return!1}}async function Z(o,s,t){s.name+="-dist";const i="module"===s.type,r=ee(i,t);s.main=i===r?"index.js":r?"index.mjs":"index.cjs",delete s.scripts,delete s.devDependencies,await e.promises.mkdir(n.join(o,"dist"),{recursive:!0}),await e.promises.writeFile(n.join(o,"dist","package.json"),JSON.stringify(s))}function ee(e,n){return"esm"===n||(!n||"either"===n)&&e}const ne={command:"run <file>",describe:"Run script",builder:{...B,module:{description:"A module type: cjs or esm",type:"string",alias:"m"},watch:{description:"Whether watch mode is enabled or not",type:"boolean",alias:"w"}},handler(e){E(e,process.cwd());const n=e.file?.toString()??"",o=process.versions.bun,s=o?"bun":"node",t=o?["--bun"]:["--no-warnings","--import","tsx"];e.watch&&t.push("--watch"),t.push(n);const[,...i]=e._,r=[...t,...i.map(e=>e.toString())];e.verbose&&console.info(`Running '${s} ${r.join(" ")}'`);const a=T.spawnSync(s,r,{stdio:"inherit",env:{...process.env}});process.exit(a.status??1)}};t(process.env),await i(r(process.argv)).scriptName("build-ts").options(B).command(z).command(q).command(K).command(ne).demandCommand().strict().version(function(){let o=n.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(n.join(o,"package.json"));)o=n.dirname(o);return JSON.parse(e.readFileSync(n.join(o,"package.json"),"utf8")).version}()).help().argv;
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../src/env.ts","../src/types.ts","../src/utils.ts","../src/sharedOptionsBuilder.ts","../src/commands/build/builder.ts","../src/commands/build/plugin.ts","../src/commands/build/typeScript.ts","../src/commands/build/build.ts","../src/commands/build/rollupLogger.ts","../src/commands/run.ts","../src/index.ts"],"sourcesContent":["import { readAndApplyEnvironmentVariables } from '@willbooster/shared-lib-node';\n\nimport type { builder } from './commands/build/builder.js';\nimport type { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\nimport type { ArgumentsType } from './types.js';\n\nlet envVars: Record<string, string | undefined> | undefined;\n\n/**\n * This function loads environment variables from `.env` files.\n * */\nexport function loadEnvironmentVariablesWithCache(\n  argv: ArgumentsType<typeof sharedOptionsBuilder>,\n  cwd: string\n): Record<string, string | undefined> {\n  if (!envVars) {\n    envVars = readAndApplyEnvironmentVariables(argv, cwd);\n    if (argv.verbose) {\n      console.info('Loaded env vars:', Object.keys(envVars));\n    }\n  }\n  return envVars;\n}\n\n/**\n * This function creates a definition of environment variables that will be injected into the build.\n * */\nexport function createEnvironmentVariablesDefinition(\n  argv: ArgumentsType<typeof builder>,\n  cwd: string\n): Record<string, string> {\n  const envVarsDef: Record<string, string> = {};\n  const envVarNames = new Set([\n    ...(argv.inline ?? []).flatMap((e) => e.toString().split(',')),\n    ...(argv.autoInline ? Object.keys(loadEnvironmentVariablesWithCache(argv, cwd)) : []),\n  ]);\n  for (const name of envVarNames) {\n    if (process.env[name] === undefined) continue;\n\n    envVarsDef[`process.env.${name}`] = JSON.stringify(process.env[name]);\n  }\n  if (argv.verbose) {\n    console.info('Inline env vars:', Object.keys(envVarsDef));\n  }\n  return envVarsDef;\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes, Options } from 'yargs';\n\nexport const allTargetCategories = ['app', 'functions', 'lib'] as const;\n\nexport type TargetCategory = (typeof allTargetCategories)[number];\n\nexport const allTargetDetails = ['app-node', 'functions', 'lib', 'lib-react'] as const;\n\nexport type TargetDetail = (typeof allTargetDetails)[number];\n\nexport type ArgumentsType<T extends Record<string, Options>> = ArgumentsCamelCase<InferredOptionTypes<T>>;\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport url from 'node:url';\n\nimport type { PackageJson } from 'type-fest';\n\nexport async function readPackageJson(dirPath: string): Promise<[PackageJson | undefined, string]> {\n  const packageJsonPath = path.join(dirPath, 'package.json');\n  try {\n    const packageJsonText = await fs.promises.readFile(packageJsonPath, 'utf8');\n    return [JSON.parse(packageJsonText) as PackageJson, packageJsonPath];\n  } catch {\n    // do nothing\n  }\n  return [undefined, packageJsonPath];\n}\n\nexport function getBuildTsRootPath(): string {\n  return url.fileURLToPath(path.dirname(path.dirname(import.meta.url)));\n}\n\nexport function getNamespaceAndName(packageJson: PackageJson): [string | undefined, string | undefined] {\n  const packageName = packageJson.name?.toString() ?? '';\n  const match = /@([^/]+)\\/(.+)/.exec(packageName);\n  const [, namespace, name] = match ?? [];\n  return [namespace, name];\n}\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  silent: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 's',\n  },\n} as const;\n","import { sharedOptionsBuilder } from '../../sharedOptionsBuilder.js';\n\nexport const builder = {\n  ...sharedOptionsBuilder,\n  input: {\n    description:\n      'Paths of source code files to be built. The first file is main. If no option is given, \"src/index.{ts,tsx}\" from package directory is targeted.',\n    type: 'array',\n    alias: 'i',\n  },\n  'core-js': {\n    description: 'Whether or not core-js is employed.',\n    type: 'boolean',\n    default: false,\n  },\n  'core-js-proposals': {\n    description: 'Whether or not core-js with proposals support is employed.',\n    type: 'boolean',\n    default: false,\n  },\n  minify: {\n    description: 'Whether or not minification is enabled.',\n    type: 'boolean',\n    default: true,\n  },\n  sourcemap: {\n    description: 'Whether or not sourcemap is enabled.',\n    type: 'boolean',\n    default: true,\n  },\n  external: {\n    description: 'Additional external dependencies.',\n    type: 'array',\n  },\n  inline: {\n    description: 'Environment variables to be inlined.',\n    type: 'array',\n  },\n  'auto-inline': {\n    description: 'Inline environment variables defined at env files.',\n    type: 'boolean',\n    default: false,\n  },\n  watch: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 'w',\n  },\n  keepImport: {\n    description: 'Identifiers to be kept as import statements.',\n    type: 'array',\n  },\n  bundleBuiltins: {\n    description: 'Module names same with builtins (e.g., undici) to be bundled.',\n    type: 'array',\n  },\n} as const;\n\nexport const appBuilder = {\n  ...builder,\n  moduleType: {\n    description: 'esm, cjs, or either (default).',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const functionsBuilder = {\n  ...appBuilder,\n  onlyPackageJson: {\n    description: 'Whether to generate only package.json.',\n    type: 'boolean',\n  },\n} as const;\n\nexport const libBuilder = {\n  ...builder,\n  moduleType: {\n    description: 'esm, cjs, either, or both (default).',\n    type: 'string',\n    alias: 'm',\n  },\n  // .js files in a package with `\"type\": \"module\"` are treated as esm.\n  // However, we want to treat them as cjs in the case where a cjs project imports an esm package.\n  // To deal with the case, we use .cjs and .mjs extensions instead of .js extension.\n  jsExtension: {\n    description: 'Whether to use .js in cjs and/or esm: either (default), both, or none.',\n    type: 'string',\n    alias: 'j',\n  },\n} as const;\n\nexport type AnyBuilderType = typeof appBuilder | typeof functionsBuilder | typeof libBuilder;\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { babel } from '@rollup/plugin-babel';\nimport * as commonjs from '@rollup/plugin-commonjs';\nimport * as json from '@rollup/plugin-json';\nimport * as resolve from '@rollup/plugin-node-resolve';\nimport * as replace from '@rollup/plugin-replace';\nimport * as terser from '@rollup/plugin-terser';\nimport type { OutputOptions, Plugin } from 'rollup';\nimport * as analyze from 'rollup-plugin-analyzer';\nimport { keepImport } from 'rollup-plugin-keep-import';\nimport { nodeExternals } from 'rollup-plugin-node-externals';\nimport preserveDirectives from 'rollup-plugin-preserve-directives';\nimport { string } from 'rollup-plugin-string';\nimport type { PackageJson } from 'type-fest';\n\nimport { createEnvironmentVariablesDefinition } from '../../env.js';\nimport type { ArgumentsType, TargetDetail } from '../../types.js';\nimport { getBuildTsRootPath } from '../../utils.js';\n\nimport type { builder } from './builder.js';\n\nexport function setupPlugins(\n  argv: ArgumentsType<typeof builder>,\n  targetDetail: TargetDetail,\n  packageJson: PackageJson,\n  namespace: string | undefined,\n  packageDirPath: string,\n  outputOptionsList: OutputOptions[]\n): Plugin[] {\n  const externalDeps = [...(argv.external ?? [])].map((item) => item.toString());\n  if (packageJson.dependencies?.['@prisma/client']) {\n    externalDeps.push('prisma-client');\n  }\n  // Since `deps: true` does not work for `import chunk from 'lodash.chunk/index.js';`\n  externalDeps.push(\n    ...Object.keys(packageJson.dependencies ?? {}),\n    ...Object.keys(packageJson.peerDependencies ?? {}),\n    ...Object.keys(packageJson.optionalDependencies ?? {})\n  );\n  // Add external dependencies from sibling packages\n  if (fs.existsSync(path.join('..', '..', 'package.json'))) {\n    const packageDirs = fs.readdirSync(path.join('..'), { withFileTypes: true });\n    for (const packageDir of packageDirs) {\n      if (!packageDir.isDirectory()) continue;\n\n      const packageJsonPath = path.join('..', packageDir.name, 'package.json');\n      if (!fs.existsSync(packageJsonPath)) continue;\n\n      const otherPackageJson: PackageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));\n      if (packageJson.dependencies?.[otherPackageJson.name ?? '']) {\n        externalDeps.push(\n          ...Object.keys(otherPackageJson.dependencies ?? {}),\n          ...Object.keys(otherPackageJson.peerDependencies ?? {}),\n          ...Object.keys(otherPackageJson.optionalDependencies ?? {})\n        );\n      }\n    }\n  }\n\n  const extensions = ['.cjs', '.mjs', '.js', '.jsx', '.json', '.cts', '.mts', '.ts', '.tsx'];\n  const babelConfigPath = path.join(getBuildTsRootPath(), 'babel.config.mjs');\n  const replacePlugin = getDefaultPluginFactory(replace);\n  const jsonPlugin = getDefaultPluginFactory(json);\n  const resolvePlugin = getDefaultPluginFactory(resolve);\n  const commonjsPlugin = getDefaultPluginFactory(commonjs);\n  const terserPlugin = getDefaultPluginFactory(terser);\n  const analyzePlugin = getDefaultPluginFactory(analyze);\n  const plugins: Plugin[] = [\n    replacePlugin({\n      // Ignore word boundaries and replace every instance of the string.\n      // cf. https://github.com/rollup/plugins/tree/master/packages/replace#word-boundaries\n      delimiters: ['', ''],\n      preventAssignment: true,\n      values: createEnvironmentVariablesDefinition(argv, packageDirPath),\n    }),\n    jsonPlugin(),\n    nodeExternals({\n      deps: true,\n      devDeps: false,\n      peerDeps: true,\n      optDeps: true,\n      include: externalDeps.map((name) => new RegExp(`^${name}(?:\\\\/.+)?`)),\n      exclude: shouldBundleSameNamespaceDependencies(targetDetail) && namespace && new RegExp(`^@?${namespace}(?:\\\\/.+)?`),\n    }),\n    resolvePlugin({\n      extensions,\n      preferBuiltins: (id: string) => !argv.bundleBuiltins?.includes(id),\n    }),\n    commonjsPlugin(),\n    keepImport({ moduleNames: argv.keepImport?.map((item) => item.toString()) ?? [] }),\n  ];\n  const isBabelHelpersBundled =\n    targetDetail === 'app-node' || targetDetail === 'functions' || !externalDeps.includes('@babel/runtime');\n  process.env.BUILDTS_USE_BABLE_RUNTIME = isBabelHelpersBundled ? '' : '1';\n  plugins.push(\n    babel({\n      configFile: babelConfigPath,\n      extensions,\n      // We need `runtime since `bundled` may break directory structure by creating _virtual directory.\n      babelHelpers: isBabelHelpersBundled ? 'bundled' : 'runtime',\n      exclude: /^(.+\\/)?node_modules\\/.+$/,\n    }),\n    ...(outputOptionsList.some((opts) => opts.preserveModules) ? [preserveDirectives()] : []),\n    string({ include: ['**/*.csv', '**/*.txt'] })\n  );\n  if (argv.minify) {\n    plugins.push(terserPlugin({ compress: { directives: false } }));\n  }\n  plugins.push(analyzePlugin({ summaryOnly: true }));\n  return plugins;\n}\n\nfunction shouldBundleSameNamespaceDependencies(targetDetail: TargetDetail): boolean {\n  return targetDetail === 'app-node' || targetDetail === 'functions';\n}\n\ntype PluginFactory = (options?: unknown) => Plugin;\n\nfunction getDefaultPluginFactory(module: { default: unknown }): PluginFactory {\n  return module.default as PluginFactory;\n}\n","import * as child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\n\nimport type { ArgumentsType } from '../../types.js';\n\nimport type { AnyBuilderType } from './builder.js';\n\nconst require = createRequire(import.meta.url);\n\nexport async function generateDeclarationFiles(\n  argv: ArgumentsType<AnyBuilderType>,\n  coreProjectDirPath: string\n): Promise<boolean> {\n  const coreConfigFile = findConfigFile(coreProjectDirPath);\n  if (!coreConfigFile) throw new Error(`Failed to find tsconfig.json in ${coreProjectDirPath}.`);\n  if (argv.verbose) {\n    console.info('Found tsconfig.json:', coreConfigFile);\n  }\n\n  const projects: [string, string, string][] = [];\n  let outDir = path.join('dist', path.basename(coreProjectDirPath), 'src');\n  if (fs.existsSync(outDir)) {\n    const parentDirPath = path.dirname(coreProjectDirPath);\n    const dirents = await fs.promises.readdir(parentDirPath, { withFileTypes: true });\n    coreProjectDirPath = path.resolve(coreProjectDirPath);\n    for (const dirent of dirents) {\n      if (!dirent.isDirectory()) continue;\n\n      const projectDirPath = path.resolve(parentDirPath, dirent.name);\n      if (projectDirPath === coreProjectDirPath) continue;\n\n      const configFile = findConfigFile(projectDirPath);\n      const outDir = path.join('dist', dirent.name, 'src');\n      if (configFile && fs.existsSync(outDir)) {\n        projects.push([projectDirPath, configFile, outDir]);\n      }\n    }\n  } else {\n    outDir = 'dist';\n  }\n  projects.push([coreProjectDirPath, coreConfigFile, outDir]);\n\n  let allSucceeded = true;\n  for (const [projectDirPath, configFile, outDir] of projects) {\n    allSucceeded &&= await runTypeScriptNative(argv, projectDirPath, configFile, path.join(coreProjectDirPath, outDir));\n  }\n  return allSucceeded;\n}\n\nasync function runTypeScriptNative(\n  argv: ArgumentsType<AnyBuilderType>,\n  projectDirPath: string,\n  configFile: string,\n  outDir: string\n): Promise<boolean> {\n  if (argv.verbose) {\n    console.info('runTypeScriptNative()', projectDirPath, configFile, outDir);\n  }\n\n  const configFileDirPath = path.dirname(configFile);\n  const tempConfigFile = path.join(configFileDirPath, `.build-ts-tsgo.${process.pid}.${Date.now()}.json`);\n  try {\n    await fs.promises.writeFile(\n      tempConfigFile,\n      JSON.stringify(await createTypeScriptNativeConfig(projectDirPath, configFile, outDir), undefined, 2)\n    );\n    const ret = child_process.spawnSync(process.execPath, [getTypeScriptNativePath(), '-p', tempConfigFile], {\n      cwd: projectDirPath,\n      stdio: 'inherit',\n    });\n    if (ret.error) throw ret.error;\n    return ret.status === 0;\n  } finally {\n    await fs.promises.rm(tempConfigFile, { force: true });\n  }\n}\n\nasync function createTypeScriptNativeConfig(\n  projectDirPath: string,\n  configFile: string,\n  outDir: string\n): Promise<Record<string, unknown>> {\n  const compilerOptions: Record<string, unknown> = {\n    declaration: true,\n    emitDeclarationOnly: true,\n    noEmit: false,\n    noEmitOnError: true,\n    outDir,\n    rootDir: 'src',\n  };\n  if (await usesNodeProtocolImport(path.join(projectDirPath, 'src'))) {\n    const types = await collectTypePackages(path.join(projectDirPath, 'node_modules', '@types'));\n    if (types.includes('node')) {\n      compilerOptions.types = types;\n    }\n  }\n  return {\n    compilerOptions,\n    extends: toRelativeConfigPath(path.dirname(configFile), configFile),\n    include: ['src/**/*'],\n  };\n}\n\nfunction findConfigFile(dirPath: string): string | undefined {\n  let currentDirPath = path.resolve(dirPath);\n  while (true) {\n    const configFile = path.join(currentDirPath, 'tsconfig.json');\n    if (fs.existsSync(configFile)) return configFile;\n\n    const parentDirPath = path.dirname(currentDirPath);\n    if (parentDirPath === currentDirPath) return undefined;\n    currentDirPath = parentDirPath;\n  }\n}\n\nfunction getTypeScriptNativePath(): string {\n  const packageJsonPath = require.resolve('@typescript/native-preview/package.json');\n  return path.join(path.dirname(packageJsonPath), 'bin', 'tsgo.js');\n}\n\nasync function usesNodeProtocolImport(dirPath: string): Promise<boolean> {\n  try {\n    const dirents = await fs.promises.readdir(dirPath, { withFileTypes: true });\n    for (const dirent of dirents) {\n      const childPath = path.join(dirPath, dirent.name);\n      if (dirent.isDirectory()) {\n        if (await usesNodeProtocolImport(childPath)) return true;\n      } else if (/\\.[cm]?tsx?$/.test(dirent.name) && (await fs.promises.readFile(childPath, 'utf8')).includes('node:')) {\n        return true;\n      }\n    }\n  } catch {\n    return false;\n  }\n  return false;\n}\n\nasync function collectTypePackages(typeRootsDirPath: string): Promise<string[]> {\n  try {\n    const dirents = await fs.promises.readdir(typeRootsDirPath, { withFileTypes: true });\n    return dirents.filter((dirent) => dirent.isDirectory()).map((dirent) => dirent.name);\n  } catch {\n    return [];\n  }\n}\n\nfunction toRelativeConfigPath(fromDirPath: string, toFilePath: string): string {\n  const relativePath = path.relative(fromDirPath, toFilePath).replaceAll(path.sep, '/');\n  return relativePath.startsWith('.') ? relativePath : `./${relativePath}`;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport dateTime from 'date-time';\nimport ms from 'pretty-ms';\nimport type { OutputOptions, RollupBuild, RollupOptions } from 'rollup';\nimport { rollup, watch } from 'rollup';\nimport type { Handler } from 'signal-exit';\nimport { onExit } from 'signal-exit';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule } from 'yargs';\n\nimport { loadEnvironmentVariablesWithCache } from '../../env.js';\nimport type { ArgumentsType, TargetCategory, TargetDetail } from '../../types.js';\nimport { allTargetCategories } from '../../types.js';\nimport { getNamespaceAndName, readPackageJson } from '../../utils.js';\n\nimport type { AnyBuilderType, builder } from './builder.js';\nimport { appBuilder, functionsBuilder, libBuilder } from './builder.js';\nimport { setupPlugins } from './plugin.js';\nimport { handleError } from './rollupLogger.js';\nimport { generateDeclarationFiles } from './typeScript.js';\n\nexport const app: CommandModule<unknown, ArgumentsType<typeof appBuilder>> = {\n  command: 'app [package]',\n  describe: 'Build an app',\n  builder: appBuilder,\n  async handler(argv) {\n    return build(argv, 'app');\n  },\n};\n\nexport const functions: CommandModule<unknown, ArgumentsType<typeof functionsBuilder>> = {\n  command: 'functions [package]',\n  describe: 'Build a GCP/Firebase functions app',\n  builder: functionsBuilder,\n  async handler(argv) {\n    if (argv.onlyPackageJson) {\n      const packageDirPath = path.resolve(argv.package?.toString() ?? '.');\n      const [packageJson, packageJsonPath] = await readPackageJson(packageDirPath);\n      if (!packageJson) {\n        console.error(`Failed to parse package.json (${packageJsonPath}).`);\n        process.exit(1);\n      }\n      await generatePackageJsonForFunctions(packageDirPath, packageJson, argv.moduleType);\n    } else {\n      return build(argv, 'functions');\n    }\n  },\n};\n\nexport const lib: CommandModule<unknown, ArgumentsType<typeof libBuilder>> = {\n  command: 'lib [package]',\n  describe: 'Build a Node.js / React library',\n  builder: libBuilder,\n  async handler(argv) {\n    return build(argv, 'lib');\n  },\n};\n\nexport async function build(argv: ArgumentsType<AnyBuilderType>, targetCategory: TargetCategory): Promise<void> {\n  process.env.NODE_ENV ||= 'production';\n\n  // `silent` is stronger than `verbose`.\n  const verbose = !argv.silent && argv.verbose;\n  const cwd = process.cwd();\n\n  const packageDirPath = path.resolve(argv.package?.toString() ?? '.');\n  const [packageJson, packageJsonPath] = await readPackageJson(packageDirPath);\n  if (!packageJson) {\n    console.error(`Failed to parse package.json (${packageJsonPath}).`);\n    process.exit(1);\n  }\n\n  loadEnvironmentVariablesWithCache(argv, packageDirPath);\n\n  const inputs = verifyInput(argv, cwd, packageDirPath);\n  const targetDetail = detectTargetDetail(targetCategory, inputs, packageDirPath);\n\n  if (verbose) {\n    console.info('argv:', argv);\n    console.info('packageJsonPath:', packageJsonPath);\n    console.info('Target (Category):', `${targetDetail} (${targetCategory})`);\n  }\n\n  const [namespace] = getNamespaceAndName(packageJson);\n  const isEsmPackage = packageJson.type === 'module';\n\n  if (argv['core-js']) {\n    process.env.BUILD_TS_COREJS = '1';\n  } else if (argv['core-js-proposals']) {\n    process.env.BUILD_TS_COREJS_WITH_PROPOSALS = '1';\n  }\n\n  if (verbose) {\n    process.env.BUILD_TS_VERBOSE = '1';\n  }\n  process.env.BUILD_TS_TARGET_CATEGORY = targetCategory;\n  process.env.BUILD_TS_TARGET_DETAIL = targetDetail;\n\n  const outputOptionsList = getOutputOptionsList(argv, targetDetail, packageDirPath, isEsmPackage);\n  if (verbose) {\n    console.info('OutputOptions:', outputOptionsList);\n  }\n  if (outputOptionsList.length === 0) {\n    console.error('Failed to detect output files.');\n    process.exit(1);\n  }\n\n  process.chdir(packageDirPath);\n  await fs.promises.rm(path.join(packageDirPath, 'dist'), { recursive: true, force: true });\n  if (targetDetail === 'functions') {\n    await generatePackageJsonForFunctions(packageDirPath, packageJson, argv.moduleType);\n  }\n\n  const options: RollupOptions = {\n    input:\n      targetDetail === 'functions'\n        ? Object.fromEntries(\n            inputs.map((input, index) => [index === 0 ? 'index' : path.basename(input, path.extname(input)), input])\n          )\n        : inputs,\n    plugins: setupPlugins(argv, targetDetail, packageJson, namespace, packageDirPath, outputOptionsList),\n    watch: argv.watch ? { clearScreen: false } : undefined,\n  };\n\n  const pathToRelativePath = (paths: string | Readonly<string[]>): string[] =>\n    (Array.isArray(paths) ? paths : [paths]).map((p) => path.relative(packageDirPath, p));\n  if (argv.watch) {\n    watchRollup(argv, targetDetail, packageDirPath, options, outputOptionsList, pathToRelativePath);\n  } else {\n    if (!argv.silent) {\n      console.info(\n        chalk.cyan(\n          `Bundles ${chalk.bold(pathToRelativePath(inputs).join(', '))} → ${chalk.bold(\n            pathToRelativePath(outputOptionsList.map((opts) => opts.file || opts.dir || '')).join(', ')\n          )}\\non ${packageDirPath} ...`\n        )\n      );\n    }\n\n    let bundle: RollupBuild | undefined;\n    let buildFailed = false;\n    try {\n      const startTime = Date.now();\n      const _bundle = await rollup(options);\n      bundle = _bundle;\n      await Promise.all(outputOptionsList.map((opts) => _bundle.write(opts)));\n\n      if (!argv.silent) {\n        console.info(\n          chalk.green(\n            `Created ${pathToRelativePath(outputOptionsList.map((opts) => opts.file || opts.dir || '')).join(\n              ', '\n            )} in ${chalk.bold(ms(Date.now() - startTime))}`\n          )\n        );\n      }\n    } catch (error) {\n      buildFailed = true;\n      console.error('Failed to build due to:', error);\n    }\n    await bundle?.close();\n    if (buildFailed) process.exit(1);\n\n    if (\n      targetDetail !== 'app-node' &&\n      targetDetail !== 'functions' &&\n      !(await generateDeclarationFiles(argv, packageDirPath))\n    ) {\n      process.exit(1);\n    }\n  }\n}\n\nfunction watchRollup(\n  argv: ArgumentsType<AnyBuilderType>,\n  targetDetail: string,\n  packageDirPath: string,\n  options: RollupOptions,\n  outputOptionsList: OutputOptions[],\n  pathToRelativePath: (paths: string | Readonly<string[]>) => string[]\n): void {\n  const watcher = watch({ ...options, output: outputOptionsList });\n\n  const close = async (code: number | null | undefined): Promise<void> => {\n    process.removeListener('uncaughtException', close);\n    process.stdin.removeListener('end', close);\n    if (watcher) await watcher.close();\n    if (code) process.exit(code);\n  };\n  onExit(close as unknown as Handler);\n  process.on('uncaughtException', close);\n  if (!process.stdin.isTTY) {\n    process.stdin.on('end', close);\n    process.stdin.resume();\n  }\n\n  watcher.on('event', async (event) => {\n    switch (event.code) {\n      case 'ERROR': {\n        handleError(event.error, true);\n        break;\n      }\n      case 'BUNDLE_START': {\n        if (argv.silent) break;\n\n        const eventInput = event.input;\n        const inputFiles: string[] = [];\n        if (typeof eventInput === 'string') {\n          inputFiles.push(eventInput);\n        } else {\n          inputFiles.push(\n            ...(Array.isArray(eventInput) ? eventInput : Object.values(eventInput as Record<string, string>))\n          );\n        }\n        console.info(\n          chalk.cyan(\n            `Bundles ${chalk.bold(pathToRelativePath(inputFiles).join(', '))} → ${chalk.bold(\n              pathToRelativePath(event.output).join(', ')\n            )}\\non ${packageDirPath} ...`\n          )\n        );\n        break;\n      }\n      case 'BUNDLE_END': {\n        if (argv.silent) break;\n\n        console.info(\n          chalk.green(\n            `Created ${chalk.bold(pathToRelativePath(event.output).join(', '))} in ${chalk.bold(ms(event.duration))}`\n          )\n        );\n\n        if (targetDetail !== 'app-node' && targetDetail !== 'functions') {\n          await generateDeclarationFiles(argv, packageDirPath);\n        }\n        break;\n      }\n      case 'END': {\n        if (argv.silent) break;\n\n        console.info(`\\n[${dateTime()}] waiting for changes...`);\n        break;\n      }\n    }\n\n    if ('result' in event && event.result) {\n      void event.result.close();\n    }\n  });\n}\n\nfunction verifyInput(argv: ArgumentsType<typeof builder>, cwd: string, packageDirPath: string): string[] {\n  if (argv.input && argv.input.length > 0) return argv.input.map((p) => path.resolve(cwd, p.toString()));\n\n  const srcDirPath = path.join(packageDirPath, 'src');\n  for (const ext of ['ts', 'tsx', 'cts', 'mts']) {\n    const input = path.join(srcDirPath, `index.${ext}`);\n    if (fs.existsSync(input)) return [input];\n  }\n\n  console.error('Failed to detect input file.');\n  process.exit(1);\n}\n\nfunction detectTargetDetail(targetCategory: string, inputs: string[], packageDirPath: string): TargetDetail {\n  switch (targetCategory) {\n    case 'app': {\n      return 'app-node';\n    }\n    case 'functions': {\n      return 'functions';\n    }\n    case 'lib': {\n      if (inputs.some((input) => input.endsWith('.tsx')) || doesSrcContainTsx(packageDirPath)) {\n        return 'lib-react';\n      }\n      return 'lib';\n    }\n    default: {\n      console.error('target option must be one of: ' + allTargetCategories.join(', '));\n      process.exit(1);\n    }\n  }\n}\n\nfunction doesSrcContainTsx(packageDirPath: string): boolean {\n  const srcDirPath = path.join(packageDirPath, 'src');\n  return doesDirectoryContainTsx(srcDirPath);\n}\n\nfunction doesDirectoryContainTsx(dirPath: string): boolean {\n  try {\n    const entries = fs.readdirSync(dirPath, { withFileTypes: true });\n    return entries.some((entry) => {\n      const entryPath = path.join(dirPath, entry.name);\n      if (entry.isDirectory()) return doesDirectoryContainTsx(entryPath);\n      return entry.isFile() && entry.name.endsWith('.tsx');\n    });\n  } catch {\n    return false;\n  }\n}\n\nasync function generatePackageJsonForFunctions(\n  packageDirPath: string,\n  packageJson: PackageJson,\n  moduleType: string | undefined\n): Promise<void> {\n  packageJson.name += '-dist';\n  const esmPackage = packageJson.type === 'module';\n  const esmOutput = isEsmOutput(esmPackage, moduleType);\n  packageJson.main = esmPackage === esmOutput ? 'index.js' : esmOutput ? 'index.mjs' : 'index.cjs';\n\n  // Prevent Firebase Functions from running `build` script since we are building code before deploying.\n  delete packageJson.scripts;\n  // devDependencies are not required since we are building code before deploying.\n  delete packageJson.devDependencies;\n\n  await fs.promises.mkdir(path.join(packageDirPath, 'dist'), { recursive: true });\n  await fs.promises.writeFile(path.join(packageDirPath, 'dist', 'package.json'), JSON.stringify(packageJson));\n}\n\nfunction getOutputOptionsList(\n  argv: ArgumentsType<AnyBuilderType>,\n  targetDetail: TargetDetail,\n  packageDirPath: string,\n  isEsmPackage: boolean\n): OutputOptions[] {\n  const outDirPath = path.join(packageDirPath, 'dist');\n  if (targetDetail === 'app-node' || targetDetail === 'functions') {\n    return [\n      {\n        dir: outDirPath,\n        format: isEsmOutput(isEsmPackage, argv.moduleType) ? 'module' : 'commonjs',\n        sourcemap: argv.sourcemap && 'inline',\n      },\n    ];\n  }\n\n  // The following import statement in an esm module causes the following error:\n  // Statement:\n  //   import { usePrevious } from 'react-use';\n  // Error:\n  //   Named export 'usePrevious' not found. The requested module 'react-use' is a CommonJS module,\n  //   which may not support all module.exports as named exports.\n  // We need cjs modules for web apps to avoid the error.\n  // Also, splitting a library is useful in both modules, so preserveModules should be true.\n  const outputOptionsList: OutputOptions[] = [];\n  const moduleType = argv.moduleType || 'both';\n  const jsExt = argv.jsExtension || 'either';\n  if (moduleType === 'cjs' || moduleType === 'both' || (moduleType === 'either' && !isEsmPackage)) {\n    outputOptionsList.push({\n      dir: outDirPath,\n      entryFileNames: jsExt === 'both' || (jsExt === 'either' && !isEsmPackage) ? '[name].js' : '[name].cjs',\n      format: 'commonjs',\n      preserveModules: true,\n      preserveModulesRoot: path.join(packageDirPath, 'src'),\n      sourcemap: argv.sourcemap,\n    });\n  }\n  if (moduleType === 'esm' || moduleType === 'both' || (moduleType === 'either' && isEsmPackage)) {\n    outputOptionsList.push({\n      dir: outDirPath,\n      entryFileNames: jsExt === 'both' || (jsExt === 'either' && isEsmPackage) ? '[name].js' : '[name].mjs',\n      format: 'module',\n      preserveModules: true,\n      preserveModulesRoot: path.join(packageDirPath, 'src'),\n      sourcemap: argv.sourcemap,\n    });\n  }\n  return outputOptionsList;\n}\n\nfunction isEsmOutput(isEsmPackage: boolean, moduleType: string | undefined): boolean {\n  return moduleType === 'esm' || ((!moduleType || moduleType === 'either') && isEsmPackage);\n}\n","import process from 'node:process';\n\nimport chalk from 'chalk';\nimport type { RollupError } from 'rollup';\n\nexport function handleError(error: RollupError, recover = false): void {\n  const name = error.name || (error.cause as Error)?.name;\n  const nameSection = name ? `${name}: ` : '';\n  const pluginSection = error.plugin ? `(plugin ${error.plugin}) ` : '';\n  const message = `${pluginSection}${nameSection}${error.message}`;\n\n  const outputLines = [chalk.bold(chalk.red(`[!] ${chalk.bold(message.toString())}`))];\n\n  if (error.url) {\n    outputLines.push(chalk.cyan(error.url));\n  }\n\n  if (error.loc) {\n    outputLines.push(`${error.loc.file || error.id} (${error.loc.line}:${error.loc.column})`);\n  } else if (error.id) {\n    outputLines.push(error.id);\n  }\n\n  if (error.frame) {\n    outputLines.push(chalk.dim(error.frame));\n  }\n\n  if (error.stack) {\n    outputLines.push(chalk.dim(error.stack?.replace(`${nameSection}${error.message}\\n`, '')));\n  }\n\n  outputLines.push('', '');\n  console.error(outputLines.join('\\n'));\n\n  if (!recover) process.exit(1);\n}\n","import * as child_process from 'node:child_process';\n\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { loadEnvironmentVariablesWithCache } from '../env.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  ...sharedOptionsBuilder,\n  module: {\n    description: 'A module type: cjs or esm',\n    type: 'string',\n    alias: 'm',\n  },\n  watch: {\n    description: 'Whether watch mode is enabled or not',\n    type: 'boolean',\n    alias: 'w',\n  },\n} as const;\n\nexport const run: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'run <file>',\n  describe: 'Run script',\n  builder,\n  handler(argv) {\n    loadEnvironmentVariablesWithCache(argv, process.cwd());\n\n    const file = argv.file?.toString() ?? '';\n\n    // cf. https://bun.sh/guides/util/detect-bun\n    const isRunningOnBun = process.versions.bun;\n    const runtime = isRunningOnBun ? 'bun' : 'node';\n    const args = isRunningOnBun ? ['--bun'] : ['--no-warnings', '--import', 'tsx'];\n    if (argv.watch) {\n      args.push('--watch');\n    }\n    args.push(file);\n    const [, ...additionalArguments] = argv._;\n    const runtimeArgs = [...args, ...additionalArguments.map((arg) => arg.toString())];\n    if (argv.verbose) {\n      console.info(`Running '${runtime} ${runtimeArgs.join(' ')}'`);\n    }\n    const ret = child_process.spawnSync(runtime, runtimeArgs, {\n      stdio: 'inherit',\n      env: { ...process.env },\n    });\n    process.exit(ret.status ?? 1);\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { app, functions, lib } from './commands/build/build.js';\nimport { run } from './commands/run.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nremoveNpmAndYarnEnvironmentVariables(process.env);\n\nawait yargs(hideBin(process.argv))\n  .scriptName('build-ts')\n  .options(sharedOptionsBuilder)\n  .command(app)\n  .command(functions)\n  .command(lib)\n  .command(run)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n"],"names":["envVars","loadEnvironmentVariablesWithCache","argv","cwd","readAndApplyEnvironmentVariables","verbose","console","info","Object","keys","createEnvironmentVariablesDefinition","envVarsDef","envVarNames","Set","inline","flatMap","e","toString","split","autoInline","name","undefined","process","env","JSON","stringify","allTargetCategories","async","readPackageJson","dirPath","packageJsonPath","path","join","packageJsonText","fs","promises","readFile","parse","sharedOptionsBuilder","yargsOptionsBuilderForEnv","silent","description","type","alias","builder","input","default","minify","sourcemap","external","watch","keepImport","bundleBuiltins","appBuilder","moduleType","functionsBuilder","onlyPackageJson","libBuilder","jsExtension","setupPlugins","targetDetail","packageJson","namespace","packageDirPath","outputOptionsList","externalDeps","map","item","dependencies","push","peerDependencies","optionalDependencies","existsSync","packageDirs","readdirSync","withFileTypes","packageDir","isDirectory","otherPackageJson","readFileSync","extensions","babelConfigPath","url","fileURLToPath","dirname","replacePlugin","getDefaultPluginFactory","replace","jsonPlugin","json","resolvePlugin","resolve","commonjsPlugin","commonjs","terserPlugin","terser","analyzePlugin","analyze","plugins","delimiters","preventAssignment","values","nodeExternals","deps","devDeps","peerDeps","optDeps","include","RegExp","exclude","shouldBundleSameNamespaceDependencies","preferBuiltins","id","includes","moduleNames","isBabelHelpersBundled","BUILDTS_USE_BABLE_RUNTIME","babel","configFile","babelHelpers","some","opts","preserveModules","preserveDirectives","string","compress","directives","summaryOnly","module","require","createRequire","generateDeclarationFiles","coreProjectDirPath","coreConfigFile","findConfigFile","Error","projects","outDir","basename","parentDirPath","dirents","readdir","dirent","projectDirPath","allSucceeded","runTypeScriptNative","configFileDirPath","tempConfigFile","pid","Date","now","writeFile","compilerOptions","declaration","emitDeclarationOnly","noEmit","noEmitOnError","rootDir","usesNodeProtocolImport","types","typeRootsDirPath","filter","collectTypePackages","extends","toRelativeConfigPath","createTypeScriptNativeConfig","ret","child_process","spawnSync","execPath","getTypeScriptNativePath","stdio","error","status","rm","force","currentDirPath","childPath","test","fromDirPath","toFilePath","relativePath","relative","replaceAll","sep","startsWith","app","command","describe","handler","build","functions","package","exit","generatePackageJsonForFunctions","lib","targetCategory","NODE_ENV","inputs","length","p","srcDirPath","ext","verifyInput","endsWith","doesDirectoryContainTsx","doesSrcContainTsx","detectTargetDetail","packageName","match","exec","getNamespaceAndName","isEsmPackage","BUILD_TS_COREJS","BUILD_TS_COREJS_WITH_PROPOSALS","BUILD_TS_VERBOSE","BUILD_TS_TARGET_CATEGORY","BUILD_TS_TARGET_DETAIL","outDirPath","dir","format","isEsmOutput","jsExt","entryFileNames","preserveModulesRoot","getOutputOptionsList","chdir","recursive","options","fromEntries","index","extname","clearScreen","pathToRelativePath","paths","Array","isArray","watcher","output","close","removeListener","stdin","code","onExit","on","isTTY","resume","event","recover","cause","nameSection","message","plugin","outputLines","chalk","bold","red","cyan","loc","file","line","column","frame","dim","stack","handleError","eventInput","inputFiles","green","ms","duration","dateTime","result","watchRollup","bundle","buildFailed","startTime","_bundle","rollup","Promise","all","write","entry","entryPath","isFile","esmPackage","esmOutput","main","scripts","devDependencies","mkdir","run","isRunningOnBun","versions","bun","runtime","args","additionalArguments","_","runtimeArgs","arg","removeNpmAndYarnEnvironmentVariables","yargs","hideBin","scriptName","demandCommand","strict","version","packageJsonDir","URL","pathname","getVersion","help"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "build-ts",
|
|
3
|
-
"version": "17.1.
|
|
3
|
+
"version": "17.1.6",
|
|
4
4
|
"license": "UNLICENSED",
|
|
5
5
|
"author": "WillBooster Inc.",
|
|
6
6
|
"repository": {
|
|
@@ -58,7 +58,7 @@
|
|
|
58
58
|
"rollup": "4.60.1",
|
|
59
59
|
"rollup-plugin-analyzer": "4.0.0",
|
|
60
60
|
"rollup-plugin-keep-import": "1.0.3",
|
|
61
|
-
"rollup-plugin-node-externals": "
|
|
61
|
+
"rollup-plugin-node-externals": "9.0.0",
|
|
62
62
|
"rollup-plugin-preserve-directives": "0.4.0",
|
|
63
63
|
"rollup-plugin-string": "3.0.0",
|
|
64
64
|
"signal-exit": "4.1.0",
|