From 2dd045b0b4de69c57cb44168f11d2532b9fedb09 Mon Sep 17 00:00:00 2001 From: Heyward Fann Date: Wed, 18 Dec 2024 18:30:55 +0800 Subject: [PATCH] feat(model): resolve languageID for spring-boot Related #5028 A better way is adding a languageID pattern in languageserver/extension configuration, but this needs pass through more layers, needs more works, just made this quickfix for now. --- src/__tests__/modules/document.test.ts | 16 ++++++++++++++++ src/model/document.ts | 11 ++++++++++- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/src/__tests__/modules/document.test.ts b/src/__tests__/modules/document.test.ts index 387eeb8188b..13ad9cc4ec0 100644 --- a/src/__tests__/modules/document.test.ts +++ b/src/__tests__/modules/document.test.ts @@ -188,6 +188,22 @@ describe('Document', () => { await nvim.command(`edit +setl\\ filetype=txt.vim foo`) let doc = await workspace.document expect(doc.languageId).toBe('txt') + + await nvim.command(`edit +setl\\ filetype=jproperties application.properties`) + doc = await workspace.document + expect(doc.languageId).toBe('spring-boot-properties') + + await nvim.command(`edit +setl\\ filetype=jproperties bootstrap.test.properties`) + doc = await workspace.document + expect(doc.languageId).toBe('spring-boot-properties') + + await nvim.command(`edit +setl\\ filetype=yaml application.yml`) + doc = await workspace.document + expect(doc.languageId).toBe('spring-boot-properties-yaml') + + await nvim.command(`edit +setl\\ filetype=yaml application.test.yaml`) + doc = await workspace.document + expect(doc.languageId).toBe('spring-boot-properties-yaml') }) it('should parse iskeyword of character range', async () => { diff --git a/src/model/document.ts b/src/model/document.ts index 9be17cc1ddd..394a42ff2a7 100644 --- a/src/model/document.ts +++ b/src/model/document.ts @@ -128,7 +128,16 @@ export default class Document { */ public get languageId(): string { let { _filetype } = this - return _filetype.includes('.') ? _filetype.match(/(.*?)\./)[1] : _filetype + const ft = _filetype.includes('.') ? _filetype.match(/(.*?)\./)[1] : _filetype + + if (ft === 'jproperties' && /(application|bootstrap).*\.properties$/.test(this._bufname)) { + return 'spring-boot-properties' + } + if (ft === 'yaml' && /(application|bootstrap).*\.ya?ml$/.test(this._bufname)) { + return 'spring-boot-properties-yaml' + } + + return ft } /**