@liuli-util/cli 3.20.2 → 3.22.0
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.
- package/CHANGELOG.md +22 -0
- package/README.md +69 -25
- package/README.zh-CN.md +7 -7
- package/package.json +40 -36
- package/src/commands/deploy/DeployService.ts +20 -2
- package/src/commands/deploy/__tests__/DeployService.test.ts +23 -4
- package/src/commands/esbuild/ESBuildProgram.ts +5 -9
- package/src/commands/esbuild/__tests__/ESBuildProgram.test.ts +2 -2
- package/src/commands/esbuild/util/autoExternal.ts +22 -0
- package/src/commands/esbuild/util/env.ts +67 -0
- package/src/commands/esbuild/util/index.ts +10 -0
- package/src/commands/esbuild/util/log.ts +20 -0
- package/src/commands/esbuild/util/metafile.ts +17 -0
- package/src/commands/esbuild/util/nativeNodeModules.ts +43 -0
- package/src/commands/esbuild/util/nodeExternal.ts +16 -0
- package/src/commands/esbuild/util/raw.ts +27 -0
- package/src/commands/esbuild/util/resolve.ts +22 -0
- package/src/commands/esbuild/util/sideEffect.ts +29 -0
- package/src/commands/esbuild/util/userJS.ts +38 -0
- package/templates/cli/package.json +35 -33
- package/templates/lib/package.json +24 -19
- package/dist/PathUtil.d.ts +0 -7
- package/dist/PathUtil.d.ts.map +0 -1
- package/dist/bin.d.ts +0 -2
- package/dist/bin.d.ts.map +0 -1
- package/dist/bin.js +0 -171
- package/dist/bin.js.map +0 -7
- package/dist/commands/deploy/DeployService.d.ts +0 -70
- package/dist/commands/deploy/DeployService.d.ts.map +0 -1
- package/dist/commands/deploy/deploy.d.ts +0 -3
- package/dist/commands/deploy/deploy.d.ts.map +0 -1
- package/dist/commands/deploy/index.d.ts +0 -3
- package/dist/commands/deploy/index.d.ts.map +0 -1
- package/dist/commands/deploy/util/PromiseUtil.d.ts +0 -14
- package/dist/commands/deploy/util/PromiseUtil.d.ts.map +0 -1
- package/dist/commands/deploy/util/createArchive.d.ts +0 -10
- package/dist/commands/deploy/util/createArchive.d.ts.map +0 -1
- package/dist/commands/deploy/util/execPromise.d.ts +0 -4
- package/dist/commands/deploy/util/execPromise.d.ts.map +0 -1
- package/dist/commands/deploy/util/validate.d.ts +0 -8
- package/dist/commands/deploy/util/validate.d.ts.map +0 -1
- package/dist/commands/deploy/util/wait.d.ts +0 -9
- package/dist/commands/deploy/util/wait.d.ts.map +0 -1
- package/dist/commands/esbuild/ESBuildProgram.d.ts +0 -83
- package/dist/commands/esbuild/ESBuildProgram.d.ts.map +0 -1
- package/dist/commands/esbuild/index.d.ts +0 -3
- package/dist/commands/esbuild/index.d.ts.map +0 -1
- package/dist/commands/esbuild/util/debounce.d.ts +0 -15
- package/dist/commands/esbuild/util/debounce.d.ts.map +0 -1
- package/dist/commands/esbuild/util/esbuildPlugins.d.ts +0 -32
- package/dist/commands/esbuild/util/esbuildPlugins.d.ts.map +0 -1
- package/dist/commands/esbuild/util/getPkgGlobalName.d.ts +0 -6
- package/dist/commands/esbuild/util/getPkgGlobalName.d.ts.map +0 -1
- package/dist/commands/generate/GenerateProgram.d.ts +0 -18
- package/dist/commands/generate/GenerateProgram.d.ts.map +0 -1
- package/dist/commands/generate/index.d.ts +0 -3
- package/dist/commands/generate/index.d.ts.map +0 -1
- package/dist/commands/sync/SyncProgram.d.ts +0 -15
- package/dist/commands/sync/SyncProgram.d.ts.map +0 -1
- package/dist/commands/sync/index.d.ts +0 -3
- package/dist/commands/sync/index.d.ts.map +0 -1
- package/dist/commands/sync/when.d.ts +0 -21
- package/dist/commands/sync/when.d.ts.map +0 -1
- package/dist/index.d.ts +0 -4
- package/dist/index.d.ts.map +0 -1
- package/dist/index.esm.js +0 -8
- package/dist/index.esm.js.map +0 -7
- package/dist/index.js +0 -8
- package/dist/index.js.map +0 -7
- package/dist/utils/AsyncArray.d.ts +0 -21
- package/dist/utils/AsyncArray.d.ts.map +0 -1
- package/dist/utils/appendScript.d.ts +0 -7
- package/dist/utils/appendScript.d.ts.map +0 -1
- package/dist/utils/arrayToMap.d.ts +0 -3
- package/dist/utils/arrayToMap.d.ts.map +0 -1
- package/dist/utils/findParent.d.ts +0 -8
- package/dist/utils/findParent.d.ts.map +0 -1
- package/dist/utils/index.d.ts +0 -5
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/nodeCacheDir.d.ts +0 -2
- package/dist/utils/nodeCacheDir.d.ts.map +0 -1
- package/src/commands/esbuild/__tests__/.temp/package.json +0 -1
- package/src/commands/esbuild/__tests__/.temp/src/index.ts +0 -1
- package/src/commands/esbuild/util/__tests__/.temp/index.js +0 -1
- package/src/commands/esbuild/util/__tests__/esbuildPlugins.test.ts +0 -52
- package/src/commands/esbuild/util/esbuildPlugins.ts +0 -196
- package/src/commands/generate/__tests__/.temp/README.md +0 -1
- package/src/commands/generate/__tests__/.temp/package.json +0 -3
- package/src/commands/generate/__tests__/.temp/test-cli/CHANGELOG.md +0 -1
- package/src/commands/generate/__tests__/.temp/test-cli/README.md +0 -1
- package/src/commands/generate/__tests__/.temp/test-cli/bin.js +0 -3
- package/src/commands/generate/__tests__/.temp/test-cli/package.json +0 -33
- package/src/commands/generate/__tests__/.temp/test-cli/src/bin.ts +0 -13
- package/src/commands/generate/__tests__/.temp/test-cli/src/index.ts +0 -1
- package/src/commands/generate/__tests__/.temp/test-cli/tsconfig.json +0 -28
- package/src/commands/sync/__tests__/.temp/package.json +0 -16
- package/wallaby.conf.js +0 -3
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { EventExtPromise } from './util/PromiseUtil';
|
|
2
|
-
import { ConnectOptions } from 'ssh2-sftp-client';
|
|
3
|
-
export interface DeployEvents {
|
|
4
|
-
process(title: string): void;
|
|
5
|
-
}
|
|
6
|
-
/**
|
|
7
|
-
* 部署服务接口
|
|
8
|
-
*/
|
|
9
|
-
export interface IDeployService {
|
|
10
|
-
validate(): [isValidate: boolean, errorText: string];
|
|
11
|
-
/**
|
|
12
|
-
* 部署
|
|
13
|
-
*/
|
|
14
|
-
deploy(): EventExtPromise<void, DeployEvents>;
|
|
15
|
-
}
|
|
16
|
-
export declare enum DeployTypeEnum {
|
|
17
|
-
GhPages = "gh-pages",
|
|
18
|
-
Sftp = "sftp"
|
|
19
|
-
}
|
|
20
|
-
export interface BaseDeployOptions {
|
|
21
|
-
cwd: string;
|
|
22
|
-
debug: boolean;
|
|
23
|
-
type: DeployTypeEnum;
|
|
24
|
-
}
|
|
25
|
-
export interface SftpDeployOptions extends Omit<BaseDeployOptions, 'type'> {
|
|
26
|
-
dist: string;
|
|
27
|
-
dest: string;
|
|
28
|
-
sshConfig: ConnectOptions;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* sftp 集成到远端
|
|
32
|
-
*/
|
|
33
|
-
export declare class SftpDeployService implements IDeployService {
|
|
34
|
-
private readonly options;
|
|
35
|
-
constructor(options: SftpDeployOptions);
|
|
36
|
-
deploy(): EventExtPromise<void, DeployEvents>;
|
|
37
|
-
validate(): [isValidate: boolean, errorText: string];
|
|
38
|
-
}
|
|
39
|
-
export interface GhPagesDeployOptions extends Omit<BaseDeployOptions, 'type'> {
|
|
40
|
-
/**
|
|
41
|
-
* 推送的本地目录
|
|
42
|
-
*/
|
|
43
|
-
dist: string;
|
|
44
|
-
/**
|
|
45
|
-
* 推送的远端目录,默认为分支根目录
|
|
46
|
-
*/
|
|
47
|
-
dest?: string;
|
|
48
|
-
/**
|
|
49
|
-
* 推送的项目 git 地址,默认为当前项目
|
|
50
|
-
*/
|
|
51
|
-
repo?: string;
|
|
52
|
-
/**
|
|
53
|
-
* 推送的远端,默认为 origin
|
|
54
|
-
*/
|
|
55
|
-
remote?: string;
|
|
56
|
-
/**
|
|
57
|
-
* 远端分支名,默认为 gh-pages
|
|
58
|
-
*/
|
|
59
|
-
branch?: string;
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* 将本地静态资源推送到 gh-pages 远端
|
|
63
|
-
*/
|
|
64
|
-
export declare class GhPagesDeployService implements IDeployService {
|
|
65
|
-
private readonly options;
|
|
66
|
-
constructor(options: GhPagesDeployOptions);
|
|
67
|
-
deploy(): EventExtPromise<void, DeployEvents>;
|
|
68
|
-
validate(): [isValid: boolean, errorText: string];
|
|
69
|
-
}
|
|
70
|
-
//# sourceMappingURL=DeployService.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DeployService.d.ts","sourceRoot":"","sources":["../../../src/commands/deploy/DeployService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAe,MAAM,oBAAoB,CAAA;AACjE,OAAe,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AASzD,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,QAAQ,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,CAAA;IACpD;;OAEG;IACH,MAAM,IAAI,eAAe,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;CAC9C;AAED,oBAAY,cAAc;IACxB,OAAO,aAAa;IACpB,IAAI,SAAS;CACd;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,OAAO,CAAA;IACd,IAAI,EAAE,cAAc,CAAA;CACrB;AAED,MAAM,WAAW,iBAAkB,SAAQ,IAAI,CAAC,iBAAiB,EAAE,MAAM,CAAC;IACxE,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,cAAc,CAAA;CAC1B;AAED;;GAEG;AACH,qBAAa,iBAAkB,YAAW,cAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,iBAAiB;IAEvD,MAAM,IAAI,eAAe,CAAC,IAAI,EAAE,YAAY,CAAC;IAc7C,QAAQ,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC;CAsBrD;AAED,MAAM,WAAW,oBAAqB,SAAQ,IAAI,CAAC,iBAAiB,EAAE,MAAM,CAAC;IAC3E;;OAEG;IACH,IAAI,EAAE,MAAM,CAAA;IACZ;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAA;IACb;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAA;IACb;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAA;IACf;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED;;GAEG;AACH,qBAAa,oBAAqB,YAAW,cAAc;IAC7C,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,oBAAoB;IAE1D,MAAM,IAAI,eAAe,CAAC,IAAI,EAAE,YAAY,CAAC;IA4E7C,QAAQ,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC;CAkBlD"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../../../src/commands/deploy/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EAMlB,MAAM,iBAAiB,CAAA;AAgBxB,wBAAsB,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAwBpF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/deploy/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAInC,eAAO,MAAM,aAAa,SAG0E,CAAA"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { ConditionalKeys, PromiseValue } from 'type-fest';
|
|
2
|
-
declare type VoidFunc = ((...args: any[]) => void) | undefined;
|
|
3
|
-
export declare type EventExtPromise<T, E> = Promise<T> & {
|
|
4
|
-
on<K extends ConditionalKeys<E, VoidFunc>>(type: K, callback: E[K]): EventExtPromise<T, E>;
|
|
5
|
-
};
|
|
6
|
-
export declare class PromiseUtil {
|
|
7
|
-
/**
|
|
8
|
-
* 创建一个支持 on* 事件的 Promise 实例
|
|
9
|
-
* @param executor
|
|
10
|
-
*/
|
|
11
|
-
static wrapOnEvent<F extends (events: any) => Promise<any>, E extends Parameters<F>[0], K extends ConditionalKeys<E, VoidFunc>>(executor: F): EventExtPromise<PromiseValue<ReturnType<F>>, E>;
|
|
12
|
-
}
|
|
13
|
-
export {};
|
|
14
|
-
//# sourceMappingURL=PromiseUtil.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PromiseUtil.d.ts","sourceRoot":"","sources":["../../../../src/commands/deploy/util/PromiseUtil.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAEzD,aAAK,QAAQ,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC,GAAG,SAAS,CAAA;AAEtD,oBAAY,eAAe,CAAC,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,GAAG;IAC/C,EAAE,CAAC,CAAC,SAAS,eAAe,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;CAC3F,CAAA;AAED,qBAAa,WAAW;IACtB;;;OAGG;IACH,MAAM,CAAC,WAAW,CAChB,CAAC,SAAS,CAAC,MAAM,EAAE,GAAG,KAAK,OAAO,CAAC,GAAG,CAAC,EACvC,CAAC,SAAS,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC1B,CAAC,SAAS,eAAe,CAAC,CAAC,EAAE,QAAQ,CAAC,EACtC,QAAQ,EAAE,CAAC,GAAG,eAAe,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;CAgBhE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createArchive.d.ts","sourceRoot":"","sources":["../../../../src/commands/deploy/util/createArchive.ts"],"names":[],"mappings":"AAIA,oBAAY,cAAc,GAAG;IAE3B,SAAS,EAAE,MAAM,CAAA;IAEjB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED;;;GAGG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAc1E"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"execPromise.d.ts","sourceRoot":"","sources":["../../../../src/commands/deploy/util/execPromise.ts"],"names":[],"mappings":";AAAA,OAAO,EAAQ,WAAW,EAAE,MAAM,eAAe,CAAA;AAEjD,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,CAU5F"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { JSONSchemaType } from 'ajv';
|
|
2
|
-
/**
|
|
3
|
-
* 使用 ajv 校验数据
|
|
4
|
-
* @param schema json 模式配置
|
|
5
|
-
* @param data 校验的数据
|
|
6
|
-
*/
|
|
7
|
-
export declare function validate<T>(schema: JSONSchemaType<T>, data: T): [isValid: boolean, errorText: string];
|
|
8
|
-
//# sourceMappingURL=validate.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../../../src/commands/deploy/util/validate.ts"],"names":[],"mappings":"AAAA,OAAY,EAAE,cAAc,EAAE,MAAM,KAAK,CAAA;AAIzC;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,CAQrG"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 等待指定的时间/等待指定表达式成立
|
|
3
|
-
* 如果未指定等待条件则立刻执行
|
|
4
|
-
* 注: 此实现在 nodejs 10- 会存在宏任务与微任务的问题,切记 async-await 本质上还是 Promise 的语法糖,实际上并非真正的同步函数!!!即便在浏览器,也不要依赖于这种特性。
|
|
5
|
-
* @param param 等待时间/等待条件
|
|
6
|
-
* @returns Promise 对象
|
|
7
|
-
*/
|
|
8
|
-
export declare function wait(param?: number | (() => boolean | Promise<boolean>)): Promise<void>;
|
|
9
|
-
//# sourceMappingURL=wait.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"wait.d.ts","sourceRoot":"","sources":["../../../../src/commands/deploy/util/wait.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AACH,wBAAgB,IAAI,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAevF"}
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { BuildOptions, Platform, Plugin } from 'esbuild';
|
|
2
|
-
import { IOptions } from 'glob';
|
|
3
|
-
import Spinnies from 'spinnies';
|
|
4
|
-
interface ESBuildProgramOptions {
|
|
5
|
-
base: string;
|
|
6
|
-
isWatch: boolean;
|
|
7
|
-
}
|
|
8
|
-
interface Task {
|
|
9
|
-
title: string;
|
|
10
|
-
task(): Promise<any>;
|
|
11
|
-
}
|
|
12
|
-
export declare type TaskTypeEnum = 'esm' | 'cjs' | 'iife' | 'cli' | 'dts' | 'userjs';
|
|
13
|
-
export declare class ESBuildProgram {
|
|
14
|
-
private readonly options;
|
|
15
|
-
constructor(options: ESBuildProgramOptions);
|
|
16
|
-
set isWatch(isWatch: boolean);
|
|
17
|
-
static readonly globalExternal: string[];
|
|
18
|
-
/**
|
|
19
|
-
* 获取所有依赖
|
|
20
|
-
*/
|
|
21
|
-
static getDeps(base: string): Promise<string[]>;
|
|
22
|
-
/**
|
|
23
|
-
* 获取所在模块的类型
|
|
24
|
-
*/
|
|
25
|
-
static getPlatform(base: string): Promise<Platform>;
|
|
26
|
-
static getWatchOptions(base: string): {
|
|
27
|
-
pattern: string;
|
|
28
|
-
options: IOptions;
|
|
29
|
-
};
|
|
30
|
-
/**
|
|
31
|
-
* 生成类型定义
|
|
32
|
-
*/
|
|
33
|
-
genDTS(): Promise<void>;
|
|
34
|
-
/**
|
|
35
|
-
* 获取构建 cjs 的选项
|
|
36
|
-
*/
|
|
37
|
-
getBuildUserJSOption(): BuildOptions;
|
|
38
|
-
/**
|
|
39
|
-
* 获取构建 cjs 的选项
|
|
40
|
-
* @param deps
|
|
41
|
-
* @param platform
|
|
42
|
-
* @param plugins
|
|
43
|
-
*/
|
|
44
|
-
getBuildCjsOption({ deps, platform }: {
|
|
45
|
-
deps: string[];
|
|
46
|
-
platform: Platform;
|
|
47
|
-
}): BuildOptions;
|
|
48
|
-
/**
|
|
49
|
-
* 获取构建 esm 的选项
|
|
50
|
-
* @param deps
|
|
51
|
-
* @param platform
|
|
52
|
-
* @param plugins
|
|
53
|
-
*/
|
|
54
|
-
getBuildESMOption({ deps, platform }: {
|
|
55
|
-
deps: string[];
|
|
56
|
-
platform: Platform;
|
|
57
|
-
}): BuildOptions;
|
|
58
|
-
/**
|
|
59
|
-
* 获取构建 iife 的选项
|
|
60
|
-
* @param deps
|
|
61
|
-
* @param platform
|
|
62
|
-
*/
|
|
63
|
-
getBuildIifeOption({ platform, globalName }: {
|
|
64
|
-
platform: Platform;
|
|
65
|
-
globalName: string;
|
|
66
|
-
}): BuildOptions;
|
|
67
|
-
/**
|
|
68
|
-
* 获取构建 cli 的选项
|
|
69
|
-
* @param deps
|
|
70
|
-
* @param platform
|
|
71
|
-
*/
|
|
72
|
-
getBuildCliOption({ platform }: {
|
|
73
|
-
deps: string[];
|
|
74
|
-
platform: Platform;
|
|
75
|
-
}): BuildOptions;
|
|
76
|
-
static getPlugins(platform: string): Plugin[];
|
|
77
|
-
build(options: BuildOptions): Promise<void>;
|
|
78
|
-
getTasks(): Promise<Record<TaskTypeEnum, Task>>;
|
|
79
|
-
static execTask(spinnies: Spinnies, task: Task): Promise<void>;
|
|
80
|
-
execTasks(tasks: Task[]): Promise<void>;
|
|
81
|
-
}
|
|
82
|
-
export {};
|
|
83
|
-
//# sourceMappingURL=ESBuildProgram.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ESBuildProgram.d.ts","sourceRoot":"","sources":["../../../src/commands/esbuild/ESBuildProgram.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,YAAY,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAM/D,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AAG/B,OAAO,QAAQ,MAAM,UAAU,CAAA;AAK/B,UAAU,qBAAqB;IAC7B,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,UAAU,IAAI;IACZ,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,IAAI,OAAO,CAAC,GAAG,CAAC,CAAA;CACrB;AAED,oBAAY,YAAY,GAAG,KAAK,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,KAAK,GAAG,QAAQ,CAAA;AAE5E,qBAAa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,qBAAqB;IAE3D,IAAI,OAAO,CAAC,OAAO,EAAE,OAAO,EAE3B;IAED,MAAM,CAAC,QAAQ,CAAC,cAAc,WAA4C;IAE1E;;OAEG;WACU,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IASrD;;OAEG;WACU,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAiBzD,MAAM,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG;QACpC,OAAO,EAAE,MAAM,CAAA;QACf,OAAO,EAAE,QAAQ,CAAA;KAClB;IAQD;;OAEG;IACG,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAkB7B;;OAEG;IACH,oBAAoB,IAAI,YAAY;IAcpC;;;;;OAKG;IACH,iBAAiB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE;QAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,EAAE,QAAQ,CAAA;KAAE,GAAG,YAAY;IAe3F;;;;;OAKG;IACH,iBAAiB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE;QAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,EAAE,QAAQ,CAAA;KAAE,GAAG,YAAY;IAe3F;;;;OAIG;IACH,kBAAkB,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE;QAAE,QAAQ,EAAE,QAAQ,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,GAAG,YAAY;IAgBtG;;;;OAIG;IACH,iBAAiB,CAAC,EAAE,QAAQ,EAAE,EAAE;QAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,EAAE,QAAQ,CAAA;KAAE,GAAG,YAAY;IAoBrF,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,EAAE;IAQvC,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAO3C,QAAQ,IAAI,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;WA0DxC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAY9D,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;CAmB9C"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/esbuild/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AASnC,eAAO,MAAM,cAAc,SAiDxB,CAAA"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 函数去抖
|
|
3
|
-
* 去抖 (debounce) 去抖就是对于一定时间段的连续的函数调用,只让其执行一次
|
|
4
|
-
* 注: 包装后的函数如果两次操作间隔小于 delay 则不会被执行, 如果一直在操作就会一直不执行, 直到操作停止的时间大于 delay 最小间隔时间才会执行一次, 不管任何时间调用都需要停止操作等待最小延迟时间
|
|
5
|
-
* 应用场景主要在那些连续的操作, 例如页面滚动监听, 包装后的函数只会执行最后一次
|
|
6
|
-
* 注: 该函数第一次调用一定不会执行,第一次一定拿不到缓存值,后面的连续调用都会拿到上一次的缓存值。如果需要在第一次调用获取到的缓存值,则需要传入第三个参数 {@param init},默认为 {@code undefined} 的可选参数
|
|
7
|
-
* 注: 返回函数结果的高阶函数需要使用 {@see Proxy} 实现,以避免原函数原型链上的信息丢失
|
|
8
|
-
*
|
|
9
|
-
* @param fn 真正需要执行的操作
|
|
10
|
-
* @param delay 最小延迟时间,单位为 ms
|
|
11
|
-
* @param init 初始的缓存值,不填默认为 {@see undefined}
|
|
12
|
-
* @return 包装后有去抖功能的函数。该函数是异步的,与需要包装的函数 {@param fn} 是否异步没有太大关联
|
|
13
|
-
*/
|
|
14
|
-
export declare function debounce<T extends (...args: any[]) => any, R extends (...args: Parameters<T>) => Promise<ReturnType<T>>>(fn: T, delay: number, init?: any): R;
|
|
15
|
-
//# sourceMappingURL=debounce.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"debounce.d.ts","sourceRoot":"","sources":["../../../../src/commands/esbuild/util/debounce.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AACH,wBAAgB,QAAQ,CACtB,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACjC,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAC5D,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,GAAE,GAAU,GAAG,CAAC,CAY3C"}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { Plugin } from 'esbuild';
|
|
2
|
-
/**
|
|
3
|
-
* 处理 nodejs 原生模块
|
|
4
|
-
* @link https://github.com/evanw/esbuild/issues/1051#issuecomment-806325487
|
|
5
|
-
*/
|
|
6
|
-
export declare function nativeNodeModules(): Plugin;
|
|
7
|
-
/**
|
|
8
|
-
* 排除和替换 node 内置模块
|
|
9
|
-
*/
|
|
10
|
-
export declare function nodeExternals(): Plugin;
|
|
11
|
-
/**
|
|
12
|
-
* 自动排除所有依赖项
|
|
13
|
-
* golang 不支持 js 的一些语法,参考 https://github.com/evanw/esbuild/issues/1634
|
|
14
|
-
*/
|
|
15
|
-
export declare function autoExternal(): Plugin;
|
|
16
|
-
/**
|
|
17
|
-
* 通过 ?raw 将资源作为字符串打包进来
|
|
18
|
-
* @returns
|
|
19
|
-
*/
|
|
20
|
-
export declare function raw(): Plugin;
|
|
21
|
-
/**
|
|
22
|
-
* Pass environment variables to esbuild.
|
|
23
|
-
* @return An esbuild plugin.
|
|
24
|
-
*/
|
|
25
|
-
export declare function envPlugin(): Plugin;
|
|
26
|
-
/**
|
|
27
|
-
* 生成 metafile 的插件
|
|
28
|
-
* @param metafilePath
|
|
29
|
-
*/
|
|
30
|
-
export declare function metafile(metafilePath: string): Plugin;
|
|
31
|
-
export declare function userJS(): Plugin;
|
|
32
|
-
//# sourceMappingURL=esbuildPlugins.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"esbuildPlugins.d.ts","sourceRoot":"","sources":["../../../../src/commands/esbuild/util/esbuildPlugins.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAIhC;;;GAGG;AACH,wBAAgB,iBAAiB,IAAI,MAAM,CAoC1C;AAED;;GAEG;AACH,wBAAgB,aAAa,IAAI,MAAM,CAUtC;AAED;;;GAGG;AACH,wBAAgB,YAAY,IAAI,MAAM,CAerC;AAED;;;GAGG;AACH,wBAAgB,GAAG,IAAI,MAAM,CAkB5B;AAyBD;;;GAGG;AACH,wBAAgB,SAAS,IAAI,MAAM,CAYlC;AAED;;;GAGG;AACH,wBAAgB,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CASrD;AAmBD,wBAAgB,MAAM,IAAI,MAAM,CAgB/B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getPkgGlobalName.d.ts","sourceRoot":"","sources":["../../../../src/commands/esbuild/util/getPkgGlobalName.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAMrD"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
export declare enum TemplateTypeEnum {
|
|
2
|
-
Cli = "cli",
|
|
3
|
-
Lib = "lib"
|
|
4
|
-
}
|
|
5
|
-
export interface GenerateConfig {
|
|
6
|
-
template: TemplateTypeEnum;
|
|
7
|
-
dest: string;
|
|
8
|
-
initSync?: boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare class GenerateProgram {
|
|
11
|
-
/**
|
|
12
|
-
* 生成项目
|
|
13
|
-
*/
|
|
14
|
-
generate(config: GenerateConfig): Promise<void>;
|
|
15
|
-
static updatePackageJSON(destFile: string): Promise<void>;
|
|
16
|
-
static updateReadme(destFile: string): Promise<void>;
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=GenerateProgram.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"GenerateProgram.d.ts","sourceRoot":"","sources":["../../../src/commands/generate/GenerateProgram.ts"],"names":[],"mappings":"AAMA,oBAAY,gBAAgB;IAC1B,GAAG,QAAQ;IACX,GAAG,QAAQ;CACZ;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,gBAAgB,CAAA;IAC1B,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,qBAAa,eAAe;IAC1B;;OAEG;IACG,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;WAyDxC,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;WAclD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAM3D"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/generate/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAU,MAAM,WAAW,CAAA;AAW3C,eAAO,MAAM,eAAe,SAWxB,CAAA"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
export declare function mergeJson(base: string, json: object): Promise<void>;
|
|
2
|
-
export declare type SyncConfigType = 'prettier' | 'commitlint' | 'simplehooks' | 'workspaces' | 'gitignore' | 'eslint-ts' | 'eslint-vue-ts' | 'eslint-react-ts' | 'jest';
|
|
3
|
-
export interface SyncConfig {
|
|
4
|
-
type: SyncConfigType;
|
|
5
|
-
handler(): Promise<void>;
|
|
6
|
-
when?(): Promise<boolean>;
|
|
7
|
-
}
|
|
8
|
-
export declare class SyncProgram {
|
|
9
|
-
private readonly base;
|
|
10
|
-
constructor(base: string);
|
|
11
|
-
private syncConfigs;
|
|
12
|
-
sync(): Promise<void>;
|
|
13
|
-
init(): Promise<void>;
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=SyncProgram.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SyncProgram.d.ts","sourceRoot":"","sources":["../../../src/commands/sync/SyncProgram.ts"],"names":[],"mappings":"AAaA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAKzE;AAED,oBAAY,cAAc,GACtB,UAAU,GACV,YAAY,GACZ,aAAa,GACb,YAAY,GACZ,WAAW,GACX,WAAW,GACX,eAAe,GACf,iBAAiB,GACjB,MAAM,CAAA;AAEV,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,cAAc,CAAA;IACpB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;IACxB,IAAI,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,CAAA;CAC1B;AAED,qBAAa,WAAW;IACV,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,MAAM;IACzC,OAAO,CAAC,WAAW,CA8IlB;IAEK,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAarB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB5B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/sync/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAInC,eAAO,MAAM,WAAW,SAUrB,CAAA"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 判断是否包含 package.json
|
|
3
|
-
* @param cwd
|
|
4
|
-
*/
|
|
5
|
-
export declare function isNpmPackage(cwd?: string): Promise<boolean>;
|
|
6
|
-
/**
|
|
7
|
-
* 判断是 yarn2 monorepo 项目
|
|
8
|
-
* @param cwd
|
|
9
|
-
*/
|
|
10
|
-
export declare function isYarnRoot(cwd?: string): Promise<boolean>;
|
|
11
|
-
/**
|
|
12
|
-
* 判断是 yarn2 monorepo 的子模块
|
|
13
|
-
*/
|
|
14
|
-
export declare function isYarnSubModule(cwd?: string): Promise<boolean>;
|
|
15
|
-
/**
|
|
16
|
-
* 是否包含指定依赖
|
|
17
|
-
* @param deps
|
|
18
|
-
* @param cwd
|
|
19
|
-
*/
|
|
20
|
-
export declare function isIncludeDep(deps: string[], cwd?: string): Promise<boolean>;
|
|
21
|
-
//# sourceMappingURL=when.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"when.d.ts","sourceRoot":"","sources":["../../../src/commands/sync/when.ts"],"names":[],"mappings":"AAKA;;;GAGG;AACH,wBAAsB,YAAY,CAAC,GAAG,GAAE,MAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CAEhF;AAED;;;GAGG;AACH,wBAAsB,UAAU,CAAC,GAAG,GAAE,MAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CAM9E;AAED;;GAEG;AACH,wBAAsB,eAAe,CAAC,GAAG,GAAE,MAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CASnF;AAED;;;;GAIG;AACH,wBAAsB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,GAAG,GAAE,MAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CAOhG"}
|
package/dist/index.d.ts
DELETED
package/dist/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mCAAmC,CAAA;AACjD,cAAc,qCAAqC,CAAA;AACnD,cAAc,6BAA6B,CAAA"}
|
package/dist/index.esm.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
var G=Object.defineProperty;var Y=(i,e,t)=>e in i?G(i,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):i[e]=t;var M=(i=>typeof require!="undefined"?require:typeof Proxy!="undefined"?new Proxy(i,{get:(e,t)=>(typeof require!="undefined"?require:e)[t]}):i)(function(i){if(typeof require!="undefined")return require.apply(this,arguments);throw new Error('Dynamic require of "'+i+'" is not supported')});var g=(i,e,t)=>(Y(i,typeof e!="symbol"?e+"":e,t),t);import{build as $}from"esbuild";import{pathExists as B,readFile as X,readJson as j,remove as Z}from"fs-extra";import{resolve as r}from"path";import{Project as _}from"ts-morph";import{promise as A}from"glob-promise";import{readFile as ke,readJson as z,writeJson as Te}from"fs-extra";import{isAbsolute as Oe,join as Je,resolve as Q}from"path";function D(){return{name:"native-node-modules",setup(i){i.onResolve({filter:/\.node$/,namespace:"file"},t=>({path:M.resolve(t.path,{paths:[t.resolveDir]}),namespace:"node-file"})),i.onLoad({filter:/.*/,namespace:"node-file"},t=>({contents:`
|
|
2
|
-
import path from ${JSON.stringify(t.path)}
|
|
3
|
-
try { module.exports = require(path) }
|
|
4
|
-
catch {}
|
|
5
|
-
`})),i.onResolve({filter:/\.node$/,namespace:"node-file"},t=>({path:t.path,namespace:"file"}));let e=i.initialOptions;e.loader=e.loader||{},e.loader[".node"]="file"}}}function C(){return{name:"esbuild-plugin-node-externals",setup(i){i.onResolve({filter:/(^node:)/},e=>({path:e.path.slice(5),external:!0}))}}}function H(i){return["// ==UserScript==",...Object.entries(i).map(([e,t])=>Array.isArray(t)?t.map(s=>`// @${e} ${s}`):`// @${e} ${t}`).flat(),"// ==/UserScript=="].join(`
|
|
6
|
-
`)+`
|
|
7
|
-
`}function F(){return{name:"esbuild-plugin-userjs",async setup(i){let e=await z(Q(i.initialOptions.absWorkingDir,"package.json"));if(!e.userjs)throw new Error("userjs is not supported");i.initialOptions.banner||(i.initialOptions.banner={}),i.initialOptions.banner.js=H(e.userjs)}}}import{watch as ee}from"chokidar";import te from"spinnies";function W(i,e,t=null){let s,a=t;return async function(...n){return new Promise(o=>{s&&clearTimeout(s),s=setTimeout(()=>o(a=i(...n)),e),setTimeout(()=>o(a),e)})}}import{parse as se}from"json5";function E(i){return(i.startsWith("@")?i.slice(i.indexOf("/")+1):i).split("-").map(t=>t.slice(0,1).toUpperCase()+t.slice(1).toLowerCase()).join("")}var l=class{constructor(e){this.options=e}set isWatch(e){this.options.isWatch=e}static async getDeps(e){let t=await j(r(e,"package.json"));return Object.keys({...t.dependencies,...t.devDependencies,...t.peerDependencies})}static async getPlatform(e){let t=r(e,"tsconfig.json");if(await B(t)&&se(await X(t,"utf-8"))?.compilerOptions?.lib?.some(n=>n.toLowerCase()==="dom"))return"browser";let s=r(e,"package.json");if(await B(s)){let a=await j(s);if(Object.keys(a.devDependencies??{}).includes("@types/node"))return"node"}return"neutral"}static getWatchOptions(e){return{pattern:"src/**/*.ts",options:{cwd:e,ignore:"**/__tests__/**/*"}}}async genDTS(){let e=this.options.base,{pattern:t,options:s}=l.getWatchOptions(this.options.base),a=new _({tsConfigFilePath:r(e,"tsconfig.json"),skipAddingFilesFromTsConfig:!0,compilerOptions:{emitDeclarationOnly:!0,noEmit:!1,incremental:this.options.isWatch}}),n=(await A(t,s)).map(o=>r(e,o));a.addSourceFilesAtPaths(n),await a.emit({emitOnlyDtsFiles:!0})}getBuildUserJSOption(){return{entryPoints:[r(this.options.base,"./src/index.ts")],outfile:r(this.options.base,"./dist/index.user.js"),format:"iife",bundle:!0,external:[...l.globalExternal],platform:"browser",plugins:[F()],incremental:this.options.isWatch,absWorkingDir:this.options.base}}getBuildCjsOption({deps:e,platform:t}){return{entryPoints:[r(this.options.base,"./src/index.ts")],outfile:r(this.options.base,"./dist/index.js"),format:"cjs",sourcemap:!0,bundle:!0,external:[...l.globalExternal,...e],platform:t,minify:!this.options.isWatch,incremental:this.options.isWatch,metafile:this.options.isWatch}}getBuildESMOption({deps:e,platform:t}){return{entryPoints:[r(this.options.base,"./src/index.ts")],outfile:r(this.options.base,"./dist/index.esm.js"),format:"esm",sourcemap:!0,bundle:!0,external:[...l.globalExternal,...e],platform:t,minify:!this.options.isWatch,incremental:this.options.isWatch,metafile:this.options.isWatch}}getBuildIifeOption({platform:e,globalName:t}){return{entryPoints:[r(this.options.base,"./src/index.ts")],outfile:r(this.options.base,"./dist/index.iife.js"),format:"iife",sourcemap:!0,bundle:!0,external:[...l.globalExternal],platform:e,minify:!this.options.isWatch,incremental:this.options.isWatch,metafile:this.options.isWatch,globalName:t}}getBuildCliOption({platform:e}){let t=l.getPlugins(e);return{entryPoints:[r(this.options.base,"./src/bin.ts")],outfile:r(this.options.base,"./dist/bin.js"),format:"cjs",sourcemap:!0,platform:e,bundle:!0,banner:{js:"#!/usr/bin/env node"},external:[...l.globalExternal],plugins:t,minify:!this.options.isWatch,incremental:this.options.isWatch,metafile:this.options.isWatch}}static getPlugins(e){let t=[];return e==="node"&&t.push(C(),D()),t}async build(e){await $(e)}async getTasks(){let e=await l.getDeps(this.options.base),t=await l.getPlatform(this.options.base);return{esm:{title:"\u6784\u5EFA esm",task:()=>this.build(this.getBuildESMOption({deps:e,platform:t}))},cjs:{title:"\u6784\u5EFA cjs",task:()=>this.build(this.getBuildCjsOption({deps:e,platform:t}))},iife:{title:"\u6784\u5EFA iife",task:async()=>await this.build(this.getBuildIifeOption({platform:t,globalName:E((await j(r(this.options.base,"./package.json"))).name)}))},cli:{title:"\u6784\u5EFA cli",task:()=>$(this.getBuildCliOption({deps:e,platform:t}))},dts:{title:"\u751F\u6210\u7C7B\u578B\u5B9A\u4E49",task:()=>this.genDTS()},userjs:{title:"\u6253\u5305 userjs",task:()=>this.build(this.getBuildUserJSOption())}}}static async execTask(e,t){let s=Date.now();e.add(t.title,{text:t.title});try{await t.task(),e.succeed(t.title,{text:`${t.title}: ${Date.now()-s}ms`})}catch{e.fail(t.title,{text:t.title})}}async execTasks(e){let t=async()=>{let n=Date.now(),o=new te;await Promise.all(e.map(async T=>l.execTask(o,T))),console.log(`\u6784\u5EFA\u5B8C\u6210: ${Date.now()-n}ms`)};if(!this.options.isWatch){await Z(r(this.options.base,"dist")),await t();return}let{pattern:s,options:a}=l.getWatchOptions(this.options.base);await new Promise((n,o)=>{ee(s,a).on("error",o).on("all",W(t,10))})}},N=l;g(N,"globalExternal",["esbuild","pnpapi","ts-morph","ssh2"]);import u from"path";import{copy as fe,pathExists as q,readdir as he,readFile as ge,readJSON as be,remove as ye,writeFile as we,writeJSON as Pe}from"fs-extra";import{prompt as S}from"enquirer";import{readFile as oe,readJson as w,writeFile as le,writeJson as U}from"fs-extra";import f from"path";import{merge as V}from"lodash";import pe from"@liuli-util/prettier-standard-config/package.json";import ce from"@liuli-util/eslint-config-ts/package.json";import me from"@liuli-util/eslint-config-react-ts/package.json";import ue from"@liuli-util/commitlint-standard-config/package.json";import{prompt as de}from"enquirer";import{pathExists as ae,readJson as K}from"fs-extra";import{dirname as ne,resolve as O}from"path";function I(i,e,t=s=>s){return i.reduce((s,a,n,o)=>s.set(e(a,n,o),t(a,n,o)),new Map)}function L(i,e){return i?i.includes(e)?i:i+" && "+e:e}import ie from"path";function R(i,e){let t=e(i);function s(a){if(a)return i;let n=ie.dirname(i);return n===i?null:R(n,e)}return t instanceof Promise?t.then(s):s(t)}var p;(function(n){n.Filter="filter",n.Map="map",n.ForEach="forEach",n.Reduce="reduce",n.FlatMap="flatMap"})(p||(p={}));var b=class{constructor(e,t){this.type=e;this.args=t;this.type=e,this.args=t}};g(b,"Type",p);var c=class{constructor(e){this.arr=e}static reduce(e,t,s){return e.reduce((a,n,o)=>a.then(T=>t(T,n,o)),Promise.resolve(s))}static map(e,t){return Promise.all(e.map((s,a)=>t(s,a)))}static async filter(e,t){let s=[];return await c.map(e,async(a,n)=>{await t(a,n)&&s.push(a)}),s}static async flatMap(e,t){return(await Promise.all(e.map((s,a)=>t(s,a)))).flatMap(s=>s)}static async forEach(e,t){await c.map(e,t)}tasks=[];map(e){return this.tasks.push(new b(p.Map,[e])),this}flatMap(e){return this.tasks.push(new b(p.FlatMap,[e])),this}filter(e){return this.tasks.push(new b(p.Filter,[e])),this}async forEach(e){this.tasks.push(new b(p.Map,[e])),await this}then(e,t){let s=this.value();return s.then(a=>(e&&e(s),a)).catch(a=>{throw t&&t(a),a}),s}async value(){let e=this.arr;for(let t of this.tasks)switch(t.type){case p.Filter:e=await c.filter(e,t.args[0]);break;case p.Map:e=await c.map(e,t.args[0]);break;case p.FlatMap:e=await c.flatMap(e,t.args[0]);break;case p.ForEach:await c.forEach(e,t.args[0]);return;case p.Reduce:return await c.reduce(e,t.args[0],t.args[1])}return e}};async function m(i=process.cwd()){return await ae(O(i,"./package.json"))}async function d(i=process.cwd()){return await m(i)?!!(await K(O(i,"./package.json"))).workspaces:!1}async function P(i=process.cwd()){return!await m(i)||await d(i)?!1:await R(ne(i),d)!==null}async function x(i,e=process.cwd()){if(!await m(e))return!1;let t=await K(O(e,"./package.json")),s=new Set(Object.keys({...t.dependencies,...t.devDependencies}));return i.every(a=>s.has(a))}import re from"path";var y=class{};g(y,"RootPath",re.resolve(__dirname,".."));async function h(i,e){let t=f.resolve(i,"./package.json");await U(t,V(await w(t),e),{spaces:2})}var J=class{constructor(e){this.base=e}syncConfigs=[{type:"workspaces",handler:async()=>{let e=f.resolve(this.base,"./package.json"),t=f.resolve(this.base,"lerna.json"),s=await w(e),a=await w(t);a.packages=s.workspaces,await U(t,a,{spaces:2})},when:d},{type:"prettier",handler:async()=>{await h(this.base,{prettier:"@liuli-util/prettier-standard-config",devDependencies:{prettier:"^2.3.2","@liuli-util/prettier-standard-config":`^${pe.version}`}})},async when(){return await m()&&(await d()||!await P())}},{type:"commitlint",handler:async()=>{await h(this.base,{"simple-git-hooks":{"commit-msg":"yarn commitlint --edit $1"},commitlint:{extends:["@liuli-util/commitlint-standard-config"]},devDependencies:{"@commitlint/cli":"^12.1.4","@liuli-util/commitlint-standard-config":`^${ue.version}`}})},async when(){return await m()&&(await d()||!await P())}},{type:"gitignore",handler:async()=>{let e=f.resolve(this.base,".gitignore");await le(e,await oe(f.resolve(y.RootPath,"_gitignore"),"utf-8"))}},{type:"eslint-ts",handler:async()=>{await h(this.base,{eslintConfig:{extends:["@liuli-util/eslint-config-ts"]},devDependencies:{"@liuli-util/eslint-config-ts":`^${ce.version}`}})},async when(){return await m()&&!await x(["vue"])&&!await x(["react"])}},{type:"eslint-react-ts",handler:async()=>{await h(this.base,{eslintConfig:{extends:["@liuli-util/eslint-config-react-ts"]},devDependencies:{"@liuli-util/eslint-config-react-ts":`^${me.version}`}})},async when(){return await m()&&await x(["react"])}},{type:"jest",handler:async()=>{await h(this.base,{jest:{preset:"ts-jest",testMatch:["<rootDir>/src/**/__tests__/*.test.ts"]},devDependencies:{jest:"^27.4.3","ts-jest":"^27.0.7"}})}},{type:"simplehooks",handler:async()=>{let e=await w(f.resolve(this.base,"./package.json")),t={};e.prettier&&(t["src/**/*.{ts,tsx,js,jsx,css,vue}"]=["prettier --write","git add"]),e.eslintConfig&&(t["src/**/*.{ts,tsx,js,jsx}"]=["eslint --fix --quiet","git add"]);let s={scripts:{postinstall:L(e?.scripts?.postinstall,"npx simple-git-hooks")},"simple-git-hooks":{"pre-commit":"yarn lint-staged"},"lint-staged":t,devDependencies:{"simple-git-hooks":"^2.5.1","lint-staged":"^11.1.1"}};e.commitlint&&(s=V(s,{"simple-git-hooks":{"commit-msg":"yarn commitlint --edit $1"}})),await h(this.base,s)},async when(){return await m()&&(await d()||!await P())}}];async sync(){let{sync:e}=await w(f.resolve(this.base,"package.json"));if(!e)return;let t=this.syncConfigs.filter(s=>e.includes(s.type));for(let s of t)await s.handler()}async init(){let e=I(await c.filter(this.syncConfigs,async s=>s.when?await s.when():!0),s=>s.type),t=await de({type:"multiselect",message:"\u8BF7\u9009\u62E9\u9700\u8981\u540C\u6B65\u7684\u914D\u7F6E\u9879",name:"sync",choices:[...e.keys()]});await h(this.base,{sync:t.sync})}};var v;(function(t){t.Cli="cli",t.Lib="lib"})(v||(v={}));var k=class{async generate(e){if(!e.dest){let{dest:a}=await S({name:"dest",type:"input",message:"\u8BF7\u8F93\u5165\u9879\u76EE\u540D",validate(n){return n.trim()!==""}});e.dest=u.resolve(a)}if(!e.template){let{template:a}=await S({name:"template",type:"select",message:"\u8BF7\u9009\u62E9\u6A21\u677F",choices:[v.Lib,v.Cli]});e.template=a}let t=u.resolve(y.RootPath,`templates/${e.template}`),s=u.resolve(e.dest);if(await q(s)&&(await he(s)).some(a=>q(a))){let{override:a}=await S({name:"override",type:"confirm",initial:!0,message:"\u76EE\u6807\u4F4D\u7F6E\u4E0D\u662F\u4E00\u4E2A\u7A7A\u76EE\u5F55\uFF0C\u786E\u8BA4\u8981\u8986\u76D6\u4E48\uFF1F"});if(!a)return}if(await ye(s),await fe(t,s,{filter:a=>u.basename(a)!=="node_modules"}),await k.updatePackageJSON(s),await k.updateReadme(s),e.initSync){let a=new J(u.resolve(e.dest));await a.init(),await a.sync()}}static async updatePackageJSON(e){let t=u.resolve(e,"package.json");await Pe(t,{...await be(t),name:u.basename(e)},{spaces:2})}static async updateReadme(e){let t=u.resolve(e,"README.md"),s=await ge(t,"utf-8");s=s.replace("template",u.basename(e)),await we(t,s)}};export{N as ESBuildProgram,k as GenerateProgram,J as SyncProgram,v as TemplateTypeEnum,h as mergeJson};
|
|
8
|
-
//# sourceMappingURL=index.esm.js.map
|
package/dist/index.esm.js.map
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/commands/esbuild/ESBuildProgram.ts", "../src/commands/esbuild/util/esbuildPlugins.ts", "../src/commands/esbuild/util/debounce.ts", "../src/commands/esbuild/util/getPkgGlobalName.ts", "../src/commands/generate/GenerateProgram.ts", "../src/commands/sync/SyncProgram.ts", "../src/commands/sync/when.ts", "../src/utils/arrayToMap.ts", "../src/utils/appendScript.ts", "../src/utils/findParent.ts", "../src/utils/AsyncArray.ts", "../src/PathUtil.ts"],
|
|
4
|
-
"sourcesContent": ["import { build, BuildOptions, Platform, Plugin } from 'esbuild'\r\nimport { pathExists, readFile, readJson, remove } from 'fs-extra'\r\nimport * as path from 'path'\r\nimport { PackageJson } from 'type-fest'\r\nimport { Project } from 'ts-morph'\r\nimport { promise } from 'glob-promise'\r\nimport { IOptions } from 'glob'\r\nimport { nativeNodeModules, nodeExternals, userJS } from './util/esbuildPlugins'\r\nimport { watch } from 'chokidar'\r\nimport Spinnies from 'spinnies'\r\nimport { debounce } from './util/debounce'\r\nimport { parse } from 'json5'\r\nimport { getPkgGlobalName } from './util/getPkgGlobalName'\r\n\r\ninterface ESBuildProgramOptions {\r\n base: string\r\n isWatch: boolean\r\n}\r\n\r\ninterface Task {\r\n title: string\r\n task(): Promise<any>\r\n}\r\n\r\nexport type TaskTypeEnum = 'esm' | 'cjs' | 'iife' | 'cli' | 'dts' | 'userjs'\r\n\r\nexport class ESBuildProgram {\r\n constructor(private readonly options: ESBuildProgramOptions) {}\r\n\r\n set isWatch(isWatch: boolean) {\r\n this.options.isWatch = isWatch\r\n }\r\n\r\n static readonly globalExternal = ['esbuild', 'pnpapi', 'ts-morph', 'ssh2']\r\n\r\n /**\r\n * \u83B7\u53D6\u6240\u6709\u4F9D\u8D56\r\n */\r\n static async getDeps(base: string): Promise<string[]> {\r\n const json = (await readJson(path.resolve(base, 'package.json'))) as PackageJson\r\n return Object.keys({\r\n ...json.dependencies,\r\n ...json.devDependencies,\r\n ...json.peerDependencies,\r\n })\r\n }\r\n\r\n /**\r\n * \u83B7\u53D6\u6240\u5728\u6A21\u5757\u7684\u7C7B\u578B\r\n */\r\n static async getPlatform(base: string): Promise<Platform> {\r\n const tsconfigPath = path.resolve(base, 'tsconfig.json')\r\n if (await pathExists(tsconfigPath)) {\r\n const tsconfigJson = parse(await readFile(tsconfigPath, 'utf-8'))\r\n if ((tsconfigJson?.compilerOptions?.lib as string[])?.some((lib) => lib.toLowerCase() === 'dom')) {\r\n return 'browser'\r\n }\r\n }\r\n const pkgPath = path.resolve(base, 'package.json')\r\n if (await pathExists(pkgPath)) {\r\n const pkgJson = (await readJson(pkgPath)) as PackageJson\r\n if (Object.keys(pkgJson.devDependencies ?? {}).includes('@types/node')) {\r\n return 'node'\r\n }\r\n }\r\n return 'neutral'\r\n }\r\n static getWatchOptions(base: string): {\r\n pattern: string\r\n options: IOptions\r\n } {\r\n const pattern = 'src/**/*.ts'\r\n const options: Pick<IOptions, 'cwd' | 'ignore'> = {\r\n cwd: base,\r\n ignore: '**/__tests__/**/*',\r\n }\r\n return { pattern, options }\r\n }\r\n /**\r\n * \u751F\u6210\u7C7B\u578B\u5B9A\u4E49\r\n */\r\n async genDTS(): Promise<void> {\r\n const base = this.options.base\r\n const { pattern, options } = ESBuildProgram.getWatchOptions(this.options.base)\r\n const project = new Project({\r\n tsConfigFilePath: path.resolve(base, 'tsconfig.json'),\r\n skipAddingFilesFromTsConfig: true,\r\n compilerOptions: {\r\n emitDeclarationOnly: true,\r\n noEmit: false,\r\n incremental: this.options.isWatch,\r\n },\r\n })\r\n const fileList = (await promise(pattern, options)).map((filePath) => path.resolve(base, filePath))\r\n project.addSourceFilesAtPaths(fileList)\r\n await project.emit({\r\n emitOnlyDtsFiles: true,\r\n })\r\n }\r\n /**\r\n * \u83B7\u53D6\u6784\u5EFA cjs \u7684\u9009\u9879\r\n */\r\n getBuildUserJSOption(): BuildOptions {\r\n return {\r\n entryPoints: [path.resolve(this.options.base, './src/index.ts')],\r\n outfile: path.resolve(this.options.base, './dist/index.user.js'),\r\n format: 'iife',\r\n bundle: true,\r\n external: [...ESBuildProgram.globalExternal],\r\n platform: 'browser',\r\n plugins: [userJS()],\r\n incremental: this.options.isWatch,\r\n absWorkingDir: this.options.base,\r\n }\r\n }\r\n\r\n /**\r\n * \u83B7\u53D6\u6784\u5EFA cjs \u7684\u9009\u9879\r\n * @param deps\r\n * @param platform\r\n * @param plugins\r\n */\r\n getBuildCjsOption({ deps, platform }: { deps: string[]; platform: Platform }): BuildOptions {\r\n return {\r\n entryPoints: [path.resolve(this.options.base, './src/index.ts')],\r\n outfile: path.resolve(this.options.base, './dist/index.js'),\r\n format: 'cjs',\r\n sourcemap: true,\r\n bundle: true,\r\n external: [...ESBuildProgram.globalExternal, ...deps],\r\n platform: platform,\r\n minify: !this.options.isWatch,\r\n incremental: this.options.isWatch,\r\n metafile: this.options.isWatch,\r\n }\r\n }\r\n\r\n /**\r\n * \u83B7\u53D6\u6784\u5EFA esm \u7684\u9009\u9879\r\n * @param deps\r\n * @param platform\r\n * @param plugins\r\n */\r\n getBuildESMOption({ deps, platform }: { deps: string[]; platform: Platform }): BuildOptions {\r\n return {\r\n entryPoints: [path.resolve(this.options.base, './src/index.ts')],\r\n outfile: path.resolve(this.options.base, './dist/index.esm.js'),\r\n format: 'esm',\r\n sourcemap: true,\r\n bundle: true,\r\n external: [...ESBuildProgram.globalExternal, ...deps],\r\n platform: platform,\r\n minify: !this.options.isWatch,\r\n incremental: this.options.isWatch,\r\n metafile: this.options.isWatch,\r\n }\r\n }\r\n\r\n /**\r\n * \u83B7\u53D6\u6784\u5EFA iife \u7684\u9009\u9879\r\n * @param deps\r\n * @param platform\r\n */\r\n getBuildIifeOption({ platform, globalName }: { platform: Platform; globalName: string }): BuildOptions {\r\n return {\r\n entryPoints: [path.resolve(this.options.base, './src/index.ts')],\r\n outfile: path.resolve(this.options.base, './dist/index.iife.js'),\r\n format: 'iife',\r\n sourcemap: true,\r\n bundle: true,\r\n external: [...ESBuildProgram.globalExternal],\r\n platform: platform,\r\n minify: !this.options.isWatch,\r\n incremental: this.options.isWatch,\r\n metafile: this.options.isWatch,\r\n globalName,\r\n }\r\n }\r\n\r\n /**\r\n * \u83B7\u53D6\u6784\u5EFA cli \u7684\u9009\u9879\r\n * @param deps\r\n * @param platform\r\n */\r\n getBuildCliOption({ platform }: { deps: string[]; platform: Platform }): BuildOptions {\r\n const plugins = ESBuildProgram.getPlugins(platform)\r\n return {\r\n entryPoints: [path.resolve(this.options.base, './src/bin.ts')],\r\n outfile: path.resolve(this.options.base, './dist/bin.js'),\r\n format: 'cjs',\r\n sourcemap: true,\r\n platform: platform,\r\n bundle: true,\r\n banner: {\r\n js: '#!/usr/bin/env node',\r\n },\r\n external: [...ESBuildProgram.globalExternal],\r\n plugins,\r\n minify: !this.options.isWatch,\r\n incremental: this.options.isWatch,\r\n metafile: this.options.isWatch,\r\n }\r\n }\r\n\r\n static getPlugins(platform: string): Plugin[] {\r\n const plugins: Plugin[] = []\r\n if (platform === 'node') {\r\n plugins.push(nodeExternals(), nativeNodeModules())\r\n }\r\n return plugins\r\n }\r\n\r\n async build(options: BuildOptions): Promise<void> {\r\n // if (this.options.isWatch) {\r\n // options.plugins = [...(options.plugins ?? []), metafile(options.outfile + '.meta.json')]\r\n // }\r\n await build(options)\r\n }\r\n\r\n async getTasks(): Promise<Record<TaskTypeEnum, Task>> {\r\n const deps = await ESBuildProgram.getDeps(this.options.base)\r\n const platform = await ESBuildProgram.getPlatform(this.options.base)\r\n return {\r\n esm: {\r\n title: '\u6784\u5EFA esm',\r\n task: () =>\r\n this.build(\r\n this.getBuildESMOption({\r\n deps: deps,\r\n platform: platform,\r\n }),\r\n ),\r\n },\r\n cjs: {\r\n title: '\u6784\u5EFA cjs',\r\n task: () =>\r\n this.build(\r\n this.getBuildCjsOption({\r\n deps: deps,\r\n platform: platform,\r\n }),\r\n ),\r\n },\r\n iife: {\r\n title: '\u6784\u5EFA iife',\r\n task: async () => {\r\n return await this.build(\r\n this.getBuildIifeOption({\r\n platform: platform,\r\n globalName: getPkgGlobalName(\r\n ((await readJson(path.resolve(this.options.base, './package.json'))) as PackageJson).name!,\r\n ),\r\n }),\r\n )\r\n },\r\n },\r\n cli: {\r\n title: '\u6784\u5EFA cli',\r\n task: () =>\r\n build(\r\n this.getBuildCliOption({\r\n deps: deps,\r\n platform: platform,\r\n }),\r\n ),\r\n },\r\n dts: {\r\n title: '\u751F\u6210\u7C7B\u578B\u5B9A\u4E49',\r\n task: () => this.genDTS(),\r\n },\r\n userjs: {\r\n title: '\u6253\u5305 userjs',\r\n task: () => this.build(this.getBuildUserJSOption()),\r\n },\r\n }\r\n }\r\n\r\n static async execTask(spinnies: Spinnies, task: Task): Promise<void> {\r\n const start = Date.now()\r\n spinnies.add(task.title, { text: task.title })\r\n try {\r\n await task.task()\r\n spinnies.succeed(task.title, {\r\n text: `${task.title}: ${Date.now() - start}ms`,\r\n })\r\n } catch (e) {\r\n spinnies.fail(task.title, { text: task.title })\r\n }\r\n }\r\n async execTasks(tasks: Task[]): Promise<void> {\r\n const run = async () => {\r\n const start = Date.now()\r\n const spinnies = new Spinnies()\r\n await Promise.all(tasks.map(async (task) => ESBuildProgram.execTask(spinnies, task)))\r\n console.log(`\u6784\u5EFA\u5B8C\u6210: ${Date.now() - start}ms`)\r\n }\r\n\r\n if (!this.options.isWatch) {\r\n await remove(path.resolve(this.options.base, 'dist'))\r\n await run()\r\n return\r\n }\r\n\r\n const { pattern, options } = ESBuildProgram.getWatchOptions(this.options.base)\r\n await new Promise((resolve, reject) => {\r\n watch(pattern, options).on('error', reject).on('all', debounce(run, 10))\r\n })\r\n }\r\n}\r\n", "import { Plugin } from 'esbuild'\r\nimport { readFile, readJson, writeJson } from 'fs-extra'\r\nimport * as path from 'path'\r\n\r\n/**\r\n * \u5904\u7406 nodejs \u539F\u751F\u6A21\u5757\r\n * @link https://github.com/evanw/esbuild/issues/1051#issuecomment-806325487\r\n */\r\nexport function nativeNodeModules(): Plugin {\r\n return {\r\n name: 'native-node-modules',\r\n setup(build) {\r\n // If a \".node\" file is imported within a module in the \"file\" namespace, resolve\r\n // it to an absolute path and put it into the \"node-file\" virtual namespace.\r\n build.onResolve({ filter: /\\.node$/, namespace: 'file' }, (args) => ({\r\n path: require.resolve(args.path, { paths: [args.resolveDir] }),\r\n namespace: 'node-file',\r\n }))\r\n\r\n // Files in the \"node-file\" virtual namespace call \"require()\" on the\r\n // path from esbuild of the \".node\" file in the output directory.\r\n build.onLoad({ filter: /.*/, namespace: 'node-file' }, (args) => ({\r\n contents: `\r\n import path from ${JSON.stringify(args.path)}\r\n try { module.exports = require(path) }\r\n catch {}\r\n `,\r\n }))\r\n\r\n // If a \".node\" file is imported within a module in the \"node-file\" namespace, put\r\n // it in the \"file\" namespace where esbuild's default loading behavior will handle\r\n // it. It is already an absolute path since we resolved it to one above.\r\n build.onResolve({ filter: /\\.node$/, namespace: 'node-file' }, (args) => ({\r\n path: args.path,\r\n namespace: 'file',\r\n }))\r\n\r\n // Tell esbuild's default loading behavior to use the \"file\" loader for\r\n // these \".node\" files.\r\n const opts = build.initialOptions\r\n opts.loader = opts.loader || {}\r\n opts.loader['.node'] = 'file'\r\n },\r\n }\r\n}\r\n\r\n/**\r\n * \u6392\u9664\u548C\u66FF\u6362 node \u5185\u7F6E\u6A21\u5757\r\n */\r\nexport function nodeExternals(): Plugin {\r\n return {\r\n name: 'esbuild-plugin-node-externals',\r\n setup(build) {\r\n build.onResolve({ filter: /(^node:)/ }, (args) => ({\r\n path: args.path.slice(5),\r\n external: true,\r\n }))\r\n },\r\n }\r\n}\r\n\r\n/**\r\n * \u81EA\u52A8\u6392\u9664\u6240\u6709\u4F9D\u8D56\u9879\r\n * golang \u4E0D\u652F\u6301 js \u7684\u4E00\u4E9B\u8BED\u6CD5\uFF0C\u53C2\u8003 https://github.com/evanw/esbuild/issues/1634\r\n */\r\nexport function autoExternal(): Plugin {\r\n return {\r\n name: 'esbuild-plugin-auto-external',\r\n setup(build) {\r\n build.onResolve({ filter: /.*/ }, (args) => {\r\n if (/^\\.{1,2}\\//.test(args.path)) {\r\n return\r\n }\r\n return {\r\n path: args.path,\r\n external: true,\r\n }\r\n })\r\n },\r\n }\r\n}\r\n\r\n/**\r\n * \u901A\u8FC7 ?raw \u5C06\u8D44\u6E90\u4F5C\u4E3A\u5B57\u7B26\u4E32\u6253\u5305\u8FDB\u6765\r\n * @returns\r\n */\r\nexport function raw(): Plugin {\r\n return {\r\n name: 'esbuild-plugin-raw',\r\n setup(build) {\r\n build.onResolve({ filter: /\\?raw$/ }, (args) => {\r\n return {\r\n path: path.isAbsolute(args.path) ? args.path : path.join(args.resolveDir, args.path),\r\n namespace: 'raw-loader',\r\n }\r\n })\r\n build.onLoad({ filter: /\\?raw$/, namespace: 'raw-loader' }, async (args) => {\r\n return {\r\n contents: await readFile(args.path.replace(/\\?raw$/, '')),\r\n loader: 'text',\r\n }\r\n })\r\n },\r\n }\r\n}\r\n\r\n/**\r\n * @param {string} str\r\n */\r\nfunction isValidId(str: string) {\r\n try {\r\n new Function(`var ${str};`)\r\n } catch (err) {\r\n return false\r\n }\r\n return true\r\n}\r\n\r\nfunction defineImportEnv() {\r\n const definitions: Record<string, string> = {}\r\n Object.keys(process.env).forEach((key) => {\r\n if (isValidId(key)) {\r\n definitions[`import.meta.env.${key}`] = JSON.stringify(process.env[key])\r\n }\r\n })\r\n definitions['import.meta.env'] = '{}'\r\n return definitions\r\n}\r\n\r\n/**\r\n * Pass environment variables to esbuild.\r\n * @return An esbuild plugin.\r\n */\r\nexport function envPlugin(): Plugin {\r\n return {\r\n name: 'esbuild-plugin-env',\r\n setup(build) {\r\n const { platform, define = {} } = build.initialOptions\r\n if (platform === 'node') {\r\n return\r\n }\r\n build.initialOptions.define = define\r\n Object.assign(build.initialOptions.define, defineImportEnv())\r\n },\r\n }\r\n}\r\n\r\n/**\r\n * \u751F\u6210 metafile \u7684\u63D2\u4EF6\r\n * @param metafilePath\r\n */\r\nexport function metafile(metafilePath: string): Plugin {\r\n return {\r\n name: 'esbuild-plugin-metafile',\r\n setup(builder) {\r\n builder.onEnd(async (result) => {\r\n await writeJson(metafilePath, result.metafile)\r\n })\r\n },\r\n }\r\n}\r\n\r\nfunction generateBanner(meta: object) {\r\n return (\r\n [\r\n '// ==UserScript==',\r\n ...Object.entries(meta)\r\n .map(([key, value]) => {\r\n if (Array.isArray(value)) {\r\n return value.map((item) => `// @${key} ${item}`)\r\n }\r\n return `// @${key} ${value}`\r\n })\r\n .flat(),\r\n '// ==/UserScript==',\r\n ].join('\\n') + '\\n'\r\n )\r\n}\r\n\r\nexport function userJS(): Plugin {\r\n return {\r\n name: 'esbuild-plugin-userjs',\r\n async setup(build) {\r\n const json = (await readJson(path.resolve(build.initialOptions.absWorkingDir!, 'package.json'))) as {\r\n userjs: object\r\n }\r\n if (!json.userjs) {\r\n throw new Error('userjs is not supported')\r\n }\r\n if (!build.initialOptions.banner) {\r\n build.initialOptions.banner = {}\r\n }\r\n build.initialOptions.banner!['js'] = generateBanner(json.userjs)\r\n },\r\n }\r\n}\r\n", "/**\r\n * \u51FD\u6570\u53BB\u6296\r\n * \u53BB\u6296 (debounce) \u53BB\u6296\u5C31\u662F\u5BF9\u4E8E\u4E00\u5B9A\u65F6\u95F4\u6BB5\u7684\u8FDE\u7EED\u7684\u51FD\u6570\u8C03\u7528\uFF0C\u53EA\u8BA9\u5176\u6267\u884C\u4E00\u6B21\r\n * \u6CE8: \u5305\u88C5\u540E\u7684\u51FD\u6570\u5982\u679C\u4E24\u6B21\u64CD\u4F5C\u95F4\u9694\u5C0F\u4E8E delay \u5219\u4E0D\u4F1A\u88AB\u6267\u884C, \u5982\u679C\u4E00\u76F4\u5728\u64CD\u4F5C\u5C31\u4F1A\u4E00\u76F4\u4E0D\u6267\u884C, \u76F4\u5230\u64CD\u4F5C\u505C\u6B62\u7684\u65F6\u95F4\u5927\u4E8E delay \u6700\u5C0F\u95F4\u9694\u65F6\u95F4\u624D\u4F1A\u6267\u884C\u4E00\u6B21, \u4E0D\u7BA1\u4EFB\u4F55\u65F6\u95F4\u8C03\u7528\u90FD\u9700\u8981\u505C\u6B62\u64CD\u4F5C\u7B49\u5F85\u6700\u5C0F\u5EF6\u8FDF\u65F6\u95F4\r\n * \u5E94\u7528\u573A\u666F\u4E3B\u8981\u5728\u90A3\u4E9B\u8FDE\u7EED\u7684\u64CD\u4F5C, \u4F8B\u5982\u9875\u9762\u6EDA\u52A8\u76D1\u542C, \u5305\u88C5\u540E\u7684\u51FD\u6570\u53EA\u4F1A\u6267\u884C\u6700\u540E\u4E00\u6B21\r\n * \u6CE8: \u8BE5\u51FD\u6570\u7B2C\u4E00\u6B21\u8C03\u7528\u4E00\u5B9A\u4E0D\u4F1A\u6267\u884C\uFF0C\u7B2C\u4E00\u6B21\u4E00\u5B9A\u62FF\u4E0D\u5230\u7F13\u5B58\u503C\uFF0C\u540E\u9762\u7684\u8FDE\u7EED\u8C03\u7528\u90FD\u4F1A\u62FF\u5230\u4E0A\u4E00\u6B21\u7684\u7F13\u5B58\u503C\u3002\u5982\u679C\u9700\u8981\u5728\u7B2C\u4E00\u6B21\u8C03\u7528\u83B7\u53D6\u5230\u7684\u7F13\u5B58\u503C\uFF0C\u5219\u9700\u8981\u4F20\u5165\u7B2C\u4E09\u4E2A\u53C2\u6570 {@param init}\uFF0C\u9ED8\u8BA4\u4E3A {@code undefined} \u7684\u53EF\u9009\u53C2\u6570\r\n * \u6CE8: \u8FD4\u56DE\u51FD\u6570\u7ED3\u679C\u7684\u9AD8\u9636\u51FD\u6570\u9700\u8981\u4F7F\u7528 {@see Proxy} \u5B9E\u73B0\uFF0C\u4EE5\u907F\u514D\u539F\u51FD\u6570\u539F\u578B\u94FE\u4E0A\u7684\u4FE1\u606F\u4E22\u5931\r\n *\r\n * @param fn \u771F\u6B63\u9700\u8981\u6267\u884C\u7684\u64CD\u4F5C\r\n * @param delay \u6700\u5C0F\u5EF6\u8FDF\u65F6\u95F4\uFF0C\u5355\u4F4D\u4E3A ms\r\n * @param init \u521D\u59CB\u7684\u7F13\u5B58\u503C\uFF0C\u4E0D\u586B\u9ED8\u8BA4\u4E3A {@see undefined}\r\n * @return \u5305\u88C5\u540E\u6709\u53BB\u6296\u529F\u80FD\u7684\u51FD\u6570\u3002\u8BE5\u51FD\u6570\u662F\u5F02\u6B65\u7684\uFF0C\u4E0E\u9700\u8981\u5305\u88C5\u7684\u51FD\u6570 {@param fn} \u662F\u5426\u5F02\u6B65\u6CA1\u6709\u592A\u5927\u5173\u8054\r\n */\r\nexport function debounce<\r\n T extends (...args: any[]) => any,\r\n R extends (...args: Parameters<T>) => Promise<ReturnType<T>>,\r\n>(fn: T, delay: number, init: any = null): R {\r\n let flag: number\r\n let result = init\r\n return async function (...args) {\r\n return new Promise((resolve) => {\r\n if (flag) {\r\n clearTimeout(flag as any)\r\n }\r\n flag = setTimeout(() => resolve((result = fn(...args))), delay) as any\r\n setTimeout(() => resolve(result), delay)\r\n })\r\n } as R\r\n}\r\n", "/**\r\n * \u8F6C\u6362 npm \u5305\u540D\u4E3A\u4E00\u4E2A\u5408\u9002\u7684\u5168\u5C40\u53D8\u91CF\u540D\r\n * @param name\r\n */\r\nexport function getPkgGlobalName(name: string): string {\r\n const temp = name.startsWith('@') ? name.slice(name.indexOf('/') + 1) : name\r\n return temp\r\n .split('-')\r\n .map((s) => s.slice(0, 1).toUpperCase() + s.slice(1).toLowerCase())\r\n .join('')\r\n}\r\n", "import path from 'path'\r\nimport { copy, pathExists, readdir, readFile, readJSON, remove, writeFile, writeJSON } from 'fs-extra'\r\nimport { prompt } from 'enquirer'\r\nimport { SyncProgram } from '../sync/SyncProgram'\r\nimport { PathUtil } from '../../PathUtil'\r\n\r\nexport enum TemplateTypeEnum {\r\n Cli = 'cli',\r\n Lib = 'lib',\r\n}\r\n\r\nexport interface GenerateConfig {\r\n template: TemplateTypeEnum\r\n dest: string\r\n initSync?: boolean\r\n}\r\n\r\nexport class GenerateProgram {\r\n /**\r\n * \u751F\u6210\u9879\u76EE\r\n */\r\n async generate(config: GenerateConfig): Promise<void> {\r\n if (!config.dest) {\r\n const { dest } = await prompt<{ dest: string }>({\r\n name: 'dest',\r\n type: 'input',\r\n message: '\u8BF7\u8F93\u5165\u9879\u76EE\u540D',\r\n validate(input: string): boolean {\r\n return input.trim() !== ''\r\n },\r\n })\r\n config.dest = path.resolve(dest)\r\n }\r\n if (!config.template) {\r\n const { template } = await prompt<{ template: TemplateTypeEnum }>({\r\n name: 'template',\r\n type: 'select',\r\n message: '\u8BF7\u9009\u62E9\u6A21\u677F',\r\n choices: [TemplateTypeEnum.Lib, TemplateTypeEnum.Cli] as TemplateTypeEnum[],\r\n })\r\n config.template = template\r\n }\r\n\r\n /*\r\n \u514B\u9686\u9879\u76EE\r\n \u4FEE\u6539\u4E00\u4E9B\u5185\u5BB9\r\n \u5171\u901A\u4FEE\u6539\r\n - \u4FEE\u6539 package.json\uFF0C\u5220\u9664 private\uFF0C\u4FEE\u6539\u540D\u5B57\r\n \u6A21\u677F\u7279\u5B9A\u4FEE\u6539\r\n */\r\n const srcFile = path.resolve(PathUtil.RootPath, `templates/${config.template}`)\r\n const destFile = path.resolve(config.dest)\r\n if ((await pathExists(destFile)) && (await readdir(destFile)).some((file) => pathExists(file))) {\r\n const { override } = await prompt<{\r\n override: boolean\r\n }>({\r\n name: 'override',\r\n type: 'confirm',\r\n initial: true,\r\n message: '\u76EE\u6807\u4F4D\u7F6E\u4E0D\u662F\u4E00\u4E2A\u7A7A\u76EE\u5F55\uFF0C\u786E\u8BA4\u8981\u8986\u76D6\u4E48\uFF1F',\r\n })\r\n if (!override) {\r\n return\r\n }\r\n }\r\n await remove(destFile)\r\n await copy(srcFile, destFile, {\r\n filter: (source) => path.basename(source) !== 'node_modules',\r\n })\r\n await GenerateProgram.updatePackageJSON(destFile)\r\n await GenerateProgram.updateReadme(destFile)\r\n if (config.initSync) {\r\n const syncProgram = new SyncProgram(path.resolve(config.dest))\r\n await syncProgram.init()\r\n await syncProgram.sync()\r\n }\r\n }\r\n\r\n static async updatePackageJSON(destFile: string): Promise<void> {\r\n const pkgPath = path.resolve(destFile, 'package.json')\r\n await writeJSON(\r\n pkgPath,\r\n {\r\n ...(await readJSON(pkgPath)),\r\n name: path.basename(destFile),\r\n },\r\n {\r\n spaces: 2,\r\n },\r\n )\r\n }\r\n\r\n static async updateReadme(destFile: string): Promise<void> {\r\n const readmePath = path.resolve(destFile, 'README.md')\r\n let readmeFile = await readFile(readmePath, 'utf-8')\r\n readmeFile = readmeFile.replace('template', path.basename(destFile))\r\n await writeFile(readmePath, readmeFile)\r\n }\r\n}\r\n", "import { readFile, readJson, writeFile, writeJson } from 'fs-extra'\r\nimport path from 'path'\r\nimport { merge } from 'lodash'\r\nimport { PackageJson } from 'type-fest'\r\nimport prettier from '@liuli-util/prettier-standard-config/package.json'\r\nimport eslintTs from '@liuli-util/eslint-config-ts/package.json'\r\nimport eslintReactTs from '@liuli-util/eslint-config-react-ts/package.json'\r\nimport commitlint from '@liuli-util/commitlint-standard-config/package.json'\r\nimport { prompt } from 'enquirer'\r\nimport { isIncludeDep, isNpmPackage, isYarnRoot, isYarnSubModule } from './when'\r\nimport { appendScript, arrayToMap, AsyncArray } from '../../utils'\r\nimport { PathUtil } from '../../PathUtil'\r\n\r\nexport async function mergeJson(base: string, json: object): Promise<void> {\r\n const pkgJsonFilePath = path.resolve(base, './package.json')\r\n await writeJson(pkgJsonFilePath, merge(await readJson(pkgJsonFilePath), json), {\r\n spaces: 2,\r\n })\r\n}\r\n\r\nexport type SyncConfigType =\r\n | 'prettier'\r\n | 'commitlint'\r\n | 'simplehooks'\r\n | 'workspaces'\r\n | 'gitignore'\r\n | 'eslint-ts'\r\n | 'eslint-vue-ts'\r\n | 'eslint-react-ts'\r\n | 'jest'\r\n\r\nexport interface SyncConfig {\r\n type: SyncConfigType\r\n handler(): Promise<void>\r\n when?(): Promise<boolean>\r\n}\r\n\r\nexport class SyncProgram {\r\n constructor(private readonly base: string) {}\r\n private syncConfigs: SyncConfig[] = [\r\n {\r\n type: 'workspaces',\r\n handler: async () => {\r\n const pkgPath = path.resolve(this.base, './package.json')\r\n const lernaPath = path.resolve(this.base, 'lerna.json')\r\n const pkgJson = (await readJson(pkgPath)) as { workspaces: string[] }\r\n const lernaJson = await readJson(lernaPath)\r\n lernaJson.packages = pkgJson.workspaces\r\n await writeJson(lernaPath, lernaJson, {\r\n spaces: 2,\r\n })\r\n },\r\n when: isYarnRoot,\r\n },\r\n {\r\n type: 'prettier',\r\n handler: async () => {\r\n await mergeJson(this.base, {\r\n prettier: '@liuli-util/prettier-standard-config',\r\n devDependencies: {\r\n prettier: '^2.3.2',\r\n '@liuli-util/prettier-standard-config': `^${prettier.version}`,\r\n },\r\n } as PackageJson)\r\n },\r\n async when(): Promise<boolean> {\r\n return (await isNpmPackage()) && ((await isYarnRoot()) || !(await isYarnSubModule()))\r\n },\r\n },\r\n {\r\n type: 'commitlint',\r\n handler: async () => {\r\n await mergeJson(this.base, {\r\n 'simple-git-hooks': {\r\n 'commit-msg': 'yarn commitlint --edit $1',\r\n },\r\n commitlint: {\r\n extends: ['@liuli-util/commitlint-standard-config'],\r\n },\r\n devDependencies: {\r\n '@commitlint/cli': '^12.1.4',\r\n '@liuli-util/commitlint-standard-config': `^${commitlint.version}`,\r\n },\r\n } as PackageJson)\r\n },\r\n async when(): Promise<boolean> {\r\n return (await isNpmPackage()) && ((await isYarnRoot()) || !(await isYarnSubModule()))\r\n },\r\n },\r\n {\r\n type: 'gitignore',\r\n handler: async () => {\r\n const gitignorePath = path.resolve(this.base, '.gitignore')\r\n await writeFile(gitignorePath, await readFile(path.resolve(PathUtil.RootPath, '_gitignore'), 'utf-8'))\r\n },\r\n },\r\n {\r\n type: 'eslint-ts',\r\n handler: async () => {\r\n await mergeJson(this.base, {\r\n eslintConfig: {\r\n extends: ['@liuli-util/eslint-config-ts'],\r\n },\r\n devDependencies: {\r\n '@liuli-util/eslint-config-ts': `^${eslintTs.version}`,\r\n },\r\n } as PackageJson)\r\n },\r\n async when(): Promise<boolean> {\r\n return (await isNpmPackage()) && !(await isIncludeDep(['vue'])) && !(await isIncludeDep(['react']))\r\n },\r\n },\r\n {\r\n type: 'eslint-react-ts',\r\n handler: async () => {\r\n await mergeJson(this.base, {\r\n eslintConfig: {\r\n extends: ['@liuli-util/eslint-config-react-ts'],\r\n },\r\n devDependencies: {\r\n '@liuli-util/eslint-config-react-ts': `^${eslintReactTs.version}`,\r\n },\r\n } as PackageJson)\r\n },\r\n async when(): Promise<boolean> {\r\n return (await isNpmPackage()) && (await isIncludeDep(['react']))\r\n },\r\n },\r\n {\r\n type: 'jest',\r\n handler: async () => {\r\n await mergeJson(this.base, {\r\n jest: {\r\n preset: 'ts-jest',\r\n testMatch: ['<rootDir>/src/**/__tests__/*.test.ts'],\r\n },\r\n devDependencies: {\r\n jest: '^27.4.3',\r\n 'ts-jest': '^27.0.7',\r\n },\r\n })\r\n },\r\n },\r\n //\u5FC5\u987B\u653E\u5230\u6700\u540E\u4E00\u4E2A\uFF0C\u540E\u7EED\u6839\u636E\u68C0\u6D4B\u7ED3\u679C\u6DFB\u52A0 hooks\r\n {\r\n type: 'simplehooks',\r\n handler: async () => {\r\n const json = await readJson(path.resolve(this.base, './package.json'))\r\n const lintStaged: Record<string, string[]> = {}\r\n if (json.prettier) {\r\n lintStaged['src/**/*.{ts,tsx,js,jsx,css,vue}'] = ['prettier --write', 'git add']\r\n }\r\n if (json.eslintConfig) {\r\n lintStaged['src/**/*.{ts,tsx,js,jsx}'] = ['eslint --fix --quiet', 'git add']\r\n }\r\n let config = {\r\n scripts: {\r\n postinstall: appendScript(json?.scripts?.postinstall, 'npx simple-git-hooks'),\r\n },\r\n 'simple-git-hooks': {\r\n 'pre-commit': 'yarn lint-staged',\r\n },\r\n 'lint-staged': lintStaged,\r\n devDependencies: {\r\n 'simple-git-hooks': '^2.5.1',\r\n 'lint-staged': '^11.1.1',\r\n },\r\n }\r\n if (json.commitlint) {\r\n config = merge(config, {\r\n 'simple-git-hooks': {\r\n 'commit-msg': 'yarn commitlint --edit $1',\r\n },\r\n })\r\n }\r\n await mergeJson(this.base, config as PackageJson)\r\n },\r\n async when(): Promise<boolean> {\r\n return (await isNpmPackage()) && ((await isYarnRoot()) || !(await isYarnSubModule()))\r\n },\r\n },\r\n ]\r\n\r\n async sync(): Promise<void> {\r\n const { sync } = (await readJson(path.resolve(this.base, 'package.json'))) as {\r\n sync?: SyncConfigType[]\r\n }\r\n if (!sync) {\r\n return\r\n }\r\n const syncConfigs = this.syncConfigs.filter((config) => sync.includes(config.type))\r\n for (const syncConfig of syncConfigs) {\r\n await syncConfig.handler()\r\n }\r\n }\r\n\r\n async init(): Promise<void> {\r\n const configMap = arrayToMap(\r\n await AsyncArray.filter(this.syncConfigs, async (config) => {\r\n if (!config.when) {\r\n return true\r\n }\r\n return await config.when()\r\n }),\r\n (item) => item.type,\r\n )\r\n const res = await prompt<{\r\n sync: string[]\r\n }>({\r\n type: 'multiselect',\r\n message: '\u8BF7\u9009\u62E9\u9700\u8981\u540C\u6B65\u7684\u914D\u7F6E\u9879',\r\n name: 'sync',\r\n choices: [...configMap.keys()],\r\n })\r\n await mergeJson(this.base, {\r\n sync: res.sync,\r\n })\r\n }\r\n}\r\n", "import { pathExists, readJson } from 'fs-extra'\r\nimport * as path from 'path'\r\nimport { PackageJson } from 'type-fest'\r\nimport { findParent } from '../../utils'\r\n\r\n/**\r\n * \u5224\u65AD\u662F\u5426\u5305\u542B package.json\r\n * @param cwd\r\n */\r\nexport async function isNpmPackage(cwd: string = process.cwd()): Promise<boolean> {\r\n return await pathExists(path.resolve(cwd, './package.json'))\r\n}\r\n\r\n/**\r\n * \u5224\u65AD\u662F yarn2 monorepo \u9879\u76EE\r\n * @param cwd\r\n */\r\nexport async function isYarnRoot(cwd: string = process.cwd()): Promise<boolean> {\r\n if (!(await isNpmPackage(cwd))) {\r\n return false\r\n }\r\n const json = (await readJson(path.resolve(cwd, './package.json'))) as PackageJson\r\n return !!json.workspaces\r\n}\r\n\r\n/**\r\n * \u5224\u65AD\u662F yarn2 monorepo \u7684\u5B50\u6A21\u5757\r\n */\r\nexport async function isYarnSubModule(cwd: string = process.cwd()): Promise<boolean> {\r\n if (!(await isNpmPackage(cwd))) {\r\n return false\r\n }\r\n //\u5982\u679C\u662F yarn monorepo \u6839\u6A21\u5757\u5219\u76F4\u63A5\u8FD4\u56DE true\r\n if (await isYarnRoot(cwd)) {\r\n return false\r\n }\r\n return (await findParent(path.dirname(cwd), isYarnRoot)) !== null\r\n}\r\n\r\n/**\r\n * \u662F\u5426\u5305\u542B\u6307\u5B9A\u4F9D\u8D56\r\n * @param deps\r\n * @param cwd\r\n */\r\nexport async function isIncludeDep(deps: string[], cwd: string = process.cwd()): Promise<boolean> {\r\n if (!(await isNpmPackage(cwd))) {\r\n return false\r\n }\r\n const json = (await readJson(path.resolve(cwd, './package.json'))) as PackageJson\r\n const set = new Set(Object.keys({ ...json.dependencies, ...json.devDependencies }))\r\n return deps.every((dep) => set.has(dep))\r\n}\r\n", "export function arrayToMap<T, K>(\r\n arr: T[],\r\n kFn: (item: T, index: number, arr: T[]) => K,\r\n): Map<K, T>\r\nexport function arrayToMap<T, K, V>(\r\n arr: T[],\r\n kFn: (item: T, index: number, arr: T[]) => K,\r\n vFn: (item: T, index: number, arr: T[]) => V,\r\n): Map<K, V>\r\n/**\r\n * \u5C06\u6570\u7EC4\u6620\u5C04\u4E3A Map\r\n * @param arr \u6570\u7EC4\r\n * @param kFn \u4EA7\u751F Map \u5143\u7D20\u552F\u4E00\u6807\u8BC6\u7684\u51FD\u6570\r\n * @param vFn \u4EA7\u751F Map \u503C\u7684\u51FD\u6570\uFF0C\u9ED8\u8BA4\u4E3A\u8FD4\u56DE\u6570\u7EC4\u7684\u5143\u7D20\r\n * @returns \u6620\u5C04\u4EA7\u751F\u7684 map \u96C6\u5408\r\n */\r\nexport function arrayToMap<T, K, V>(\r\n arr: T[],\r\n kFn: (item: T, index: number, arr: T[]) => K,\r\n vFn: (item: T, index: number, arr: T[]) => V = (v) => v as any,\r\n): Map<K, V> {\r\n return arr.reduce(\r\n (res, item, index, arr) =>\r\n res.set(kFn(item, index, arr), vFn(item, index, arr)),\r\n new Map<K, V>(),\r\n )\r\n}\r\n", "/**\r\n * \u5728\u4E4B\u524D\u7684\u811A\u672C\u4E2D\u8FFD\u52A0\u65B0\u7684\u811A\u672C\r\n * @param oldScript\r\n * @param newScript\r\n */\r\nexport function appendScript(\r\n oldScript: string | undefined,\r\n newScript: string,\r\n): string {\r\n if (!oldScript) {\r\n return newScript\r\n }\r\n if (oldScript.includes(newScript)) {\r\n return oldScript\r\n }\r\n return oldScript + ' && ' + newScript\r\n}\r\n", "import path from 'path'\r\n\r\n/**\r\n * \u5411\u4E0A\u67E5\u627E\u76EE\u5F55\r\n * @param cwd\r\n * @param predicate\r\n */\r\nexport function findParent(\r\n cwd: string,\r\n predicate: (dir: string) => boolean,\r\n): string | null\r\nexport function findParent(\r\n cwd: string,\r\n predicate: (dir: string) => Promise<boolean>,\r\n): Promise<string | null>\r\nexport function findParent<\r\n T extends (dir: string) => boolean | Promise<boolean>,\r\n R extends string | null,\r\n>(\r\n cwd: string,\r\n predicate: T,\r\n): ReturnType<T> extends Promise<any> ? Promise<R> : R {\r\n const res = predicate(cwd)\r\n function f(res: boolean): string | null {\r\n if (res) {\r\n return cwd\r\n }\r\n const parent = path.dirname(cwd)\r\n if (parent === cwd) {\r\n return null\r\n }\r\n return findParent(parent, predicate as any)\r\n }\r\n\r\n return res instanceof Promise ? res.then(f) : (f(res) as any)\r\n}\r\n", "import { IterableElement } from 'type-fest'\r\n\r\nenum ActionTypeEnum {\r\n Filter = 'filter',\r\n Map = 'map',\r\n ForEach = 'forEach',\r\n Reduce = 'reduce',\r\n FlatMap = 'flatMap',\r\n}\r\n\r\nclass Action {\r\n public static Type = ActionTypeEnum\r\n\r\n constructor(\r\n public readonly type: ActionTypeEnum,\r\n public readonly args: any[],\r\n ) {\r\n this.type = type\r\n this.args = args\r\n }\r\n}\r\n\r\n/**\r\n * \u5F02\u6B65\u6570\u7EC4\uFF0C\u652F\u6301\u9759\u6001\u65B9\u6CD5\u548C\u94FE\u5F0F\u8C03\u7528\r\n */\r\nexport class AsyncArray<T> implements PromiseLike<T[]> {\r\n static reduce<T extends any[], R>(\r\n arr: T,\r\n fn: (res: R, item: IterableElement<T>, index: number) => Promise<R>,\r\n res: R,\r\n ): Promise<R> {\r\n return arr.reduce(\r\n (res: Promise<R>, item: IterableElement<T>, index: number) =>\r\n res.then((r) => fn(r, item, index)),\r\n Promise.resolve(res),\r\n )\r\n }\r\n\r\n static map<T, R>(\r\n arr: T[],\r\n fn: (item: T, index: number) => Promise<R>,\r\n ): Promise<R[]> {\r\n return Promise.all(arr.map((item, index) => fn(item, index)))\r\n }\r\n\r\n static async filter<T>(\r\n arr: T[],\r\n fn: (item: T, index: number) => Promise<boolean>,\r\n ): Promise<T[]> {\r\n const res: T[] = []\r\n await AsyncArray.map(arr, async (item, index) => {\r\n if (await fn(item, index)) {\r\n res.push(item)\r\n }\r\n })\r\n return res\r\n }\r\n\r\n static async flatMap<T, R>(\r\n arr: T[],\r\n fn: (item: T, index: number) => Promise<R[]>,\r\n ): Promise<R[]> {\r\n return (\r\n await Promise.all(arr.map((item, index) => fn(item, index)))\r\n ).flatMap((r) => r)\r\n }\r\n\r\n static async forEach<T extends any[]>(\r\n arr: T,\r\n fn: (item: IterableElement<T>, index: number) => Promise<void>,\r\n ): Promise<void> {\r\n await AsyncArray.map(arr, fn)\r\n }\r\n\r\n private tasks: Action[] = []\r\n\r\n constructor(private readonly arr: T[]) {}\r\n\r\n map<R>(fn: (item: T, index: number) => Promise<R>): AsyncArray<R> {\r\n this.tasks.push(new Action(ActionTypeEnum.Map, [fn]))\r\n return this as any\r\n }\r\n\r\n flatMap<R>(fn: (item: T, index: number) => Promise<R[]>): AsyncArray<R> {\r\n this.tasks.push(new Action(ActionTypeEnum.FlatMap, [fn]))\r\n return this as any\r\n }\r\n\r\n filter(fn: (item: T, index: number) => Promise<boolean>): this {\r\n this.tasks.push(new Action(ActionTypeEnum.Filter, [fn]))\r\n return this\r\n }\r\n\r\n async forEach<R>(fn: (item: T, index: number) => Promise<R>): Promise<void> {\r\n this.tasks.push(new Action(ActionTypeEnum.Map, [fn]))\r\n await this\r\n }\r\n\r\n then<TResult1 = T[], TResult2 = never>(\r\n resolve?:\r\n | ((value: T[]) => PromiseLike<TResult1> | TResult1)\r\n | undefined\r\n | null,\r\n reject?:\r\n | ((reason: any) => PromiseLike<TResult2> | TResult2)\r\n | undefined\r\n | null,\r\n ): PromiseLike<TResult1 | TResult2> {\r\n const res = this.value()\r\n res\r\n .then((r) => {\r\n resolve && resolve(res as any)\r\n return r\r\n })\r\n .catch((e) => {\r\n reject && reject(e as any)\r\n throw e\r\n })\r\n return res as any\r\n }\r\n\r\n private async value(): Promise<any> {\r\n let res = this.arr\r\n for (const task of this.tasks) {\r\n switch (task.type) {\r\n case ActionTypeEnum.Filter:\r\n res = await AsyncArray.filter(res, task.args[0])\r\n break\r\n case ActionTypeEnum.Map:\r\n res = await AsyncArray.map(res, task.args[0])\r\n break\r\n case ActionTypeEnum.FlatMap:\r\n res = await AsyncArray.flatMap(res, task.args[0])\r\n break\r\n case ActionTypeEnum.ForEach:\r\n await AsyncArray.forEach(res, task.args[0])\r\n return\r\n case ActionTypeEnum.Reduce:\r\n return await AsyncArray.reduce(res, task.args[0], task.args[1])\r\n }\r\n }\r\n return res\r\n }\r\n}\r\n", "import path from 'path'\r\n\r\nexport class PathUtil {\r\n /**\r\n * \u4ECE\u8FD9\u4E2A\u9879\u76EE\u7684\u6839\u76EE\u5F55\u8BFB\u53D6\uFF0C\u5F00\u53D1\u73AF\u5883\u662F src/../\uFF0C\u8FD0\u884C\u65F6\u5219\u662F dist/../\r\n */\r\n static readonly RootPath = path.resolve(__dirname, '..')\r\n}\r\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|