From 89b5d9431a2778e063c8d60e9361bbcfe36835ef Mon Sep 17 00:00:00 2001 From: Pierrick Gourlain Date: Sat, 1 Jun 2024 18:44:37 +0200 Subject: [PATCH] =?UTF-8?q?resolve=20${workspaceFolder}=20in=20erlang=20co?= =?UTF-8?q?nfiguration=20for=20erlangPath=20and=E2=80=A6=20(#299)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * resolve ${workspaceFolder} in erlang configuration for erlangPath and rebarPath --- .github/workflows/pr-verify.yml | 4 ++- lib/ErlangConfigurationProvider.ts | 51 ++++++++++++++++++++++-------- lib/eunitRunner.ts | 4 +-- lib/extension.ts | 4 ++- lib/lsp/lspclientextension.ts | 12 +++---- 5 files changed, 49 insertions(+), 26 deletions(-) diff --git a/.github/workflows/pr-verify.yml b/.github/workflows/pr-verify.yml index 56da4ff..68c9311 100644 --- a/.github/workflows/pr-verify.yml +++ b/.github/workflows/pr-verify.yml @@ -20,7 +20,9 @@ jobs: node: - 20 steps: - - run: sudo apt-get install erlang + - run: | + sudo apt-get update + sudo apt-get install erlang if: runner.os == 'Linux' - run: | brew install erlang@26 diff --git a/lib/ErlangConfigurationProvider.ts b/lib/ErlangConfigurationProvider.ts index c7b4adf..6792ecd 100644 --- a/lib/ErlangConfigurationProvider.ts +++ b/lib/ErlangConfigurationProvider.ts @@ -1,13 +1,14 @@ -import { - workspace, WorkspaceFolder, DebugConfiguration, DebugConfigurationProvider, CancellationToken, ProviderResult -} from 'vscode'; +import { + workspace, WorkspaceFolder, DebugConfiguration, DebugConfigurationProvider, CancellationToken, ProviderResult, WorkspaceConfiguration +} from 'vscode'; import { ErlangSettings } from './erlangSettings'; +import { stringify } from 'querystring'; //import { ErlangOutput } from './vscodeAdapter'; export class ErlangDebugConfigurationProvider implements DebugConfigurationProvider { provideDebugConfigurations?(folder: WorkspaceFolder | undefined, token?: CancellationToken): ProviderResult { if (folder) { - return []; + return []; } return undefined; } @@ -20,37 +21,59 @@ export class ErlangDebugConfigurationProvider implements DebugConfigurationProvi } }; -let currentSettings : ErlangSettings = null; +let currentSettings: ErlangSettings = null; -export function configurationChanged() : void { +export function configurationChanged(): void { let erlangConf = workspace.getConfiguration("erlang"); - let settings : ErlangSettings = { - erlangPath: erlangConf.get("erlangPath", null), + let settings: ErlangSettings = { + erlangPath: resolveVariables(erlangConf.get("erlangPath", null)), erlangArgs: erlangConf.get("erlangArgs", []), erlangDistributedNode: erlangConf.get("erlangDistributedNode", false), - rebarPath: erlangConf.get("rebarPath", null), + rebarPath: resolveVariables(erlangConf.get("rebarPath", null)), codeLensEnabled: erlangConf.get('codeLensEnabled', false), inlayHintsEnabled: erlangConf.get('inlayHintsEnabled', false), debuggerRunMode: erlangConf.get("debuggerRunMode", "Server"), includePaths: erlangConf.get("includePaths", []), linting: erlangConf.get('linting', false), rebarBuildArgs: erlangConf.get("rebarBuildArgs", ['compile']), - rootPath : extractRootPath(), + rootPath: extractRootPath(), verbose: erlangConf.get("verbose", false) }; currentSettings = settings; } -function extractRootPath() : string { - //workspace.rootPath is deprecated, and documentation notice that value is store in first workspace folder +export function resolveErlangSettings(erlangSection : WorkspaceConfiguration): any { + const erlangconfigAsJson = JSON.stringify(erlangSection); + const erlangConfiguration = JSON.parse(erlangconfigAsJson); + if (erlangConfiguration) { + erlangConfiguration.erlangPath = resolveVariables(erlangConfiguration.erlangPath); + erlangConfiguration.rebarPath = resolveVariables(erlangConfiguration.rebarPath); + } + return erlangConfiguration; +} + +function getFirstWorkspaceFolderPath(): string { let folders = workspace.workspaceFolders; if (folders && folders.length > 0) { return folders[0].uri.fsPath; } - return undefined; + return ""; +} + +function extractRootPath(): string { + const res = getFirstWorkspaceFolderPath(); + return res != "" ? res : undefined; +} + +function resolveVariables(value: string) : string { + //https://code.visualstudio.com/docs/editor/variables-reference#_predefined-variables + if (!value) return value; + value = value.replace('${workspaceFolder}', getFirstWorkspaceFolderPath); + return value; } -export function getElangConfigConfiguration() : ErlangSettings { + +export function getElangConfigConfiguration(): ErlangSettings { if (!currentSettings) { configurationChanged(); // in order to debug diff --git a/lib/eunitRunner.ts b/lib/eunitRunner.ts index 88f51d7..3945467 100644 --- a/lib/eunitRunner.ts +++ b/lib/eunitRunner.ts @@ -165,7 +165,7 @@ function readRebarConfigWithErlangShell(): Thenable { return new Promise((a, r) => { const rootPath = getElangConfigConfiguration().rootPath; var erlangShell = new erlang.ErlangShell(); - erlangShell.erlangPath = vscode.workspace.getConfiguration("erlang").get("erlangPath", null); + erlangShell.erlangPath = getElangConfigConfiguration().erlangPath; erlangShell.Start(rootPath, []).then( _ => { @@ -289,7 +289,7 @@ function compile(compileArgs: CompileArgs): Thenable { }).then(args => { var argsCmd = args.IncludeDirs.concat(["-o", eunitDirectory]).concat(args.ErlangFiles); var erlc = new erlang.ErlangCompilerShell(); - erlc.erlangPath = vscode.workspace.getConfiguration("erlang").get("erlangPath", null); + erlc.erlangPath = getElangConfigConfiguration().erlangPath; return erlc.Start(rootPath, argsCmd.map(x => x.toString())) .then(exitCode => { return args.ErlangFiles; diff --git a/lib/extension.ts b/lib/extension.ts index 0b42ce2..08d92be 100644 --- a/lib/extension.ts +++ b/lib/extension.ts @@ -42,7 +42,9 @@ export function activate(context: ExtensionContext) { eunit.activate(context); disposables.push(debug.registerDebugConfigurationProvider("erlang", new ErlangDebugConfigurationProvider())); - disposables.push(Workspace.onDidChangeConfiguration((e) => configurationChanged())); + disposables.push(Workspace.onDidChangeConfiguration((e) => configurationChanged())); + disposables.push(Workspace.onDidChangeWorkspaceFolders((e) => configurationChanged())); + let runMode = getElangConfigConfiguration().debuggerRunMode; let factory: DebugAdapterDescriptorFactory; switch (runMode) { diff --git a/lib/lsp/lspclientextension.ts b/lib/lsp/lspclientextension.ts index 4422f42..9dd7257 100644 --- a/lib/lsp/lspclientextension.ts +++ b/lib/lsp/lspclientextension.ts @@ -37,7 +37,7 @@ import * as lspRename from './lsp-rename'; // import { ErlangSettings } from '../erlangSettings'; import RebarShell from '../RebarShell'; import { ErlangOutputAdapter } from '../vscodeAdapter'; -import { getElangConfigConfiguration } from '../ErlangConfigurationProvider'; +import { getElangConfigConfiguration, resolveErlangSettings } from '../ErlangConfigurationProvider'; import { ErlangLanguageClient, erlangDocumentSelector } from './lsp-context'; /* @@ -67,8 +67,6 @@ namespace Configuration { // both client and server do use JSON the conversion is trivial. export function computeConfiguration(params: ConfigurationParams, _token: CancellationToken, _next: Function): any[] { - //lspOutputChannel.appendLine("computeConfiguration :"+ JSON.stringify(params)); - if (!params.items) { return null; } @@ -80,6 +78,8 @@ namespace Configuration { autosave: Workspace.getConfiguration("files").get("autoSave", "afterDelay") === "afterDelay", tmpdir: os.tmpdir() }); + } else if (item.section === "erlang") { + result.push(resolveErlangSettings(Workspace.getConfiguration(item.section))) } else { result.push(Workspace.getConfiguration(item.section)); @@ -225,11 +225,7 @@ export function activate(context: ExtensionContext) { didSave: (data: TextDocument, next: (data: TextDocument) => void) => { next(data);//call LSP lspcodelens.onDocumentDidSave(); - }, - // prepareRename: (document, position, token, next) => { - // return Promise.resolve(lspRename.onPrepareRename(document, position, token, next)); - - // }, + }, }; // Options to control the language client let clientOptions: LanguageClientOptions = {