base44 0.0.7 → 0.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/cli/index.js +369 -320
  2. package/package.json +2 -2
package/dist/cli/index.js CHANGED
@@ -2,7 +2,7 @@
2
2
  import { createRequire } from "node:module";
3
3
  import { EventEmitter, addAbortListener, on, once, setMaxListeners } from "node:events";
4
4
  import { ChildProcess, execFile, spawn, spawnSync } from "node:child_process";
5
- import nodePath, { basename, dirname, join, posix, resolve, win32 } from "node:path";
5
+ import path, { basename, dirname, join, posix, resolve, win32 } from "node:path";
6
6
  import fs, { appendFileSync, createReadStream, createWriteStream, readFileSync, statSync, writeFileSync } from "node:fs";
7
7
  import y, { execArgv, execPath, hrtime, platform, stdin, stdout } from "node:process";
8
8
  import os, { constants, homedir, tmpdir } from "node:os";
@@ -13,7 +13,7 @@ import O from "node:readline";
13
13
  import Stream, { Duplex, PassThrough, Readable, Transform, Writable, getDefaultHighWaterMark } from "node:stream";
14
14
  import { fileURLToPath } from "node:url";
15
15
  import fs$1 from "fs";
16
- import path, { dirname as dirname$1, parse } from "path";
16
+ import path$1, { dirname as dirname$1, parse } from "path";
17
17
  import { finished } from "node:stream/promises";
18
18
  import EE, { EventEmitter as EventEmitter$1 } from "events";
19
19
  import fsPromises, { access, copyFile, mkdir, readFile, unlink, writeFile } from "node:fs/promises";
@@ -892,7 +892,7 @@ var require_suggestSimilar = /* @__PURE__ */ __commonJSMin(((exports) => {
892
892
  var require_command = /* @__PURE__ */ __commonJSMin(((exports) => {
893
893
  const EventEmitter$2 = __require("node:events").EventEmitter;
894
894
  const childProcess = __require("node:child_process");
895
- const path$15 = __require("node:path");
895
+ const path$16 = __require("node:path");
896
896
  const fs$10 = __require("node:fs");
897
897
  const process$3 = __require("node:process");
898
898
  const { Argument, humanReadableArgName } = require_argument();
@@ -1740,9 +1740,9 @@ Expecting one of '${allowedValues.join("', '")}'`);
1740
1740
  ".cjs"
1741
1741
  ];
1742
1742
  function findFile(baseDir, baseName) {
1743
- const localBin = path$15.resolve(baseDir, baseName);
1743
+ const localBin = path$16.resolve(baseDir, baseName);
1744
1744
  if (fs$10.existsSync(localBin)) return localBin;
1745
- if (sourceExt.includes(path$15.extname(baseName))) return void 0;
1745
+ if (sourceExt.includes(path$16.extname(baseName))) return void 0;
1746
1746
  const foundExt = sourceExt.find((ext) => fs$10.existsSync(`${localBin}${ext}`));
1747
1747
  if (foundExt) return `${localBin}${foundExt}`;
1748
1748
  }
@@ -1757,17 +1757,17 @@ Expecting one of '${allowedValues.join("', '")}'`);
1757
1757
  } catch (err) {
1758
1758
  resolvedScriptPath = this._scriptPath;
1759
1759
  }
1760
- executableDir = path$15.resolve(path$15.dirname(resolvedScriptPath), executableDir);
1760
+ executableDir = path$16.resolve(path$16.dirname(resolvedScriptPath), executableDir);
1761
1761
  }
1762
1762
  if (executableDir) {
1763
1763
  let localFile = findFile(executableDir, executableFile);
1764
1764
  if (!localFile && !subcommand._executableFile && this._scriptPath) {
1765
- const legacyName = path$15.basename(this._scriptPath, path$15.extname(this._scriptPath));
1765
+ const legacyName = path$16.basename(this._scriptPath, path$16.extname(this._scriptPath));
1766
1766
  if (legacyName !== this._name) localFile = findFile(executableDir, `${legacyName}-${subcommand._name}`);
1767
1767
  }
1768
1768
  executableFile = localFile || executableFile;
1769
1769
  }
1770
- launchWithNode = sourceExt.includes(path$15.extname(executableFile));
1770
+ launchWithNode = sourceExt.includes(path$16.extname(executableFile));
1771
1771
  let proc$1;
1772
1772
  if (process$3.platform !== "win32") if (launchWithNode) {
1773
1773
  args.unshift(executableFile);
@@ -2473,7 +2473,7 @@ Expecting one of '${allowedValues.join("', '")}'`);
2473
2473
  * @return {Command}
2474
2474
  */
2475
2475
  nameFromFilename(filename) {
2476
- this._name = path$15.basename(filename, path$15.extname(filename));
2476
+ this._name = path$16.basename(filename, path$16.extname(filename));
2477
2477
  return this;
2478
2478
  }
2479
2479
  /**
@@ -2487,9 +2487,9 @@ Expecting one of '${allowedValues.join("', '")}'`);
2487
2487
  * @param {string} [path]
2488
2488
  * @return {(string|null|Command)}
2489
2489
  */
2490
- executableDir(path$16) {
2491
- if (path$16 === void 0) return this._executableDir;
2492
- this._executableDir = path$16;
2490
+ executableDir(path$17) {
2491
+ if (path$17 === void 0) return this._executableDir;
2492
+ this._executableDir = path$17;
2493
2493
  return this;
2494
2494
  }
2495
2495
  /**
@@ -4701,11 +4701,11 @@ function aborted$1(x$2, startIndex = 0) {
4701
4701
  for (let i$1 = startIndex; i$1 < x$2.issues.length; i$1++) if (x$2.issues[i$1]?.continue !== true) return true;
4702
4702
  return false;
4703
4703
  }
4704
- function prefixIssues(path$16, issues) {
4704
+ function prefixIssues(path$17, issues) {
4705
4705
  return issues.map((iss) => {
4706
4706
  var _a$1;
4707
4707
  (_a$1 = iss).path ?? (_a$1.path = []);
4708
- iss.path.unshift(path$16);
4708
+ iss.path.unshift(path$17);
4709
4709
  return iss;
4710
4710
  });
4711
4711
  }
@@ -9212,7 +9212,7 @@ var require_package$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9212
9212
  //#region node_modules/dotenv/lib/main.js
9213
9213
  var require_main = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9214
9214
  const fs$9 = __require("fs");
9215
- const path$14 = __require("path");
9215
+ const path$15 = __require("path");
9216
9216
  const os$3 = __require("os");
9217
9217
  const crypto = __require("crypto");
9218
9218
  const version = require_package$1().version;
@@ -9350,12 +9350,12 @@ var require_main = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9350
9350
  if (options && options.path && options.path.length > 0) if (Array.isArray(options.path)) {
9351
9351
  for (const filepath of options.path) if (fs$9.existsSync(filepath)) possibleVaultPath = filepath.endsWith(".vault") ? filepath : `${filepath}.vault`;
9352
9352
  } else possibleVaultPath = options.path.endsWith(".vault") ? options.path : `${options.path}.vault`;
9353
- else possibleVaultPath = path$14.resolve(process.cwd(), ".env.vault");
9353
+ else possibleVaultPath = path$15.resolve(process.cwd(), ".env.vault");
9354
9354
  if (fs$9.existsSync(possibleVaultPath)) return possibleVaultPath;
9355
9355
  return null;
9356
9356
  }
9357
9357
  function _resolveHome(envPath) {
9358
- return envPath[0] === "~" ? path$14.join(os$3.homedir(), envPath.slice(1)) : envPath;
9358
+ return envPath[0] === "~" ? path$15.join(os$3.homedir(), envPath.slice(1)) : envPath;
9359
9359
  }
9360
9360
  function _configVault(options) {
9361
9361
  const debug = parseBoolean(process.env.DOTENV_CONFIG_DEBUG || options && options.debug);
@@ -9368,7 +9368,7 @@ var require_main = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9368
9368
  return { parsed };
9369
9369
  }
9370
9370
  function configDotenv(options) {
9371
- const dotenvPath = path$14.resolve(process.cwd(), ".env");
9371
+ const dotenvPath = path$15.resolve(process.cwd(), ".env");
9372
9372
  let encoding = "utf8";
9373
9373
  let processEnv = process.env;
9374
9374
  if (options && options.processEnv != null) processEnv = options.processEnv;
@@ -9384,11 +9384,11 @@ var require_main = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9384
9384
  }
9385
9385
  let lastError;
9386
9386
  const parsedAll = {};
9387
- for (const path$16 of optionPaths) try {
9388
- const parsed = DotenvModule.parse(fs$9.readFileSync(path$16, { encoding }));
9387
+ for (const path$17 of optionPaths) try {
9388
+ const parsed = DotenvModule.parse(fs$9.readFileSync(path$17, { encoding }));
9389
9389
  DotenvModule.populate(parsedAll, parsed, options);
9390
9390
  } catch (e$1) {
9391
- if (debug) _debug(`Failed to load ${path$16} ${e$1.message}`);
9391
+ if (debug) _debug(`Failed to load ${path$17} ${e$1.message}`);
9392
9392
  lastError = e$1;
9393
9393
  }
9394
9394
  const populated = DotenvModule.populate(processEnv, parsedAll, options);
@@ -9398,7 +9398,7 @@ var require_main = /* @__PURE__ */ __commonJSMin(((exports, module) => {
9398
9398
  const keysCount = Object.keys(populated).length;
9399
9399
  const shortPaths = [];
9400
9400
  for (const filePath of optionPaths) try {
9401
- const relative = path$14.relative(process.cwd(), filePath);
9401
+ const relative = path$15.relative(process.cwd(), filePath);
9402
9402
  shortPaths.push(relative);
9403
9403
  } catch (e$1) {
9404
9404
  if (debug) _debug(`Failed to load ${filePath} ${e$1.message}`);
@@ -9716,7 +9716,7 @@ var require_path = /* @__PURE__ */ __commonJSMin(((exports) => {
9716
9716
  Object.defineProperty(exports, "__esModule", { value: true });
9717
9717
  exports.convertPosixPathToPattern = exports.convertWindowsPathToPattern = exports.convertPathToPattern = exports.escapePosixPath = exports.escapeWindowsPath = exports.escape = exports.removeLeadingDotSegment = exports.makeAbsolute = exports.unixify = void 0;
9718
9718
  const os$2 = __require("os");
9719
- const path$13 = __require("path");
9719
+ const path$14 = __require("path");
9720
9720
  const IS_WINDOWS_PLATFORM = os$2.platform() === "win32";
9721
9721
  const LEADING_DOT_SEGMENT_CHARACTERS_COUNT = 2;
9722
9722
  /**
@@ -9745,7 +9745,7 @@ var require_path = /* @__PURE__ */ __commonJSMin(((exports) => {
9745
9745
  }
9746
9746
  exports.unixify = unixify;
9747
9747
  function makeAbsolute(cwd, filepath) {
9748
- return path$13.resolve(cwd, filepath);
9748
+ return path$14.resolve(cwd, filepath);
9749
9749
  }
9750
9750
  exports.makeAbsolute = makeAbsolute;
9751
9751
  function removeLeadingDotSegment(entry) {
@@ -11011,7 +11011,7 @@ var require_braces = /* @__PURE__ */ __commonJSMin(((exports, module) => {
11011
11011
  //#endregion
11012
11012
  //#region node_modules/micromatch/node_modules/picomatch/lib/constants.js
11013
11013
  var require_constants$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
11014
- const path$12 = __require("path");
11014
+ const path$13 = __require("path");
11015
11015
  const WIN_SLASH = "\\\\/";
11016
11016
  const WIN_NO_SLASH = `[^${WIN_SLASH}]`;
11017
11017
  /**
@@ -11136,7 +11136,7 @@ var require_constants$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
11136
11136
  CHAR_UNDERSCORE: 95,
11137
11137
  CHAR_VERTICAL_LINE: 124,
11138
11138
  CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279,
11139
- SEP: path$12.sep,
11139
+ SEP: path$13.sep,
11140
11140
  extglobChars(chars) {
11141
11141
  return {
11142
11142
  "!": {
@@ -11175,7 +11175,7 @@ var require_constants$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
11175
11175
  //#endregion
11176
11176
  //#region node_modules/micromatch/node_modules/picomatch/lib/utils.js
11177
11177
  var require_utils$3 = /* @__PURE__ */ __commonJSMin(((exports) => {
11178
- const path$11 = __require("path");
11178
+ const path$12 = __require("path");
11179
11179
  const win32 = process.platform === "win32";
11180
11180
  const { REGEX_BACKSLASH, REGEX_REMOVE_BACKSLASH, REGEX_SPECIAL_CHARS, REGEX_SPECIAL_CHARS_GLOBAL } = require_constants$1();
11181
11181
  exports.isObject = (val) => val !== null && typeof val === "object" && !Array.isArray(val);
@@ -11195,7 +11195,7 @@ var require_utils$3 = /* @__PURE__ */ __commonJSMin(((exports) => {
11195
11195
  };
11196
11196
  exports.isWindows = (options) => {
11197
11197
  if (options && typeof options.windows === "boolean") return options.windows;
11198
- return win32 === true || path$11.sep === "\\";
11198
+ return win32 === true || path$12.sep === "\\";
11199
11199
  };
11200
11200
  exports.escapeLast = (input, char, lastIdx) => {
11201
11201
  const idx = input.lastIndexOf(char, lastIdx);
@@ -12342,7 +12342,7 @@ var require_parse$2 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
12342
12342
  if (opts$1.noglobstar === true) return star;
12343
12343
  return `(${capture}(?:(?!${START_ANCHOR}${opts$1.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;
12344
12344
  };
12345
- const create$2 = (str) => {
12345
+ const create$1 = (str) => {
12346
12346
  switch (str) {
12347
12347
  case "*": return `${nodot}${ONE_CHAR}${star}`;
12348
12348
  case ".*": return `${DOT_LITERAL}${ONE_CHAR}${star}`;
@@ -12355,13 +12355,13 @@ var require_parse$2 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
12355
12355
  default: {
12356
12356
  const match = /^(.*?)\.(\w+)$/.exec(str);
12357
12357
  if (!match) return;
12358
- const source$1 = create$2(match[1]);
12358
+ const source$1 = create$1(match[1]);
12359
12359
  if (!source$1) return;
12360
12360
  return source$1 + DOT_LITERAL + match[2];
12361
12361
  }
12362
12362
  }
12363
12363
  };
12364
- let source = create$2(utils.removePrefix(input, state));
12364
+ let source = create$1(utils.removePrefix(input, state));
12365
12365
  if (source && opts.strictSlashes !== true) source += `${SLASH_LITERAL}?`;
12366
12366
  return source;
12367
12367
  };
@@ -12371,7 +12371,7 @@ var require_parse$2 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
12371
12371
  //#endregion
12372
12372
  //#region node_modules/micromatch/node_modules/picomatch/lib/picomatch.js
12373
12373
  var require_picomatch$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
12374
- const path$10 = __require("path");
12374
+ const path$11 = __require("path");
12375
12375
  const scan = require_scan();
12376
12376
  const parse = require_parse$2();
12377
12377
  const utils = require_utils$3();
@@ -12510,7 +12510,7 @@ var require_picomatch$1 = /* @__PURE__ */ __commonJSMin(((exports, module) => {
12510
12510
  * @api public
12511
12511
  */
12512
12512
  picomatch.matchBase = (input, glob, options, posix$1 = utils.isWindows(options)) => {
12513
- return (glob instanceof RegExp ? glob : picomatch.makeRe(glob, options)).test(path$10.basename(input));
12513
+ return (glob instanceof RegExp ? glob : picomatch.makeRe(glob, options)).test(path$11.basename(input));
12514
12514
  };
12515
12515
  /**
12516
12516
  * Returns true if **any** of the given glob `patterns` match the specified `string`.
@@ -13068,7 +13068,7 @@ var require_micromatch = /* @__PURE__ */ __commonJSMin(((exports, module) => {
13068
13068
  var require_pattern = /* @__PURE__ */ __commonJSMin(((exports) => {
13069
13069
  Object.defineProperty(exports, "__esModule", { value: true });
13070
13070
  exports.isAbsolute = exports.partitionAbsoluteAndRelative = exports.removeDuplicateSlashes = exports.matchAny = exports.convertPatternsToRe = exports.makeRe = exports.getPatternParts = exports.expandBraceExpansion = exports.expandPatternsWithBraceExpansion = exports.isAffectDepthOfReadingPattern = exports.endsWithSlashGlobStar = exports.hasGlobStar = exports.getBaseDirectory = exports.isPatternRelatedToParentDirectory = exports.getPatternsOutsideCurrentDirectory = exports.getPatternsInsideCurrentDirectory = exports.getPositivePatterns = exports.getNegativePatterns = exports.isPositivePattern = exports.isNegativePattern = exports.convertToNegativePattern = exports.convertToPositivePattern = exports.isDynamicPattern = exports.isStaticPattern = void 0;
13071
- const path$9 = __require("path");
13071
+ const path$10 = __require("path");
13072
13072
  const globParent = require_glob_parent();
13073
13073
  const micromatch = require_micromatch();
13074
13074
  const GLOBSTAR = "**";
@@ -13176,7 +13176,7 @@ var require_pattern = /* @__PURE__ */ __commonJSMin(((exports) => {
13176
13176
  }
13177
13177
  exports.endsWithSlashGlobStar = endsWithSlashGlobStar;
13178
13178
  function isAffectDepthOfReadingPattern(pattern) {
13179
- const basename$1 = path$9.basename(pattern);
13179
+ const basename$1 = path$10.basename(pattern);
13180
13180
  return endsWithSlashGlobStar(pattern) || isStaticPattern(basename$1);
13181
13181
  }
13182
13182
  exports.isAffectDepthOfReadingPattern = isAffectDepthOfReadingPattern;
@@ -13250,7 +13250,7 @@ var require_pattern = /* @__PURE__ */ __commonJSMin(((exports) => {
13250
13250
  }
13251
13251
  exports.partitionAbsoluteAndRelative = partitionAbsoluteAndRelative;
13252
13252
  function isAbsolute(pattern) {
13253
- return path$9.isAbsolute(pattern);
13253
+ return path$10.isAbsolute(pattern);
13254
13254
  }
13255
13255
  exports.isAbsolute = isAbsolute;
13256
13256
  }));
@@ -13493,8 +13493,8 @@ var require_tasks = /* @__PURE__ */ __commonJSMin(((exports) => {
13493
13493
  var require_async$5 = /* @__PURE__ */ __commonJSMin(((exports) => {
13494
13494
  Object.defineProperty(exports, "__esModule", { value: true });
13495
13495
  exports.read = void 0;
13496
- function read(path$16, settings, callback) {
13497
- settings.fs.lstat(path$16, (lstatError, lstat) => {
13496
+ function read(path$17, settings, callback) {
13497
+ settings.fs.lstat(path$17, (lstatError, lstat) => {
13498
13498
  if (lstatError !== null) {
13499
13499
  callFailureCallback(callback, lstatError);
13500
13500
  return;
@@ -13503,7 +13503,7 @@ var require_async$5 = /* @__PURE__ */ __commonJSMin(((exports) => {
13503
13503
  callSuccessCallback(callback, lstat);
13504
13504
  return;
13505
13505
  }
13506
- settings.fs.stat(path$16, (statError, stat) => {
13506
+ settings.fs.stat(path$17, (statError, stat) => {
13507
13507
  if (statError !== null) {
13508
13508
  if (settings.throwErrorOnBrokenSymbolicLink) {
13509
13509
  callFailureCallback(callback, statError);
@@ -13531,11 +13531,11 @@ var require_async$5 = /* @__PURE__ */ __commonJSMin(((exports) => {
13531
13531
  var require_sync$5 = /* @__PURE__ */ __commonJSMin(((exports) => {
13532
13532
  Object.defineProperty(exports, "__esModule", { value: true });
13533
13533
  exports.read = void 0;
13534
- function read(path$16, settings) {
13535
- const lstat = settings.fs.lstatSync(path$16);
13534
+ function read(path$17, settings) {
13535
+ const lstat = settings.fs.lstatSync(path$17);
13536
13536
  if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) return lstat;
13537
13537
  try {
13538
- const stat = settings.fs.statSync(path$16);
13538
+ const stat = settings.fs.statSync(path$17);
13539
13539
  if (settings.markSymbolicLink) stat.isSymbolicLink = () => true;
13540
13540
  return stat;
13541
13541
  } catch (error) {
@@ -13594,17 +13594,17 @@ var require_out$3 = /* @__PURE__ */ __commonJSMin(((exports) => {
13594
13594
  const sync = require_sync$5();
13595
13595
  const settings_1 = require_settings$3();
13596
13596
  exports.Settings = settings_1.default;
13597
- function stat(path$16, optionsOrSettingsOrCallback, callback) {
13597
+ function stat(path$17, optionsOrSettingsOrCallback, callback) {
13598
13598
  if (typeof optionsOrSettingsOrCallback === "function") {
13599
- async.read(path$16, getSettings(), optionsOrSettingsOrCallback);
13599
+ async.read(path$17, getSettings(), optionsOrSettingsOrCallback);
13600
13600
  return;
13601
13601
  }
13602
- async.read(path$16, getSettings(optionsOrSettingsOrCallback), callback);
13602
+ async.read(path$17, getSettings(optionsOrSettingsOrCallback), callback);
13603
13603
  }
13604
13604
  exports.stat = stat;
13605
- function statSync(path$16, optionsOrSettings) {
13605
+ function statSync(path$17, optionsOrSettings) {
13606
13606
  const settings = getSettings(optionsOrSettings);
13607
- return sync.read(path$16, settings);
13607
+ return sync.read(path$17, settings);
13608
13608
  }
13609
13609
  exports.statSync = statSync;
13610
13610
  function getSettings(settingsOrOptions = {}) {
@@ -13803,16 +13803,16 @@ var require_async$4 = /* @__PURE__ */ __commonJSMin(((exports) => {
13803
13803
  return;
13804
13804
  }
13805
13805
  rpl(names.map((name$1) => {
13806
- const path$16 = common.joinPathSegments(directory, name$1, settings.pathSegmentSeparator);
13806
+ const path$17 = common.joinPathSegments(directory, name$1, settings.pathSegmentSeparator);
13807
13807
  return (done) => {
13808
- fsStat.stat(path$16, settings.fsStatSettings, (error, stats) => {
13808
+ fsStat.stat(path$17, settings.fsStatSettings, (error, stats) => {
13809
13809
  if (error !== null) {
13810
13810
  done(error);
13811
13811
  return;
13812
13812
  }
13813
13813
  const entry = {
13814
13814
  name: name$1,
13815
- path: path$16,
13815
+ path: path$17,
13816
13816
  dirent: utils.fs.createDirentFromStats(name$1, stats)
13817
13817
  };
13818
13818
  if (settings.stats) entry.stats = stats;
@@ -13909,7 +13909,7 @@ var require_fs = /* @__PURE__ */ __commonJSMin(((exports) => {
13909
13909
  //#region node_modules/@nodelib/fs.scandir/out/settings.js
13910
13910
  var require_settings$2 = /* @__PURE__ */ __commonJSMin(((exports) => {
13911
13911
  Object.defineProperty(exports, "__esModule", { value: true });
13912
- const path$8 = __require("path");
13912
+ const path$9 = __require("path");
13913
13913
  const fsStat = require_out$3();
13914
13914
  const fs = require_fs();
13915
13915
  var Settings = class {
@@ -13917,7 +13917,7 @@ var require_settings$2 = /* @__PURE__ */ __commonJSMin(((exports) => {
13917
13917
  this._options = _options;
13918
13918
  this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false);
13919
13919
  this.fs = fs.createFileSystemAdapter(this._options.fs);
13920
- this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path$8.sep);
13920
+ this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path$9.sep);
13921
13921
  this.stats = this._getValue(this._options.stats, false);
13922
13922
  this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
13923
13923
  this.fsStatSettings = new fsStat.Settings({
@@ -13942,17 +13942,17 @@ var require_out$2 = /* @__PURE__ */ __commonJSMin(((exports) => {
13942
13942
  const sync = require_sync$4();
13943
13943
  const settings_1 = require_settings$2();
13944
13944
  exports.Settings = settings_1.default;
13945
- function scandir(path$16, optionsOrSettingsOrCallback, callback) {
13945
+ function scandir(path$17, optionsOrSettingsOrCallback, callback) {
13946
13946
  if (typeof optionsOrSettingsOrCallback === "function") {
13947
- async.read(path$16, getSettings(), optionsOrSettingsOrCallback);
13947
+ async.read(path$17, getSettings(), optionsOrSettingsOrCallback);
13948
13948
  return;
13949
13949
  }
13950
- async.read(path$16, getSettings(optionsOrSettingsOrCallback), callback);
13950
+ async.read(path$17, getSettings(optionsOrSettingsOrCallback), callback);
13951
13951
  }
13952
13952
  exports.scandir = scandir;
13953
- function scandirSync(path$16, optionsOrSettings) {
13953
+ function scandirSync(path$17, optionsOrSettings) {
13954
13954
  const settings = getSettings(optionsOrSettings);
13955
- return sync.read(path$16, settings);
13955
+ return sync.read(path$17, settings);
13956
13956
  }
13957
13957
  exports.scandirSync = scandirSync;
13958
13958
  function getSettings(settingsOrOptions = {}) {
@@ -14522,7 +14522,7 @@ var require_sync$2 = /* @__PURE__ */ __commonJSMin(((exports) => {
14522
14522
  //#region node_modules/@nodelib/fs.walk/out/settings.js
14523
14523
  var require_settings$1 = /* @__PURE__ */ __commonJSMin(((exports) => {
14524
14524
  Object.defineProperty(exports, "__esModule", { value: true });
14525
- const path$7 = __require("path");
14525
+ const path$8 = __require("path");
14526
14526
  const fsScandir = require_out$2();
14527
14527
  var Settings = class {
14528
14528
  constructor(_options = {}) {
@@ -14532,7 +14532,7 @@ var require_settings$1 = /* @__PURE__ */ __commonJSMin(((exports) => {
14532
14532
  this.deepFilter = this._getValue(this._options.deepFilter, null);
14533
14533
  this.entryFilter = this._getValue(this._options.entryFilter, null);
14534
14534
  this.errorFilter = this._getValue(this._options.errorFilter, null);
14535
- this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path$7.sep);
14535
+ this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path$8.sep);
14536
14536
  this.fsScandirSettings = new fsScandir.Settings({
14537
14537
  followSymbolicLinks: this._options.followSymbolicLinks,
14538
14538
  fs: this._options.fs,
@@ -14586,7 +14586,7 @@ var require_out$1 = /* @__PURE__ */ __commonJSMin(((exports) => {
14586
14586
  //#region node_modules/fast-glob/out/readers/reader.js
14587
14587
  var require_reader = /* @__PURE__ */ __commonJSMin(((exports) => {
14588
14588
  Object.defineProperty(exports, "__esModule", { value: true });
14589
- const path$6 = __require("path");
14589
+ const path$7 = __require("path");
14590
14590
  const fsStat = require_out$3();
14591
14591
  const utils = require_utils$2();
14592
14592
  var Reader = class {
@@ -14599,7 +14599,7 @@ var require_reader = /* @__PURE__ */ __commonJSMin(((exports) => {
14599
14599
  });
14600
14600
  }
14601
14601
  _getFullEntryPath(filepath) {
14602
- return path$6.resolve(this._settings.cwd, filepath);
14602
+ return path$7.resolve(this._settings.cwd, filepath);
14603
14603
  }
14604
14604
  _makeEntry(stats, pattern) {
14605
14605
  const entry = {
@@ -14943,7 +14943,7 @@ var require_entry = /* @__PURE__ */ __commonJSMin(((exports) => {
14943
14943
  //#region node_modules/fast-glob/out/providers/provider.js
14944
14944
  var require_provider = /* @__PURE__ */ __commonJSMin(((exports) => {
14945
14945
  Object.defineProperty(exports, "__esModule", { value: true });
14946
- const path$5 = __require("path");
14946
+ const path$6 = __require("path");
14947
14947
  const deep_1 = require_deep();
14948
14948
  const entry_1 = require_entry$1();
14949
14949
  const error_1 = require_error();
@@ -14957,7 +14957,7 @@ var require_provider = /* @__PURE__ */ __commonJSMin(((exports) => {
14957
14957
  this.entryTransformer = new entry_2.default(this._settings);
14958
14958
  }
14959
14959
  _getRootDirectory(task) {
14960
- return path$5.resolve(this._settings.cwd, task.base);
14960
+ return path$6.resolve(this._settings.cwd, task.base);
14961
14961
  }
14962
14962
  _getReaderOptions(task) {
14963
14963
  const basePath = task.base === "." ? "" : task.base;
@@ -15410,14 +15410,14 @@ var require_ignore = /* @__PURE__ */ __commonJSMin(((exports, module) => {
15410
15410
  makeArray(isString(pattern) ? splitPattern(pattern) : pattern).forEach(this._add, this);
15411
15411
  return this._added;
15412
15412
  }
15413
- test(path$16, checkUnignored, mode) {
15413
+ test(path$17, checkUnignored, mode) {
15414
15414
  let ignored = false;
15415
15415
  let unignored = false;
15416
15416
  let matchedRule;
15417
15417
  this._rules.forEach((rule) => {
15418
15418
  const { negative } = rule;
15419
15419
  if (unignored === negative && ignored !== unignored || negative && !ignored && !unignored && !checkUnignored) return;
15420
- if (!rule[mode].test(path$16)) return;
15420
+ if (!rule[mode].test(path$17)) return;
15421
15421
  ignored = !negative;
15422
15422
  unignored = negative;
15423
15423
  matchedRule = negative ? UNDEFINED : rule;
@@ -15433,13 +15433,13 @@ var require_ignore = /* @__PURE__ */ __commonJSMin(((exports, module) => {
15433
15433
  const throwError = (message, Ctor) => {
15434
15434
  throw new Ctor(message);
15435
15435
  };
15436
- const checkPath = (path$16, originalPath, doThrow) => {
15437
- if (!isString(path$16)) return doThrow(`path must be a string, but got \`${originalPath}\``, TypeError);
15438
- if (!path$16) return doThrow(`path must not be empty`, TypeError);
15439
- if (checkPath.isNotRelative(path$16)) return doThrow(`path should be a \`path.relative()\`d string, but got "${originalPath}"`, RangeError);
15436
+ const checkPath = (path$17, originalPath, doThrow) => {
15437
+ if (!isString(path$17)) return doThrow(`path must be a string, but got \`${originalPath}\``, TypeError);
15438
+ if (!path$17) return doThrow(`path must not be empty`, TypeError);
15439
+ if (checkPath.isNotRelative(path$17)) return doThrow(`path should be a \`path.relative()\`d string, but got "${originalPath}"`, RangeError);
15440
15440
  return true;
15441
15441
  };
15442
- const isNotRelative = (path$16) => REGEX_TEST_INVALID_PATH.test(path$16);
15442
+ const isNotRelative = (path$17) => REGEX_TEST_INVALID_PATH.test(path$17);
15443
15443
  checkPath.isNotRelative = isNotRelative;
15444
15444
  /* istanbul ignore next */
15445
15445
  checkPath.convert = (p$1) => p$1;
@@ -15462,49 +15462,49 @@ var require_ignore = /* @__PURE__ */ __commonJSMin(((exports, module) => {
15462
15462
  return this.add(pattern);
15463
15463
  }
15464
15464
  _test(originalPath, cache$1, checkUnignored, slices) {
15465
- const path$16 = originalPath && checkPath.convert(originalPath);
15466
- checkPath(path$16, originalPath, this._strictPathCheck ? throwError : RETURN_FALSE);
15467
- return this._t(path$16, cache$1, checkUnignored, slices);
15465
+ const path$17 = originalPath && checkPath.convert(originalPath);
15466
+ checkPath(path$17, originalPath, this._strictPathCheck ? throwError : RETURN_FALSE);
15467
+ return this._t(path$17, cache$1, checkUnignored, slices);
15468
15468
  }
15469
- checkIgnore(path$16) {
15470
- if (!REGEX_TEST_TRAILING_SLASH.test(path$16)) return this.test(path$16);
15471
- const slices = path$16.split(SLASH).filter(Boolean);
15469
+ checkIgnore(path$17) {
15470
+ if (!REGEX_TEST_TRAILING_SLASH.test(path$17)) return this.test(path$17);
15471
+ const slices = path$17.split(SLASH).filter(Boolean);
15472
15472
  slices.pop();
15473
15473
  if (slices.length) {
15474
15474
  const parent = this._t(slices.join(SLASH) + SLASH, this._testCache, true, slices);
15475
15475
  if (parent.ignored) return parent;
15476
15476
  }
15477
- return this._rules.test(path$16, false, MODE_CHECK_IGNORE);
15477
+ return this._rules.test(path$17, false, MODE_CHECK_IGNORE);
15478
15478
  }
15479
- _t(path$16, cache$1, checkUnignored, slices) {
15480
- if (path$16 in cache$1) return cache$1[path$16];
15481
- if (!slices) slices = path$16.split(SLASH).filter(Boolean);
15479
+ _t(path$17, cache$1, checkUnignored, slices) {
15480
+ if (path$17 in cache$1) return cache$1[path$17];
15481
+ if (!slices) slices = path$17.split(SLASH).filter(Boolean);
15482
15482
  slices.pop();
15483
- if (!slices.length) return cache$1[path$16] = this._rules.test(path$16, checkUnignored, MODE_IGNORE);
15483
+ if (!slices.length) return cache$1[path$17] = this._rules.test(path$17, checkUnignored, MODE_IGNORE);
15484
15484
  const parent = this._t(slices.join(SLASH) + SLASH, cache$1, checkUnignored, slices);
15485
- return cache$1[path$16] = parent.ignored ? parent : this._rules.test(path$16, checkUnignored, MODE_IGNORE);
15485
+ return cache$1[path$17] = parent.ignored ? parent : this._rules.test(path$17, checkUnignored, MODE_IGNORE);
15486
15486
  }
15487
- ignores(path$16) {
15488
- return this._test(path$16, this._ignoreCache, false).ignored;
15487
+ ignores(path$17) {
15488
+ return this._test(path$17, this._ignoreCache, false).ignored;
15489
15489
  }
15490
15490
  createFilter() {
15491
- return (path$16) => !this.ignores(path$16);
15491
+ return (path$17) => !this.ignores(path$17);
15492
15492
  }
15493
15493
  filter(paths) {
15494
15494
  return makeArray(paths).filter(this.createFilter());
15495
15495
  }
15496
- test(path$16) {
15497
- return this._test(path$16, this._testCache, true);
15496
+ test(path$17) {
15497
+ return this._test(path$17, this._testCache, true);
15498
15498
  }
15499
15499
  };
15500
15500
  const factory = (options) => new Ignore(options);
15501
- const isPathValid = (path$16) => checkPath(path$16 && checkPath.convert(path$16), path$16, RETURN_FALSE);
15501
+ const isPathValid = (path$17) => checkPath(path$17 && checkPath.convert(path$17), path$17, RETURN_FALSE);
15502
15502
  /* istanbul ignore next */
15503
15503
  const setupWindows = () => {
15504
15504
  const makePosix = (str) => /^\\\\\?\\/.test(str) || /["<>|\u0000-\u001F]+/u.test(str) ? str : str.replace(/\\/g, "/");
15505
15505
  checkPath.convert = makePosix;
15506
15506
  const REGEX_TEST_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\//i;
15507
- checkPath.isNotRelative = (path$16) => REGEX_TEST_WINDOWS_PATH_ABSOLUTE.test(path$16) || isNotRelative(path$16);
15507
+ checkPath.isNotRelative = (path$17) => REGEX_TEST_WINDOWS_PATH_ABSOLUTE.test(path$17) || isNotRelative(path$17);
15508
15508
  };
15509
15509
  /* istanbul ignore next */
15510
15510
  if (typeof process !== "undefined" && process.platform === "win32") setupWindows();
@@ -15518,15 +15518,15 @@ var require_ignore = /* @__PURE__ */ __commonJSMin(((exports, module) => {
15518
15518
  //#region node_modules/is-path-inside/index.js
15519
15519
  var import_ignore = /* @__PURE__ */ __toESM(require_ignore(), 1);
15520
15520
  function isPathInside(childPath, parentPath) {
15521
- const relation = nodePath.relative(parentPath, childPath);
15522
- return Boolean(relation && relation !== ".." && !relation.startsWith(`..${nodePath.sep}`) && relation !== nodePath.resolve(childPath));
15521
+ const relation = path.relative(parentPath, childPath);
15522
+ return Boolean(relation && relation !== ".." && !relation.startsWith(`..${path.sep}`) && relation !== path.resolve(childPath));
15523
15523
  }
15524
15524
 
15525
15525
  //#endregion
15526
15526
  //#region node_modules/slash/index.js
15527
- function slash(path$16) {
15528
- if (path$16.startsWith("\\\\?\\")) return path$16;
15529
- return path$16.replace(/\\/g, "/");
15527
+ function slash(path$17) {
15528
+ if (path$17.startsWith("\\\\?\\")) return path$17;
15529
+ return path$17.replace(/\\/g, "/");
15530
15530
  }
15531
15531
 
15532
15532
  //#endregion
@@ -15612,7 +15612,7 @@ const buildPathChain = (startPath, rootPath) => {
15612
15612
  let currentPath = startPath;
15613
15613
  chain.push(currentPath);
15614
15614
  while (currentPath !== rootPath) {
15615
- const parentPath = nodePath.dirname(currentPath);
15615
+ const parentPath = path.dirname(currentPath);
15616
15616
  if (parentPath === currentPath) break;
15617
15617
  currentPath = parentPath;
15618
15618
  chain.push(currentPath);
@@ -15621,7 +15621,7 @@ const buildPathChain = (startPath, rootPath) => {
15621
15621
  };
15622
15622
  const findGitRootInChain = async (paths, statMethod) => {
15623
15623
  for (const directory of paths) {
15624
- const gitPath = nodePath.join(directory, ".git");
15624
+ const gitPath = path.join(directory, ".git");
15625
15625
  try {
15626
15626
  if (pathHasGitDirectory(await statMethod(gitPath))) return directory;
15627
15627
  } catch {}
@@ -15630,11 +15630,11 @@ const findGitRootInChain = async (paths, statMethod) => {
15630
15630
  const findGitRootSyncUncached = (cwd, fsImplementation) => {
15631
15631
  const statSyncMethod = getStatSyncMethod$1(fsImplementation);
15632
15632
  if (!statSyncMethod) return;
15633
- const currentPath = nodePath.resolve(cwd);
15634
- const { root } = nodePath.parse(currentPath);
15633
+ const currentPath = path.resolve(cwd);
15634
+ const { root } = path.parse(currentPath);
15635
15635
  const chain = buildPathChain(currentPath, root);
15636
15636
  for (const directory of chain) {
15637
- const gitPath = nodePath.join(directory, ".git");
15637
+ const gitPath = path.join(directory, ".git");
15638
15638
  try {
15639
15639
  if (pathHasGitDirectory(statSyncMethod(gitPath))) return directory;
15640
15640
  } catch {}
@@ -15647,8 +15647,8 @@ const findGitRootSync = (cwd, fsImplementation) => {
15647
15647
  const findGitRootAsyncUncached = async (cwd, fsImplementation) => {
15648
15648
  const statMethod = getAsyncStatMethod(fsImplementation);
15649
15649
  if (!statMethod) return findGitRootSync(cwd, fsImplementation);
15650
- const currentPath = nodePath.resolve(cwd);
15651
- const { root } = nodePath.parse(currentPath);
15650
+ const currentPath = path.resolve(cwd);
15651
+ const { root } = path.parse(currentPath);
15652
15652
  return findGitRootInChain(buildPathChain(currentPath, root), statMethod);
15653
15653
  };
15654
15654
  const findGitRoot = async (cwd, fsImplementation) => {
@@ -15663,8 +15663,8 @@ Get paths to all .gitignore files from git root to cwd (inclusive).
15663
15663
  @returns {string[]} Array of .gitignore file paths to search for.
15664
15664
  */
15665
15665
  const isWithinGitRoot = (gitRoot, cwd) => {
15666
- const resolvedGitRoot = nodePath.resolve(gitRoot);
15667
- const resolvedCwd = nodePath.resolve(cwd);
15666
+ const resolvedGitRoot = path.resolve(gitRoot);
15667
+ const resolvedCwd = path.resolve(cwd);
15668
15668
  return resolvedCwd === resolvedGitRoot || isPathInside(resolvedCwd, resolvedGitRoot);
15669
15669
  };
15670
15670
  const getParentGitignorePaths = (gitRoot, cwd) => {
@@ -15672,7 +15672,7 @@ const getParentGitignorePaths = (gitRoot, cwd) => {
15672
15672
  if (typeof cwd !== "string") throw new TypeError("cwd must be a string");
15673
15673
  if (!gitRoot) return [];
15674
15674
  if (!isWithinGitRoot(gitRoot, cwd)) return [];
15675
- return [...buildPathChain(nodePath.resolve(cwd), nodePath.resolve(gitRoot))].reverse().map((directory) => nodePath.join(directory, ".gitignore"));
15675
+ return [...buildPathChain(path.resolve(cwd), path.resolve(gitRoot))].reverse().map((directory) => path.join(directory, ".gitignore"));
15676
15676
  };
15677
15677
  /**
15678
15678
  Convert ignore patterns to fast-glob compatible format.
@@ -15779,18 +15779,18 @@ const applyBaseToPattern = (pattern, base) => {
15779
15779
  const slashIndex = cleanPattern.indexOf("/");
15780
15780
  const hasNonTrailingSlash = slashIndex !== -1 && slashIndex !== cleanPattern.length - 1;
15781
15781
  let result;
15782
- if (!hasNonTrailingSlash) result = nodePath.posix.join(base, "**", cleanPattern);
15783
- else if (cleanPattern.startsWith("/")) result = nodePath.posix.join(base, cleanPattern.slice(1));
15784
- else result = nodePath.posix.join(base, cleanPattern);
15782
+ if (!hasNonTrailingSlash) result = path.posix.join(base, "**", cleanPattern);
15783
+ else if (cleanPattern.startsWith("/")) result = path.posix.join(base, cleanPattern.slice(1));
15784
+ else result = path.posix.join(base, cleanPattern);
15785
15785
  return isNegative ? "!" + result : result;
15786
15786
  };
15787
15787
  const parseIgnoreFile = (file, cwd) => {
15788
- const base = slash(nodePath.relative(cwd, nodePath.dirname(file.filePath)));
15788
+ const base = slash(path.relative(cwd, path.dirname(file.filePath)));
15789
15789
  return file.content.split(/\r?\n/).filter((line) => line && !line.startsWith("#")).map((pattern) => applyBaseToPattern(pattern, base));
15790
15790
  };
15791
15791
  const toRelativePath = (fileOrDirectory, cwd) => {
15792
- if (nodePath.isAbsolute(fileOrDirectory)) {
15793
- const relativePath = nodePath.relative(cwd, fileOrDirectory);
15792
+ if (path.isAbsolute(fileOrDirectory)) {
15793
+ const relativePath = path.relative(cwd, fileOrDirectory);
15794
15794
  if (relativePath && !isPathInside(fileOrDirectory, cwd)) return;
15795
15795
  return relativePath;
15796
15796
  }
@@ -15800,11 +15800,11 @@ const toRelativePath = (fileOrDirectory, cwd) => {
15800
15800
  };
15801
15801
  const createIgnorePredicate = (patterns, cwd, baseDir) => {
15802
15802
  const ignores = (0, import_ignore.default)().add(patterns);
15803
- const resolvedCwd = nodePath.normalize(nodePath.resolve(cwd));
15804
- const resolvedBaseDir = nodePath.normalize(nodePath.resolve(baseDir));
15803
+ const resolvedCwd = path.normalize(path.resolve(cwd));
15804
+ const resolvedBaseDir = path.normalize(path.resolve(baseDir));
15805
15805
  return (fileOrDirectory) => {
15806
15806
  fileOrDirectory = toPath$1(fileOrDirectory);
15807
- if (nodePath.normalize(nodePath.resolve(fileOrDirectory)) === resolvedCwd) return false;
15807
+ if (path.normalize(path.resolve(fileOrDirectory)) === resolvedCwd) return false;
15808
15808
  const relativePath = toRelativePath(fileOrDirectory, resolvedBaseDir);
15809
15809
  if (relativePath === void 0) return false;
15810
15810
  return relativePath ? ignores.ignores(slash(relativePath)) : false;
@@ -15879,35 +15879,35 @@ const assertPatternsInput = (patterns) => {
15879
15879
  };
15880
15880
  const getStatMethod = (fsImplementation) => bindFsMethod(fsImplementation?.promises, "stat") ?? bindFsMethod(fs.promises, "stat") ?? promisifyFsMethod(fsImplementation, "stat");
15881
15881
  const getStatSyncMethod = (fsImplementation) => bindFsMethod(fsImplementation, "statSync") ?? bindFsMethod(fs, "statSync");
15882
- const isDirectory = async (path$16, fsImplementation) => {
15882
+ const isDirectory = async (path$17, fsImplementation) => {
15883
15883
  try {
15884
- return (await getStatMethod(fsImplementation)(path$16)).isDirectory();
15884
+ return (await getStatMethod(fsImplementation)(path$17)).isDirectory();
15885
15885
  } catch {
15886
15886
  return false;
15887
15887
  }
15888
15888
  };
15889
- const isDirectorySync = (path$16, fsImplementation) => {
15889
+ const isDirectorySync = (path$17, fsImplementation) => {
15890
15890
  try {
15891
- return getStatSyncMethod(fsImplementation)(path$16).isDirectory();
15891
+ return getStatSyncMethod(fsImplementation)(path$17).isDirectory();
15892
15892
  } catch {
15893
15893
  return false;
15894
15894
  }
15895
15895
  };
15896
15896
  const normalizePathForDirectoryGlob = (filePath, cwd) => {
15897
- const path$16 = isNegativePattern(filePath) ? filePath.slice(1) : filePath;
15898
- return nodePath.isAbsolute(path$16) ? path$16 : nodePath.join(cwd, path$16);
15897
+ const path$17 = isNegativePattern(filePath) ? filePath.slice(1) : filePath;
15898
+ return path.isAbsolute(path$17) ? path$17 : path.join(cwd, path$17);
15899
15899
  };
15900
15900
  const shouldExpandGlobstarDirectory = (pattern) => {
15901
15901
  const match = pattern?.match(/\*\*\/([^/]+)$/);
15902
15902
  if (!match) return false;
15903
15903
  const dirname$2 = match[1];
15904
15904
  const hasWildcards = /[*?[\]{}]/.test(dirname$2);
15905
- const hasExtension = nodePath.extname(dirname$2) && !dirname$2.startsWith(".");
15905
+ const hasExtension = path.extname(dirname$2) && !dirname$2.startsWith(".");
15906
15906
  return !hasWildcards && !hasExtension;
15907
15907
  };
15908
15908
  const getDirectoryGlob = ({ directoryPath, files, extensions }) => {
15909
15909
  const extensionGlob = extensions?.length > 0 ? `.${extensions.length > 1 ? `{${extensions.join(",")}}` : extensions[0]}` : "";
15910
- return files ? files.map((file) => nodePath.posix.join(directoryPath, `**/${nodePath.extname(file) ? file : `${file}${extensionGlob}`}`)) : [nodePath.posix.join(directoryPath, `**${extensionGlob ? `/*${extensionGlob}` : ""}`)];
15910
+ return files ? files.map((file) => path.posix.join(directoryPath, `**/${path.extname(file) ? file : `${file}${extensionGlob}`}`)) : [path.posix.join(directoryPath, `**${extensionGlob ? `/*${extensionGlob}` : ""}`)];
15911
15911
  };
15912
15912
  const directoryToGlob = async (directoryPaths, { cwd = y.cwd(), files, extensions, fs: fsImplementation } = {}) => {
15913
15913
  return (await Promise.all(directoryPaths.map(async (directoryPath) => {
@@ -16022,12 +16022,12 @@ const createFilterFunction = (isIgnored, cwd) => {
16022
16022
  const basePath = cwd || y.cwd();
16023
16023
  const pathCache = /* @__PURE__ */ new Map();
16024
16024
  return (fastGlobResult) => {
16025
- const pathKey$1 = nodePath.normalize(fastGlobResult.path ?? fastGlobResult);
16025
+ const pathKey$1 = path.normalize(fastGlobResult.path ?? fastGlobResult);
16026
16026
  if (seen.has(pathKey$1)) return false;
16027
16027
  if (isIgnored) {
16028
16028
  let absolutePath = pathCache.get(pathKey$1);
16029
16029
  if (absolutePath === void 0) {
16030
- absolutePath = nodePath.isAbsolute(pathKey$1) ? pathKey$1 : nodePath.resolve(basePath, pathKey$1);
16030
+ absolutePath = path.isAbsolute(pathKey$1) ? pathKey$1 : path.resolve(basePath, pathKey$1);
16031
16031
  pathCache.set(pathKey$1, absolutePath);
16032
16032
  if (pathCache.size > 1e4) pathCache.clear();
16033
16033
  }
@@ -17100,9 +17100,9 @@ var require_lib = /* @__PURE__ */ __commonJSMin(((exports, module) => {
17100
17100
  //#endregion
17101
17101
  //#region src/core/utils/fs.ts
17102
17102
  var import_lib = /* @__PURE__ */ __toESM(require_lib(), 1);
17103
- async function pathExists(path$16) {
17103
+ async function pathExists(path$17) {
17104
17104
  try {
17105
- await access(path$16);
17105
+ await access(path$17);
17106
17106
  return true;
17107
17107
  } catch {
17108
17108
  return false;
@@ -17605,7 +17605,7 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
17605
17605
  * @public
17606
17606
  */
17607
17607
  var fs$5 = __require("fs");
17608
- var path$4 = __require("path");
17608
+ var path$5 = __require("path");
17609
17609
  var utils = require_utils();
17610
17610
  var scopeOptionWarned = false;
17611
17611
  /** @type {string} */
@@ -17675,9 +17675,9 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
17675
17675
  * @return {String}
17676
17676
  */
17677
17677
  exports.resolveInclude = function(name$1, filename, isDir) {
17678
- var dirname$2 = path$4.dirname;
17679
- var extname = path$4.extname;
17680
- var resolve$1 = path$4.resolve;
17678
+ var dirname$2 = path$5.dirname;
17679
+ var extname = path$5.extname;
17680
+ var resolve$1 = path$5.resolve;
17681
17681
  var includePath = resolve$1(isDir ? filename : dirname$2(filename), name$1);
17682
17682
  if (!extname(name$1)) includePath += ".ejs";
17683
17683
  return includePath;
@@ -17703,22 +17703,22 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
17703
17703
  * @param {Options} options compilation options
17704
17704
  * @return {String}
17705
17705
  */
17706
- function getIncludePath(path$16, options) {
17706
+ function getIncludePath(path$17, options) {
17707
17707
  var includePath;
17708
17708
  var filePath;
17709
17709
  var views = options.views;
17710
- var match = /^[A-Za-z]+:\\|^\//.exec(path$16);
17710
+ var match = /^[A-Za-z]+:\\|^\//.exec(path$17);
17711
17711
  if (match && match.length) {
17712
- path$16 = path$16.replace(/^\/*/, "");
17713
- if (Array.isArray(options.root)) includePath = resolvePaths(path$16, options.root);
17714
- else includePath = exports.resolveInclude(path$16, options.root || "/", true);
17712
+ path$17 = path$17.replace(/^\/*/, "");
17713
+ if (Array.isArray(options.root)) includePath = resolvePaths(path$17, options.root);
17714
+ else includePath = exports.resolveInclude(path$17, options.root || "/", true);
17715
17715
  } else {
17716
17716
  if (options.filename) {
17717
- filePath = exports.resolveInclude(path$16, options.filename);
17717
+ filePath = exports.resolveInclude(path$17, options.filename);
17718
17718
  if (fs$5.existsSync(filePath)) includePath = filePath;
17719
17719
  }
17720
- if (!includePath && Array.isArray(views)) includePath = resolvePaths(path$16, views);
17721
- if (!includePath && typeof options.includer !== "function") throw new Error("Could not find the include file \"" + options.escapeFunction(path$16) + "\"");
17720
+ if (!includePath && Array.isArray(views)) includePath = resolvePaths(path$17, views);
17721
+ if (!includePath && typeof options.includer !== "function") throw new Error("Could not find the include file \"" + options.escapeFunction(path$17) + "\"");
17722
17722
  }
17723
17723
  return includePath;
17724
17724
  }
@@ -17810,11 +17810,11 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
17810
17810
  * Depending on the value of `options.client`, either type might be returned
17811
17811
  * @static
17812
17812
  */
17813
- function includeFile(path$16, options) {
17813
+ function includeFile(path$17, options) {
17814
17814
  var opts = utils.shallowCopy(utils.createNullProtoObjWherePossible(), options);
17815
- opts.filename = getIncludePath(path$16, opts);
17815
+ opts.filename = getIncludePath(path$17, opts);
17816
17816
  if (typeof options.includer === "function") {
17817
- var includerResult = options.includer(path$16, opts.filename);
17817
+ var includerResult = options.includer(path$17, opts.filename);
17818
17818
  if (includerResult) {
17819
17819
  if (includerResult.filename) opts.filename = includerResult.filename;
17820
17820
  if (includerResult.template) return handleCache(opts, includerResult.template);
@@ -18065,10 +18065,10 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
18065
18065
  throw e$1;
18066
18066
  }
18067
18067
  var returnedFn = opts.client ? fn : function anonymous(data) {
18068
- var include = function(path$16, includeData) {
18068
+ var include = function(path$17, includeData) {
18069
18069
  var d$2 = utils.shallowCopy(utils.createNullProtoObjWherePossible(), data);
18070
18070
  if (includeData) d$2 = utils.shallowCopy(d$2, includeData);
18071
- return includeFile(path$16, opts)(d$2);
18071
+ return includeFile(path$17, opts)(d$2);
18072
18072
  };
18073
18073
  return fn.apply(opts.context, [
18074
18074
  data || utils.createNullProtoObjWherePossible(),
@@ -18079,7 +18079,7 @@ var require_ejs = /* @__PURE__ */ __commonJSMin(((exports) => {
18079
18079
  };
18080
18080
  if (opts.filename && typeof Object.defineProperty === "function") {
18081
18081
  var filename = opts.filename;
18082
- var basename$1 = path$4.basename(filename, path$4.extname(filename));
18082
+ var basename$1 = path$5.basename(filename, path$5.extname(filename));
18083
18083
  try {
18084
18084
  Object.defineProperty(returnedFn, "name", {
18085
18085
  value: basename$1,
@@ -26260,14 +26260,12 @@ async function printAnimatedLines(lines) {
26260
26260
  //#region src/cli/utils/banner.ts
26261
26261
  const orange$1 = source_default.hex("#E86B3C");
26262
26262
  const BANNER_LINES = [
26263
- "",
26264
26263
  "██████╗ █████╗ ███████╗███████╗ ██╗ ██╗██╗ ██╗",
26265
26264
  "██╔══██╗██╔══██╗██╔════╝██╔════╝ ██║ ██║██║ ██║",
26266
26265
  "██████╔╝███████║███████╗█████╗ ███████║███████║",
26267
26266
  "██╔══██╗██╔══██║╚════██║██╔══╝ ╚════██║╚════██║",
26268
26267
  "██████╔╝██║ ██║███████║███████╗ ██║ ██║",
26269
- "╚═════╝ ╚═╝ ╚═╝╚══════╝╚══════╝ ╚═╝ ╚═╝",
26270
- ""
26268
+ "╚═════╝ ╚═╝ ╚═╝╚══════╝╚══════╝ ╚═╝ ╚═╝"
26271
26269
  ];
26272
26270
  /**
26273
26271
  * Print the Base44 banner with smooth animation if supported,
@@ -26320,6 +26318,7 @@ const base44Color = source_default.bgHex("#E86B3C");
26320
26318
  * });
26321
26319
  */
26322
26320
  async function runCommand(commandFn, options) {
26321
+ console.log();
26323
26322
  if (options?.fullBanner) {
26324
26323
  await printBanner();
26325
26324
  Ie("");
@@ -27385,15 +27384,15 @@ var ReadStream = class extends Minipass {
27385
27384
  [_size];
27386
27385
  [_remain];
27387
27386
  [_autoClose];
27388
- constructor(path$16, opt) {
27387
+ constructor(path$17, opt) {
27389
27388
  opt = opt || {};
27390
27389
  super(opt);
27391
27390
  this.readable = true;
27392
27391
  this.writable = false;
27393
- if (typeof path$16 !== "string") throw new TypeError("path must be a string");
27392
+ if (typeof path$17 !== "string") throw new TypeError("path must be a string");
27394
27393
  this[_errored] = false;
27395
27394
  this[_fd] = typeof opt.fd === "number" ? opt.fd : void 0;
27396
- this[_path] = path$16;
27395
+ this[_path] = path$17;
27397
27396
  this[_readSize] = opt.readSize || 16 * 1024 * 1024;
27398
27397
  this[_reading] = false;
27399
27398
  this[_size] = typeof opt.size === "number" ? opt.size : Infinity;
@@ -27535,10 +27534,10 @@ var WriteStream = class extends EE {
27535
27534
  [_flags];
27536
27535
  [_finished] = false;
27537
27536
  [_pos];
27538
- constructor(path$16, opt) {
27537
+ constructor(path$17, opt) {
27539
27538
  opt = opt || {};
27540
27539
  super(opt);
27541
- this[_path] = path$16;
27540
+ this[_path] = path$17;
27542
27541
  this[_fd] = typeof opt.fd === "number" ? opt.fd : void 0;
27543
27542
  this[_mode] = opt.mode === void 0 ? 438 : opt.mode;
27544
27543
  this[_pos] = typeof opt.start === "number" ? opt.start : void 0;
@@ -28297,10 +28296,10 @@ var Header = class {
28297
28296
  if (!(buf.length >= off + 512)) throw new Error("need 512 bytes for header");
28298
28297
  const prefixSize = this.ctime || this.atime ? 130 : 155;
28299
28298
  const split = splitPrefix(this.path || "", prefixSize);
28300
- const path$16 = split[0];
28299
+ const path$17 = split[0];
28301
28300
  const prefix = split[1];
28302
28301
  this.needPax = !!split[2];
28303
- this.needPax = encString(buf, off, 100, path$16) || this.needPax;
28302
+ this.needPax = encString(buf, off, 100, path$17) || this.needPax;
28304
28303
  this.needPax = encNumber(buf, off + 100, 8, this.mode) || this.needPax;
28305
28304
  this.needPax = encNumber(buf, off + 108, 8, this.uid) || this.needPax;
28306
28305
  this.needPax = encNumber(buf, off + 116, 8, this.gid) || this.needPax;
@@ -29139,16 +29138,16 @@ const modeFix = (mode, isDir, portable) => {
29139
29138
  //#endregion
29140
29139
  //#region node_modules/tar/dist/esm/strip-absolute-path.js
29141
29140
  const { isAbsolute, parse: parse$1 } = win32;
29142
- const stripAbsolutePath = (path$16) => {
29141
+ const stripAbsolutePath = (path$17) => {
29143
29142
  let r$1 = "";
29144
- let parsed = parse$1(path$16);
29145
- while (isAbsolute(path$16) || parsed.root) {
29146
- const root = path$16.charAt(0) === "/" && path$16.slice(0, 4) !== "//?/" ? "/" : parsed.root;
29147
- path$16 = path$16.slice(root.length);
29143
+ let parsed = parse$1(path$17);
29144
+ while (isAbsolute(path$17) || parsed.root) {
29145
+ const root = path$17.charAt(0) === "/" && path$17.slice(0, 4) !== "//?/" ? "/" : parsed.root;
29146
+ path$17 = path$17.slice(root.length);
29148
29147
  r$1 += root;
29149
- parsed = parse$1(path$16);
29148
+ parsed = parse$1(path$17);
29150
29149
  }
29151
- return [r$1, path$16];
29150
+ return [r$1, path$17];
29152
29151
  };
29153
29152
 
29154
29153
  //#endregion
@@ -29168,10 +29167,10 @@ const decode = (s) => win.reduce((s$1, c$1) => s$1.split(c$1).join(toRaw.get(c$1
29168
29167
 
29169
29168
  //#endregion
29170
29169
  //#region node_modules/tar/dist/esm/write-entry.js
29171
- const prefixPath = (path$16, prefix) => {
29172
- if (!prefix) return normalizeWindowsPath(path$16);
29173
- path$16 = normalizeWindowsPath(path$16).replace(/^\.(\/|$)/, "");
29174
- return stripTrailingSlashes(prefix) + "/" + path$16;
29170
+ const prefixPath = (path$17, prefix) => {
29171
+ if (!prefix) return normalizeWindowsPath(path$17);
29172
+ path$17 = normalizeWindowsPath(path$17).replace(/^\.(\/|$)/, "");
29173
+ return stripTrailingSlashes(prefix) + "/" + path$17;
29175
29174
  };
29176
29175
  const maxReadSize = 16 * 1024 * 1024;
29177
29176
  const PROCESS$1 = Symbol("process");
@@ -29253,7 +29252,7 @@ var WriteEntry = class extends Minipass {
29253
29252
  this.path = decode(this.path.replace(/\\/g, "/"));
29254
29253
  p$1 = p$1.replace(/\\/g, "/");
29255
29254
  }
29256
- this.absolute = normalizeWindowsPath(opt.absolute || path.resolve(this.cwd, p$1));
29255
+ this.absolute = normalizeWindowsPath(opt.absolute || path$1.resolve(this.cwd, p$1));
29257
29256
  if (this.path === "") this.path = "./";
29258
29257
  if (pathWarn) this.warn("TAR_ENTRY_INFO", `stripping ${pathWarn} from absolute path`, {
29259
29258
  entry: this,
@@ -29295,8 +29294,8 @@ var WriteEntry = class extends Minipass {
29295
29294
  [MODE](mode) {
29296
29295
  return modeFix(mode, this.type === "Directory", this.portable);
29297
29296
  }
29298
- [PREFIX](path$16) {
29299
- return prefixPath(path$16, this.prefix);
29297
+ [PREFIX](path$17) {
29298
+ return prefixPath(path$17, this.prefix);
29300
29299
  }
29301
29300
  [HEADER]() {
29302
29301
  /* c8 ignore start */
@@ -29362,7 +29361,7 @@ var WriteEntry = class extends Minipass {
29362
29361
  if (!this.stat) throw new Error("cannot create link entry without stat");
29363
29362
  /* c8 ignore stop */
29364
29363
  this.type = "Link";
29365
- this.linkpath = normalizeWindowsPath(path.relative(this.cwd, linkpath));
29364
+ this.linkpath = normalizeWindowsPath(path$1.relative(this.cwd, linkpath));
29366
29365
  this.stat.size = 0;
29367
29366
  this[HEADER]();
29368
29367
  this.end();
@@ -29628,8 +29627,8 @@ var WriteEntryTar = class extends Minipass {
29628
29627
  super.write(b$2);
29629
29628
  readEntry.pipe(this);
29630
29629
  }
29631
- [PREFIX](path$16) {
29632
- return prefixPath(path$16, this.prefix);
29630
+ [PREFIX](path$17) {
29631
+ return prefixPath(path$17, this.prefix);
29633
29632
  }
29634
29633
  [MODE](mode) {
29635
29634
  return modeFix(mode, this.type === "Directory", this.portable);
@@ -29938,8 +29937,8 @@ var PackJob = class {
29938
29937
  pending = false;
29939
29938
  ignore = false;
29940
29939
  piped = false;
29941
- constructor(path$16, absolute) {
29942
- this.path = path$16 || "./";
29940
+ constructor(path$17, absolute) {
29941
+ this.path = path$17 || "./";
29943
29942
  this.absolute = absolute;
29944
29943
  }
29945
29944
  };
@@ -30044,36 +30043,36 @@ var Pack = class extends Minipass {
30044
30043
  [WRITE](chunk) {
30045
30044
  return super.write(chunk);
30046
30045
  }
30047
- add(path$16) {
30048
- this.write(path$16);
30046
+ add(path$17) {
30047
+ this.write(path$17);
30049
30048
  return this;
30050
30049
  }
30051
- end(path$16, encoding, cb) {
30050
+ end(path$17, encoding, cb) {
30052
30051
  /* c8 ignore start */
30053
- if (typeof path$16 === "function") {
30054
- cb = path$16;
30055
- path$16 = void 0;
30052
+ if (typeof path$17 === "function") {
30053
+ cb = path$17;
30054
+ path$17 = void 0;
30056
30055
  }
30057
30056
  if (typeof encoding === "function") {
30058
30057
  cb = encoding;
30059
30058
  encoding = void 0;
30060
30059
  }
30061
30060
  /* c8 ignore stop */
30062
- if (path$16) this.add(path$16);
30061
+ if (path$17) this.add(path$17);
30063
30062
  this[ENDED$1] = true;
30064
30063
  this[PROCESS]();
30065
30064
  /* c8 ignore next */
30066
30065
  if (cb) cb();
30067
30066
  return this;
30068
30067
  }
30069
- write(path$16) {
30068
+ write(path$17) {
30070
30069
  if (this[ENDED$1]) throw new Error("write after end");
30071
- if (path$16 instanceof ReadEntry) this[ADDTARENTRY](path$16);
30072
- else this[ADDFSENTRY](path$16);
30070
+ if (path$17 instanceof ReadEntry) this[ADDTARENTRY](path$17);
30071
+ else this[ADDFSENTRY](path$17);
30073
30072
  return this.flowing;
30074
30073
  }
30075
30074
  [ADDTARENTRY](p$1) {
30076
- const absolute = normalizeWindowsPath(path.resolve(this.cwd, p$1.path));
30075
+ const absolute = normalizeWindowsPath(path$1.resolve(this.cwd, p$1.path));
30077
30076
  if (!this.filter(p$1.path, p$1)) p$1.resume();
30078
30077
  else {
30079
30078
  const job = new PackJob(p$1.path, absolute);
@@ -30085,7 +30084,7 @@ var Pack = class extends Minipass {
30085
30084
  this[PROCESS]();
30086
30085
  }
30087
30086
  [ADDFSENTRY](p$1) {
30088
- const absolute = normalizeWindowsPath(path.resolve(this.cwd, p$1));
30087
+ const absolute = normalizeWindowsPath(path$1.resolve(this.cwd, p$1));
30089
30088
  this[QUEUE].push(new PackJob(p$1, absolute));
30090
30089
  this[PROCESS]();
30091
30090
  }
@@ -30286,7 +30285,7 @@ const createFile = (opt, files) => {
30286
30285
  const addFilesSync$1 = (p$1, files) => {
30287
30286
  files.forEach((file) => {
30288
30287
  if (file.charAt(0) === "@") list({
30289
- file: nodePath.resolve(p$1.cwd, file.slice(1)),
30288
+ file: path.resolve(p$1.cwd, file.slice(1)),
30290
30289
  sync: true,
30291
30290
  noResume: true,
30292
30291
  onReadEntry: (entry) => p$1.add(entry)
@@ -30299,7 +30298,7 @@ const addFilesAsync$1 = async (p$1, files) => {
30299
30298
  for (let i$1 = 0; i$1 < files.length; i$1++) {
30300
30299
  const file = String(files[i$1]);
30301
30300
  if (file.charAt(0) === "@") await list({
30302
- file: nodePath.resolve(String(p$1.cwd), file.slice(1)),
30301
+ file: path.resolve(String(p$1.cwd), file.slice(1)),
30303
30302
  noResume: true,
30304
30303
  onReadEntry: (entry) => {
30305
30304
  p$1.add(entry);
@@ -30319,7 +30318,7 @@ const createAsync = (opt, files) => {
30319
30318
  addFilesAsync$1(p$1, files);
30320
30319
  return p$1;
30321
30320
  };
30322
- const create$1 = makeCommand(createFileSync, createFile, createSync, createAsync, (_opt, files) => {
30321
+ const create = makeCommand(createFileSync, createFile, createSync, createAsync, (_opt, files) => {
30323
30322
  if (!files?.length) throw new TypeError("no paths specified to add to archive");
30324
30323
  });
30325
30324
 
@@ -30337,9 +30336,9 @@ const getWriteFlag = !fMapEnabled ? () => "w" : (size) => size < fMapLimit ? fMa
30337
30336
 
30338
30337
  //#endregion
30339
30338
  //#region node_modules/chownr/dist/esm/index.js
30340
- const lchownSync = (path$16, uid, gid) => {
30339
+ const lchownSync = (path$17, uid, gid) => {
30341
30340
  try {
30342
- return fs.lchownSync(path$16, uid, gid);
30341
+ return fs.lchownSync(path$17, uid, gid);
30343
30342
  } catch (er) {
30344
30343
  if (er?.code !== "ENOENT") throw er;
30345
30344
  }
@@ -30350,11 +30349,11 @@ const chown = (cpath, uid, gid, cb) => {
30350
30349
  });
30351
30350
  };
30352
30351
  const chownrKid = (p$1, child, uid, gid, cb) => {
30353
- if (child.isDirectory()) chownr(nodePath.resolve(p$1, child.name), uid, gid, (er) => {
30352
+ if (child.isDirectory()) chownr(path.resolve(p$1, child.name), uid, gid, (er) => {
30354
30353
  if (er) return cb(er);
30355
- chown(nodePath.resolve(p$1, child.name), uid, gid, cb);
30354
+ chown(path.resolve(p$1, child.name), uid, gid, cb);
30356
30355
  });
30357
- else chown(nodePath.resolve(p$1, child.name), uid, gid, cb);
30356
+ else chown(path.resolve(p$1, child.name), uid, gid, cb);
30358
30357
  };
30359
30358
  const chownr = (p$1, uid, gid, cb) => {
30360
30359
  fs.readdir(p$1, { withFileTypes: true }, (er, children) => {
@@ -30376,8 +30375,8 @@ const chownr = (p$1, uid, gid, cb) => {
30376
30375
  });
30377
30376
  };
30378
30377
  const chownrKidSync = (p$1, child, uid, gid) => {
30379
- if (child.isDirectory()) chownrSync(nodePath.resolve(p$1, child.name), uid, gid);
30380
- lchownSync(nodePath.resolve(p$1, child.name), uid, gid);
30378
+ if (child.isDirectory()) chownrSync(path.resolve(p$1, child.name), uid, gid);
30379
+ lchownSync(path.resolve(p$1, child.name), uid, gid);
30381
30380
  };
30382
30381
  const chownrSync = (p$1, uid, gid) => {
30383
30382
  let children;
@@ -30399,9 +30398,9 @@ var CwdError = class extends Error {
30399
30398
  path;
30400
30399
  code;
30401
30400
  syscall = "chdir";
30402
- constructor(path$16, code$1) {
30403
- super(`${code$1}: Cannot cd into '${path$16}'`);
30404
- this.path = path$16;
30401
+ constructor(path$17, code$1) {
30402
+ super(`${code$1}: Cannot cd into '${path$17}'`);
30403
+ this.path = path$17;
30405
30404
  this.code = code$1;
30406
30405
  }
30407
30406
  get name() {
@@ -30416,10 +30415,10 @@ var SymlinkError = class extends Error {
30416
30415
  symlink;
30417
30416
  syscall = "symlink";
30418
30417
  code = "TAR_SYMLINK_ERROR";
30419
- constructor(symlink, path$16) {
30418
+ constructor(symlink, path$17) {
30420
30419
  super("TAR_SYMLINK_ERROR: Cannot extract through symbolic link");
30421
30420
  this.symlink = symlink;
30422
- this.path = path$16;
30421
+ this.path = path$17;
30423
30422
  }
30424
30423
  get name() {
30425
30424
  return "SymlinkError";
@@ -30465,12 +30464,12 @@ const mkdir$1 = (dir, opt, cb) => {
30465
30464
  mode,
30466
30465
  recursive: true
30467
30466
  }).then((made) => done(null, made ?? void 0), done);
30468
- mkdir_(cwd, normalizeWindowsPath(nodePath.relative(cwd, dir)).split("/"), mode, unlink$1, cwd, void 0, done);
30467
+ mkdir_(cwd, normalizeWindowsPath(path.relative(cwd, dir)).split("/"), mode, unlink$1, cwd, void 0, done);
30469
30468
  };
30470
30469
  const mkdir_ = (base, parts, mode, unlink$1, cwd, created, cb) => {
30471
30470
  if (!parts.length) return cb(null, created);
30472
30471
  const p$1 = parts.shift();
30473
- const part = normalizeWindowsPath(nodePath.resolve(base + "/" + p$1));
30472
+ const part = normalizeWindowsPath(path.resolve(base + "/" + p$1));
30474
30473
  fs.mkdir(part, mode, onmkdir(part, parts, mode, unlink$1, cwd, created, cb));
30475
30474
  };
30476
30475
  const onmkdir = (part, parts, mode, unlink$1, cwd, created, cb) => (er) => {
@@ -30526,10 +30525,10 @@ const mkdirSync = (dir, opt) => {
30526
30525
  mode,
30527
30526
  recursive: true
30528
30527
  }) ?? void 0);
30529
- const parts = normalizeWindowsPath(nodePath.relative(cwd, dir)).split("/");
30528
+ const parts = normalizeWindowsPath(path.relative(cwd, dir)).split("/");
30530
30529
  let created = void 0;
30531
30530
  for (let p$1 = parts.shift(), part = cwd; p$1 && (part += "/" + p$1); p$1 = parts.shift()) {
30532
- part = normalizeWindowsPath(nodePath.resolve(part));
30531
+ part = normalizeWindowsPath(path.resolve(part));
30533
30532
  try {
30534
30533
  fs.mkdirSync(part, mode);
30535
30534
  created = created || part;
@@ -30569,11 +30568,11 @@ const normalizeUnicode = (s) => {
30569
30568
  //#endregion
30570
30569
  //#region node_modules/tar/dist/esm/path-reservations.js
30571
30570
  const isWindows$1 = (process.env.TESTING_TAR_FAKE_PLATFORM || process.platform) === "win32";
30572
- const getDirs = (path$16) => {
30573
- return path$16.split("/").slice(0, -1).reduce((set, path$17) => {
30571
+ const getDirs = (path$17) => {
30572
+ return path$17.split("/").slice(0, -1).reduce((set, path$18) => {
30574
30573
  const s = set[set.length - 1];
30575
- if (s !== void 0) path$17 = join(s, path$17);
30576
- set.push(path$17 || "/");
30574
+ if (s !== void 0) path$18 = join(s, path$18);
30575
+ set.push(path$18 || "/");
30577
30576
  return set;
30578
30577
  }, []);
30579
30578
  };
@@ -30585,7 +30584,7 @@ var PathReservations = class {
30585
30584
  paths = isWindows$1 ? ["win32 parallelization disabled"] : paths.map((p$1) => {
30586
30585
  return stripTrailingSlashes(join(normalizeUnicode(p$1))).toLowerCase();
30587
30586
  });
30588
- const dirs = new Set(paths.map((path$16) => getDirs(path$16)).reduce((a$1, b$2) => a$1.concat(b$2)));
30587
+ const dirs = new Set(paths.map((path$17) => getDirs(path$17)).reduce((a$1, b$2) => a$1.concat(b$2)));
30589
30588
  this.#reservations.set(fn, {
30590
30589
  dirs,
30591
30590
  paths
@@ -30612,8 +30611,8 @@ var PathReservations = class {
30612
30611
  if (!res) throw new Error("function does not have any path reservations");
30613
30612
  /* c8 ignore stop */
30614
30613
  return {
30615
- paths: res.paths.map((path$16) => this.#queues.get(path$16)),
30616
- dirs: [...res.dirs].map((path$16) => this.#queues.get(path$16))
30614
+ paths: res.paths.map((path$17) => this.#queues.get(path$17)),
30615
+ dirs: [...res.dirs].map((path$17) => this.#queues.get(path$17))
30617
30616
  };
30618
30617
  }
30619
30618
  check(fn) {
@@ -30634,14 +30633,14 @@ var PathReservations = class {
30634
30633
  /* c8 ignore stop */
30635
30634
  const { paths, dirs } = res;
30636
30635
  const next = /* @__PURE__ */ new Set();
30637
- for (const path$16 of paths) {
30638
- const q$2 = this.#queues.get(path$16);
30636
+ for (const path$17 of paths) {
30637
+ const q$2 = this.#queues.get(path$17);
30639
30638
  /* c8 ignore start */
30640
30639
  if (!q$2 || q$2?.[0] !== fn) continue;
30641
30640
  /* c8 ignore stop */
30642
30641
  const q0 = q$2[1];
30643
30642
  if (!q0) {
30644
- this.#queues.delete(path$16);
30643
+ this.#queues.delete(path$17);
30645
30644
  continue;
30646
30645
  }
30647
30646
  q$2.shift();
@@ -30682,6 +30681,7 @@ const SYMLINK = Symbol("symlink");
30682
30681
  const HARDLINK = Symbol("hardlink");
30683
30682
  const UNSUPPORTED = Symbol("unsupported");
30684
30683
  const CHECKPATH = Symbol("checkPath");
30684
+ const STRIPABSOLUTEPATH = Symbol("stripAbsolutePath");
30685
30685
  const MKDIR = Symbol("mkdir");
30686
30686
  const ONERROR = Symbol("onError");
30687
30687
  const PENDING = Symbol("pending");
@@ -30697,20 +30697,20 @@ const CHECKED_CWD = Symbol("checkedCwd");
30697
30697
  const isWindows = (process.env.TESTING_TAR_FAKE_PLATFORM || process.platform) === "win32";
30698
30698
  const DEFAULT_MAX_DEPTH = 1024;
30699
30699
  /* c8 ignore start */
30700
- const unlinkFile = (path$16, cb) => {
30701
- if (!isWindows) return fs.unlink(path$16, cb);
30702
- const name$1 = path$16 + ".DELETE." + randomBytes(16).toString("hex");
30703
- fs.rename(path$16, name$1, (er) => {
30700
+ const unlinkFile = (path$17, cb) => {
30701
+ if (!isWindows) return fs.unlink(path$17, cb);
30702
+ const name$1 = path$17 + ".DELETE." + randomBytes(16).toString("hex");
30703
+ fs.rename(path$17, name$1, (er) => {
30704
30704
  if (er) return cb(er);
30705
30705
  fs.unlink(name$1, cb);
30706
30706
  });
30707
30707
  };
30708
30708
  /* c8 ignore stop */
30709
30709
  /* c8 ignore start */
30710
- const unlinkFileSync = (path$16) => {
30711
- if (!isWindows) return fs.unlinkSync(path$16);
30712
- const name$1 = path$16 + ".DELETE." + randomBytes(16).toString("hex");
30713
- fs.renameSync(path$16, name$1);
30710
+ const unlinkFileSync = (path$17) => {
30711
+ if (!isWindows) return fs.unlinkSync(path$17);
30712
+ const name$1 = path$17 + ".DELETE." + randomBytes(16).toString("hex");
30713
+ fs.renameSync(path$17, name$1);
30714
30714
  fs.unlinkSync(name$1);
30715
30715
  };
30716
30716
  /* c8 ignore stop */
@@ -30775,7 +30775,7 @@ var Unpack = class extends Parser {
30775
30775
  this.noMtime = !!opt.noMtime;
30776
30776
  this.preservePaths = !!opt.preservePaths;
30777
30777
  this.unlink = !!opt.unlink;
30778
- this.cwd = normalizeWindowsPath(nodePath.resolve(opt.cwd || process.cwd()));
30778
+ this.cwd = normalizeWindowsPath(path.resolve(opt.cwd || process.cwd()));
30779
30779
  this.strip = Number(opt.strip) || 0;
30780
30780
  this.processUmask = !this.chmod ? 0 : typeof opt.processUmask === "number" ? opt.processUmask : process.umask();
30781
30781
  this.umask = typeof opt.umask === "number" ? opt.umask : this.processUmask;
@@ -30794,6 +30794,27 @@ var Unpack = class extends Parser {
30794
30794
  this.emit("end");
30795
30795
  }
30796
30796
  }
30797
+ [STRIPABSOLUTEPATH](entry, field) {
30798
+ const path$17 = entry[field];
30799
+ if (!path$17 || this.preservePaths) return true;
30800
+ const parts = path$17.split("/");
30801
+ if (parts.includes("..") || isWindows && /^[a-z]:\.\.$/i.test(parts[0] ?? "")) {
30802
+ this.warn("TAR_ENTRY_ERROR", `${field} contains '..'`, {
30803
+ entry,
30804
+ [field]: path$17
30805
+ });
30806
+ return false;
30807
+ }
30808
+ const [root, stripped] = stripAbsolutePath(path$17);
30809
+ if (root) {
30810
+ entry[field] = String(stripped);
30811
+ this.warn("TAR_ENTRY_INFO", `stripping ${root} from absolute ${field}`, {
30812
+ entry,
30813
+ [field]: path$17
30814
+ });
30815
+ }
30816
+ return true;
30817
+ }
30797
30818
  [CHECKPATH](entry) {
30798
30819
  const p$1 = normalizeWindowsPath(entry.path);
30799
30820
  const parts = p$1.split("/");
@@ -30816,25 +30837,9 @@ var Unpack = class extends Parser {
30816
30837
  });
30817
30838
  return false;
30818
30839
  }
30819
- if (!this.preservePaths) {
30820
- if (parts.includes("..") || isWindows && /^[a-z]:\.\.$/i.test(parts[0] ?? "")) {
30821
- this.warn("TAR_ENTRY_ERROR", `path contains '..'`, {
30822
- entry,
30823
- path: p$1
30824
- });
30825
- return false;
30826
- }
30827
- const [root, stripped] = stripAbsolutePath(p$1);
30828
- if (root) {
30829
- entry.path = String(stripped);
30830
- this.warn("TAR_ENTRY_INFO", `stripping ${root} from absolute path`, {
30831
- entry,
30832
- path: p$1
30833
- });
30834
- }
30835
- }
30836
- if (nodePath.isAbsolute(entry.path)) entry.absolute = normalizeWindowsPath(nodePath.resolve(entry.path));
30837
- else entry.absolute = normalizeWindowsPath(nodePath.resolve(this.cwd, entry.path));
30840
+ if (!this[STRIPABSOLUTEPATH](entry, "path") || !this[STRIPABSOLUTEPATH](entry, "linkpath")) return false;
30841
+ if (path.isAbsolute(entry.path)) entry.absolute = normalizeWindowsPath(path.resolve(entry.path));
30842
+ else entry.absolute = normalizeWindowsPath(path.resolve(this.cwd, entry.path));
30838
30843
  /* c8 ignore start - defense in depth */
30839
30844
  if (!this.preservePaths && typeof entry.absolute === "string" && entry.absolute.indexOf(this.cwd + "/") !== 0 && entry.absolute !== this.cwd) {
30840
30845
  this.warn("TAR_ENTRY_ERROR", "path escaped extraction target", {
@@ -30848,9 +30853,9 @@ var Unpack = class extends Parser {
30848
30853
  /* c8 ignore stop */
30849
30854
  if (entry.absolute === this.cwd && entry.type !== "Directory" && entry.type !== "GNUDumpDir") return false;
30850
30855
  if (this.win32) {
30851
- const { root: aRoot } = nodePath.win32.parse(String(entry.absolute));
30856
+ const { root: aRoot } = path.win32.parse(String(entry.absolute));
30852
30857
  entry.absolute = aRoot + encode(String(entry.absolute).slice(aRoot.length));
30853
- const { root: pRoot } = nodePath.win32.parse(entry.path);
30858
+ const { root: pRoot } = path.win32.parse(entry.path);
30854
30859
  entry.path = pRoot + encode(entry.path.slice(pRoot.length));
30855
30860
  }
30856
30861
  return true;
@@ -30996,7 +31001,7 @@ var Unpack = class extends Parser {
30996
31001
  this[LINK](entry, String(entry.linkpath), "symlink", done);
30997
31002
  }
30998
31003
  [HARDLINK](entry, done) {
30999
- const linkpath = normalizeWindowsPath(nodePath.resolve(this.cwd, String(entry.linkpath)));
31004
+ const linkpath = normalizeWindowsPath(path.resolve(this.cwd, String(entry.linkpath)));
31000
31005
  this[LINK](entry, linkpath, "link", done);
31001
31006
  }
31002
31007
  [PEND]() {
@@ -31036,7 +31041,7 @@ var Unpack = class extends Parser {
31036
31041
  };
31037
31042
  const start = () => {
31038
31043
  if (entry.absolute !== this.cwd) {
31039
- const parent = normalizeWindowsPath(nodePath.dirname(String(entry.absolute)));
31044
+ const parent = normalizeWindowsPath(path.dirname(String(entry.absolute)));
31040
31045
  if (parent !== this.cwd) return this[MKDIR](parent, this.dmode, (er) => {
31041
31046
  if (er) {
31042
31047
  this[ONERROR](er, entry);
@@ -31118,7 +31123,7 @@ var UnpackSync = class extends Unpack {
31118
31123
  this[CHECKED_CWD] = true;
31119
31124
  }
31120
31125
  if (entry.absolute !== this.cwd) {
31121
- const parent = normalizeWindowsPath(nodePath.dirname(String(entry.absolute)));
31126
+ const parent = normalizeWindowsPath(path.dirname(String(entry.absolute)));
31122
31127
  if (parent !== this.cwd) {
31123
31128
  const mkParent = this[MKDIR](parent, this.dmode);
31124
31129
  if (mkParent) return this[ONERROR](mkParent, entry);
@@ -31390,7 +31395,7 @@ const replaceAsync = (opt, files) => {
31390
31395
  const addFilesSync = (p$1, files) => {
31391
31396
  files.forEach((file) => {
31392
31397
  if (file.charAt(0) === "@") list({
31393
- file: nodePath.resolve(p$1.cwd, file.slice(1)),
31398
+ file: path.resolve(p$1.cwd, file.slice(1)),
31394
31399
  sync: true,
31395
31400
  noResume: true,
31396
31401
  onReadEntry: (entry) => p$1.add(entry)
@@ -31403,7 +31408,7 @@ const addFilesAsync = async (p$1, files) => {
31403
31408
  for (let i$1 = 0; i$1 < files.length; i$1++) {
31404
31409
  const file = String(files[i$1]);
31405
31410
  if (file.charAt(0) === "@") await list({
31406
- file: nodePath.resolve(String(p$1.cwd), file.slice(1)),
31411
+ file: path.resolve(String(p$1.cwd), file.slice(1)),
31407
31412
  noResume: true,
31408
31413
  onReadEntry: (entry) => p$1.add(entry)
31409
31414
  });
@@ -31438,7 +31443,7 @@ const update = makeCommand(replace.syncFile, replace.asyncFile, replace.syncNoFi
31438
31443
  const mtimeFilter = (opt) => {
31439
31444
  const filter = opt.filter;
31440
31445
  if (!opt.mtimeCache) opt.mtimeCache = /* @__PURE__ */ new Map();
31441
- opt.filter = filter ? (path$16, stat) => filter(path$16, stat) && !((opt.mtimeCache?.get(path$16) ?? stat.mtime ?? 0) > (stat.mtime ?? 0)) : (path$16, stat) => !((opt.mtimeCache?.get(path$16) ?? stat.mtime ?? 0) > (stat.mtime ?? 0));
31446
+ opt.filter = filter ? (path$17, stat) => filter(path$17, stat) && !((opt.mtimeCache?.get(path$17) ?? stat.mtime ?? 0) > (stat.mtime ?? 0)) : (path$17, stat) => !((opt.mtimeCache?.get(path$17) ?? stat.mtime ?? 0) > (stat.mtime ?? 0));
31442
31447
  };
31443
31448
 
31444
31449
  //#endregion
@@ -31455,7 +31460,7 @@ async function deploySite(siteOutputDir) {
31455
31460
  }
31456
31461
  }
31457
31462
  async function createArchive(pathToArchive, targetArchivePath) {
31458
- await create$1({
31463
+ await create({
31459
31464
  gzip: true,
31460
31465
  file: targetArchivePath,
31461
31466
  cwd: pathToArchive
@@ -32276,28 +32281,28 @@ var require_windows = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32276
32281
  module.exports = isexe;
32277
32282
  isexe.sync = sync;
32278
32283
  var fs$4 = __require("fs");
32279
- function checkPathExt(path$16, options) {
32284
+ function checkPathExt(path$17, options) {
32280
32285
  var pathext = options.pathExt !== void 0 ? options.pathExt : process.env.PATHEXT;
32281
32286
  if (!pathext) return true;
32282
32287
  pathext = pathext.split(";");
32283
32288
  if (pathext.indexOf("") !== -1) return true;
32284
32289
  for (var i$1 = 0; i$1 < pathext.length; i$1++) {
32285
32290
  var p$1 = pathext[i$1].toLowerCase();
32286
- if (p$1 && path$16.substr(-p$1.length).toLowerCase() === p$1) return true;
32291
+ if (p$1 && path$17.substr(-p$1.length).toLowerCase() === p$1) return true;
32287
32292
  }
32288
32293
  return false;
32289
32294
  }
32290
- function checkStat(stat, path$16, options) {
32295
+ function checkStat(stat, path$17, options) {
32291
32296
  if (!stat.isSymbolicLink() && !stat.isFile()) return false;
32292
- return checkPathExt(path$16, options);
32297
+ return checkPathExt(path$17, options);
32293
32298
  }
32294
- function isexe(path$16, options, cb) {
32295
- fs$4.stat(path$16, function(er, stat) {
32296
- cb(er, er ? false : checkStat(stat, path$16, options));
32299
+ function isexe(path$17, options, cb) {
32300
+ fs$4.stat(path$17, function(er, stat) {
32301
+ cb(er, er ? false : checkStat(stat, path$17, options));
32297
32302
  });
32298
32303
  }
32299
- function sync(path$16, options) {
32300
- return checkStat(fs$4.statSync(path$16), path$16, options);
32304
+ function sync(path$17, options) {
32305
+ return checkStat(fs$4.statSync(path$17), path$17, options);
32301
32306
  }
32302
32307
  }));
32303
32308
 
@@ -32307,13 +32312,13 @@ var require_mode = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32307
32312
  module.exports = isexe;
32308
32313
  isexe.sync = sync;
32309
32314
  var fs$3 = __require("fs");
32310
- function isexe(path$16, options, cb) {
32311
- fs$3.stat(path$16, function(er, stat) {
32315
+ function isexe(path$17, options, cb) {
32316
+ fs$3.stat(path$17, function(er, stat) {
32312
32317
  cb(er, er ? false : checkStat(stat, options));
32313
32318
  });
32314
32319
  }
32315
- function sync(path$16, options) {
32316
- return checkStat(fs$3.statSync(path$16), options);
32320
+ function sync(path$17, options) {
32321
+ return checkStat(fs$3.statSync(path$17), options);
32317
32322
  }
32318
32323
  function checkStat(stat, options) {
32319
32324
  return stat.isFile() && checkMode(stat, options);
@@ -32341,7 +32346,7 @@ var require_isexe = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32341
32346
  else core = require_mode();
32342
32347
  module.exports = isexe;
32343
32348
  isexe.sync = sync;
32344
- function isexe(path$16, options, cb) {
32349
+ function isexe(path$17, options, cb) {
32345
32350
  if (typeof options === "function") {
32346
32351
  cb = options;
32347
32352
  options = {};
@@ -32349,13 +32354,13 @@ var require_isexe = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32349
32354
  if (!cb) {
32350
32355
  if (typeof Promise !== "function") throw new TypeError("callback not provided");
32351
32356
  return new Promise(function(resolve$1, reject) {
32352
- isexe(path$16, options || {}, function(er, is) {
32357
+ isexe(path$17, options || {}, function(er, is) {
32353
32358
  if (er) reject(er);
32354
32359
  else resolve$1(is);
32355
32360
  });
32356
32361
  });
32357
32362
  }
32358
- core(path$16, options || {}, function(er, is) {
32363
+ core(path$17, options || {}, function(er, is) {
32359
32364
  if (er) {
32360
32365
  if (er.code === "EACCES" || options && options.ignoreErrors) {
32361
32366
  er = null;
@@ -32365,9 +32370,9 @@ var require_isexe = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32365
32370
  cb(er, is);
32366
32371
  });
32367
32372
  }
32368
- function sync(path$16, options) {
32373
+ function sync(path$17, options) {
32369
32374
  try {
32370
- return core.sync(path$16, options || {});
32375
+ return core.sync(path$17, options || {});
32371
32376
  } catch (er) {
32372
32377
  if (options && options.ignoreErrors || er.code === "EACCES") return false;
32373
32378
  else throw er;
@@ -32379,7 +32384,7 @@ var require_isexe = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32379
32384
  //#region node_modules/which/which.js
32380
32385
  var require_which = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32381
32386
  const isWindows = process.platform === "win32" || process.env.OSTYPE === "cygwin" || process.env.OSTYPE === "msys";
32382
- const path$3 = __require("path");
32387
+ const path$4 = __require("path");
32383
32388
  const COLON = isWindows ? ";" : ":";
32384
32389
  const isexe = require_isexe();
32385
32390
  const getNotFoundError = (cmd) => Object.assign(/* @__PURE__ */ new Error(`not found: ${cmd}`), { code: "ENOENT" });
@@ -32409,7 +32414,7 @@ var require_which = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32409
32414
  if (i$1 === pathEnv.length) return opt.all && found.length ? resolve$1(found) : reject(getNotFoundError(cmd));
32410
32415
  const ppRaw = pathEnv[i$1];
32411
32416
  const pathPart = /^".*"$/.test(ppRaw) ? ppRaw.slice(1, -1) : ppRaw;
32412
- const pCmd = path$3.join(pathPart, cmd);
32417
+ const pCmd = path$4.join(pathPart, cmd);
32413
32418
  resolve$1(subStep(!pathPart && /^\.[\\\/]/.test(cmd) ? cmd.slice(0, 2) + pCmd : pCmd, i$1, 0));
32414
32419
  });
32415
32420
  const subStep = (p$1, i$1, ii) => new Promise((resolve$1, reject) => {
@@ -32430,7 +32435,7 @@ var require_which = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32430
32435
  for (let i$1 = 0; i$1 < pathEnv.length; i$1++) {
32431
32436
  const ppRaw = pathEnv[i$1];
32432
32437
  const pathPart = /^".*"$/.test(ppRaw) ? ppRaw.slice(1, -1) : ppRaw;
32433
- const pCmd = path$3.join(pathPart, cmd);
32438
+ const pCmd = path$4.join(pathPart, cmd);
32434
32439
  const p$1 = !pathPart && /^\.[\\\/]/.test(cmd) ? cmd.slice(0, 2) + pCmd : pCmd;
32435
32440
  for (let j = 0; j < pathExt.length; j++) {
32436
32441
  const cur = p$1 + pathExt[j];
@@ -32463,7 +32468,7 @@ var require_path_key = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32463
32468
  //#endregion
32464
32469
  //#region node_modules/cross-spawn/lib/util/resolveCommand.js
32465
32470
  var require_resolveCommand = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32466
- const path$2 = __require("path");
32471
+ const path$3 = __require("path");
32467
32472
  const which = require_which();
32468
32473
  const getPathKey = require_path_key();
32469
32474
  function resolveCommandAttempt(parsed, withoutPathExt) {
@@ -32478,12 +32483,12 @@ var require_resolveCommand = /* @__PURE__ */ __commonJSMin(((exports, module) =>
32478
32483
  try {
32479
32484
  resolved = which.sync(parsed.command, {
32480
32485
  path: env$1[getPathKey({ env: env$1 })],
32481
- pathExt: withoutPathExt ? path$2.delimiter : void 0
32486
+ pathExt: withoutPathExt ? path$3.delimiter : void 0
32482
32487
  });
32483
32488
  } catch (e$1) {} finally {
32484
32489
  if (shouldSwitchCwd) process.chdir(cwd);
32485
32490
  }
32486
- if (resolved) resolved = path$2.resolve(hasCustomCwd ? parsed.options.cwd : "", resolved);
32491
+ if (resolved) resolved = path$3.resolve(hasCustomCwd ? parsed.options.cwd : "", resolved);
32487
32492
  return resolved;
32488
32493
  }
32489
32494
  function resolveCommand(parsed) {
@@ -32526,8 +32531,8 @@ var require_shebang_command = /* @__PURE__ */ __commonJSMin(((exports, module) =
32526
32531
  module.exports = (string$2 = "") => {
32527
32532
  const match = string$2.match(shebangRegex);
32528
32533
  if (!match) return null;
32529
- const [path$16, argument] = match[0].replace(/#! ?/, "").split(" ");
32530
- const binary = path$16.split("/").pop();
32534
+ const [path$17, argument] = match[0].replace(/#! ?/, "").split(" ");
32535
+ const binary = path$17.split("/").pop();
32531
32536
  if (binary === "env") return argument;
32532
32537
  return argument ? `${binary} ${argument}` : binary;
32533
32538
  };
@@ -32555,7 +32560,7 @@ var require_readShebang = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32555
32560
  //#endregion
32556
32561
  //#region node_modules/cross-spawn/lib/parse.js
32557
32562
  var require_parse = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32558
- const path$1 = __require("path");
32563
+ const path$2 = __require("path");
32559
32564
  const resolveCommand = require_resolveCommand();
32560
32565
  const escape = require_escape();
32561
32566
  const readShebang = require_readShebang();
@@ -32578,7 +32583,7 @@ var require_parse = /* @__PURE__ */ __commonJSMin(((exports, module) => {
32578
32583
  const needsShell = !isExecutableRegExp.test(commandFile);
32579
32584
  if (parsed.options.forceShell || needsShell) {
32580
32585
  const needsDoubleEscapeMetaChars = isCmdShimRegExp.test(commandFile);
32581
- parsed.command = path$1.normalize(parsed.command);
32586
+ parsed.command = path$2.normalize(parsed.command);
32582
32587
  parsed.command = escape.command(parsed.command);
32583
32588
  parsed.args = parsed.args.map((arg) => escape.argument(arg, needsDoubleEscapeMetaChars));
32584
32589
  parsed.args = [
@@ -32696,12 +32701,12 @@ function toPath(urlOrPath) {
32696
32701
  }
32697
32702
  function traversePathUp(startPath) {
32698
32703
  return { *[Symbol.iterator]() {
32699
- let currentPath = nodePath.resolve(toPath(startPath));
32704
+ let currentPath = path.resolve(toPath(startPath));
32700
32705
  let previousPath;
32701
32706
  while (previousPath !== currentPath) {
32702
32707
  yield currentPath;
32703
32708
  previousPath = currentPath;
32704
- currentPath = nodePath.resolve(currentPath, "..");
32709
+ currentPath = path.resolve(currentPath, "..");
32705
32710
  }
32706
32711
  } };
32707
32712
  }
@@ -32710,21 +32715,21 @@ const TEN_MEGABYTES_IN_BYTES = 10 * 1024 * 1024;
32710
32715
  //#endregion
32711
32716
  //#region node_modules/npm-run-path/index.js
32712
32717
  const npmRunPath = ({ cwd = y.cwd(), path: pathOption = y.env[pathKey()], preferLocal = true, execPath: execPath$1 = y.execPath, addExecPath = true } = {}) => {
32713
- const cwdPath = nodePath.resolve(toPath(cwd));
32718
+ const cwdPath = path.resolve(toPath(cwd));
32714
32719
  const result = [];
32715
- const pathParts = pathOption.split(nodePath.delimiter);
32720
+ const pathParts = pathOption.split(path.delimiter);
32716
32721
  if (preferLocal) applyPreferLocal(result, pathParts, cwdPath);
32717
32722
  if (addExecPath) applyExecPath(result, pathParts, execPath$1, cwdPath);
32718
- return pathOption === "" || pathOption === nodePath.delimiter ? `${result.join(nodePath.delimiter)}${pathOption}` : [...result, pathOption].join(nodePath.delimiter);
32723
+ return pathOption === "" || pathOption === path.delimiter ? `${result.join(path.delimiter)}${pathOption}` : [...result, pathOption].join(path.delimiter);
32719
32724
  };
32720
32725
  const applyPreferLocal = (result, pathParts, cwdPath) => {
32721
32726
  for (const directory of traversePathUp(cwdPath)) {
32722
- const pathPart = nodePath.join(directory, "node_modules/.bin");
32727
+ const pathPart = path.join(directory, "node_modules/.bin");
32723
32728
  if (!pathParts.includes(pathPart)) result.push(pathPart);
32724
32729
  }
32725
32730
  };
32726
32731
  const applyExecPath = (result, pathParts, execPath$1, cwdPath) => {
32727
- const pathPart = nodePath.resolve(cwdPath, toPath(execPath$1), "..");
32732
+ const pathPart = path.resolve(cwdPath, toPath(execPath$1), "..");
32728
32733
  if (!pathParts.includes(pathPart)) result.push(pathPart);
32729
32734
  };
32730
32735
  const npmRunPathEnv = ({ env: env$1 = y.env, ...options } = {}) => {
@@ -33756,10 +33761,10 @@ const mapNode = ({ options }) => {
33756
33761
  node: true
33757
33762
  } };
33758
33763
  };
33759
- const handleNodeOption = (file, commandArguments, { node: shouldHandleNode = false, nodePath: nodePath$1 = execPath, nodeOptions = execArgv.filter((nodeOption) => !nodeOption.startsWith("--inspect")), cwd, execPath: formerNodePath, ...options }) => {
33764
+ const handleNodeOption = (file, commandArguments, { node: shouldHandleNode = false, nodePath = execPath, nodeOptions = execArgv.filter((nodeOption) => !nodeOption.startsWith("--inspect")), cwd, execPath: formerNodePath, ...options }) => {
33760
33765
  if (formerNodePath !== void 0) throw new TypeError("The \"execPath\" option has been removed. Please use the \"nodePath\" option instead.");
33761
- const normalizedNodePath = safeNormalizeFileUrl(nodePath$1, "The \"nodePath\" option");
33762
- const resolvedNodePath = nodePath.resolve(cwd, normalizedNodePath);
33766
+ const normalizedNodePath = safeNormalizeFileUrl(nodePath, "The \"nodePath\" option");
33767
+ const resolvedNodePath = path.resolve(cwd, normalizedNodePath);
33763
33768
  const newOptions = {
33764
33769
  ...options,
33765
33770
  nodePath: resolvedNodePath,
@@ -33771,7 +33776,7 @@ const handleNodeOption = (file, commandArguments, { node: shouldHandleNode = fal
33771
33776
  commandArguments,
33772
33777
  newOptions
33773
33778
  ];
33774
- if (nodePath.basename(file, ".exe") === "node") throw new TypeError("When the \"node\" option is true, the first argument does not need to be \"node\".");
33779
+ if (path.basename(file, ".exe") === "node") throw new TypeError("When the \"node\" option is true, the first argument does not need to be \"node\".");
33775
33780
  return [
33776
33781
  resolvedNodePath,
33777
33782
  [
@@ -33858,7 +33863,7 @@ const serializeEncoding = (encoding) => typeof encoding === "string" ? `"${encod
33858
33863
  //#region node_modules/execa/lib/arguments/cwd.js
33859
33864
  const normalizeCwd = (cwd = getDefaultCwd()) => {
33860
33865
  const cwdString = safeNormalizeFileUrl(cwd, "The \"cwd\" option");
33861
- return nodePath.resolve(cwdString);
33866
+ return path.resolve(cwdString);
33862
33867
  };
33863
33868
  const getDefaultCwd = () => {
33864
33869
  try {
@@ -33897,7 +33902,7 @@ const normalizeOptions = (filePath, rawArguments, rawOptions) => {
33897
33902
  options.killSignal = normalizeKillSignal(options.killSignal);
33898
33903
  options.forceKillAfterDelay = normalizeForceKillAfterDelay(options.forceKillAfterDelay);
33899
33904
  options.lines = options.lines.map((lines, fdNumber) => lines && !BINARY_ENCODINGS.has(options.encoding) && options.buffer[fdNumber]);
33900
- if (y.platform === "win32" && nodePath.basename(file, ".exe") === "cmd") commandArguments.unshift("/q");
33905
+ if (y.platform === "win32" && path.basename(file, ".exe") === "cmd") commandArguments.unshift("/q");
33901
33906
  return {
33902
33907
  file,
33903
33908
  commandArguments,
@@ -33922,7 +33927,7 @@ const addDefaultOptions = ({ extendEnv = true, preferLocal = false, cwd, localDi
33922
33927
  ipc,
33923
33928
  serialization
33924
33929
  });
33925
- const getEnv = ({ env: envOption, extendEnv, preferLocal, node, localDirectory, nodePath: nodePath$1 }) => {
33930
+ const getEnv = ({ env: envOption, extendEnv, preferLocal, node, localDirectory, nodePath }) => {
33926
33931
  const env$1 = extendEnv ? {
33927
33932
  ...y.env,
33928
33933
  ...envOption
@@ -33930,7 +33935,7 @@ const getEnv = ({ env: envOption, extendEnv, preferLocal, node, localDirectory,
33930
33935
  if (preferLocal || node) return npmRunPathEnv({
33931
33936
  env: env$1,
33932
33937
  cwd: localDirectory,
33933
- execPath: nodePath$1,
33938
+ execPath: nodePath,
33934
33939
  preferLocal,
33935
33940
  addExecPath: node
33936
33941
  });
@@ -35675,12 +35680,12 @@ const logOutputSync = ({ serializedResult, fdNumber, state, verboseInfo, encodin
35675
35680
  }
35676
35681
  };
35677
35682
  const writeToFiles = (serializedResult, stdioItems, outputFiles) => {
35678
- for (const { path: path$16, append } of stdioItems.filter(({ type }) => FILE_TYPES.has(type))) {
35679
- const pathString = typeof path$16 === "string" ? path$16 : path$16.toString();
35680
- if (append || outputFiles.has(pathString)) appendFileSync(path$16, serializedResult);
35683
+ for (const { path: path$17, append } of stdioItems.filter(({ type }) => FILE_TYPES.has(type))) {
35684
+ const pathString = typeof path$17 === "string" ? path$17 : path$17.toString();
35685
+ if (append || outputFiles.has(pathString)) appendFileSync(path$17, serializedResult);
35681
35686
  else {
35682
35687
  outputFiles.add(pathString);
35683
- writeFileSync(path$16, serializedResult);
35688
+ writeFileSync(path$17, serializedResult);
35684
35689
  }
35685
35690
  }
35686
35691
  };
@@ -38153,13 +38158,31 @@ var require_lodash = /* @__PURE__ */ __commonJSMin(((exports, module) => {
38153
38158
  var import_lodash = /* @__PURE__ */ __toESM(require_lodash(), 1);
38154
38159
  const orange = source_default.hex("#E86B3C");
38155
38160
  const cyan = source_default.hex("#00D4FF");
38156
- async function create() {
38161
+ const DEFAULT_TEMPLATE_ID = "backend-only";
38162
+ async function getDefaultTemplate() {
38163
+ const template = (await listTemplates()).find((t) => t.id === DEFAULT_TEMPLATE_ID);
38164
+ if (!template) throw new Error(`Default template "${DEFAULT_TEMPLATE_ID}" not found`);
38165
+ return template;
38166
+ }
38167
+ function validateNonInteractiveFlags(command) {
38168
+ const { name: name$1, path: path$17 } = command.opts();
38169
+ const providedCount = [name$1, path$17].filter(Boolean).length;
38170
+ if (providedCount > 0 && providedCount < 2) command.error("Non-interactive mode requires all flags: --name, --path");
38171
+ }
38172
+ async function chooseCreate(options) {
38173
+ if (!!(options.name && options.path)) await runCommand(() => createNonInteractive(options), { requireAuth: true });
38174
+ else await runCommand(() => createInteractive(options), {
38175
+ fullBanner: true,
38176
+ requireAuth: true
38177
+ });
38178
+ }
38179
+ async function createInteractive(options) {
38157
38180
  const templateOptions = (await listTemplates()).map((t) => ({
38158
38181
  value: t,
38159
38182
  label: t.name,
38160
38183
  hint: t.description
38161
38184
  }));
38162
- const { template, name: name$1, description, projectPath } = await Ce({
38185
+ const result = await Ce({
38163
38186
  template: () => ve({
38164
38187
  message: "Pick a template",
38165
38188
  options: templateOptions
@@ -38184,11 +38207,32 @@ async function create() {
38184
38207
  });
38185
38208
  }
38186
38209
  }, { onCancel: onPromptCancel });
38210
+ return await executeCreate({
38211
+ template: result.template,
38212
+ name: result.name,
38213
+ description: result.description || void 0,
38214
+ projectPath: result.projectPath,
38215
+ deploy: options.deploy,
38216
+ isInteractive: true
38217
+ });
38218
+ }
38219
+ async function createNonInteractive(options) {
38220
+ return await executeCreate({
38221
+ template: await getDefaultTemplate(),
38222
+ name: options.name,
38223
+ description: options.description,
38224
+ projectPath: options.path,
38225
+ deploy: options.deploy,
38226
+ isInteractive: false
38227
+ });
38228
+ }
38229
+ async function executeCreate({ template, name: rawName, description, projectPath, deploy, isInteractive }) {
38230
+ const name$1 = rawName.trim();
38187
38231
  const resolvedPath = resolve(projectPath);
38188
38232
  const { projectId } = await runTask("Setting up your project...", async () => {
38189
38233
  return await createProjectFiles({
38190
- name: name$1.trim(),
38191
- description: description ? description.trim() : void 0,
38234
+ name: name$1,
38235
+ description: description?.trim(),
38192
38236
  path: resolvedPath,
38193
38237
  template
38194
38238
  });
@@ -38200,8 +38244,12 @@ async function create() {
38200
38244
  const { project, entities } = await readProjectConfig(resolvedPath);
38201
38245
  let finalAppUrl;
38202
38246
  if (entities.length > 0) {
38203
- const shouldPushEntities = await ye({ message: "Would you like to push entities now?" });
38204
- if (!pD(shouldPushEntities) && shouldPushEntities) await runTask(`Pushing ${entities.length} entities to Base44...`, async () => {
38247
+ let shouldPushEntities;
38248
+ if (isInteractive) {
38249
+ const result = await ye({ message: "Would you like to push entities now?" });
38250
+ shouldPushEntities = !pD(result) && result;
38251
+ } else shouldPushEntities = !!deploy;
38252
+ if (shouldPushEntities) await runTask(`Pushing ${entities.length} entities to Base44...`, async () => {
38205
38253
  await pushEntities(entities);
38206
38254
  }, {
38207
38255
  successMessage: orange("Entities pushed successfully"),
@@ -38209,11 +38257,13 @@ async function create() {
38209
38257
  });
38210
38258
  }
38211
38259
  if (project.site) {
38212
- const installCommand = project.site.installCommand;
38213
- const buildCommand = project.site.buildCommand;
38214
- const outputDirectory = project.site.outputDirectory;
38215
- const shouldDeploy = await ye({ message: "Would you like to deploy the site now?" });
38216
- if (!pD(shouldDeploy) && shouldDeploy && installCommand && buildCommand && outputDirectory) {
38260
+ const { installCommand, buildCommand, outputDirectory } = project.site;
38261
+ let shouldDeploy;
38262
+ if (isInteractive) {
38263
+ const result = await ye({ message: "Would you like to deploy the site now?" });
38264
+ shouldDeploy = !pD(result) && result;
38265
+ } else shouldDeploy = !!deploy;
38266
+ if (shouldDeploy && installCommand && buildCommand && outputDirectory) {
38217
38267
  const { appUrl } = await runTask("Installing dependencies...", async (updateMessage) => {
38218
38268
  await execa({
38219
38269
  cwd: resolvedPath,
@@ -38234,26 +38284,25 @@ async function create() {
38234
38284
  }
38235
38285
  }
38236
38286
  const dashboardUrl = `${getBase44ApiUrl()}/apps/${projectId}/editor/preview`;
38237
- M.message(`${source_default.dim("Project")}: ${orange(name$1.trim())}`);
38287
+ M.message(`${source_default.dim("Project")}: ${orange(name$1)}`);
38238
38288
  M.message(`${source_default.dim("Dashboard")}: ${cyan(dashboardUrl)}`);
38239
38289
  if (finalAppUrl) M.message(`${source_default.dim("Site")}: ${cyan(finalAppUrl)}`);
38240
38290
  return { outroMessage: "Your project is set and ready to use" };
38241
38291
  }
38242
- const createCommand = new Command("create").description("Create a new Base44 project").action(async () => {
38243
- await runCommand(create, {
38244
- fullBanner: true,
38245
- requireAuth: true
38246
- });
38292
+ const createCommand = new Command("create").description("Create a new Base44 project").option("-n, --name <name>", "Project name").option("-d, --description <description>", "Project description").option("-p, --path <path>", "Path where to create the project").option("--deploy", "Build and deploy the site").hook("preAction", validateNonInteractiveFlags).action(async (options) => {
38293
+ await chooseCreate(options);
38247
38294
  });
38248
38295
 
38249
38296
  //#endregion
38250
38297
  //#region src/cli/commands/site/deploy.ts
38251
- async function deployAction() {
38298
+ async function deployAction(options) {
38252
38299
  const { project } = await readProjectConfig();
38253
38300
  if (!project.site?.outputDirectory) throw new Error("No site configuration found. Please add 'site.outputDirectory' to your config.jsonc");
38254
38301
  const outputDir = resolve(project.root, project.site.outputDirectory);
38255
- const shouldDeploy = await ye({ message: `Deploy site from ${project.site.outputDirectory}?` });
38256
- if (pD(shouldDeploy) || !shouldDeploy) return { outroMessage: "Deployment cancelled" };
38302
+ if (!options.yes) {
38303
+ const shouldDeploy = await ye({ message: `Deploy site from ${project.site.outputDirectory}?` });
38304
+ if (pD(shouldDeploy) || !shouldDeploy) return { outroMessage: "Deployment cancelled" };
38305
+ }
38257
38306
  return { outroMessage: `Visit your site at: ${(await runTask("Creating archive and deploying site...", async () => {
38258
38307
  return await deploySite(outputDir);
38259
38308
  }, {
@@ -38261,13 +38310,13 @@ async function deployAction() {
38261
38310
  errorMessage: "Deployment failed"
38262
38311
  })).appUrl}` };
38263
38312
  }
38264
- const siteDeployCommand = new Command("site").description("Manage site deployments").addCommand(new Command("deploy").description("Deploy built site files to Base44 hosting").action(async () => {
38265
- await runCommand(deployAction, { requireAuth: true });
38313
+ const siteDeployCommand = new Command("site").description("Manage site deployments").addCommand(new Command("deploy").description("Deploy built site files to Base44 hosting").option("-y, --yes", "Skip confirmation prompt").action(async (options) => {
38314
+ await runCommand(() => deployAction(options), { requireAuth: true });
38266
38315
  }));
38267
38316
 
38268
38317
  //#endregion
38269
38318
  //#region package.json
38270
- var version = "0.0.7";
38319
+ var version = "0.0.9";
38271
38320
 
38272
38321
  //#endregion
38273
38322
  //#region src/cli/index.ts