diff --git a/client/src/language/EmbeddedLanguageDocsManager.ts b/client/src/language/EmbeddedLanguageDocsManager.ts index 841b8f49e..da6a66f91 100644 --- a/client/src/language/EmbeddedLanguageDocsManager.ts +++ b/client/src/language/EmbeddedLanguageDocsManager.ts @@ -29,11 +29,19 @@ type EmbeddedLanguageDocsRecord = Partial() // map of original uri to embedded documents infos private _storagePath: string | undefined + private readonly filesWaitingToUpdate = new Map() get storagePath (): string | undefined { return this._storagePath } + get embeddedLanguageDocsFolder (): string | undefined { + if (this._storagePath === undefined) { + return + } + return path.join(this._storagePath, EMBEDDED_DOCUMENTS_FOLDER) + } + async setStoragePath (newStoragePath: string | undefined): Promise { logger.debug(`Set embedded language documents storage path. New: ${newStoragePath}. Old: ${this._storagePath}`) if (this._storagePath === newStoragePath) { @@ -104,13 +112,13 @@ export default class EmbeddedLanguageDocsManager { } private createEmbeddedLanguageDocUri (embeddedLanguageDoc: EmbeddedLanguageDoc): Uri | undefined { - if (this.storagePath === undefined) { + if (this.embeddedLanguageDocsFolder === undefined) { return undefined } const randomName = randomUUID() const fileExtension = fileExtensionsMap[embeddedLanguageDoc.language] const embeddedLanguageDocFilename = randomName + fileExtension - const pathToEmbeddedLanguageDocsFolder = path.join(this.storagePath, EMBEDDED_DOCUMENTS_FOLDER) + const pathToEmbeddedLanguageDocsFolder = this.embeddedLanguageDocsFolder return Uri.parse(`file://${pathToEmbeddedLanguageDocsFolder}/${embeddedLanguageDocFilename}`) } @@ -124,6 +132,10 @@ export default class EmbeddedLanguageDocsManager { private async updateEmbeddedLanguageDocFile (embeddedLanguageDoc: EmbeddedLanguageDoc, uri: Uri): Promise { const document = await workspace.openTextDocument(uri) + if (document.isDirty) { + this.filesWaitingToUpdate.set(uri.toString(), embeddedLanguageDoc) + return + } const fullRange = new Range( document.positionAt(0), document.positionAt(document.getText().length) @@ -133,6 +145,11 @@ export default class EmbeddedLanguageDocsManager { await workspace.applyEdit(workspaceEdit) await document.save() this.registerEmbeddedLanguageDocInfos(embeddedLanguageDoc, uri) + const fileWaitingToUpdate = this.filesWaitingToUpdate.get(uri.toString()) + if (fileWaitingToUpdate !== undefined) { + this.filesWaitingToUpdate.delete(uri.toString()) + await this.updateEmbeddedLanguageDocFile(fileWaitingToUpdate, uri) + } } private async createEmbeddedLanguageDocFile (embeddedLanguageDoc: EmbeddedLanguageDoc): Promise { diff --git a/client/src/language/languageClient.ts b/client/src/language/languageClient.ts index a49df642f..41d993220 100644 --- a/client/src/language/languageClient.ts +++ b/client/src/language/languageClient.ts @@ -10,7 +10,8 @@ import { type ExtensionContext, window, commands, - languages + languages, + TabInputText } from 'vscode' import { @@ -114,6 +115,28 @@ export async function activateLanguageServer (context: ExtensionContext): Promis void embeddedLanguageDocsManager.saveEmbeddedLanguageDocs(embeddedLanguageDocs) }) + window.tabGroups.onDidChangeTabs((event) => { + [...event.opened, ...event.changed].forEach((tab) => { + if (tab.input instanceof TabInputText) { + const uri = tab.input.uri + if (embeddedLanguageDocsManager.embeddedLanguageDocsFolder === undefined) { + return + } + // Close embedded document tabs when they open automatically + if (uri.fsPath.includes(embeddedLanguageDocsManager.embeddedLanguageDocsFolder)) { + if ( + // Prevent prompt to appear on unsaved files + !tab.isDirty && + // Make possible to open embedded documents in a tab + !tab.isPreview && !tab.isActive && !tab.isPinned + ) { + void window.tabGroups.close(tab, false) + } + } + } + }) + }) + // Start the client and launch the server await client.start()