-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.pnpmfile.cjs
195 lines (180 loc) · 4.88 KB
/
.pnpmfile.cjs
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
// @ts-check
/// PNPM Typedefs.
// From <https://github.com/pnpm/pnpm/blob/eeb76cd1d0a3133d71d96de5646e305f34474652/hooks/pnpmfile/src/Hooks.ts> & <https://github.com/pnpm/pnpm/blob/d500d9f12e8819bf2659abece126938fb3a9ac87/packages/types/src/package.ts>.
const VERBOSE = false;
/**
* A local `package.json` or a remote manifest from a registry as deserialized JSON.
*
* @typedef {Object} Pkg
* @property {string?} name
* @property {string?} version
* @property {Record<string, string>?} dependencies
*/
/**
* A context object passed to hooks.
* Currently contains naught but a logger.
*
* @typedef {Object} HookContext
* @property {(message: string) => void} log
*/
/// Ported code from the Yarn plugin.
/**
* A full list of nolyfilled packages.
*
* Based on <https://github.com/wojtekmaj/yarn-plugin-nolyfill/blob/main/src/index.ts>.
* Keep in sync with <https://github.com/SukkaW/nolyfill/blob/master/packages/tools/cli/src/all-packages.ts>.
* Do note that nolyfill doesn't use CD, so check that the versions listed there have been published.
*
* @type {string[]}
*/
const allPackages = [
"abab",
"array-buffer-byte-length",
"array-flatten",
"array-includes",
"array.from",
"array.of",
"array.prototype.at",
"array.prototype.every",
"array.prototype.find",
"array.prototype.findlast",
"array.prototype.findlastindex",
"array.prototype.flat",
"array.prototype.flatmap",
"array.prototype.flatmap",
"array.prototype.foreach",
"array.prototype.reduce",
"array.prototype.toreversed",
"array.prototype.tosorted",
"arraybuffer.prototype.slice",
"assert",
"asynciterator.prototype",
"available-typed-arrays",
"deep-equal",
"deep-equal-json",
"define-properties",
"es-aggregate-error",
"es-iterator-helpers",
"es-set-tostringtag",
"es6-object-assign",
"function-bind",
"function.prototype.name",
"get-symbol-description",
"globalthis",
"gopd",
"harmony-reflect",
"has",
"has-property-descriptors",
"has-proto",
"has-symbols",
"has-tostringtag",
"hasown",
"internal-slot",
"is-arguments",
"is-array-buffer",
"is-core-module",
"is-date-object",
"is-generator-function",
"is-nan",
"is-regex",
"is-shared-array-buffer",
"is-string",
"is-symbol",
"is-typed-array",
"is-weakref",
"isarray",
"iterator.prototype",
"json-stable-stringify",
"jsonify",
"number-is-nan",
"object-is",
"object-keys",
"object.assign",
"object.entries",
"object.fromentries",
"object.getownpropertydescriptors",
"object.groupby",
"object.hasown",
"object.values",
"promise.allsettled",
"promise.any",
"reflect.getprototypeof",
"reflect.ownkeys",
"regexp.prototype.flags",
"safe-array-concat",
"safe-regex-test",
"set-function-length",
"side-channel",
"string.prototype.at",
"string.prototype.codepointat",
"string.prototype.includes",
"string.prototype.matchall",
"string.prototype.padend",
"string.prototype.padstart",
"string.prototype.repeat",
"string.prototype.replaceall",
"string.prototype.split",
"string.prototype.startswith",
"string.prototype.trim",
"string.prototype.trimend",
"string.prototype.trimleft",
"string.prototype.trimright",
"string.prototype.trimstart",
"typed-array-buffer",
"typed-array-byte-length",
"typed-array-byte-offset",
"typed-array-length",
"typedarray",
"typedarray.prototype.slice",
"unbox-primitive",
"util.promisify",
"which-boxed-primitive",
"which-typed-array",
];
/**
* A map of all nolyfilled packages.
* The keys are the original package names, the values are the nolyfilled package names.
*
* @type {Map<string, string>}
*/
const PATCHES = new Map(allPackages.map((name) => [name, `@nolyfill/${name}`]));
/// Wiring code (pnpm specific)
/**
* @param {Pkg} pkg - The package read.
* @param {HookContext} context - The context of the hook.
* @returns {Pkg} - The package to use.
*/
function readPackage(pkg, context) {
// Not really necessary, but I prefer to keep the original package unmodified.
const newPkg = { ...pkg };
// If the package has dependencies, check if any of them need to be nolyfilled.
if (newPkg.dependencies) {
// Iterate over all dependencies.
for (const name of Object.keys(newPkg.dependencies)) {
// Get the possible nolyfill package name.
const nolyfill = PATCHES.get(name);
// Check if there is nolyfill for the package.
if (nolyfill !== undefined) {
// Replace the original package with the nolyfill.
newPkg.dependencies[name] = `npm:${nolyfill}@^1`;
if (VERBOSE) {
// Tell the user that the package has been nolyfilled.
context.log(`${name} => ${nolyfill}`);
}
}
}
}
// Return the (possibly modified) package.
return newPkg;
}
/// Exports
/**
* A pnpmfile allows you to use hooks to modify the behavior of pnpm.
*
* From <https://pnpm.io/pnpmfile>.
*/
module.exports = {
hooks: {
readPackage,
},
};