Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/build/lib/compilation.js
3520 views
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 () {
19
var ownKeys = function(o) {
20
ownKeys = Object.getOwnPropertyNames || function (o) {
21
var ar = [];
22
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
return ar;
24
};
25
return ownKeys(o);
26
};
27
return function (mod) {
28
if (mod && mod.__esModule) return mod;
29
var result = {};
30
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
__setModuleDefault(result, mod);
32
return result;
33
};
34
})();
35
var __importDefault = (this && this.__importDefault) || function (mod) {
36
return (mod && mod.__esModule) ? mod : { "default": mod };
37
};
38
Object.defineProperty(exports, "__esModule", { value: true });
39
exports.watchApiProposalNamesTask = exports.compileApiProposalNamesTask = void 0;
40
exports.createCompile = createCompile;
41
exports.transpileTask = transpileTask;
42
exports.compileTask = compileTask;
43
exports.watchTask = watchTask;
44
/*---------------------------------------------------------------------------------------------
45
* Copyright (c) Microsoft Corporation. All rights reserved.
46
* Licensed under the MIT License. See License.txt in the project root for license information.
47
*--------------------------------------------------------------------------------------------*/
48
const event_stream_1 = __importDefault(require("event-stream"));
49
const fs_1 = __importDefault(require("fs"));
50
const gulp_1 = __importDefault(require("gulp"));
51
const path_1 = __importDefault(require("path"));
52
const monacodts = __importStar(require("./monaco-api"));
53
const nls = __importStar(require("./nls"));
54
const reporter_1 = require("./reporter");
55
const util = __importStar(require("./util"));
56
const fancy_log_1 = __importDefault(require("fancy-log"));
57
const ansi_colors_1 = __importDefault(require("ansi-colors"));
58
const os_1 = __importDefault(require("os"));
59
const vinyl_1 = __importDefault(require("vinyl"));
60
const task = __importStar(require("./task"));
61
const index_1 = require("./mangle/index");
62
const ts = require("typescript");
63
const watch = require('./watch');
64
// --- gulp-tsb: compile and transpile --------------------------------
65
const reporter = (0, reporter_1.createReporter)();
66
function getTypeScriptCompilerOptions(src) {
67
const rootDir = path_1.default.join(__dirname, `../../${src}`);
68
const options = {};
69
options.verbose = false;
70
options.sourceMap = true;
71
if (process.env['VSCODE_NO_SOURCEMAP']) { // To be used by developers in a hurry
72
options.sourceMap = false;
73
}
74
options.rootDir = rootDir;
75
options.baseUrl = rootDir;
76
options.sourceRoot = util.toFileUri(rootDir);
77
options.newLine = /\r\n/.test(fs_1.default.readFileSync(__filename, 'utf8')) ? 0 : 1;
78
return options;
79
}
80
function createCompile(src, { build, emitError, transpileOnly, preserveEnglish }) {
81
const tsb = require('./tsb');
82
const sourcemaps = require('gulp-sourcemaps');
83
const projectPath = path_1.default.join(__dirname, '../../', src, 'tsconfig.json');
84
const overrideOptions = { ...getTypeScriptCompilerOptions(src), inlineSources: Boolean(build) };
85
if (!build) {
86
overrideOptions.inlineSourceMap = true;
87
}
88
const compilation = tsb.create(projectPath, overrideOptions, {
89
verbose: false,
90
transpileOnly: Boolean(transpileOnly),
91
transpileWithEsbuild: typeof transpileOnly !== 'boolean' && transpileOnly.esbuild
92
}, err => reporter(err));
93
function pipeline(token) {
94
const bom = require('gulp-bom');
95
const tsFilter = util.filter(data => /\.ts$/.test(data.path));
96
const isUtf8Test = (f) => /(\/|\\)test(\/|\\).*utf8/.test(f.path);
97
const isRuntimeJs = (f) => f.path.endsWith('.js') && !f.path.includes('fixtures');
98
const noDeclarationsFilter = util.filter(data => !(/\.d\.ts$/.test(data.path)));
99
const input = event_stream_1.default.through();
100
const output = input
101
.pipe(util.$if(isUtf8Test, bom())) // this is required to preserve BOM in test files that loose it otherwise
102
.pipe(util.$if(!build && isRuntimeJs, util.appendOwnPathSourceURL()))
103
.pipe(tsFilter)
104
.pipe(util.loadSourcemaps())
105
.pipe(compilation(token))
106
.pipe(noDeclarationsFilter)
107
.pipe(util.$if(build, nls.nls({ preserveEnglish })))
108
.pipe(noDeclarationsFilter.restore)
109
.pipe(util.$if(!transpileOnly, sourcemaps.write('.', {
110
addComment: false,
111
includeContent: !!build,
112
sourceRoot: overrideOptions.sourceRoot
113
})))
114
.pipe(tsFilter.restore)
115
.pipe(reporter.end(!!emitError));
116
return event_stream_1.default.duplex(input, output);
117
}
118
pipeline.tsProjectSrc = () => {
119
return compilation.src({ base: src });
120
};
121
pipeline.projectPath = projectPath;
122
return pipeline;
123
}
124
function transpileTask(src, out, esbuild) {
125
const task = () => {
126
const transpile = createCompile(src, { build: false, emitError: true, transpileOnly: { esbuild: !!esbuild }, preserveEnglish: false });
127
const srcPipe = gulp_1.default.src(`${src}/**`, { base: `${src}` });
128
return srcPipe
129
.pipe(transpile())
130
.pipe(gulp_1.default.dest(out));
131
};
132
task.taskName = `transpile-${path_1.default.basename(src)}`;
133
return task;
134
}
135
function compileTask(src, out, build, options = {}) {
136
const task = () => {
137
if (os_1.default.totalmem() < 4_000_000_000) {
138
throw new Error('compilation requires 4GB of RAM');
139
}
140
const compile = createCompile(src, { build, emitError: true, transpileOnly: false, preserveEnglish: !!options.preserveEnglish });
141
const srcPipe = gulp_1.default.src(`${src}/**`, { base: `${src}` });
142
const generator = new MonacoGenerator(false);
143
if (src === 'src') {
144
generator.execute();
145
}
146
// mangle: TypeScript to TypeScript
147
let mangleStream = event_stream_1.default.through();
148
if (build && !options.disableMangle) {
149
let ts2tsMangler = new index_1.Mangler(compile.projectPath, (...data) => (0, fancy_log_1.default)(ansi_colors_1.default.blue('[mangler]'), ...data), { mangleExports: true, manglePrivateFields: true });
150
const newContentsByFileName = ts2tsMangler.computeNewFileContents(new Set(['saveState']));
151
mangleStream = event_stream_1.default.through(async function write(data) {
152
const tsNormalPath = ts.normalizePath(data.path);
153
const newContents = (await newContentsByFileName).get(tsNormalPath);
154
if (newContents !== undefined) {
155
data.contents = Buffer.from(newContents.out);
156
data.sourceMap = newContents.sourceMap && JSON.parse(newContents.sourceMap);
157
}
158
this.push(data);
159
}, async function end() {
160
// free resources
161
(await newContentsByFileName).clear();
162
this.push(null);
163
ts2tsMangler = undefined;
164
});
165
}
166
return srcPipe
167
.pipe(mangleStream)
168
.pipe(generator.stream)
169
.pipe(compile())
170
.pipe(gulp_1.default.dest(out));
171
};
172
task.taskName = `compile-${path_1.default.basename(src)}`;
173
return task;
174
}
175
function watchTask(out, build, srcPath = 'src') {
176
const task = () => {
177
const compile = createCompile(srcPath, { build, emitError: false, transpileOnly: false, preserveEnglish: false });
178
const src = gulp_1.default.src(`${srcPath}/**`, { base: srcPath });
179
const watchSrc = watch(`${srcPath}/**`, { base: srcPath, readDelay: 200 });
180
const generator = new MonacoGenerator(true);
181
generator.execute();
182
return watchSrc
183
.pipe(generator.stream)
184
.pipe(util.incremental(compile, src, true))
185
.pipe(gulp_1.default.dest(out));
186
};
187
task.taskName = `watch-${path_1.default.basename(out)}`;
188
return task;
189
}
190
const REPO_SRC_FOLDER = path_1.default.join(__dirname, '../../src');
191
class MonacoGenerator {
192
_isWatch;
193
stream;
194
_watchedFiles;
195
_fsProvider;
196
_declarationResolver;
197
constructor(isWatch) {
198
this._isWatch = isWatch;
199
this.stream = event_stream_1.default.through();
200
this._watchedFiles = {};
201
const onWillReadFile = (moduleId, filePath) => {
202
if (!this._isWatch) {
203
return;
204
}
205
if (this._watchedFiles[filePath]) {
206
return;
207
}
208
this._watchedFiles[filePath] = true;
209
fs_1.default.watchFile(filePath, () => {
210
this._declarationResolver.invalidateCache(moduleId);
211
this._executeSoon();
212
});
213
};
214
this._fsProvider = new class extends monacodts.FSProvider {
215
readFileSync(moduleId, filePath) {
216
onWillReadFile(moduleId, filePath);
217
return super.readFileSync(moduleId, filePath);
218
}
219
};
220
this._declarationResolver = new monacodts.DeclarationResolver(this._fsProvider);
221
if (this._isWatch) {
222
fs_1.default.watchFile(monacodts.RECIPE_PATH, () => {
223
this._executeSoon();
224
});
225
}
226
}
227
_executeSoonTimer = null;
228
_executeSoon() {
229
if (this._executeSoonTimer !== null) {
230
clearTimeout(this._executeSoonTimer);
231
this._executeSoonTimer = null;
232
}
233
this._executeSoonTimer = setTimeout(() => {
234
this._executeSoonTimer = null;
235
this.execute();
236
}, 20);
237
}
238
_run() {
239
const r = monacodts.run3(this._declarationResolver);
240
if (!r && !this._isWatch) {
241
// The build must always be able to generate the monaco.d.ts
242
throw new Error(`monaco.d.ts generation error - Cannot continue`);
243
}
244
return r;
245
}
246
_log(message, ...rest) {
247
(0, fancy_log_1.default)(ansi_colors_1.default.cyan('[monaco.d.ts]'), message, ...rest);
248
}
249
execute() {
250
const startTime = Date.now();
251
const result = this._run();
252
if (!result) {
253
// nothing really changed
254
return;
255
}
256
if (result.isTheSame) {
257
return;
258
}
259
fs_1.default.writeFileSync(result.filePath, result.content);
260
fs_1.default.writeFileSync(path_1.default.join(REPO_SRC_FOLDER, 'vs/editor/common/standalone/standaloneEnums.ts'), result.enums);
261
this._log(`monaco.d.ts is changed - total time took ${Date.now() - startTime} ms`);
262
if (!this._isWatch) {
263
this.stream.emit('error', 'monaco.d.ts is no longer up to date. Please run gulp watch and commit the new file.');
264
}
265
}
266
}
267
function generateApiProposalNames() {
268
let eol;
269
try {
270
const src = fs_1.default.readFileSync('src/vs/platform/extensions/common/extensionsApiProposals.ts', 'utf-8');
271
const match = /\r?\n/m.exec(src);
272
eol = match ? match[0] : os_1.default.EOL;
273
}
274
catch {
275
eol = os_1.default.EOL;
276
}
277
const pattern = /vscode\.proposed\.([a-zA-Z\d]+)\.d\.ts$/;
278
const versionPattern = /^\s*\/\/\s*version\s*:\s*(\d+)\s*$/mi;
279
const proposals = new Map();
280
const input = event_stream_1.default.through();
281
const output = input
282
.pipe(util.filter((f) => pattern.test(f.path)))
283
.pipe(event_stream_1.default.through((f) => {
284
const name = path_1.default.basename(f.path);
285
const match = pattern.exec(name);
286
if (!match) {
287
return;
288
}
289
const proposalName = match[1];
290
const contents = f.contents.toString('utf8');
291
const versionMatch = versionPattern.exec(contents);
292
const version = versionMatch ? versionMatch[1] : undefined;
293
proposals.set(proposalName, {
294
proposal: `https://raw.githubusercontent.com/microsoft/vscode/main/src/vscode-dts/vscode.proposed.${proposalName}.d.ts`,
295
version: version ? parseInt(version) : undefined
296
});
297
}, function () {
298
const names = [...proposals.keys()].sort();
299
const contents = [
300
'/*---------------------------------------------------------------------------------------------',
301
' * Copyright (c) Microsoft Corporation. All rights reserved.',
302
' * Licensed under the MIT License. See License.txt in the project root for license information.',
303
' *--------------------------------------------------------------------------------------------*/',
304
'',
305
'// THIS IS A GENERATED FILE. DO NOT EDIT DIRECTLY.',
306
'',
307
'const _allApiProposals = {',
308
`${names.map(proposalName => {
309
const proposal = proposals.get(proposalName);
310
return `\t${proposalName}: {${eol}\t\tproposal: '${proposal.proposal}',${eol}${proposal.version ? `\t\tversion: ${proposal.version}${eol}` : ''}\t}`;
311
}).join(`,${eol}`)}`,
312
'};',
313
'export const allApiProposals = Object.freeze<{ [proposalName: string]: Readonly<{ proposal: string; version?: number }> }>(_allApiProposals);',
314
'export type ApiProposalName = keyof typeof _allApiProposals;',
315
'',
316
].join(eol);
317
this.emit('data', new vinyl_1.default({
318
path: 'vs/platform/extensions/common/extensionsApiProposals.ts',
319
contents: Buffer.from(contents)
320
}));
321
this.emit('end');
322
}));
323
return event_stream_1.default.duplex(input, output);
324
}
325
const apiProposalNamesReporter = (0, reporter_1.createReporter)('api-proposal-names');
326
exports.compileApiProposalNamesTask = task.define('compile-api-proposal-names', () => {
327
return gulp_1.default.src('src/vscode-dts/**')
328
.pipe(generateApiProposalNames())
329
.pipe(gulp_1.default.dest('src'))
330
.pipe(apiProposalNamesReporter.end(true));
331
});
332
exports.watchApiProposalNamesTask = task.define('watch-api-proposal-names', () => {
333
const task = () => gulp_1.default.src('src/vscode-dts/**')
334
.pipe(generateApiProposalNames())
335
.pipe(apiProposalNamesReporter.end(true));
336
return watch('src/vscode-dts/**', { readDelay: 200 })
337
.pipe(util.debounce(task))
338
.pipe(gulp_1.default.dest('src'));
339
});
340
//# sourceMappingURL=compilation.js.map
341