HEX
Server: nginx/1.24.0
System: Linux nowruzgan 6.8.0-57-generic #59-Ubuntu SMP PREEMPT_DYNAMIC Sat Mar 15 17:40:59 UTC 2025 x86_64
User: babak (1000)
PHP: 8.3.6
Disabled: NONE
Upload Files
File: /var/dev/shahnamag/back-end/node_modules/@nestjs/cli/commands/start.command.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.StartCommand = void 0;
const ui_1 = require("../lib/ui");
const remaining_flags_1 = require("../lib/utils/remaining-flags");
const abstract_command_1 = require("./abstract.command");
class StartCommand extends abstract_command_1.AbstractCommand {
    load(program) {
        program
            .command('start [app]')
            .allowUnknownOption()
            .option('-c, --config [path]', 'Path to nest-cli configuration file.')
            .option('-p, --path [path]', 'Path to tsconfig file.')
            .option('-w, --watch', 'Run in watch mode (live-reload).')
            .option('-b, --builder [name]', 'Builder to be used (tsc, webpack, swc).')
            .option('--watchAssets', 'Watch non-ts (e.g., .graphql) files mode.')
            .option('-d, --debug [hostport] ', 'Run in debug mode (with --inspect flag).')
            .option('--webpack', 'Use webpack for compilation (deprecated option, use --builder instead).')
            .option('--webpackPath [path]', 'Path to webpack configuration.')
            .option('--type-check', 'Enable type checking (when SWC is used).')
            .option('--tsc', 'Use typescript compiler for compilation.')
            .option('--sourceRoot [sourceRoot]', 'Points at the root of the source code for the single project in standard mode structures, or the default project in monorepo mode structures.')
            .option('--entryFile [entryFile]', "Path to the entry file where this command will work with. Defaults to the one defined at your Nest's CLI config file.")
            .option('-e, --exec [binary]', 'Binary to run (default: "node").')
            .option('--preserveWatchOutput', 'Use "preserveWatchOutput" option when using tsc watch mode.')
            .option('--shell', "Spawn child processes within a shell (see node's child_process.spawn() method docs). Default: true.", true)
            .option('--no-shell', 'Do not spawn child processes within a shell.')
            .option('--env-file [path]', 'Path to an env file (.env) to be loaded into the environment.')
            .description('Run Nest application.')
            .action(async (app, command) => {
            const options = [];
            options.push({
                name: 'config',
                value: command.config,
            });
            const isWebpackEnabled = command.tsc ? false : command.webpack;
            options.push({ name: 'webpack', value: isWebpackEnabled });
            options.push({ name: 'debug', value: command.debug });
            options.push({ name: 'watch', value: !!command.watch });
            options.push({ name: 'watchAssets', value: !!command.watchAssets });
            options.push({
                name: 'path',
                value: command.path,
            });
            options.push({
                name: 'webpackPath',
                value: command.webpackPath,
            });
            options.push({
                name: 'exec',
                value: command.exec,
            });
            options.push({
                name: 'sourceRoot',
                value: command.sourceRoot,
            });
            options.push({
                name: 'entryFile',
                value: command.entryFile,
            });
            options.push({
                name: 'preserveWatchOutput',
                value: !!command.preserveWatchOutput &&
                    !!command.watch &&
                    !isWebpackEnabled,
            });
            options.push({
                name: 'shell',
                value: !!command.shell,
            });
            options.push({
                name: 'envFile',
                value: command.envFile,
            });
            const availableBuilders = ['tsc', 'webpack', 'swc'];
            if (command.builder && !availableBuilders.includes(command.builder)) {
                console.error(ui_1.ERROR_PREFIX +
                    ` Invalid builder option: ${command.builder}. Available builders: ${availableBuilders.join(', ')}`);
                return;
            }
            options.push({
                name: 'builder',
                value: command.builder,
            });
            options.push({
                name: 'typeCheck',
                value: command.typeCheck,
            });
            const inputs = [];
            inputs.push({ name: 'app', value: app });
            const flags = (0, remaining_flags_1.getRemainingFlags)(program);
            try {
                await this.action.handle(inputs, options, flags);
            }
            catch (err) {
                process.exit(1);
            }
        });
    }
}
exports.StartCommand = StartCommand;