Skip to content

Commit

Permalink
fix: swap toRemove & toAdd in deltaExtensions
Browse files Browse the repository at this point in the history
When we try to remove & add the same extension in a very short
timeframe, it does not get initialized properly because it gets both
added to `toRemove` and `toAdd`. When that happens, the extension is
first added, and then immediately removed. By swapping `toRemove` and
`toAdd` we ensure that the extension is first removed, and then newly
added.
  • Loading branch information
CompuIves committed Nov 7, 2023
1 parent 29f389a commit 0f8c669
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions src/service-override/extensions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -433,14 +433,14 @@ export class SimpleExtensionService extends AbstractExtensionService implements

public async deltaExtensions (toAdd: IExtensionWithExtHostKind[], toRemove: IExtension[]): Promise<void> {
const extHostPicker = (this._extensionHostKindPicker as LocalBrowserExtensionHostKindPicker)
for (const extension of toRemove) {
extHostPicker.removeForcedExtensionHostKind(extension.identifier.id)
}
for (const extension of toAdd) {
if (extension.extHostKind != null) {
extHostPicker.setForcedExtensionHostKind(extension.identifier.id, extension.extHostKind)
}
}
for (const extension of toRemove) {
extHostPicker.removeForcedExtensionHostKind(extension.identifier.id)
}

await this._handleDeltaExtensions(new DeltaExtensionsQueueItem(toAdd, toRemove))
}
Expand Down

0 comments on commit 0f8c669

Please sign in to comment.