Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/main'
Browse files Browse the repository at this point in the history
  • Loading branch information
dabreadman committed Sep 30, 2024
2 parents c1713c9 + c295ef3 commit 24444c4
Show file tree
Hide file tree
Showing 112 changed files with 1,425 additions and 2,022 deletions.
22 changes: 20 additions & 2 deletions .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -948,6 +948,7 @@
"vs/workbench/~",
"vs/workbench/services/*/~",
"vs/workbench/contrib/*/~",
"vs/workbench/contrib/terminal/terminalContribChatExports*",
"vs/workbench/contrib/terminal/terminalContribExports*",
"vscode-notebook-renderer", // Type only import
"@vscode/tree-sitter-wasm", // type import
Expand Down Expand Up @@ -979,7 +980,6 @@
// Only allow terminalContrib to import from itself, this works because
// terminalContrib is one extra folder deep
"vs/workbench/contrib/terminalContrib/*/~",
"vs/workbench/contrib/terminal/terminalContribExports*",
"vscode-notebook-renderer", // Type only import
{
"when": "hasBrowser",
Expand Down Expand Up @@ -1043,10 +1043,18 @@
"vs/workbench/contrib/**"
]
},
{
"target": "src/vs/workbench/contrib/terminal/terminalContribChatExports.ts",
"layer": "browser",
"restrictions": [
"vs/workbench/contrib/terminalContrib/*/~"
]
},
{
"target": "src/vs/workbench/contrib/terminal/terminalContribExports.ts",
"layer": "browser",
"restrictions": [
"vs/platform/*/~",
"vs/workbench/contrib/terminalContrib/*/~"
]
},
Expand Down Expand Up @@ -1133,8 +1141,18 @@
"restrictions": []
},
{
"target": "src/{bootstrap-cli.ts,bootstrap-esm.ts,bootstrap-fork.ts,bootstrap-node.ts,bootstrap-import.ts,bootstrap-meta.ts,bootstrap-window.ts,cli.ts,main.ts,server-cli.ts,server-main.ts,bootstrap-server.ts}",
"target": "src/bootstrap-window.ts",
"restrictions": []
},
{
"target": "src/{bootstrap-cli.ts,bootstrap-esm.ts,bootstrap-fork.ts,bootstrap-import.ts,bootstrap-meta.ts,bootstrap-node.ts,bootstrap-server.ts,cli.ts,main.ts,server-cli.ts,server-main.ts}",
"restrictions": [
"vs/**/common/*",
"vs/**/node/*",
"vs/nls.js",
"src/*.js",
"*" // node.js
]
}
]
}
Expand Down
21 changes: 9 additions & 12 deletions build/buildfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,20 +26,17 @@ function createModuleDescription(name, exclude) {
* @param {string} name
*/
function createEditorWorkerModuleDescription(name) {
const description = createModuleDescription(name, ['vs/base/common/worker/simpleWorker', 'vs/editor/common/services/editorSimpleWorker']);
description.name = `${description.name}.esm`;

return description;
return createModuleDescription(name, ['vs/base/common/worker/simpleWorker', 'vs/editor/common/services/editorSimpleWorker']);
}

exports.workerEditor = createEditorWorkerModuleDescription('vs/editor/common/services/editorSimpleWorker');
exports.workerExtensionHost = createEditorWorkerModuleDescription('vs/workbench/api/worker/extensionHostWorker');
exports.workerNotebook = createEditorWorkerModuleDescription('vs/workbench/contrib/notebook/common/services/notebookSimpleWorker');
exports.workerLanguageDetection = createEditorWorkerModuleDescription('vs/workbench/services/languageDetection/browser/languageDetectionSimpleWorker');
exports.workerLocalFileSearch = createEditorWorkerModuleDescription('vs/workbench/services/search/worker/localFileSearch');
exports.workerProfileAnalysis = createEditorWorkerModuleDescription('vs/platform/profiling/electron-sandbox/profileAnalysisWorker');
exports.workerOutputLinks = createEditorWorkerModuleDescription('vs/workbench/contrib/output/common/outputLinkComputer');
exports.workerBackgroundTokenization = createEditorWorkerModuleDescription('vs/workbench/services/textMate/browser/backgroundTokenization/worker/textMateTokenizationWorker.worker');
exports.workerEditor = createEditorWorkerModuleDescription('vs/editor/common/services/editorSimpleWorkerMain');
exports.workerExtensionHost = createEditorWorkerModuleDescription('vs/workbench/api/worker/extensionHostWorkerMain');
exports.workerNotebook = createEditorWorkerModuleDescription('vs/workbench/contrib/notebook/common/services/notebookSimpleWorkerMain');
exports.workerLanguageDetection = createEditorWorkerModuleDescription('vs/workbench/services/languageDetection/browser/languageDetectionSimpleWorkerMain');
exports.workerLocalFileSearch = createEditorWorkerModuleDescription('vs/workbench/services/search/worker/localFileSearchMain');
exports.workerProfileAnalysis = createEditorWorkerModuleDescription('vs/platform/profiling/electron-sandbox/profileAnalysisWorkerMain');
exports.workerOutputLinks = createEditorWorkerModuleDescription('vs/workbench/contrib/output/common/outputLinkComputerMain');
exports.workerBackgroundTokenization = createEditorWorkerModuleDescription('vs/workbench/services/textMate/browser/backgroundTokenization/worker/textMateTokenizationWorker.workerMain');

exports.workbenchDesktop = [
createModuleDescription('vs/workbench/contrib/debug/node/telemetryApp'),
Expand Down
10 changes: 2 additions & 8 deletions build/eslint.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,11 @@ const vfs = require('vinyl-fs');
const { eslintFilter } = require('./filters');

function eslint() {
const gulpeslint = require('gulp-eslint');
const eslint = require('./gulp-eslint');
return vfs
.src(eslintFilter, { base: '.', follow: true, allowEmpty: true })
.pipe(
gulpeslint({
configFile: '.eslintrc.json'
})
)
.pipe(gulpeslint.formatEach('compact'))
.pipe(
gulpeslint.results((results) => {
eslint((results) => {
if (results.warningCount > 0 || results.errorCount > 0) {
throw new Error('eslint failed with warnings and/or errors');
}
Expand Down
78 changes: 78 additions & 0 deletions build/gulp-eslint.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/

'use strict';

const { ESLint } = require('eslint');
const { Transform } = require('stream');
const { relative } = require('path');
const fancyLog = require('fancy-log');

/**
* @param {Function} action - A function to handle all ESLint results
* @returns {stream} gulp file stream
*/
function eslint(action) {
const linter = new ESLint();
const formatter = linter.loadFormatter('compact');

const results = [];
results.errorCount = 0;
results.warningCount = 0;

return transform(
async (file, enc, cb) => {
const filePath = relative(process.cwd(), file.path);

if (file.isNull()) {
cb(null, file);
return;
}

if (file.isStream()) {
cb(new Error('vinyl files with Stream contents are not supported'));
return;
}

try {
// TODO: Should this be checked?
if (await linter.isPathIgnored(filePath)) {
cb(null, file);
return;
}

const result = (await linter.lintText(file.contents.toString(), { filePath }))[0];
results.push(result);
results.errorCount += result.errorCount;
results.warningCount += result.warningCount;

const message = (await formatter).format([result]);
if (message) {
fancyLog(message);
}
cb(null, file);
} catch (error) {
cb(error);
}
},
(done) => {
try {
action(results);
done();
} catch (error) {
done(error);
}
});
}

function transform(transform, flush) {
return new Transform({
objectMode: true,
transform,
flush
});
}

module.exports = eslint;
10 changes: 2 additions & 8 deletions build/hygiene.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ const copyrightHeaderLines = [
];

function hygiene(some, linting = true) {
const gulpeslint = require('gulp-eslint');
const eslint = require('./gulp-eslint');
const gulpstylelint = require('./stylelint');
const formatter = require('./lib/formatter');

Expand Down Expand Up @@ -172,13 +172,7 @@ function hygiene(some, linting = true) {
result
.pipe(filter(eslintFilter))
.pipe(
gulpeslint({
configFile: '.eslintrc.json'
})
)
.pipe(gulpeslint.formatEach('compact'))
.pipe(
gulpeslint.results((results) => {
eslint((results) => {
errorCount += results.warningCount;
errorCount += results.errorCount;
})
Expand Down
13 changes: 10 additions & 3 deletions build/lib/stylelint/vscode-known-variables.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,10 @@
"--vscode-activityBarTop-dropBorder",
"--vscode-activityBarTop-foreground",
"--vscode-activityBarTop-inactiveForeground",
"--vscode-activityErrorBadge-background",
"--vscode-activityErrorBadge-foreground",
"--vscode-activityWarningBadge-background",
"--vscode-activityWarningBadge-foreground",
"--vscode-badge-background",
"--vscode-badge-foreground",
"--vscode-banner-background",
Expand Down Expand Up @@ -150,6 +154,7 @@
"--vscode-editor-placeholder-foreground",
"--vscode-editor-rangeHighlightBackground",
"--vscode-editor-rangeHighlightBorder",
"--vscode-editor-compositionBorder",
"--vscode-editor-selectionBackground",
"--vscode-editor-selectionForeground",
"--vscode-editor-selectionHighlightBackground",
Expand Down Expand Up @@ -546,14 +551,16 @@
"--vscode-scmGraph-foreground1",
"--vscode-scmGraph-foreground2",
"--vscode-scmGraph-foreground3",
"--vscode-scmGraph-foreground4",
"--vscode-scmGraph-foreground5",
"--vscode-scmGraph-historyItemBaseRefColor",
"--vscode-scmGraph-historyItemRefColor",
"--vscode-scmGraph-historyItemRemoteRefColor",
"--vscode-scmGraph-historyItemHoverAdditionsForeground",
"--vscode-scmGraph-historyItemHoverDefaultLabelBackground",
"--vscode-scmGraph-historyItemHoverDefaultLabelForeground",
"--vscode-scmGraph-historyItemHoverDeletionsForeground",
"--vscode-scmGraph-historyItemHoverLabelForeground",
"--vscode-scmGraph-historyItemRefColor",
"--vscode-scmGraph-historyItemRemoteRefColor",
"--vscode-scrollbar-shadow",
"--vscode-scrollbarSlider-activeBackground",
"--vscode-scrollbarSlider-background",
Expand Down Expand Up @@ -881,4 +888,4 @@
"--widget-color",
"--text-link-decoration"
]
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,20 +12,20 @@ export class ActiveLineMarker {
this._update(previous && (previous.codeElement || previous.element));
}

_update(before: HTMLElement | undefined) {
private _update(before: HTMLElement | undefined) {
this._unmarkActiveElement(this._current);
this._markActiveElement(before);
this._current = before;
}

_unmarkActiveElement(element: HTMLElement | undefined) {
private _unmarkActiveElement(element: HTMLElement | undefined) {
if (!element) {
return;
}
element.classList.toggle('code-active-line', false);
}

_markActiveElement(element: HTMLElement | undefined) {
private _markActiveElement(element: HTMLElement | undefined) {
if (!element) {
return;
}
Expand Down
34 changes: 17 additions & 17 deletions extensions/markdown-language-features/preview-src/csp.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,45 +11,45 @@ import { getStrings } from './strings';
* Shows an alert when there is a content security policy violation.
*/
export class CspAlerter {
private didShow = false;
private didHaveCspWarning = false;
private _didShow = false;
private _didHaveCspWarning = false;

private messaging?: MessagePoster;
private _messaging?: MessagePoster;

constructor(
private readonly settingsManager: SettingsManager,
private readonly _settingsManager: SettingsManager,
) {
document.addEventListener('securitypolicyviolation', () => {
this.onCspWarning();
this._onCspWarning();
});

window.addEventListener('message', (event) => {
if (event && event.data && event.data.name === 'vscode-did-block-svg') {
this.onCspWarning();
this._onCspWarning();
}
});
}

public setPoster(poster: MessagePoster) {
this.messaging = poster;
if (this.didHaveCspWarning) {
this.showCspWarning();
this._messaging = poster;
if (this._didHaveCspWarning) {
this._showCspWarning();
}
}

private onCspWarning() {
this.didHaveCspWarning = true;
this.showCspWarning();
private _onCspWarning() {
this._didHaveCspWarning = true;
this._showCspWarning();
}

private showCspWarning() {
private _showCspWarning() {
const strings = getStrings();
const settings = this.settingsManager.settings;
const settings = this._settingsManager.settings;

if (this.didShow || settings.disableSecurityWarnings || !this.messaging) {
if (this._didShow || settings.disableSecurityWarnings || !this._messaging) {
return;
}
this.didShow = true;
this._didShow = true;

const notification = document.createElement('a');
notification.innerText = strings.cspAlertMessageText;
Expand All @@ -59,7 +59,7 @@ export class CspAlerter {
notification.setAttribute('role', 'button');
notification.setAttribute('aria-label', strings.cspAlertMessageLabel);
notification.onclick = () => {
this.messaging!.postMessage('showPreviewSecuritySelector', { source: settings.source });
this._messaging!.postMessage('showPreviewSecuritySelector', { source: settings.source });
};
document.body.appendChild(notification);
}
Expand Down
20 changes: 10 additions & 10 deletions extensions/markdown-language-features/preview-src/loading.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,15 @@
import { MessagePoster } from './messaging';

export class StyleLoadingMonitor {
private unloadedStyles: string[] = [];
private finishedLoading: boolean = false;
private _unloadedStyles: string[] = [];
private _finishedLoading: boolean = false;

private poster?: MessagePoster;
private _poster?: MessagePoster;

constructor() {
const onStyleLoadError = (event: any) => {
const source = event.target.dataset.source;
this.unloadedStyles.push(source);
this._unloadedStyles.push(source);
};

window.addEventListener('DOMContentLoaded', () => {
Expand All @@ -25,18 +25,18 @@ export class StyleLoadingMonitor {
});

window.addEventListener('load', () => {
if (!this.unloadedStyles.length) {
if (!this._unloadedStyles.length) {
return;
}
this.finishedLoading = true;
this.poster?.postMessage('previewStyleLoadError', { unloadedStyles: this.unloadedStyles });
this._finishedLoading = true;
this._poster?.postMessage('previewStyleLoadError', { unloadedStyles: this._unloadedStyles });
});
}

public setPoster(poster: MessagePoster): void {
this.poster = poster;
if (this.finishedLoading) {
poster.postMessage('previewStyleLoadError', { unloadedStyles: this.unloadedStyles });
this._poster = poster;
if (this._finishedLoading) {
poster.postMessage('previewStyleLoadError', { unloadedStyles: this._unloadedStyles });
}
}
}
Loading

0 comments on commit 24444c4

Please sign in to comment.