From 367d5f39bd888fba48ddf3fde389f48c4ad907a8 Mon Sep 17 00:00:00 2001 From: Georg Schwarz Date: Thu, 24 Oct 2024 10:13:21 +0200 Subject: [PATCH 1/2] Replicate logic to get file path like in Langium to fix Windows file path issues --- libs/interpreter-lib/src/parsing-util.ts | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/libs/interpreter-lib/src/parsing-util.ts b/libs/interpreter-lib/src/parsing-util.ts index f3b1473d..e12fd97e 100644 --- a/libs/interpreter-lib/src/parsing-util.ts +++ b/libs/interpreter-lib/src/parsing-util.ts @@ -10,7 +10,7 @@ import { type JayveeServices, initializeWorkspace, } from '@jvalue/jayvee-language-server'; -import { type AstNode, type LangiumDocument } from 'langium'; +import { type AstNode, type LangiumDocument, UriUtils } from 'langium'; import { type LangiumServices } from 'langium/lsp'; import { DiagnosticSeverity } from 'vscode-languageserver-protocol'; import { URI } from 'vscode-uri'; @@ -44,9 +44,9 @@ export async function extractDocumentFromFile( return Promise.reject(ExitCode.FAILURE); } - const document = services.shared.workspace.LangiumDocuments.getDocument( - URI.file(path.resolve(filePath)), - ); + const fileUri = getFileUriLikeLangiumImpl(filePath); + const document = + services.shared.workspace.LangiumDocuments.getDocument(fileUri); if (document === undefined) { logger.logErr(`Did not load file ${filePath} correctly.`); return Promise.reject(ExitCode.FAILURE); @@ -55,6 +55,20 @@ export async function extractDocumentFromFile( return await validateDocument(document, services, logger); } +/** + * Creates the URI for a file path in a way similar to Langium. + * This is necessary to make sure that the document lookup works on Windows. + * Fixed https://github.com/jvalue/jayvee/issues/623. + * Workaround needs to be removed once the issue is fixed in Langium: + * https://github.com/eclipse-langium/langium/issues/1725 + */ +function getFileUriLikeLangiumImpl(filePath: string): URI { + const folderPath = path.dirname(filePath); + const folderUri = URI.parse(path.resolve(folderPath)); + const fileName = path.basename(filePath); + return UriUtils.joinPath(folderUri, fileName); +} + /** * Extracts a document from a string that contains a model. * Does not load an additional working directory. From 9fd22505b60b1f1a0d214d99a4141f36f15a7752 Mon Sep 17 00:00:00 2001 From: Georg Schwarz Date: Thu, 24 Oct 2024 10:13:36 +0200 Subject: [PATCH 2/2] Bump version to 0.6.3 --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 187de8da..18b1969b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "jayvee", - "version": "0.6.2", + "version": "0.6.3", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "jayvee", - "version": "0.6.2", + "version": "0.6.3", "dependencies": { "@docusaurus/core": "2.4.1", "@docusaurus/preset-classic": "2.4.1", diff --git a/package.json b/package.json index 433944b1..6a40d83c 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "jayvee", - "version": "0.6.2", + "version": "0.6.3", "scripts": { "nx": "nx", "format": "nx format:write",