@umijs/utils 4.0.0-canary.20220628.1 → 4.0.0-canary.20220713.1

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.
@@ -0,0 +1,6 @@
1
+ export interface IGitInfo {
2
+ username: string;
3
+ email: string;
4
+ }
5
+ declare const getGitInfo: () => Promise<IGitInfo>;
6
+ export default getGitInfo;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const execa = __importStar(require("../compiled/execa"));
27
+ const getGitInfo = async () => {
28
+ try {
29
+ const [{ stdout: username }, { stdout: email }] = await Promise.all([
30
+ execa.execaCommand('git config --global user.name'),
31
+ execa.execaCommand('git config --global user.email'),
32
+ ]);
33
+ return { username, email };
34
+ }
35
+ catch (e) {
36
+ return {
37
+ username: '',
38
+ email: '',
39
+ };
40
+ }
41
+ };
42
+ exports.default = getGitInfo;
package/dist/index.d.ts CHANGED
@@ -22,8 +22,10 @@ import yParser from '../compiled/yargs-parser';
22
22
  import BaseGenerator from './BaseGenerator/BaseGenerator';
23
23
  import generateFile from './BaseGenerator/generateFile';
24
24
  import Generator from './Generator/Generator';
25
+ import getGitInfo from './getGitInfo';
25
26
  import installDeps from './installDeps';
26
27
  import * as logger from './logger';
28
+ import * as printHelp from './printHelp';
27
29
  import updatePackageJSON from './updatePackageJSON';
28
30
  export * from './getCorejsVersion';
29
31
  export * from './importLazy';
@@ -34,4 +36,4 @@ export * from './randomColor/randomColor';
34
36
  export * as register from './register';
35
37
  export * from './tryPaths';
36
38
  export * from './winPath';
37
- export { address, axios, chalk, cheerio, chokidar, crossSpawn, debug, deepmerge, execa, fsExtra, glob, Generator, BaseGenerator, generateFile, installDeps, lodash, logger, Mustache, pkgUp, portfinder, prompts, resolve, rimraf, semver, stripAnsi, updatePackageJSON, yParser, };
39
+ export { address, axios, chalk, cheerio, chokidar, crossSpawn, debug, deepmerge, execa, fsExtra, glob, Generator, BaseGenerator, generateFile, installDeps, lodash, logger, Mustache, pkgUp, portfinder, prompts, resolve, rimraf, semver, stripAnsi, updatePackageJSON, yParser, getGitInfo, printHelp, };
package/dist/index.js CHANGED
@@ -29,7 +29,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
29
29
  return (mod && mod.__esModule) ? mod : { "default": mod };
30
30
  };
31
31
  Object.defineProperty(exports, "__esModule", { value: true });
32
- exports.yParser = exports.updatePackageJSON = exports.stripAnsi = exports.semver = exports.rimraf = exports.resolve = exports.prompts = exports.portfinder = exports.pkgUp = exports.Mustache = exports.logger = exports.lodash = exports.installDeps = exports.generateFile = exports.BaseGenerator = exports.Generator = exports.glob = exports.fsExtra = exports.execa = exports.deepmerge = exports.debug = exports.crossSpawn = exports.chokidar = exports.cheerio = exports.chalk = exports.axios = exports.address = exports.register = void 0;
32
+ exports.printHelp = exports.getGitInfo = exports.yParser = exports.updatePackageJSON = exports.stripAnsi = exports.semver = exports.rimraf = exports.resolve = exports.prompts = exports.portfinder = exports.pkgUp = exports.Mustache = exports.logger = exports.lodash = exports.installDeps = exports.generateFile = exports.BaseGenerator = exports.Generator = exports.glob = exports.fsExtra = exports.execa = exports.deepmerge = exports.debug = exports.crossSpawn = exports.chokidar = exports.cheerio = exports.chalk = exports.axios = exports.address = exports.register = void 0;
33
33
  const chokidar = __importStar(require("chokidar"));
34
34
  exports.chokidar = chokidar;
35
35
  const address_1 = __importDefault(require("../compiled/address"));
@@ -79,10 +79,14 @@ const generateFile_1 = __importDefault(require("./BaseGenerator/generateFile"));
79
79
  exports.generateFile = generateFile_1.default;
80
80
  const Generator_1 = __importDefault(require("./Generator/Generator"));
81
81
  exports.Generator = Generator_1.default;
82
+ const getGitInfo_1 = __importDefault(require("./getGitInfo"));
83
+ exports.getGitInfo = getGitInfo_1.default;
82
84
  const installDeps_1 = __importDefault(require("./installDeps"));
83
85
  exports.installDeps = installDeps_1.default;
84
86
  const logger = __importStar(require("./logger"));
85
87
  exports.logger = logger;
88
+ const printHelp = __importStar(require("./printHelp"));
89
+ exports.printHelp = printHelp;
86
90
  const updatePackageJSON_1 = __importDefault(require("./updatePackageJSON"));
87
91
  exports.updatePackageJSON = updatePackageJSON_1.default;
88
92
  __exportStar(require("./getCorejsVersion"), exports);
package/dist/logger.d.ts CHANGED
@@ -16,4 +16,4 @@ export declare function info(...message: any[]): void;
16
16
  export declare function event(...message: any[]): void;
17
17
  export declare function debug(...message: any[]): void;
18
18
  export declare function fatal(...message: any[]): void;
19
- export declare function getLatestLogFilePath(): string;
19
+ export declare function getLatestLogFilePath(): string | null;
package/dist/logger.js CHANGED
@@ -5,33 +5,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.getLatestLogFilePath = exports.fatal = exports.debug = exports.event = exports.info = exports.ready = exports.warn = exports.error = exports.wait = exports.prefixes = void 0;
7
7
  const path_1 = require("path");
8
- const pino_1 = __importDefault(require("pino"));
9
8
  const chalk_1 = __importDefault(require("../compiled/chalk"));
10
9
  const fs_extra_1 = __importDefault(require("../compiled/fs-extra"));
10
+ const importLazy_1 = require("./importLazy");
11
+ const enableFSLogger = process.env.FS_LOGGER !== 'none' && !process.versions.webcontainer;
11
12
  const loggerDir = (0, path_1.join)(process.cwd(), 'node_modules/.cache/logger');
12
13
  const loggerPath = (0, path_1.join)(loggerDir, 'umi.log');
13
- fs_extra_1.default.mkdirpSync(loggerDir);
14
- const customLevels = {
15
- ready: 31,
16
- event: 32,
17
- wait: 55,
18
- // 虽然这里设置了 debug 为 30,但日志中还是 20,符合预期
19
- // 这里不加会不生成到 umi.log,transport 的 level 配置没有生效,原因不明
20
- debug: 30,
21
- };
22
- const logger = (0, pino_1.default)({
23
- customLevels,
24
- }, pino_1.default.transport({
25
- targets: [
26
- {
27
- target: require.resolve('pino/file'),
28
- options: {
29
- destination: loggerPath,
30
- },
31
- level: 'trace',
32
- },
33
- ],
34
- }));
35
14
  exports.prefixes = {
36
15
  wait: chalk_1.default.cyan('wait') + ' -',
37
16
  error: chalk_1.default.red('error') + ' -',
@@ -42,6 +21,38 @@ exports.prefixes = {
42
21
  event: chalk_1.default.magenta('event') + ' -',
43
22
  debug: chalk_1.default.gray('debug') + ' -',
44
23
  };
24
+ let logger;
25
+ if (enableFSLogger) {
26
+ const { default: pino } = (0, importLazy_1.importLazy)(require.resolve('pino'));
27
+ fs_extra_1.default.mkdirpSync(loggerDir);
28
+ const customLevels = {
29
+ ready: 31,
30
+ event: 32,
31
+ wait: 55,
32
+ // 虽然这里设置了 debug 为 30,但日志中还是 20,符合预期
33
+ // 这里不加会不生成到 umi.log,transport 的 level 配置没有生效,原因不明
34
+ debug: 30,
35
+ };
36
+ logger = pino({
37
+ customLevels,
38
+ }, pino.transport({
39
+ targets: [
40
+ {
41
+ target: require.resolve('pino/file'),
42
+ options: {
43
+ destination: loggerPath,
44
+ },
45
+ level: 'trace',
46
+ },
47
+ ],
48
+ }));
49
+ }
50
+ else {
51
+ logger = {};
52
+ Object.keys(exports.prefixes).forEach((key) => {
53
+ logger[key] = () => { };
54
+ });
55
+ }
45
56
  function wait(...message) {
46
57
  console.log(exports.prefixes.wait, ...message);
47
58
  logger.wait(message[0]);
@@ -85,6 +96,6 @@ function fatal(...message) {
85
96
  }
86
97
  exports.fatal = fatal;
87
98
  function getLatestLogFilePath() {
88
- return loggerPath;
99
+ return enableFSLogger ? loggerPath : null;
89
100
  }
90
101
  exports.getLatestLogFilePath = getLatestLogFilePath;
@@ -0,0 +1,2 @@
1
+ export declare function exit(): void;
2
+ export declare function runtime(e: Error): void;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.runtime = exports.exit = void 0;
27
+ const logger = __importStar(require("./logger"));
28
+ const FEEDBACK_MESSAGE = '如果你需要进交流群,请访问 https://fb.umijs.org';
29
+ function exit() {
30
+ const loggerPath = logger.getLatestLogFilePath();
31
+ if (loggerPath) {
32
+ logger.fatal('A complete log of this run can be found in:');
33
+ logger.fatal(loggerPath);
34
+ }
35
+ logger.fatal('Consider reporting a GitHub issue on https://github.com/umijs/umi/issues');
36
+ logger.fatal(FEEDBACK_MESSAGE);
37
+ }
38
+ exports.exit = exit;
39
+ function runtime(e) {
40
+ logger.error(e);
41
+ logger.fatal(FEEDBACK_MESSAGE);
42
+ }
43
+ exports.runtime = runtime;
package/dist/register.js CHANGED
@@ -12,13 +12,21 @@ function transform(opts) {
12
12
  const { code, filename, implementor } = opts;
13
13
  files.push(filename);
14
14
  const ext = (0, path_1.extname)(filename);
15
- return implementor.transformSync(code, {
16
- loader: ext.slice(1),
17
- // consistent with `tsconfig.base.json`
18
- // https://github.com/umijs/umi-next/pull/729
19
- target: 'es2019',
20
- format: 'cjs',
21
- }).code;
15
+ try {
16
+ return implementor.transformSync(code, {
17
+ sourcefile: filename,
18
+ loader: ext.slice(1),
19
+ // consistent with `tsconfig.base.json`
20
+ // https://github.com/umijs/umi-next/pull/729
21
+ target: 'es2019',
22
+ format: 'cjs',
23
+ logLevel: 'error',
24
+ }).code;
25
+ }
26
+ catch (e) {
27
+ // @ts-ignore
28
+ throw new Error(`Parse file failed: [${filename}]`, { cause: e });
29
+ }
22
30
  }
23
31
  function register(opts) {
24
32
  files = [];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@umijs/utils",
3
- "version": "4.0.0-canary.20220628.1",
3
+ "version": "4.0.0-canary.20220713.1",
4
4
  "homepage": "https://github.com/umijs/umi/tree/master/packages/utils#readme",
5
5
  "bugs": "https://github.com/umijs/umi/issues",
6
6
  "repository": {