summaryrefslogtreecommitdiff
path: root/server/src/server.ts
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/server.ts')
-rw-r--r--server/src/server.ts33
1 files changed, 27 insertions, 6 deletions
diff --git a/server/src/server.ts b/server/src/server.ts
index de62214..4be7e27 100644
--- a/server/src/server.ts
+++ b/server/src/server.ts
@@ -51,6 +51,7 @@ const documents: TextDocuments<TextDocument> = new TextDocuments(TextDocument);
let hasConfigurationCapability = false;
let hasWorkspaceFolderCapability = false;
+let rootUri = '';
connection.onInitialize(async (params: InitializeParams) => {
const capabilities = params.capabilities;
@@ -87,6 +88,11 @@ connection.onInitialize(async (params: InitializeParams) => {
supported: true,
},
};
+ } else {
+ process.stderr.write("No hasWorkspaceFolderCapability in onInitialize().\n");
+ if (params.rootUri!=null) {
+ rootUri = params.rootUri;
+ }
}
await getPerlAssetsPath(); // Ensures assets are unpacked. Should this be in onInitialized?
return result;
@@ -183,15 +189,30 @@ async function dispatchForMods(textDocument: TextDocument) {
}
async function getWorkspaceFoldersSafe(): Promise<WorkspaceFolder[]> {
- try {
- const workspaceFolders = await connection.workspace.getWorkspaceFolders();
- if (!workspaceFolders) {
+ process.stderr.write("Now in getWorkspaceFoldersSafe().\n");
+ if (hasWorkspaceFolderCapability) {
+ process.stderr.write("getWorkspaceFoldersSafe() has hasWorkspaceFolderCapability.\n");
+ try {
+ const workspaceFolders = await connection.workspace.getWorkspaceFolders();
+ if (!workspaceFolders) {
+ return [];
+ } else {
+ return workspaceFolders;
+ }
+ } catch (error) {
return [];
+ }
+ } else {
+ process.stderr.write("No hasWorkspaceFolderCapability in getWorkspaceFoldersSafe() .\n");
+ if (rootUri!=null) {
+ const dummyFolder: WorkspaceFolder = {
+ uri: rootUri,
+ name: rootUri,
+ }
+ return [dummyFolder];
} else {
- return workspaceFolders;
+ return [];
}
- } catch (error) {
- return [];
}
}