@algosail/lsp 0.1.1 → 0.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +2 -2
- package/lib/completion.js +3 -3
- package/lib/validate.js +5 -5
- package/package.json +1 -1
package/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
2
|
+
import { createRequire } from 'module'
|
|
3
3
|
// import path from 'path'
|
|
4
|
-
import { createConnection, ProposedFeatures } from 'vscode-languageserver
|
|
4
|
+
import { createConnection, ProposedFeatures, TextDocumentSyncKind } from 'vscode-languageserver'
|
|
5
5
|
import { createParser } from '@algosail/parser'
|
|
6
6
|
|
|
7
7
|
import { validateDocument } from './lib/validate.js'
|
package/lib/completion.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CompletionItemKind } from 'vscode-languageserver
|
|
1
|
+
import { CompletionItemKind } from 'vscode-languageserver'
|
|
2
2
|
import { MarkupKind } from 'vscode-languageserver-types'
|
|
3
3
|
import { builtinWords } from '@algosail/builtins'
|
|
4
4
|
|
|
@@ -51,7 +51,7 @@ export function getCompletionItems(parser, uri) {
|
|
|
51
51
|
})
|
|
52
52
|
for (const field of map.fields) {
|
|
53
53
|
items.push({
|
|
54
|
-
label: `~${key}$${map.name}
|
|
54
|
+
label: `~${key}$${map.name}.${field.name}`,
|
|
55
55
|
kind: CompletionItemKind.Field,
|
|
56
56
|
detail: `Field :${field.name}${field.type ? ` (${field.type.kind})` : ''} of ~${key}$${map.name}`,
|
|
57
57
|
documentation: field.doc ? { kind: MarkupKind.Markdown, value: field.doc } : undefined,
|
|
@@ -102,7 +102,7 @@ export function getCompletionItems(parser, uri) {
|
|
|
102
102
|
})
|
|
103
103
|
for (const field of map.fields) {
|
|
104
104
|
items.push({
|
|
105
|
-
label: `$${map.name}
|
|
105
|
+
label: `$${map.name}.${field.name}`,
|
|
106
106
|
kind: CompletionItemKind.Field,
|
|
107
107
|
detail: `Field :${field.name}${field.type ? ` (${field.type.kind})` : ''} of $${map.name}`,
|
|
108
108
|
documentation: field.doc ? { kind: MarkupKind.Markdown, value: field.doc } : undefined,
|
package/lib/validate.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DiagnosticSeverity } from 'vscode-languageserver
|
|
1
|
+
import { DiagnosticSeverity } from 'vscode-languageserver'
|
|
2
2
|
|
|
3
3
|
export const validateDocument = async (connection, parser, uri, text) => {
|
|
4
4
|
try {
|
|
@@ -8,12 +8,12 @@ export const validateDocument = async (connection, parser, uri, text) => {
|
|
|
8
8
|
severity: DiagnosticSeverity.Error,
|
|
9
9
|
range: {
|
|
10
10
|
start: {
|
|
11
|
-
line: err.startPosition.row
|
|
12
|
-
character: err.startPosition.column
|
|
11
|
+
line: err.startPosition.row,
|
|
12
|
+
character: err.startPosition.column,
|
|
13
13
|
},
|
|
14
14
|
end: {
|
|
15
|
-
line: err.endPosition.row
|
|
16
|
-
character: err.endPosition.column
|
|
15
|
+
line: err.endPosition.row,
|
|
16
|
+
character: err.endPosition.column,
|
|
17
17
|
},
|
|
18
18
|
},
|
|
19
19
|
message: err.type === 'error' ? `Unexpected token ${err.text}` : `Missing ${err.text}`,
|