UNPKG

@selfage/bundler_cli

Version:

CLI for bundling and running bundled frontend or backend TypeScript files.

196 lines 36.3 kB
#!/usr/bin/env node "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const fs = require("fs"); const path = require("path"); const bundler_1 = require("./bundler"); const runner_in_node_1 = require("./runner_in_node"); const runner_in_puppeteer_1 = require("./runner_in_puppeteer"); const to_unix_path_1 = require("./to_unix_path"); const web_app_bundler_1 = require("./web_app_bundler"); const web_server_bundler_1 = require("./web_server_bundler"); const commander_1 = require("commander"); require("source-map-support/register"); let EXTRA_FILES_OPTION = [ "-e, --extra-files <extraFiles...>", `Extra TypeScript files to be bundled together with and before the source ` + `file.`, ]; let INLINE_JS_CODE_OPTION = [ "-i, --inline-js <inlineJs...>", `Inline JavaScript code to be bundled together with and before all files.`, ]; let ASSET_EXT_OPTION = [ "-a, --asset-exts <assetExts...>", `A list of file exts that are treated as assets. E.g., with ` + `"-a .png .jpg", you could \`import imagePath = require('./image.png')\` ` + `which enables \`<img src={imagePath}>\` or ` + `\`fs.readFileSync(imagePath)\`. If not provided, it will look for ` + `\`assetExts\` field in ./package.json which should be a list of strings.`, ]; let SKIP_MINIFY_OPTION = [ "-s, --skip-minify", `Skip minification when bundling. Useful for inspecting bundling issues.`, ]; let DEBUG_OPTION = [ "-d, --debug", "Include inline source map and inline source.", ]; let TSCONFIG_FILE_OPTION = [ "-c, --tsconfig-file <file>", `The file path to tsconfig.json. If not provided, it will try to look for ` + `it at the current working directory.`, ]; let ENTRIES_CONFIG_FILE_OPTION = [ "-ec, --entries-config-file <entriesConfigFile>", `A config file to specify a list of entry files, each of which should ` + `be a single page application. Loop for "WebAppEntries" in ` + `https://github.com/selfage/bundler_cli/blob/main/web_app_entries_def.ts ` + `for its schema. Its directory is the base that all imported assets ` + `should be relative to, and a web server can serve files at this ` + `directory. If not provided, it will look for ./${web_app_bundler_1.DEFAULT_ENTRIES_CONFIG_FILE}.`, ]; let FROM_DIR_OPTION = [ "-f, --from-dir <fromDir>", `The directoy to copy from. If not provided, it will be the current ` + `working directory.`, ]; let TO_DIR_OPTION = [ "-t, --to-dir <toDir>", `The directoy to copy to. If not provided, or when <toDir> equals ` + `<fromDir>, no copies happen.`, ]; let BASE_DIR_OPTION = [ "-b, --base-dir <baseDir>", `The base directory that all imported assets should be relative to, such ` + `that a web server can serve files at this directory. If not provided, ` + `it will be the current working directory.`, ]; let OUT_DIR_OPTION = [ "-o, --out-dir <outDir>", `The output directory to where files will be copied. If not provided, or ` + `when <outDir> equals <baseDir>, no copies happen.`, ]; let PORT_OPTION = [ "-p, --port <port>", `The port number to start your local server. Default to 8000.`, ]; let NO_HEADLESS_BROWSER_OPTION = [ "-nh, --no-headless", `Turn off running the browser in headless mode.`, ]; function main() { let packageConfig = JSON.parse(fs.readFileSync(path.join(__dirname, "package.json")).toString()); let program = new commander_1.Command(); program.version(packageConfig.version); program .command("bundleForNode <sourceFile> <outputFile>") .alias("bfn") .description(`Compile and bundle from a TypeScript source file that can be run in ` + `Node. Both file exts can be neglected and are always fixed as .ts ` + `and .js respectively. Npm modules are not actually bundled due to ` + `many of them not compatible with bundling.`) .option(FROM_DIR_OPTION[0], FROM_DIR_OPTION[1]) .option(TO_DIR_OPTION[0], TO_DIR_OPTION[1]) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .action(async (sourceFile, outputFile, options) => { await (0, bundler_1.bundleForNode)((0, to_unix_path_1.toUnixPath)(sourceFile), (0, to_unix_path_1.toUnixPath)(outputFile), (0, to_unix_path_1.toUnixPath)(options.fromDir), (0, to_unix_path_1.toUnixPath)(options.toDir), (0, to_unix_path_1.toUnixPathFromBundleOptions)(options)); }); program .command("runInNode <sourceFile> [pass-through-args...]") .alias("nrun") .description(`Compile and bundle from a TypeScript source file, and run the bundled ` + `JavaScript file in Node. The file ext can be neglected and is ` + `always fixed as .ts. "--" is needed in between <sourceFile> and ` + `pass through arguments.`) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .action((sourceFile, passThroughArgs, options) => (0, runner_in_node_1.runInNode)((0, to_unix_path_1.toUnixPath)(sourceFile), (0, to_unix_path_1.toUnixPathFromBundleOptions)(options), passThroughArgs)); program .command("bundleForBrowser <sourceFile> <outputFile>") .alias("bfb") .description(`Compile and bundle from a TypeScript source file that can be run in ` + `Browser. Both file exts can be neglected and are always fixed as ` + `.ts and .js respectively.`) .option(BASE_DIR_OPTION[0], BASE_DIR_OPTION[1]) .option(OUT_DIR_OPTION[0], OUT_DIR_OPTION[1]) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .action(async (sourceFile, outputFile, options) => { await (0, bundler_1.bundleForBrowser)((0, to_unix_path_1.toUnixPath)(sourceFile), (0, to_unix_path_1.toUnixPath)(outputFile), (0, to_unix_path_1.toUnixPath)(options.baseDir), (0, to_unix_path_1.toUnixPath)(options.outDir), (0, to_unix_path_1.toUnixPathFromBundleOptions)(options)); }); program .command("runInPuppeteer <sourceFile> [pass-through-args...]") .alias("prun") .description(`Compile and bundle from a TypeScript source file, and run the bundled ` + `JavaScript file in Puppeteer, i.e., headless Chrome. The file ext ` + `can be neglected and is always fixed as .ts. "--" is needed in ` + `between <sourceFile> and pass through arguments.`) .option(BASE_DIR_OPTION[0], BASE_DIR_OPTION[1]) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .option(PORT_OPTION[0], PORT_OPTION[1], (value) => parseInt(value, 10)) .option(NO_HEADLESS_BROWSER_OPTION[0], NO_HEADLESS_BROWSER_OPTION[1]) .action((sourceFile, passThroughArgs, options) => (0, runner_in_puppeteer_1.runInPuppeteer)((0, to_unix_path_1.toUnixPath)(sourceFile), (0, to_unix_path_1.toUnixPath)(options.baseDir), options.port, options.headless, (0, to_unix_path_1.toUnixPathFromBundleOptions)(options), passThroughArgs)); program .command("bundleWebApps") .alias("bwa") .description(`Bundle all TypeScript source files based on <entriesConfig>, generate ` + `HTML files pointing to the bundled JS files respectively, compress ` + `them with Gzip, collect a list of all bundled JS & HTML file paths ` + `and asset file paths to <bundledResources>, and finally copy those ` + `files into <outDir> where your web server can be started.`) .option(ENTRIES_CONFIG_FILE_OPTION[0], ENTRIES_CONFIG_FILE_OPTION[1]) .option("-br, --bundled-resources-file <bundledResourcesFile>", `An output file generated after bundling, containing a JSON array of ` + `files that need to be copied to <outDir> and served in your web ` + `server. If not provided, it will write to ` + `./${web_app_bundler_1.DEFAULT_BUNDLED_RESOURCES_FILE}.`) .option(OUT_DIR_OPTION[0], OUT_DIR_OPTION[1]) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .action((options) => (0, web_app_bundler_1.bundleWebApps)((0, to_unix_path_1.toUnixPath)(options.entriesConfigFile), (0, to_unix_path_1.toUnixPath)(options.bundledResourcesFile), (0, to_unix_path_1.toUnixPath)(options.outDir), (0, to_unix_path_1.toUnixPathFromBundleOptions)(options))); program .command("bundleWebServer <serverSourceFile> <serverOutputFile>") .alias("bws") .description(`Bundle a TypeScript source file as the server's main file and output. ` + `Both file exts can be neglected and are always fixed as .ts and .js ` + `respectively. Npm modules are not actually bundled due to many of ` + `them not compatible with bundling. It will also bundle web apps ` + `based on <entriesConfigFile> as well as <baseDir>. Finally, all ` + `bundled files and imported or extra assets will be copied from ` + `<fromDir> to <toDir>, without any source file or intermediate file.`) .option(ENTRIES_CONFIG_FILE_OPTION[0], ENTRIES_CONFIG_FILE_OPTION[1]) .option(FROM_DIR_OPTION[0], FROM_DIR_OPTION[1]) .option(TO_DIR_OPTION[0], TO_DIR_OPTION[1]) .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1]) .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1]) .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1]) .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1]) .option(DEBUG_OPTION[0], DEBUG_OPTION[1]) .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1]) .action((serverSourceFile, serverOutputFile, options) => (0, web_server_bundler_1.bundleWebServer)((0, to_unix_path_1.toUnixPath)(serverSourceFile), (0, to_unix_path_1.toUnixPath)(serverOutputFile), (0, to_unix_path_1.toUnixPath)(options.entriesConfigFile), (0, to_unix_path_1.toUnixPath)(options.fromDir), (0, to_unix_path_1.toUnixPath)(options.toDir), (0, to_unix_path_1.toUnixPathFromBundleOptions)(options))); program.parse(); } main(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport fs = require(\"fs\");\nimport path = require(\"path\");\nimport { bundleForBrowser, bundleForNode } from \"./bundler\";\nimport { runInNode } from \"./runner_in_node\";\nimport { runInPuppeteer } from \"./runner_in_puppeteer\";\nimport { toUnixPath, toUnixPathFromBundleOptions } from \"./to_unix_path\";\nimport {\n  DEFAULT_BUNDLED_RESOURCES_FILE,\n  DEFAULT_ENTRIES_CONFIG_FILE,\n  bundleWebApps,\n} from \"./web_app_bundler\";\nimport { bundleWebServer } from \"./web_server_bundler\";\nimport { Command } from \"commander\";\nimport \"source-map-support/register\";\n\nlet EXTRA_FILES_OPTION = [\n  \"-e, --extra-files <extraFiles...>\",\n  `Extra TypeScript files to be bundled together with and before the source ` +\n    `file.`,\n];\nlet INLINE_JS_CODE_OPTION = [\n  \"-i, --inline-js <inlineJs...>\",\n  `Inline JavaScript code to be bundled together with and before all files.`,\n];\nlet ASSET_EXT_OPTION = [\n  \"-a, --asset-exts <assetExts...>\",\n  `A list of file exts that are treated as assets. E.g., with ` +\n    `\"-a .png .jpg\", you could \\`import imagePath = require('./image.png')\\` ` +\n    `which enables \\`<img src={imagePath}>\\` or ` +\n    `\\`fs.readFileSync(imagePath)\\`. If not provided, it will look for ` +\n    `\\`assetExts\\` field in ./package.json which should be a list of strings.`,\n];\nlet SKIP_MINIFY_OPTION = [\n  \"-s, --skip-minify\",\n  `Skip minification when bundling. Useful for inspecting bundling issues.`,\n];\nlet DEBUG_OPTION = [\n  \"-d, --debug\",\n  \"Include inline source map and inline source.\",\n];\nlet TSCONFIG_FILE_OPTION = [\n  \"-c, --tsconfig-file <file>\",\n  `The file path to tsconfig.json. If not provided, it will try to look for ` +\n    `it at the current working directory.`,\n];\nlet ENTRIES_CONFIG_FILE_OPTION = [\n  \"-ec, --entries-config-file <entriesConfigFile>\",\n  `A config file to specify a list of entry files, each of which should ` +\n    `be a single page application. Loop for \"WebAppEntries\" in ` +\n    `https://github.com/selfage/bundler_cli/blob/main/web_app_entries_def.ts ` +\n    `for its schema. Its directory is the base that all imported assets ` +\n    `should be relative to, and a web server can serve files at this ` +\n    `directory. If not provided, it will look for ./${DEFAULT_ENTRIES_CONFIG_FILE}.`,\n];\nlet FROM_DIR_OPTION = [\n  \"-f, --from-dir <fromDir>\",\n  `The directoy to copy from. If not provided, it will be the current ` +\n    `working directory.`,\n];\nlet TO_DIR_OPTION = [\n  \"-t, --to-dir <toDir>\",\n  `The directoy to copy to. If not provided, or when <toDir> equals ` +\n    `<fromDir>, no copies happen.`,\n];\nlet BASE_DIR_OPTION = [\n  \"-b, --base-dir <baseDir>\",\n  `The base directory that all imported assets should be relative to, such ` +\n    `that a web server can serve files at this directory. If not provided, ` +\n    `it will be the current working directory.`,\n];\nlet OUT_DIR_OPTION = [\n  \"-o, --out-dir <outDir>\",\n  `The output directory to where files will be copied. If not provided, or ` +\n    `when <outDir> equals <baseDir>, no copies happen.`,\n];\nlet PORT_OPTION = [\n  \"-p, --port <port>\",\n  `The port number to start your local server. Default to 8000.`,\n];\nlet NO_HEADLESS_BROWSER_OPTION = [\n  \"-nh, --no-headless\",\n  `Turn off running the browser in headless mode.`,\n];\n\nfunction main(): void {\n  let packageConfig = JSON.parse(\n    fs.readFileSync(path.join(__dirname, \"package.json\")).toString(),\n  );\n  let program = new Command();\n  program.version(packageConfig.version);\n  program\n    .command(\"bundleForNode <sourceFile> <outputFile>\")\n    .alias(\"bfn\")\n    .description(\n      `Compile and bundle from a TypeScript source file that can be run in ` +\n        `Node. Both file exts can be neglected and are always fixed as .ts ` +\n        `and .js respectively. Npm modules are not actually bundled due to ` +\n        `many of them not compatible with bundling.`,\n    )\n    .option(FROM_DIR_OPTION[0], FROM_DIR_OPTION[1])\n    .option(TO_DIR_OPTION[0], TO_DIR_OPTION[1])\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .action(async (sourceFile, outputFile, options) => {\n      await bundleForNode(\n        toUnixPath(sourceFile),\n        toUnixPath(outputFile),\n        toUnixPath(options.fromDir),\n        toUnixPath(options.toDir),\n        toUnixPathFromBundleOptions(options),\n      );\n    });\n  program\n    .command(\"runInNode <sourceFile> [pass-through-args...]\")\n    .alias(\"nrun\")\n    .description(\n      `Compile and bundle from a TypeScript source file, and run the bundled ` +\n        `JavaScript file in Node. The file ext can be neglected and is ` +\n        `always fixed as .ts. \"--\" is needed in between <sourceFile> and ` +\n        `pass through arguments.`,\n    )\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .action((sourceFile, passThroughArgs, options) =>\n      runInNode(\n        toUnixPath(sourceFile),\n        toUnixPathFromBundleOptions(options),\n        passThroughArgs as Array<string>,\n      ),\n    );\n  program\n    .command(\"bundleForBrowser <sourceFile> <outputFile>\")\n    .alias(\"bfb\")\n    .description(\n      `Compile and bundle from a TypeScript source file that can be run in ` +\n        `Browser. Both file exts can be neglected and are always fixed as ` +\n        `.ts and .js respectively.`,\n    )\n    .option(BASE_DIR_OPTION[0], BASE_DIR_OPTION[1])\n    .option(OUT_DIR_OPTION[0], OUT_DIR_OPTION[1])\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .action(async (sourceFile, outputFile, options) => {\n      await bundleForBrowser(\n        toUnixPath(sourceFile),\n        toUnixPath(outputFile),\n        toUnixPath(options.baseDir),\n        toUnixPath(options.outDir),\n        toUnixPathFromBundleOptions(options),\n      );\n    });\n  program\n    .command(\"runInPuppeteer <sourceFile> [pass-through-args...]\")\n    .alias(\"prun\")\n    .description(\n      `Compile and bundle from a TypeScript source file, and run the bundled ` +\n        `JavaScript file in Puppeteer, i.e., headless Chrome. The file ext ` +\n        `can be neglected and is always fixed as .ts. \"--\" is needed in ` +\n        `between <sourceFile> and pass through arguments.`,\n    )\n    .option(BASE_DIR_OPTION[0], BASE_DIR_OPTION[1])\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .option(PORT_OPTION[0], PORT_OPTION[1], (value) => parseInt(value, 10))\n    .option(NO_HEADLESS_BROWSER_OPTION[0], NO_HEADLESS_BROWSER_OPTION[1])\n    .action((sourceFile, passThroughArgs, options) =>\n      runInPuppeteer(\n        toUnixPath(sourceFile),\n        toUnixPath(options.baseDir),\n        options.port as number,\n        options.headless as boolean,\n        toUnixPathFromBundleOptions(options),\n        passThroughArgs as Array<string>,\n      ),\n    );\n  program\n    .command(\"bundleWebApps\")\n    .alias(\"bwa\")\n    .description(\n      `Bundle all TypeScript source files based on <entriesConfig>, generate ` +\n        `HTML files pointing to the bundled JS files respectively, compress ` +\n        `them with Gzip, collect a list of all bundled JS & HTML file paths ` +\n        `and asset file paths to <bundledResources>, and finally copy those ` +\n        `files into <outDir> where your web server can be started.`,\n    )\n    .option(ENTRIES_CONFIG_FILE_OPTION[0], ENTRIES_CONFIG_FILE_OPTION[1])\n    .option(\n      \"-br, --bundled-resources-file <bundledResourcesFile>\",\n      `An output file generated after bundling, containing a JSON array of ` +\n        `files that need to be copied to <outDir> and served in your web ` +\n        `server. If not provided, it will write to ` +\n        `./${DEFAULT_BUNDLED_RESOURCES_FILE}.`,\n    )\n    .option(OUT_DIR_OPTION[0], OUT_DIR_OPTION[1])\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .action((options) =>\n      bundleWebApps(\n        toUnixPath(options.entriesConfigFile),\n        toUnixPath(options.bundledResourcesFile),\n        toUnixPath(options.outDir),\n        toUnixPathFromBundleOptions(options),\n      ),\n    );\n  program\n    .command(\"bundleWebServer <serverSourceFile> <serverOutputFile>\")\n    .alias(\"bws\")\n    .description(\n      `Bundle a TypeScript source file as the server's main file and output. ` +\n        `Both file exts can be neglected and are always fixed as .ts and .js ` +\n        `respectively. Npm modules are not actually bundled due to many of ` +\n        `them not compatible with bundling. It will also bundle web apps ` +\n        `based on <entriesConfigFile> as well as <baseDir>. Finally, all ` +\n        `bundled files and imported or extra assets will be copied from ` +\n        `<fromDir> to <toDir>, without any source file or intermediate file.`,\n    )\n    .option(ENTRIES_CONFIG_FILE_OPTION[0], ENTRIES_CONFIG_FILE_OPTION[1])\n    .option(FROM_DIR_OPTION[0], FROM_DIR_OPTION[1])\n    .option(TO_DIR_OPTION[0], TO_DIR_OPTION[1])\n    .option(EXTRA_FILES_OPTION[0], EXTRA_FILES_OPTION[1])\n    .option(INLINE_JS_CODE_OPTION[0], INLINE_JS_CODE_OPTION[1])\n    .option(ASSET_EXT_OPTION[0], ASSET_EXT_OPTION[1])\n    .option(SKIP_MINIFY_OPTION[0], SKIP_MINIFY_OPTION[1])\n    .option(DEBUG_OPTION[0], DEBUG_OPTION[1])\n    .option(TSCONFIG_FILE_OPTION[0], TSCONFIG_FILE_OPTION[1])\n    .action((serverSourceFile, serverOutputFile, options) =>\n      bundleWebServer(\n        toUnixPath(serverSourceFile),\n        toUnixPath(serverOutputFile),\n        toUnixPath(options.entriesConfigFile),\n        toUnixPath(options.fromDir),\n        toUnixPath(options.toDir),\n        toUnixPathFromBundleOptions(options),\n      ),\n    );\n  program.parse();\n}\n\nmain();\n"]}