Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/build/lib/builtInExtensions.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.getExtensionStream = getExtensionStream;
40
exports.getBuiltInExtensions = getBuiltInExtensions;
41
/*---------------------------------------------------------------------------------------------
42
* Copyright (c) Microsoft Corporation. All rights reserved.
43
* Licensed under the MIT License. See License.txt in the project root for license information.
44
*--------------------------------------------------------------------------------------------*/
45
const fs_1 = __importDefault(require("fs"));
46
const path_1 = __importDefault(require("path"));
47
const os_1 = __importDefault(require("os"));
48
const rimraf_1 = __importDefault(require("rimraf"));
49
const event_stream_1 = __importDefault(require("event-stream"));
50
const gulp_rename_1 = __importDefault(require("gulp-rename"));
51
const vinyl_fs_1 = __importDefault(require("vinyl-fs"));
52
const ext = __importStar(require("./extensions"));
53
const fancy_log_1 = __importDefault(require("fancy-log"));
54
const ansi_colors_1 = __importDefault(require("ansi-colors"));
55
const root = path_1.default.dirname(path_1.default.dirname(__dirname));
56
const productjson = JSON.parse(fs_1.default.readFileSync(path_1.default.join(__dirname, '../../product.json'), 'utf8'));
57
const builtInExtensions = productjson.builtInExtensions || [];
58
const webBuiltInExtensions = productjson.webBuiltInExtensions || [];
59
const controlFilePath = path_1.default.join(os_1.default.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
60
const ENABLE_LOGGING = !process.env['VSCODE_BUILD_BUILTIN_EXTENSIONS_SILENCE_PLEASE'];
61
function log(...messages) {
62
if (ENABLE_LOGGING) {
63
(0, fancy_log_1.default)(...messages);
64
}
65
}
66
function getExtensionPath(extension) {
67
return path_1.default.join(root, '.build', 'builtInExtensions', extension.name);
68
}
69
function isUpToDate(extension) {
70
const packagePath = path_1.default.join(getExtensionPath(extension), 'package.json');
71
if (!fs_1.default.existsSync(packagePath)) {
72
return false;
73
}
74
const packageContents = fs_1.default.readFileSync(packagePath, { encoding: 'utf8' });
75
try {
76
const diskVersion = JSON.parse(packageContents).version;
77
return (diskVersion === extension.version);
78
}
79
catch (err) {
80
return false;
81
}
82
}
83
function getExtensionDownloadStream(extension) {
84
let input;
85
if (extension.vsix) {
86
input = ext.fromVsix(path_1.default.join(root, extension.vsix), extension);
87
}
88
else if (productjson.extensionsGallery?.serviceUrl) {
89
input = ext.fromMarketplace(productjson.extensionsGallery.serviceUrl, extension);
90
}
91
else {
92
input = ext.fromGithub(extension);
93
}
94
return input.pipe((0, gulp_rename_1.default)(p => p.dirname = `${extension.name}/${p.dirname}`));
95
}
96
function getExtensionStream(extension) {
97
// if the extension exists on disk, use those files instead of downloading anew
98
if (isUpToDate(extension)) {
99
log('[extensions]', `${extension.name}@${extension.version} up to date`, ansi_colors_1.default.green('✔︎'));
100
return vinyl_fs_1.default.src(['**'], { cwd: getExtensionPath(extension), dot: true })
101
.pipe((0, gulp_rename_1.default)(p => p.dirname = `${extension.name}/${p.dirname}`));
102
}
103
return getExtensionDownloadStream(extension);
104
}
105
function syncMarketplaceExtension(extension) {
106
const galleryServiceUrl = productjson.extensionsGallery?.serviceUrl;
107
const source = ansi_colors_1.default.blue(galleryServiceUrl ? '[marketplace]' : '[github]');
108
if (isUpToDate(extension)) {
109
log(source, `${extension.name}@${extension.version}`, ansi_colors_1.default.green('✔︎'));
110
return event_stream_1.default.readArray([]);
111
}
112
rimraf_1.default.sync(getExtensionPath(extension));
113
return getExtensionDownloadStream(extension)
114
.pipe(vinyl_fs_1.default.dest('.build/builtInExtensions'))
115
.on('end', () => log(source, extension.name, ansi_colors_1.default.green('✔︎')));
116
}
117
function syncExtension(extension, controlState) {
118
if (extension.platforms) {
119
const platforms = new Set(extension.platforms);
120
if (!platforms.has(process.platform)) {
121
log(ansi_colors_1.default.gray('[skip]'), `${extension.name}@${extension.version}: Platform '${process.platform}' not supported: [${extension.platforms}]`, ansi_colors_1.default.green('✔︎'));
122
return event_stream_1.default.readArray([]);
123
}
124
}
125
switch (controlState) {
126
case 'disabled':
127
log(ansi_colors_1.default.blue('[disabled]'), ansi_colors_1.default.gray(extension.name));
128
return event_stream_1.default.readArray([]);
129
case 'marketplace':
130
return syncMarketplaceExtension(extension);
131
default:
132
if (!fs_1.default.existsSync(controlState)) {
133
log(ansi_colors_1.default.red(`Error: Built-in extension '${extension.name}' is configured to run from '${controlState}' but that path does not exist.`));
134
return event_stream_1.default.readArray([]);
135
}
136
else if (!fs_1.default.existsSync(path_1.default.join(controlState, 'package.json'))) {
137
log(ansi_colors_1.default.red(`Error: Built-in extension '${extension.name}' is configured to run from '${controlState}' but there is no 'package.json' file in that directory.`));
138
return event_stream_1.default.readArray([]);
139
}
140
log(ansi_colors_1.default.blue('[local]'), `${extension.name}: ${ansi_colors_1.default.cyan(controlState)}`, ansi_colors_1.default.green('✔︎'));
141
return event_stream_1.default.readArray([]);
142
}
143
}
144
function readControlFile() {
145
try {
146
return JSON.parse(fs_1.default.readFileSync(controlFilePath, 'utf8'));
147
}
148
catch (err) {
149
return {};
150
}
151
}
152
function writeControlFile(control) {
153
fs_1.default.mkdirSync(path_1.default.dirname(controlFilePath), { recursive: true });
154
fs_1.default.writeFileSync(controlFilePath, JSON.stringify(control, null, 2));
155
}
156
function getBuiltInExtensions() {
157
log('Synchronizing built-in extensions...');
158
log(`You can manage built-in extensions with the ${ansi_colors_1.default.cyan('--builtin')} flag`);
159
const control = readControlFile();
160
const streams = [];
161
for (const extension of [...builtInExtensions, ...webBuiltInExtensions]) {
162
const controlState = control[extension.name] || 'marketplace';
163
control[extension.name] = controlState;
164
streams.push(syncExtension(extension, controlState));
165
}
166
writeControlFile(control);
167
return new Promise((resolve, reject) => {
168
event_stream_1.default.merge(streams)
169
.on('error', reject)
170
.on('end', resolve);
171
});
172
}
173
if (require.main === module) {
174
getBuiltInExtensions().then(() => process.exit(0)).catch(err => {
175
console.error(err);
176
process.exit(1);
177
});
178
}
179
//# sourceMappingURL=builtInExtensions.js.map
180