@angular-devkit/core 7.0.3 → 7.0.7

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.
@@ -24,13 +24,10 @@ function createConsoleLogger(verbose = false, stdout = process.stdout, stderr =
24
24
  color = src_1.terminal.white;
25
25
  break;
26
26
  case 'warn':
27
- color = src_1.terminal.yellow;
28
- break;
29
- case 'error':
30
- color = src_1.terminal.red;
31
- output = stderr;
27
+ color = (x) => src_1.terminal.bold(src_1.terminal.yellow(x));
32
28
  break;
33
29
  case 'fatal':
30
+ case 'error':
34
31
  color = (x) => src_1.terminal.bold(src_1.terminal.red(x));
35
32
  output = stderr;
36
33
  break;
@@ -40,4 +37,4 @@ function createConsoleLogger(verbose = false, stdout = process.stdout, stderr =
40
37
  return logger;
41
38
  }
42
39
  exports.createConsoleLogger = createConsoleLogger;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLWxvZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvY29yZS9ub2RlL2NsaS1sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCw4Q0FBd0M7QUFDeEMsZ0NBQTJDO0FBTTNDOztHQUVHO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQ2pDLE9BQU8sR0FBRyxLQUFLLEVBQ2YsU0FBd0IsT0FBTyxDQUFDLE1BQU0sRUFDdEMsU0FBd0IsT0FBTyxDQUFDLE1BQU07SUFFdEMsTUFBTSxNQUFNLEdBQUcsSUFBSSxhQUFPLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRWpELE1BQU07U0FDSCxJQUFJLENBQUMsa0JBQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQztTQUMxRCxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDakIsSUFBSSxLQUFLLEdBQTBCLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBUSxDQUFDLEdBQUcsQ0FBQyxjQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEUsSUFBSSxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3BCLFFBQVEsS0FBSyxDQUFDLEtBQUssRUFBRTtZQUNuQixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLGNBQVEsQ0FBQyxLQUFLLENBQUM7Z0JBQ3ZCLE1BQU07WUFDUixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLGNBQVEsQ0FBQyxNQUFNLENBQUM7Z0JBQ3hCLE1BQU07WUFDUixLQUFLLE9BQU87Z0JBQ1YsS0FBSyxHQUFHLGNBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQ3JCLE1BQU0sR0FBRyxNQUFNLENBQUM7Z0JBQ2hCLE1BQU07WUFDUixLQUFLLE9BQU87Z0JBQ1YsS0FBSyxHQUFHLENBQUMsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxjQUFRLENBQUMsSUFBSSxDQUFDLGNBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDdEQsTUFBTSxHQUFHLE1BQU0sQ0FBQztnQkFDaEIsTUFBTTtTQUNUO1FBRUQsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO0lBQzVDLENBQUMsQ0FBQyxDQUFDO0lBRUwsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQWpDRCxrREFpQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyBmaWx0ZXIgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBsb2dnaW5nLCB0ZXJtaW5hbCB9IGZyb20gJy4uL3NyYyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvY2Vzc091dHB1dCB7XG4gIHdyaXRlKGJ1ZmZlcjogc3RyaW5nIHwgQnVmZmVyKTogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBBIExvZ2dlciB0aGF0IHNlbmRzIGluZm9ybWF0aW9uIHRvIFNURE9VVCBhbmQgU1RERVJSLlxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQ29uc29sZUxvZ2dlcihcbiAgdmVyYm9zZSA9IGZhbHNlLFxuICBzdGRvdXQ6IFByb2Nlc3NPdXRwdXQgPSBwcm9jZXNzLnN0ZG91dCxcbiAgc3RkZXJyOiBQcm9jZXNzT3V0cHV0ID0gcHJvY2Vzcy5zdGRlcnIsXG4pOiBsb2dnaW5nLkxvZ2dlciB7XG4gIGNvbnN0IGxvZ2dlciA9IG5ldyBsb2dnaW5nLkluZGVudExvZ2dlcignY2xpbmcnKTtcblxuICBsb2dnZXJcbiAgICAucGlwZShmaWx0ZXIoZW50cnkgPT4gKGVudHJ5LmxldmVsICE9ICdkZWJ1ZycgfHwgdmVyYm9zZSkpKVxuICAgIC5zdWJzY3JpYmUoZW50cnkgPT4ge1xuICAgICAgbGV0IGNvbG9yOiAoczogc3RyaW5nKSA9PiBzdHJpbmcgPSB4ID0+IHRlcm1pbmFsLmRpbSh0ZXJtaW5hbC53aGl0ZSh4KSk7XG4gICAgICBsZXQgb3V0cHV0ID0gc3Rkb3V0O1xuICAgICAgc3dpdGNoIChlbnRyeS5sZXZlbCkge1xuICAgICAgICBjYXNlICdpbmZvJzpcbiAgICAgICAgICBjb2xvciA9IHRlcm1pbmFsLndoaXRlO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICd3YXJuJzpcbiAgICAgICAgICBjb2xvciA9IHRlcm1pbmFsLnllbGxvdztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnZXJyb3InOlxuICAgICAgICAgIGNvbG9yID0gdGVybWluYWwucmVkO1xuICAgICAgICAgIG91dHB1dCA9IHN0ZGVycjtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnZmF0YWwnOlxuICAgICAgICAgIGNvbG9yID0gKHg6IHN0cmluZykgPT4gdGVybWluYWwuYm9sZCh0ZXJtaW5hbC5yZWQoeCkpO1xuICAgICAgICAgIG91dHB1dCA9IHN0ZGVycjtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cblxuICAgICAgb3V0cHV0LndyaXRlKGNvbG9yKGVudHJ5Lm1lc3NhZ2UpICsgJ1xcbicpO1xuICAgIH0pO1xuXG4gIHJldHVybiBsb2dnZXI7XG59XG4iXX0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLWxvZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIuLyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvY29yZS9ub2RlL2NsaS1sb2dnZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCw4Q0FBd0M7QUFDeEMsZ0NBQTJDO0FBTTNDOztHQUVHO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQ2pDLE9BQU8sR0FBRyxLQUFLLEVBQ2YsU0FBd0IsT0FBTyxDQUFDLE1BQU0sRUFDdEMsU0FBd0IsT0FBTyxDQUFDLE1BQU07SUFFdEMsTUFBTSxNQUFNLEdBQUcsSUFBSSxhQUFPLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRWpELE1BQU07U0FDSCxJQUFJLENBQUMsa0JBQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsQ0FBQztTQUMxRCxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDakIsSUFBSSxLQUFLLEdBQTBCLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBUSxDQUFDLEdBQUcsQ0FBQyxjQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEUsSUFBSSxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3BCLFFBQVEsS0FBSyxDQUFDLEtBQUssRUFBRTtZQUNuQixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLGNBQVEsQ0FBQyxLQUFLLENBQUM7Z0JBQ3ZCLE1BQU07WUFDUixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLENBQUMsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxjQUFRLENBQUMsSUFBSSxDQUFDLGNBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDekQsTUFBTTtZQUNSLEtBQUssT0FBTyxDQUFDO1lBQ2IsS0FBSyxPQUFPO2dCQUNWLEtBQUssR0FBRyxDQUFDLENBQVMsRUFBRSxFQUFFLENBQUMsY0FBUSxDQUFDLElBQUksQ0FBQyxjQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3RELE1BQU0sR0FBRyxNQUFNLENBQUM7Z0JBQ2hCLE1BQU07U0FDVDtRQUVELE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUM1QyxDQUFDLENBQUMsQ0FBQztJQUVMLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUM7QUE5QkQsa0RBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHsgZmlsdGVyIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgbG9nZ2luZywgdGVybWluYWwgfSBmcm9tICcuLi9zcmMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByb2Nlc3NPdXRwdXQge1xuICB3cml0ZShidWZmZXI6IHN0cmluZyB8IEJ1ZmZlcik6IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBMb2dnZXIgdGhhdCBzZW5kcyBpbmZvcm1hdGlvbiB0byBTVERPVVQgYW5kIFNUREVSUi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUNvbnNvbGVMb2dnZXIoXG4gIHZlcmJvc2UgPSBmYWxzZSxcbiAgc3Rkb3V0OiBQcm9jZXNzT3V0cHV0ID0gcHJvY2Vzcy5zdGRvdXQsXG4gIHN0ZGVycjogUHJvY2Vzc091dHB1dCA9IHByb2Nlc3Muc3RkZXJyLFxuKTogbG9nZ2luZy5Mb2dnZXIge1xuICBjb25zdCBsb2dnZXIgPSBuZXcgbG9nZ2luZy5JbmRlbnRMb2dnZXIoJ2NsaW5nJyk7XG5cbiAgbG9nZ2VyXG4gICAgLnBpcGUoZmlsdGVyKGVudHJ5ID0+IChlbnRyeS5sZXZlbCAhPSAnZGVidWcnIHx8IHZlcmJvc2UpKSlcbiAgICAuc3Vic2NyaWJlKGVudHJ5ID0+IHtcbiAgICAgIGxldCBjb2xvcjogKHM6IHN0cmluZykgPT4gc3RyaW5nID0geCA9PiB0ZXJtaW5hbC5kaW0odGVybWluYWwud2hpdGUoeCkpO1xuICAgICAgbGV0IG91dHB1dCA9IHN0ZG91dDtcbiAgICAgIHN3aXRjaCAoZW50cnkubGV2ZWwpIHtcbiAgICAgICAgY2FzZSAnaW5mbyc6XG4gICAgICAgICAgY29sb3IgPSB0ZXJtaW5hbC53aGl0ZTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnd2Fybic6XG4gICAgICAgICAgY29sb3IgPSAoeDogc3RyaW5nKSA9PiB0ZXJtaW5hbC5ib2xkKHRlcm1pbmFsLnllbGxvdyh4KSk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ2ZhdGFsJzpcbiAgICAgICAgY2FzZSAnZXJyb3InOlxuICAgICAgICAgIGNvbG9yID0gKHg6IHN0cmluZykgPT4gdGVybWluYWwuYm9sZCh0ZXJtaW5hbC5yZWQoeCkpO1xuICAgICAgICAgIG91dHB1dCA9IHN0ZGVycjtcbiAgICAgICAgICBicmVhaztcbiAgICAgIH1cblxuICAgICAgb3V0cHV0LndyaXRlKGNvbG9yKGVudHJ5Lm1lc3NhZ2UpICsgJ1xcbicpO1xuICAgIH0pO1xuXG4gIHJldHVybiBsb2dnZXI7XG59XG4iXX0=
package/node/resolve.js CHANGED
@@ -188,6 +188,12 @@ function resolve(x, options) {
188
188
  }
189
189
  function nodeModulesPaths(start, opts) {
190
190
  const modules = ['node_modules'];
191
+ if (process.env.BAZEL_TARGET) {
192
+ // When running test under Bazel, node_modules have to be resolved
193
+ // differently. node_modules are installed in the `npm` workspace.
194
+ // For more info, see `yarn_install` rule in WORKSPACE file.
195
+ modules.push(path.join('npm', 'node_modules'));
196
+ }
191
197
  // ensure that `start` is an absolute path at this point,
192
198
  // resolving against the process' current working directory
193
199
  let absoluteStart = path.resolve(start);
@@ -223,4 +229,4 @@ function resolve(x, options) {
223
229
  }
224
230
  }
225
231
  exports.resolve = resolve;
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolve.js","sourceRoot":"./","sources":["packages/angular_devkit/core/node/resolve.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { BaseException } from '../src';\nimport { isFile } from './fs';\n\n/**\n * Exception thrown when a module could not be resolved.\n */\nexport class ModuleNotFoundException extends BaseException {\n  public readonly code: string;\n\n  constructor(public readonly moduleName: string, public readonly basePath: string) {\n    super(`Could not find module ${JSON.stringify(moduleName)} from ${JSON.stringify(basePath)}.`);\n    this.code = 'MODULE_NOT_FOUND';\n  }\n}\n\n/**\n * Returns a list of all the callers from the resolve() call.\n * @returns {string[]}\n * @private\n */\nfunction _caller(): string[] {\n  // see https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi\n  const error = Error as {} as { prepareStackTrace: (x: {}, stack: {}) => {} };\n  const origPrepareStackTrace = error.prepareStackTrace;\n  error.prepareStackTrace = (_, stack) => stack;\n  const stack = (new Error()).stack as {} | undefined as { getFileName(): string }[] | undefined;\n  error.prepareStackTrace = origPrepareStackTrace;\n\n  return stack ? stack.map(x => x.getFileName()).filter(x => !!x) : [];\n}\n\n\n/**\n * Get the global directory for node_modules. This is based on NPM code itself, and may be subject\n * to change, but is relatively stable.\n * @returns {string} The path to node_modules itself.\n * @private\n */\nfunction _getGlobalNodeModules() {\n  let globalPrefix;\n\n  if (process.env.PREFIX) {\n    globalPrefix = process.env.PREFIX;\n  } else if (process.platform === 'win32') {\n    // c:\\node\\node.exe --> prefix=c:\\node\\\n    globalPrefix = path.dirname(process.execPath);\n  } else {\n    // /usr/local/bin/node --> prefix=/usr/local\n    globalPrefix = path.dirname(path.dirname(process.execPath));\n\n    // destdir only is respected on Unix\n    const destdir = process.env.DESTDIR;\n    if (destdir) {\n      globalPrefix = path.join(destdir, globalPrefix);\n    }\n  }\n\n  return (process.platform !== 'win32')\n    ? path.resolve(globalPrefix || '', 'lib', 'node_modules')\n    : path.resolve(globalPrefix || '', 'node_modules');\n}\n\n\nexport interface ResolveOptions {\n  /**\n   * The basedir to use from which to resolve.\n   */\n  basedir: string;\n\n  /**\n   * The list of extensions to resolve. By default uses Object.keys(require.extensions).\n   */\n  extensions?: string[];\n\n  /**\n   * An additional list of paths to look into.\n   */\n  paths?: string[];\n\n  /**\n   * Whether or not to preserve symbolic links. If false, the actual paths pointed by\n   * the symbolic links will be used. This defaults to true.\n   */\n  preserveSymlinks?: boolean;\n\n  /**\n   * Whether to fallback to a global lookup if the basedir one failed.\n   */\n  checkGlobal?: boolean;\n\n  /**\n   * Whether to fallback to using the local caller's directory if the basedir failed.\n   */\n  checkLocal?: boolean;\n\n  /**\n   * Whether to only resolve and return the first package.json file found. By default,\n   * resolves the main field or the index of the package.\n   */\n  resolvePackageJson?: boolean;\n}\n\n\nlet _resolveHook: ((x: string, options: ResolveOptions) => string | null) | null = null;\nexport function setResolveHook(\n  hook: ((x: string, options: ResolveOptions) => string | null) | null,\n) {\n  _resolveHook = hook;\n}\n\n\n/**\n * Resolve a package using a logic similar to npm require.resolve, but with more options.\n * @param x The package name to resolve.\n * @param options A list of options. See documentation of those options.\n * @returns {string} Path to the index to include, or if `resolvePackageJson` option was\n *                   passed, a path to that file.\n * @throws {ModuleNotFoundException} If no module with that name was found anywhere.\n */\nexport function resolve(x: string, options: ResolveOptions): string {\n  if (_resolveHook) {\n    const maybe = _resolveHook(x, options);\n    if (maybe) {\n      return maybe;\n    }\n  }\n\n  const readFileSync = fs.readFileSync;\n\n  const extensions: string[] = options.extensions || Object.keys(require.extensions);\n  const basePath = options.basedir;\n\n  options.paths = options.paths || [];\n\n  if (/^(?:\\.\\.?(?:\\/|$)|\\/|([A-Za-z]:)?[/\\\\])/.test(x)) {\n    let res = path.resolve(basePath, x);\n    if (x === '..' || x.slice(-1) === '/') {\n      res += '/';\n    }\n\n    const m = loadAsFileSync(res) || loadAsDirectorySync(res);\n    if (m) {\n      return m;\n    }\n  } else {\n    const n = loadNodeModulesSync(x, basePath);\n    if (n) {\n      return n;\n    }\n  }\n\n  // Fallback to checking the local (callee) node modules.\n  if (options.checkLocal) {\n    const callers = _caller();\n    for (const caller of callers) {\n      const localDir = path.dirname(caller);\n      if (localDir !== options.basedir) {\n        try {\n          return resolve(x, {\n            ...options,\n            checkLocal: false,\n            checkGlobal: false,\n            basedir: localDir,\n          });\n        } catch (e) {\n          // Just swap the basePath with the original call one.\n          if (!(e instanceof ModuleNotFoundException)) {\n            throw e;\n          }\n        }\n      }\n    }\n  }\n\n  // Fallback to checking the global node modules.\n  if (options.checkGlobal) {\n    const globalDir = path.dirname(_getGlobalNodeModules());\n    if (globalDir !== options.basedir) {\n      try {\n        return resolve(x, {\n          ...options,\n          checkLocal: false,\n          checkGlobal: false,\n          basedir: globalDir,\n        });\n      } catch (e) {\n        // Just swap the basePath with the original call one.\n        if (!(e instanceof ModuleNotFoundException)) {\n          throw e;\n        }\n      }\n    }\n  }\n\n  throw new ModuleNotFoundException(x, basePath);\n\n  function loadAsFileSync(x: string): string | null {\n    if (isFile(x)) {\n      return x;\n    }\n\n    return extensions.map(ex => x + ex).find(f => isFile(f)) || null;\n  }\n\n  function loadAsDirectorySync(x: string): string | null {\n    const pkgfile = path.join(x, 'package.json');\n    if (isFile(pkgfile)) {\n      if (options.resolvePackageJson) {\n        return pkgfile;\n      }\n\n      try {\n        const body = readFileSync(pkgfile, 'UTF8');\n        const pkg = JSON.parse(body);\n\n        if (pkg['main']) {\n          if (pkg['main'] === '.' || pkg['main'] === './') {\n            pkg['main'] = 'index';\n          }\n\n          const m = loadAsFileSync(path.resolve(x, pkg['main']));\n          if (m) {\n            return m;\n          }\n          const n = loadAsDirectorySync(path.resolve(x, pkg['main']));\n          if (n) {\n            return n;\n          }\n        }\n      } catch {}\n    }\n\n    return loadAsFileSync(path.join(x, '/index'));\n  }\n\n  function loadNodeModulesSync(x: string, start: string): string | null {\n    const dirs = nodeModulesPaths(start, options);\n    for (const dir of dirs) {\n      const m = loadAsFileSync(path.join(dir, '/', x));\n      if (m) {\n        return m;\n      }\n      const n = loadAsDirectorySync(path.join(dir, '/', x));\n      if (n) {\n        return n;\n      }\n    }\n\n    return null;\n  }\n\n  function nodeModulesPaths(start: string, opts: ResolveOptions) {\n    const modules = ['node_modules'];\n\n    // ensure that `start` is an absolute path at this point,\n    // resolving against the process' current working directory\n    let absoluteStart = path.resolve(start);\n\n    if (opts && opts.preserveSymlinks === false) {\n      try {\n        absoluteStart = fs.realpathSync(absoluteStart);\n      } catch (err) {\n        if (err.code !== 'ENOENT') {\n          throw err;\n        }\n      }\n    }\n\n    let prefix = '/';\n    if (/^([A-Za-z]:)/.test(absoluteStart)) {\n      prefix = '';\n    } else if (/^\\\\\\\\/.test(absoluteStart)) {\n      prefix = '\\\\\\\\';\n    }\n\n    const paths = [absoluteStart];\n    let parsed = path.parse(absoluteStart);\n    while (parsed.dir !== paths[paths.length - 1]) {\n      paths.push(parsed.dir);\n      parsed = path.parse(parsed.dir);\n    }\n\n    const dirs = paths.reduce((dirs: string[], aPath: string) => {\n      return dirs.concat(modules.map(function (moduleDir) {\n        return path.join(prefix, aPath, moduleDir);\n      }));\n    }, []);\n\n    return opts && opts.paths ? dirs.concat(opts.paths) : dirs;\n  }\n}\n"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolve.js","sourceRoot":"./","sources":["packages/angular_devkit/core/node/resolve.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { BaseException } from '../src';\nimport { isFile } from './fs';\n\n/**\n * Exception thrown when a module could not be resolved.\n */\nexport class ModuleNotFoundException extends BaseException {\n  public readonly code: string;\n\n  constructor(public readonly moduleName: string, public readonly basePath: string) {\n    super(`Could not find module ${JSON.stringify(moduleName)} from ${JSON.stringify(basePath)}.`);\n    this.code = 'MODULE_NOT_FOUND';\n  }\n}\n\n/**\n * Returns a list of all the callers from the resolve() call.\n * @returns {string[]}\n * @private\n */\nfunction _caller(): string[] {\n  // see https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi\n  const error = Error as {} as { prepareStackTrace: (x: {}, stack: {}) => {} };\n  const origPrepareStackTrace = error.prepareStackTrace;\n  error.prepareStackTrace = (_, stack) => stack;\n  const stack = (new Error()).stack as {} | undefined as { getFileName(): string }[] | undefined;\n  error.prepareStackTrace = origPrepareStackTrace;\n\n  return stack ? stack.map(x => x.getFileName()).filter(x => !!x) : [];\n}\n\n\n/**\n * Get the global directory for node_modules. This is based on NPM code itself, and may be subject\n * to change, but is relatively stable.\n * @returns {string} The path to node_modules itself.\n * @private\n */\nfunction _getGlobalNodeModules() {\n  let globalPrefix;\n\n  if (process.env.PREFIX) {\n    globalPrefix = process.env.PREFIX;\n  } else if (process.platform === 'win32') {\n    // c:\\node\\node.exe --> prefix=c:\\node\\\n    globalPrefix = path.dirname(process.execPath);\n  } else {\n    // /usr/local/bin/node --> prefix=/usr/local\n    globalPrefix = path.dirname(path.dirname(process.execPath));\n\n    // destdir only is respected on Unix\n    const destdir = process.env.DESTDIR;\n    if (destdir) {\n      globalPrefix = path.join(destdir, globalPrefix);\n    }\n  }\n\n  return (process.platform !== 'win32')\n    ? path.resolve(globalPrefix || '', 'lib', 'node_modules')\n    : path.resolve(globalPrefix || '', 'node_modules');\n}\n\n\nexport interface ResolveOptions {\n  /**\n   * The basedir to use from which to resolve.\n   */\n  basedir: string;\n\n  /**\n   * The list of extensions to resolve. By default uses Object.keys(require.extensions).\n   */\n  extensions?: string[];\n\n  /**\n   * An additional list of paths to look into.\n   */\n  paths?: string[];\n\n  /**\n   * Whether or not to preserve symbolic links. If false, the actual paths pointed by\n   * the symbolic links will be used. This defaults to true.\n   */\n  preserveSymlinks?: boolean;\n\n  /**\n   * Whether to fallback to a global lookup if the basedir one failed.\n   */\n  checkGlobal?: boolean;\n\n  /**\n   * Whether to fallback to using the local caller's directory if the basedir failed.\n   */\n  checkLocal?: boolean;\n\n  /**\n   * Whether to only resolve and return the first package.json file found. By default,\n   * resolves the main field or the index of the package.\n   */\n  resolvePackageJson?: boolean;\n}\n\n\nlet _resolveHook: ((x: string, options: ResolveOptions) => string | null) | null = null;\nexport function setResolveHook(\n  hook: ((x: string, options: ResolveOptions) => string | null) | null,\n) {\n  _resolveHook = hook;\n}\n\n\n/**\n * Resolve a package using a logic similar to npm require.resolve, but with more options.\n * @param x The package name to resolve.\n * @param options A list of options. See documentation of those options.\n * @returns {string} Path to the index to include, or if `resolvePackageJson` option was\n *                   passed, a path to that file.\n * @throws {ModuleNotFoundException} If no module with that name was found anywhere.\n */\nexport function resolve(x: string, options: ResolveOptions): string {\n  if (_resolveHook) {\n    const maybe = _resolveHook(x, options);\n    if (maybe) {\n      return maybe;\n    }\n  }\n\n  const readFileSync = fs.readFileSync;\n\n  const extensions: string[] = options.extensions || Object.keys(require.extensions);\n  const basePath = options.basedir;\n\n  options.paths = options.paths || [];\n\n  if (/^(?:\\.\\.?(?:\\/|$)|\\/|([A-Za-z]:)?[/\\\\])/.test(x)) {\n    let res = path.resolve(basePath, x);\n    if (x === '..' || x.slice(-1) === '/') {\n      res += '/';\n    }\n\n    const m = loadAsFileSync(res) || loadAsDirectorySync(res);\n    if (m) {\n      return m;\n    }\n  } else {\n    const n = loadNodeModulesSync(x, basePath);\n    if (n) {\n      return n;\n    }\n  }\n\n  // Fallback to checking the local (callee) node modules.\n  if (options.checkLocal) {\n    const callers = _caller();\n    for (const caller of callers) {\n      const localDir = path.dirname(caller);\n      if (localDir !== options.basedir) {\n        try {\n          return resolve(x, {\n            ...options,\n            checkLocal: false,\n            checkGlobal: false,\n            basedir: localDir,\n          });\n        } catch (e) {\n          // Just swap the basePath with the original call one.\n          if (!(e instanceof ModuleNotFoundException)) {\n            throw e;\n          }\n        }\n      }\n    }\n  }\n\n  // Fallback to checking the global node modules.\n  if (options.checkGlobal) {\n    const globalDir = path.dirname(_getGlobalNodeModules());\n    if (globalDir !== options.basedir) {\n      try {\n        return resolve(x, {\n          ...options,\n          checkLocal: false,\n          checkGlobal: false,\n          basedir: globalDir,\n        });\n      } catch (e) {\n        // Just swap the basePath with the original call one.\n        if (!(e instanceof ModuleNotFoundException)) {\n          throw e;\n        }\n      }\n    }\n  }\n\n  throw new ModuleNotFoundException(x, basePath);\n\n  function loadAsFileSync(x: string): string | null {\n    if (isFile(x)) {\n      return x;\n    }\n\n    return extensions.map(ex => x + ex).find(f => isFile(f)) || null;\n  }\n\n  function loadAsDirectorySync(x: string): string | null {\n    const pkgfile = path.join(x, 'package.json');\n    if (isFile(pkgfile)) {\n      if (options.resolvePackageJson) {\n        return pkgfile;\n      }\n\n      try {\n        const body = readFileSync(pkgfile, 'UTF8');\n        const pkg = JSON.parse(body);\n\n        if (pkg['main']) {\n          if (pkg['main'] === '.' || pkg['main'] === './') {\n            pkg['main'] = 'index';\n          }\n\n          const m = loadAsFileSync(path.resolve(x, pkg['main']));\n          if (m) {\n            return m;\n          }\n          const n = loadAsDirectorySync(path.resolve(x, pkg['main']));\n          if (n) {\n            return n;\n          }\n        }\n      } catch {}\n    }\n\n    return loadAsFileSync(path.join(x, '/index'));\n  }\n\n  function loadNodeModulesSync(x: string, start: string): string | null {\n    const dirs = nodeModulesPaths(start, options);\n    for (const dir of dirs) {\n      const m = loadAsFileSync(path.join(dir, '/', x));\n      if (m) {\n        return m;\n      }\n      const n = loadAsDirectorySync(path.join(dir, '/', x));\n      if (n) {\n        return n;\n      }\n    }\n\n    return null;\n  }\n\n  function nodeModulesPaths(start: string, opts: ResolveOptions) {\n    const modules = ['node_modules'];\n    if (process.env.BAZEL_TARGET) {\n      // When running test under Bazel, node_modules have to be resolved\n      // differently. node_modules are installed in the `npm` workspace.\n      // For more info, see `yarn_install` rule in WORKSPACE file.\n      modules.push(path.join('npm', 'node_modules'));\n    }\n\n    // ensure that `start` is an absolute path at this point,\n    // resolving against the process' current working directory\n    let absoluteStart = path.resolve(start);\n\n    if (opts && opts.preserveSymlinks === false) {\n      try {\n        absoluteStart = fs.realpathSync(absoluteStart);\n      } catch (err) {\n        if (err.code !== 'ENOENT') {\n          throw err;\n        }\n      }\n    }\n\n    let prefix = '/';\n    if (/^([A-Za-z]:)/.test(absoluteStart)) {\n      prefix = '';\n    } else if (/^\\\\\\\\/.test(absoluteStart)) {\n      prefix = '\\\\\\\\';\n    }\n\n    const paths = [absoluteStart];\n    let parsed = path.parse(absoluteStart);\n    while (parsed.dir !== paths[paths.length - 1]) {\n      paths.push(parsed.dir);\n      parsed = path.parse(parsed.dir);\n    }\n\n    const dirs = paths.reduce((dirs: string[], aPath: string) => {\n      return dirs.concat(modules.map(function (moduleDir) {\n        return path.join(prefix, aPath, moduleDir);\n      }));\n    }, []);\n\n    return opts && opts.paths ? dirs.concat(opts.paths) : dirs;\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular-devkit/core",
3
- "version": "7.0.3",
3
+ "version": "7.0.7",
4
4
  "description": "Angular DevKit - Core Utility Library",
5
5
  "main": "src/index.js",
6
6
  "typings": "src/index.d.ts",
@@ -253,9 +253,10 @@ exports.path = (strings, ...values) => {
253
253
  return normalize(String.raw(strings, ...values));
254
254
  };
255
255
  function asWindowsPath(path) {
256
- const drive = path.match(/^\/(\w)\/(.*)$/);
256
+ const drive = path.match(/^\/(\w)(?:\/(.*))?$/);
257
257
  if (drive) {
258
- return `${drive[1]}:\\${drive[2].replace(/\//g, '\\')}`;
258
+ const subPath = drive[2] ? drive[2].replace(/\//g, '\\') : '';
259
+ return `${drive[1]}:\\${subPath}`;
259
260
  }
260
261
  return path.replace(/\//g, '\\');
261
262
  }
@@ -273,4 +274,4 @@ function getSystemPath(path) {
273
274
  }
274
275
  }
275
276
  exports.getSystemPath = getSystemPath;
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"./","sources":["packages/angular_devkit/core/src/virtual-fs/path.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { BaseException } from '../exception';\nimport { TemplateTag } from '../utils/literals';\n\n\nexport class InvalidPathException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} is invalid.`); }\n}\nexport class PathMustBeAbsoluteException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} must be absolute.`); }\n}\nexport class PathCannotBeFragmentException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} cannot be made a fragment.`); }\n}\n\n\n/**\n * A Path recognized by most methods in the DevKit.\n */\nexport type Path = string & {\n  __PRIVATE_DEVKIT_PATH: void;\n};\n\n/**\n * A Path fragment (file or directory name) recognized by most methods in the DevKit.\n */\nexport type PathFragment = Path & {\n  __PRIVATE_DEVKIT_PATH_FRAGMENT: void;\n};\n\n\n/**\n * The Separator for normalized path.\n * @type {Path}\n */\nexport const NormalizedSep = '/' as Path;\n\n\n/**\n * The root of a normalized path.\n * @type {Path}\n */\nexport const NormalizedRoot = NormalizedSep as Path;\n\n\n/**\n * Split a path into multiple path fragments. Each fragments except the last one will end with\n * a path separator.\n * @param {Path} path The path to split.\n * @returns {Path[]} An array of path fragments.\n */\nexport function split(path: Path): PathFragment[] {\n  const fragments = path.split(NormalizedSep).map(x => fragment(x));\n  if (fragments[fragments.length - 1].length === 0) {\n    fragments.pop();\n  }\n\n  return fragments;\n}\n\n/**\n *\n */\nexport function extname(path: Path): string {\n  const base = basename(path);\n  const i = base.lastIndexOf('.');\n  if (i < 1) {\n    return '';\n  } else {\n    return base.substr(i);\n  }\n}\n\n\n/**\n * Return the basename of the path, as a Path. See path.basename\n */\nexport function basename(path: Path): PathFragment {\n  const i = path.lastIndexOf(NormalizedSep);\n  if (i == -1) {\n    return fragment(path);\n  } else {\n    return fragment(path.substr(path.lastIndexOf(NormalizedSep) + 1));\n  }\n}\n\n\n/**\n * Return the dirname of the path, as a Path. See path.dirname\n */\nexport function dirname(path: Path): Path {\n  const index = path.lastIndexOf(NormalizedSep);\n  if (index === -1) {\n    return '' as Path;\n  }\n\n  const endIndex = index === 0 ? 1 : index; // case of file under root: '/file'\n\n  return normalize(path.substr(0, endIndex));\n}\n\n\n/**\n * Join multiple paths together, and normalize the result. Accepts strings that will be\n * normalized as well (but the original must be a path).\n */\nexport function join(p1: Path, ...others: string[]): Path {\n  if (others.length > 0) {\n    return normalize((p1 ? p1 + NormalizedSep : '') + others.join(NormalizedSep));\n  } else {\n    return p1;\n  }\n}\n\n\n/**\n * Returns true if a path is absolute.\n */\nexport function isAbsolute(p: Path) {\n  return p.startsWith(NormalizedSep);\n}\n\n\n/**\n * Returns a path such that `join(from, relative(from, to)) == to`.\n * Both paths must be absolute, otherwise it does not make much sense.\n */\nexport function relative(from: Path, to: Path): Path {\n  if (!isAbsolute(from)) {\n    throw new PathMustBeAbsoluteException(from);\n  }\n  if (!isAbsolute(to)) {\n    throw new PathMustBeAbsoluteException(to);\n  }\n\n  let p: string;\n\n  if (from == to) {\n    p = '';\n  } else {\n    const splitFrom = from.split(NormalizedSep);\n    const splitTo = to.split(NormalizedSep);\n\n    while (splitFrom.length > 0 && splitTo.length > 0 && splitFrom[0] == splitTo[0]) {\n      splitFrom.shift();\n      splitTo.shift();\n    }\n\n    if (splitFrom.length == 0) {\n      p = splitTo.join(NormalizedSep);\n    } else {\n      p = splitFrom.map(_ => '..').concat(splitTo).join(NormalizedSep);\n    }\n  }\n\n  return normalize(p);\n}\n\n\n/**\n * Returns a Path that is the resolution of p2, from p1. If p2 is absolute, it will return p2,\n * otherwise will join both p1 and p2.\n */\nexport function resolve(p1: Path, p2: Path) {\n  if (isAbsolute(p2)) {\n    return p2;\n  } else {\n    return join(p1, p2);\n  }\n}\n\n\nexport function fragment(path: string): PathFragment {\n  if (path.indexOf(NormalizedSep) != -1) {\n    throw new PathCannotBeFragmentException(path);\n  }\n\n  return path as PathFragment;\n}\n\n\n/**\n * normalize() cache to reduce computation. For now this grows and we never flush it, but in the\n * future we might want to add a few cache flush to prevent this from growing too large.\n */\nlet normalizedCache = new Map<string, Path>();\n\n\n/**\n * Reset the cache. This is only useful for testing.\n * @private\n */\nexport function resetNormalizeCache() {\n  normalizedCache = new Map<string, Path>();\n}\n\n\n/**\n * Normalize a string into a Path. This is the only mean to get a Path type from a string that\n * represents a system path. This method cache the results as real world paths tend to be\n * duplicated often.\n * Normalization includes:\n *   - Windows backslashes `\\\\` are replaced with `/`.\n *   - Windows drivers are replaced with `/X/`, where X is the drive letter.\n *   - Absolute paths starts with `/`.\n *   - Multiple `/` are replaced by a single one.\n *   - Path segments `.` are removed.\n *   - Path segments `..` are resolved.\n *   - If a path is absolute, having a `..` at the start is invalid (and will throw).\n * @param path The path to be normalized.\n */\nexport function normalize(path: string): Path {\n  let maybePath = normalizedCache.get(path);\n  if (!maybePath) {\n    maybePath = noCacheNormalize(path);\n    normalizedCache.set(path, maybePath);\n  }\n\n  return maybePath;\n}\n\n\n/**\n * The no cache version of the normalize() function. Used for benchmarking and testing.\n */\nexport function noCacheNormalize(path: string): Path {\n  if (path == '' || path == '.') {\n    return '' as Path;\n  } else if (path == NormalizedRoot) {\n    return NormalizedRoot;\n  }\n\n  // Match absolute windows path.\n  const original = path;\n  if (path.match(/^[A-Z]:[\\/\\\\]/i)) {\n    path = '\\\\' + path[0] + '\\\\' + path.substr(3);\n  }\n\n  // We convert Windows paths as well here.\n  const p = path.split(/[\\/\\\\]/g);\n  let relative = false;\n  let i = 1;\n\n  // Special case the first one.\n  if (p[0] != '') {\n    p.unshift('.');\n    relative = true;\n  }\n\n  while (i < p.length) {\n    if (p[i] == '.') {\n      p.splice(i, 1);\n    } else if (p[i] == '..') {\n      if (i < 2 && !relative) {\n        throw new InvalidPathException(original);\n      } else if (i >= 2 && p[i - 1] != '..') {\n        p.splice(i - 1, 2);\n        i--;\n      } else {\n        i++;\n      }\n    } else if (p[i] == '') {\n      p.splice(i, 1);\n    } else {\n      i++;\n    }\n  }\n\n  if (p.length == 1) {\n    return p[0] == '' ? NormalizedSep : '' as Path;\n  } else {\n    if (p[0] == '.') {\n      p.shift();\n    }\n\n    return p.join(NormalizedSep) as Path;\n  }\n}\n\n\nexport const path: TemplateTag<Path> = (strings, ...values) => {\n  return normalize(String.raw(strings, ...values));\n};\n\n\n// Platform-specific paths.\nexport type WindowsPath = string & {\n  __PRIVATE_DEVKIT_WINDOWS_PATH: void;\n};\nexport type PosixPath = string & {\n  __PRIVATE_DEVKIT_POSIX_PATH: void;\n};\n\nexport function asWindowsPath(path: Path): WindowsPath {\n  const drive = path.match(/^\\/(\\w)\\/(.*)$/);\n  if (drive) {\n    return `${drive[1]}:\\\\${drive[2].replace(/\\//g, '\\\\')}` as WindowsPath;\n  }\n\n  return path.replace(/\\//g, '\\\\') as WindowsPath;\n}\n\nexport function asPosixPath(path: Path): PosixPath {\n  return path as string as PosixPath;\n}\n\nexport function getSystemPath(path: Path): string {\n  if (process.platform.startsWith('win32')) {\n    return asWindowsPath(path);\n  } else {\n    return asPosixPath(path);\n  }\n}\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"./","sources":["packages/angular_devkit/core/src/virtual-fs/path.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { BaseException } from '../exception';\nimport { TemplateTag } from '../utils/literals';\n\n\nexport class InvalidPathException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} is invalid.`); }\n}\nexport class PathMustBeAbsoluteException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} must be absolute.`); }\n}\nexport class PathCannotBeFragmentException extends BaseException {\n  constructor(path: string) { super(`Path ${JSON.stringify(path)} cannot be made a fragment.`); }\n}\n\n\n/**\n * A Path recognized by most methods in the DevKit.\n */\nexport type Path = string & {\n  __PRIVATE_DEVKIT_PATH: void;\n};\n\n/**\n * A Path fragment (file or directory name) recognized by most methods in the DevKit.\n */\nexport type PathFragment = Path & {\n  __PRIVATE_DEVKIT_PATH_FRAGMENT: void;\n};\n\n\n/**\n * The Separator for normalized path.\n * @type {Path}\n */\nexport const NormalizedSep = '/' as Path;\n\n\n/**\n * The root of a normalized path.\n * @type {Path}\n */\nexport const NormalizedRoot = NormalizedSep as Path;\n\n\n/**\n * Split a path into multiple path fragments. Each fragments except the last one will end with\n * a path separator.\n * @param {Path} path The path to split.\n * @returns {Path[]} An array of path fragments.\n */\nexport function split(path: Path): PathFragment[] {\n  const fragments = path.split(NormalizedSep).map(x => fragment(x));\n  if (fragments[fragments.length - 1].length === 0) {\n    fragments.pop();\n  }\n\n  return fragments;\n}\n\n/**\n *\n */\nexport function extname(path: Path): string {\n  const base = basename(path);\n  const i = base.lastIndexOf('.');\n  if (i < 1) {\n    return '';\n  } else {\n    return base.substr(i);\n  }\n}\n\n\n/**\n * Return the basename of the path, as a Path. See path.basename\n */\nexport function basename(path: Path): PathFragment {\n  const i = path.lastIndexOf(NormalizedSep);\n  if (i == -1) {\n    return fragment(path);\n  } else {\n    return fragment(path.substr(path.lastIndexOf(NormalizedSep) + 1));\n  }\n}\n\n\n/**\n * Return the dirname of the path, as a Path. See path.dirname\n */\nexport function dirname(path: Path): Path {\n  const index = path.lastIndexOf(NormalizedSep);\n  if (index === -1) {\n    return '' as Path;\n  }\n\n  const endIndex = index === 0 ? 1 : index; // case of file under root: '/file'\n\n  return normalize(path.substr(0, endIndex));\n}\n\n\n/**\n * Join multiple paths together, and normalize the result. Accepts strings that will be\n * normalized as well (but the original must be a path).\n */\nexport function join(p1: Path, ...others: string[]): Path {\n  if (others.length > 0) {\n    return normalize((p1 ? p1 + NormalizedSep : '') + others.join(NormalizedSep));\n  } else {\n    return p1;\n  }\n}\n\n\n/**\n * Returns true if a path is absolute.\n */\nexport function isAbsolute(p: Path) {\n  return p.startsWith(NormalizedSep);\n}\n\n\n/**\n * Returns a path such that `join(from, relative(from, to)) == to`.\n * Both paths must be absolute, otherwise it does not make much sense.\n */\nexport function relative(from: Path, to: Path): Path {\n  if (!isAbsolute(from)) {\n    throw new PathMustBeAbsoluteException(from);\n  }\n  if (!isAbsolute(to)) {\n    throw new PathMustBeAbsoluteException(to);\n  }\n\n  let p: string;\n\n  if (from == to) {\n    p = '';\n  } else {\n    const splitFrom = from.split(NormalizedSep);\n    const splitTo = to.split(NormalizedSep);\n\n    while (splitFrom.length > 0 && splitTo.length > 0 && splitFrom[0] == splitTo[0]) {\n      splitFrom.shift();\n      splitTo.shift();\n    }\n\n    if (splitFrom.length == 0) {\n      p = splitTo.join(NormalizedSep);\n    } else {\n      p = splitFrom.map(_ => '..').concat(splitTo).join(NormalizedSep);\n    }\n  }\n\n  return normalize(p);\n}\n\n\n/**\n * Returns a Path that is the resolution of p2, from p1. If p2 is absolute, it will return p2,\n * otherwise will join both p1 and p2.\n */\nexport function resolve(p1: Path, p2: Path) {\n  if (isAbsolute(p2)) {\n    return p2;\n  } else {\n    return join(p1, p2);\n  }\n}\n\n\nexport function fragment(path: string): PathFragment {\n  if (path.indexOf(NormalizedSep) != -1) {\n    throw new PathCannotBeFragmentException(path);\n  }\n\n  return path as PathFragment;\n}\n\n\n/**\n * normalize() cache to reduce computation. For now this grows and we never flush it, but in the\n * future we might want to add a few cache flush to prevent this from growing too large.\n */\nlet normalizedCache = new Map<string, Path>();\n\n\n/**\n * Reset the cache. This is only useful for testing.\n * @private\n */\nexport function resetNormalizeCache() {\n  normalizedCache = new Map<string, Path>();\n}\n\n\n/**\n * Normalize a string into a Path. This is the only mean to get a Path type from a string that\n * represents a system path. This method cache the results as real world paths tend to be\n * duplicated often.\n * Normalization includes:\n *   - Windows backslashes `\\\\` are replaced with `/`.\n *   - Windows drivers are replaced with `/X/`, where X is the drive letter.\n *   - Absolute paths starts with `/`.\n *   - Multiple `/` are replaced by a single one.\n *   - Path segments `.` are removed.\n *   - Path segments `..` are resolved.\n *   - If a path is absolute, having a `..` at the start is invalid (and will throw).\n * @param path The path to be normalized.\n */\nexport function normalize(path: string): Path {\n  let maybePath = normalizedCache.get(path);\n  if (!maybePath) {\n    maybePath = noCacheNormalize(path);\n    normalizedCache.set(path, maybePath);\n  }\n\n  return maybePath;\n}\n\n\n/**\n * The no cache version of the normalize() function. Used for benchmarking and testing.\n */\nexport function noCacheNormalize(path: string): Path {\n  if (path == '' || path == '.') {\n    return '' as Path;\n  } else if (path == NormalizedRoot) {\n    return NormalizedRoot;\n  }\n\n  // Match absolute windows path.\n  const original = path;\n  if (path.match(/^[A-Z]:[\\/\\\\]/i)) {\n    path = '\\\\' + path[0] + '\\\\' + path.substr(3);\n  }\n\n  // We convert Windows paths as well here.\n  const p = path.split(/[\\/\\\\]/g);\n  let relative = false;\n  let i = 1;\n\n  // Special case the first one.\n  if (p[0] != '') {\n    p.unshift('.');\n    relative = true;\n  }\n\n  while (i < p.length) {\n    if (p[i] == '.') {\n      p.splice(i, 1);\n    } else if (p[i] == '..') {\n      if (i < 2 && !relative) {\n        throw new InvalidPathException(original);\n      } else if (i >= 2 && p[i - 1] != '..') {\n        p.splice(i - 1, 2);\n        i--;\n      } else {\n        i++;\n      }\n    } else if (p[i] == '') {\n      p.splice(i, 1);\n    } else {\n      i++;\n    }\n  }\n\n  if (p.length == 1) {\n    return p[0] == '' ? NormalizedSep : '' as Path;\n  } else {\n    if (p[0] == '.') {\n      p.shift();\n    }\n\n    return p.join(NormalizedSep) as Path;\n  }\n}\n\n\nexport const path: TemplateTag<Path> = (strings, ...values) => {\n  return normalize(String.raw(strings, ...values));\n};\n\n\n// Platform-specific paths.\nexport type WindowsPath = string & {\n  __PRIVATE_DEVKIT_WINDOWS_PATH: void;\n};\nexport type PosixPath = string & {\n  __PRIVATE_DEVKIT_POSIX_PATH: void;\n};\n\nexport function asWindowsPath(path: Path): WindowsPath {\n  const drive = path.match(/^\\/(\\w)(?:\\/(.*))?$/);\n  if (drive) {\n    const subPath = drive[2] ? drive[2].replace(/\\//g, '\\\\') : '';\n\n    return `${drive[1]}:\\\\${subPath}` as WindowsPath;\n  }\n\n  return path.replace(/\\//g, '\\\\') as WindowsPath;\n}\n\nexport function asPosixPath(path: Path): PosixPath {\n  return path as string as PosixPath;\n}\n\nexport function getSystemPath(path: Path): string {\n  if (process.platform.startsWith('win32')) {\n    return asWindowsPath(path);\n  } else {\n    return asPosixPath(path);\n  }\n}\n"]}