执行过npm install命令的vue-element-admin源码
康凯
2022-05-20 aa4c235a8ca67ea8b731f90c951a465e92c0a865
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
'use strict';
 
Object.defineProperty(exports, '__esModule', {
  value: true
});
exports.default = void 0;
 
function _path() {
  const data = _interopRequireDefault(require('path'));
 
  _path = function _path() {
    return data;
  };
 
  return data;
}
 
function _fs() {
  const data = _interopRequireDefault(require('fs'));
 
  _fs = function _fs() {
    return data;
  };
 
  return data;
}
 
var _constants = require('./constants');
 
function _interopRequireDefault(obj) {
  return obj && obj.__esModule ? obj : {default: obj};
}
 
/**
 * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
const isFile = filePath =>
  _fs().default.existsSync(filePath) &&
  !_fs()
    .default.lstatSync(filePath)
    .isDirectory();
 
var _default = (pathToResolve, cwd) => {
  if (!_path().default.isAbsolute(cwd)) {
    throw new Error(`"cwd" must be an absolute path. cwd: ${cwd}`);
  }
 
  const absolutePath = _path().default.isAbsolute(pathToResolve)
    ? pathToResolve
    : _path().default.resolve(cwd, pathToResolve);
 
  if (isFile(absolutePath)) {
    return absolutePath;
  } // This is a guard against passing non existing path as a project/config,
  // that will otherwise result in a very confusing situation.
  // e.g.
  // With a directory structure like this:
  //   my_project/
  //     packcage.json
  //
  // Passing a `my_project/some_directory_that_doesnt_exist` as a project
  // name will resolve into a (possibly empty) `my_project/package.json` and
  // try to run all tests it finds under `my_project` directory.
 
  if (!_fs().default.existsSync(absolutePath)) {
    throw new Error(
      `Can't find a root directory while resolving a config file path.\n` +
        `Provided path to resolve: ${pathToResolve}\n` +
        `cwd: ${cwd}`
    );
  }
 
  return resolveConfigPathByTraversing(absolutePath, pathToResolve, cwd);
};
 
exports.default = _default;
 
const resolveConfigPathByTraversing = (pathToResolve, initialPath, cwd) => {
  const jestConfig = _path().default.resolve(
    pathToResolve,
    _constants.JEST_CONFIG
  );
 
  if (isFile(jestConfig)) {
    return jestConfig;
  }
 
  const packageJson = _path().default.resolve(
    pathToResolve,
    _constants.PACKAGE_JSON
  );
 
  if (isFile(packageJson)) {
    return packageJson;
  } // This is the system root.
  // We tried everything, config is nowhere to be found ¯\_(ツ)_/¯
 
  if (pathToResolve === _path().default.dirname(pathToResolve)) {
    throw new Error(makeResolutionErrorMessage(initialPath, cwd));
  } // go up a level and try it again
 
  return resolveConfigPathByTraversing(
    _path().default.dirname(pathToResolve),
    initialPath,
    cwd
  );
};
 
const makeResolutionErrorMessage = (initialPath, cwd) =>
  'Could not find a config file based on provided values:\n' +
  `path: "${initialPath}"\n` +
  `cwd: "${cwd}"\n` +
  'Config paths must be specified by either a direct path to a config\n' +
  'file, or a path to a directory. If directory is given, Jest will try to\n' +
  `traverse directory tree up, until it finds either "${_constants.JEST_CONFIG}" or\n` +
  `"${_constants.PACKAGE_JSON}".`;