@likec4/language-server 1.47.0 → 1.48.0
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/LICENSE +1 -1
- package/browser/package.json +2 -2
- package/browser-worker/package.json +2 -2
- package/bundled/package.json +4 -0
- package/dist/LikeC4LanguageServices.d.mts +4 -0
- package/dist/LikeC4LanguageServices.mjs +3 -0
- package/dist/_chunks/ConfigurableLayouter.mjs +1956 -0
- package/dist/_chunks/LikeC4LanguageServices.d.mts +1978 -0
- package/dist/_chunks/LikeC4LanguageServices.mjs +725 -0
- package/dist/_chunks/ast.d.mts +1444 -0
- package/dist/_chunks/ast.mjs +2375 -0
- package/dist/_chunks/ast2.mjs +176 -0
- package/dist/_chunks/common-exports.mjs +0 -0
- package/dist/_chunks/filesystem.mjs +58 -0
- package/dist/_chunks/grammar.mjs +8 -0
- package/dist/_chunks/icons.mjs +5211 -0
- package/dist/_chunks/libs/@hono/node-server.mjs +436 -0
- package/dist/_chunks/libs/@msgpack/msgpack.mjs +805 -0
- package/dist/_chunks/libs/eventemitter3.mjs +243 -0
- package/dist/_chunks/libs/fast-equals.mjs +446 -0
- package/dist/_chunks/libs/hono.mjs +1829 -0
- package/dist/_chunks/libs/p-queue.mjs +449 -0
- package/dist/_chunks/libs/parse-ms.mjs +36 -0
- package/dist/_chunks/libs/picomatch.mjs +1673 -0
- package/dist/_chunks/libs/pretty-ms.mjs +80 -0
- package/dist/_chunks/libs/remeda.mjs +482 -0
- package/dist/_chunks/libs/strip-indent.mjs +15 -0
- package/dist/_chunks/libs/ufo.mjs +166 -0
- package/dist/_chunks/likec4lib.mjs +9 -0
- package/dist/_chunks/mcp.mjs +33 -0
- package/dist/_chunks/module.mjs +28 -0
- package/dist/_chunks/module2.mjs +6576 -0
- package/dist/_chunks/protocol.d.mts +311 -0
- package/dist/_chunks/protocol.mjs +78 -0
- package/dist/_chunks/rolldown-runtime.mjs +42 -0
- package/dist/ast.d.mts +4 -0
- package/dist/ast.mjs +4 -0
- package/dist/browser-worker.d.mts +1 -0
- package/dist/browser-worker.mjs +6 -0
- package/dist/browser.d.mts +11 -0
- package/dist/browser.mjs +27 -0
- package/dist/bundled.d.mts +28 -0
- package/dist/bundled.mjs +51 -4853
- package/dist/common-exports.d.mts +4 -0
- package/dist/common-exports.mjs +5 -0
- package/dist/filesystem/index.d.mts +4 -0
- package/dist/filesystem/index.mjs +3 -0
- package/dist/generated/ast.d.mts +2 -0
- package/dist/generated/ast.mjs +3 -0
- package/dist/generated/grammar.d.mts +6 -0
- package/dist/generated/grammar.mjs +3 -0
- package/dist/generated/module.d.mts +14 -0
- package/dist/generated/module.mjs +3 -0
- package/dist/generated-lib/icons.d.mts +4 -0
- package/dist/generated-lib/icons.mjs +3 -0
- package/dist/index.d.mts +4 -0
- package/dist/index.mjs +48 -0
- package/dist/likec4lib.d.mts +9 -0
- package/dist/likec4lib.mjs +4 -0
- package/dist/mcp/index.d.mts +4 -0
- package/dist/mcp/index.mjs +3 -0
- package/dist/module.d.mts +4 -0
- package/dist/module.mjs +3 -0
- package/dist/protocol.d.mts +2 -0
- package/dist/protocol.mjs +3 -0
- package/likec4lib/package.json +2 -2
- package/package.json +106 -63
- package/protocol/package.json +2 -2
- package/dist/LikeC4LanguageServices.d.ts +0 -115
- package/dist/LikeC4LanguageServices.js +0 -164
- package/dist/Rpc.d.ts +0 -9
- package/dist/Rpc.js +0 -276
- package/dist/ast.d.ts +0 -226
- package/dist/ast.js +0 -264
- package/dist/browser-worker.d.ts +0 -1
- package/dist/browser-worker.js +0 -4
- package/dist/browser.d.ts +0 -10
- package/dist/browser.js +0 -34
- package/dist/bundled.d.ts +0 -8
- package/dist/bundled.js +0 -44
- package/dist/documentation/documentation-provider.d.ts +0 -8
- package/dist/documentation/documentation-provider.js +0 -51
- package/dist/documentation/index.d.ts +0 -1
- package/dist/documentation/index.js +0 -1
- package/dist/empty.d.ts +0 -2
- package/dist/empty.js +0 -2
- package/dist/filesystem/ChokidarWatcher.d.ts +0 -19
- package/dist/filesystem/ChokidarWatcher.js +0 -133
- package/dist/filesystem/FileSystemWatcher.d.ts +0 -19
- package/dist/filesystem/FileSystemWatcher.js +0 -14
- package/dist/filesystem/LikeC4FileSystem.d.ts +0 -3
- package/dist/filesystem/LikeC4FileSystem.js +0 -140
- package/dist/filesystem/index.d.ts +0 -55
- package/dist/filesystem/index.js +0 -29
- package/dist/formatting/LikeC4Formatter.d.ts +0 -59
- package/dist/formatting/LikeC4Formatter.js +0 -637
- package/dist/formatting/utils.d.ts +0 -6
- package/dist/formatting/utils.js +0 -18
- package/dist/generated/ast.d.ts +0 -1411
- package/dist/generated/ast.js +0 -2207
- package/dist/generated/grammar.d.ts +0 -6
- package/dist/generated/grammar.js +0 -7
- package/dist/generated/module.d.ts +0 -14
- package/dist/generated/module.js +0 -27
- package/dist/generated-lib/icons.d.ts +0 -1
- package/dist/generated-lib/icons.js +0 -18
- package/dist/index.d.ts +0 -37
- package/dist/index.js +0 -54
- package/dist/likec4lib.d.ts +0 -6
- package/dist/likec4lib.js +0 -7
- package/dist/logger.d.ts +0 -17
- package/dist/logger.js +0 -81
- package/dist/lsp/CodeActionProvider.d.ts +0 -14
- package/dist/lsp/CodeActionProvider.js +0 -33
- package/dist/lsp/CodeLensProvider.d.ts +0 -9
- package/dist/lsp/CodeLensProvider.js +0 -44
- package/dist/lsp/CompletionProvider.d.ts +0 -13
- package/dist/lsp/CompletionProvider.js +0 -238
- package/dist/lsp/DocumentHighlightProvider.d.ts +0 -9
- package/dist/lsp/DocumentHighlightProvider.js +0 -10
- package/dist/lsp/DocumentLinkProvider.d.ts +0 -11
- package/dist/lsp/DocumentLinkProvider.js +0 -58
- package/dist/lsp/DocumentSymbolProvider.d.ts +0 -33
- package/dist/lsp/DocumentSymbolProvider.js +0 -317
- package/dist/lsp/HoverProvider.d.ts +0 -10
- package/dist/lsp/HoverProvider.js +0 -106
- package/dist/lsp/RenameProvider.d.ts +0 -5
- package/dist/lsp/RenameProvider.js +0 -6
- package/dist/lsp/SemanticTokenProvider.d.ts +0 -19
- package/dist/lsp/SemanticTokenProvider.js +0 -305
- package/dist/lsp/index.d.ts +0 -8
- package/dist/lsp/index.js +0 -9
- package/dist/mcp/MCPServerFactory.d.ts +0 -8
- package/dist/mcp/MCPServerFactory.js +0 -73
- package/dist/mcp/NoopLikeC4MCPServer.d.ts +0 -9
- package/dist/mcp/NoopLikeC4MCPServer.js +0 -17
- package/dist/mcp/interfaces.d.ts +0 -13
- package/dist/mcp/interfaces.js +0 -4
- package/dist/mcp/server/StdioLikeC4MCPServer.d.ts +0 -16
- package/dist/mcp/server/StdioLikeC4MCPServer.js +0 -51
- package/dist/mcp/server/StreamableLikeC4MCPServer.d.ts +0 -16
- package/dist/mcp/server/StreamableLikeC4MCPServer.js +0 -121
- package/dist/mcp/server/WithMCPServer.d.ts +0 -4
- package/dist/mcp/server/WithMCPServer.js +0 -54
- package/dist/mcp/tools/_common.d.ts +0 -88
- package/dist/mcp/tools/_common.js +0 -49
- package/dist/mcp/tools/find-relationships.d.ts +0 -202
- package/dist/mcp/tools/find-relationships.js +0 -150
- package/dist/mcp/tools/list-projects.d.ts +0 -194
- package/dist/mcp/tools/list-projects.js +0 -62
- package/dist/mcp/tools/open-view.d.ts +0 -200
- package/dist/mcp/tools/open-view.js +0 -52
- package/dist/mcp/tools/read-deployment.d.ts +0 -200
- package/dist/mcp/tools/read-deployment.js +0 -150
- package/dist/mcp/tools/read-element.d.ts +0 -200
- package/dist/mcp/tools/read-element.js +0 -218
- package/dist/mcp/tools/read-project-summary.d.ts +0 -198
- package/dist/mcp/tools/read-project-summary.js +0 -176
- package/dist/mcp/tools/read-view.d.ts +0 -200
- package/dist/mcp/tools/read-view.js +0 -203
- package/dist/mcp/tools/search-element.d.ts +0 -198
- package/dist/mcp/tools/search-element.js +0 -177
- package/dist/mcp/utils.d.ts +0 -18
- package/dist/mcp/utils.js +0 -48
- package/dist/model/builder/MergedExtends.d.ts +0 -13
- package/dist/model/builder/MergedExtends.js +0 -74
- package/dist/model/builder/MergedSpecification.d.ts +0 -32
- package/dist/model/builder/MergedSpecification.js +0 -175
- package/dist/model/builder/buildModel.d.ts +0 -16
- package/dist/model/builder/buildModel.js +0 -245
- package/dist/model/deployments-index.d.ts +0 -10
- package/dist/model/deployments-index.js +0 -102
- package/dist/model/fqn-index.d.ts +0 -61
- package/dist/model/fqn-index.js +0 -253
- package/dist/model/index.d.ts +0 -6
- package/dist/model/index.js +0 -6
- package/dist/model/model-builder.d.ts +0 -54
- package/dist/model/model-builder.js +0 -233
- package/dist/model/model-locator.d.ts +0 -39
- package/dist/model/model-locator.js +0 -240
- package/dist/model/model-parser-where.d.ts +0 -4
- package/dist/model/model-parser-where.js +0 -81
- package/dist/model/model-parser.d.ts +0 -645
- package/dist/model/model-parser.js +0 -133
- package/dist/model/parser/Base.d.ts +0 -69
- package/dist/model/parser/Base.js +0 -382
- package/dist/model/parser/DeploymentModelParser.d.ts +0 -71
- package/dist/model/parser/DeploymentModelParser.js +0 -176
- package/dist/model/parser/DeploymentViewParser.d.ts +0 -75
- package/dist/model/parser/DeploymentViewParser.js +0 -86
- package/dist/model/parser/FqnRefParser.d.ts +0 -66
- package/dist/model/parser/FqnRefParser.js +0 -382
- package/dist/model/parser/GlobalsParser.d.ts +0 -109
- package/dist/model/parser/GlobalsParser.js +0 -84
- package/dist/model/parser/ImportsParser.d.ts +0 -46
- package/dist/model/parser/ImportsParser.js +0 -24
- package/dist/model/parser/ModelParser.d.ts +0 -71
- package/dist/model/parser/ModelParser.js +0 -209
- package/dist/model/parser/PredicatesParser.d.ts +0 -75
- package/dist/model/parser/PredicatesParser.js +0 -45
- package/dist/model/parser/SpecificationParser.d.ts +0 -53
- package/dist/model/parser/SpecificationParser.js +0 -113
- package/dist/model/parser/ValueConverter.d.ts +0 -4
- package/dist/model/parser/ValueConverter.js +0 -12
- package/dist/model/parser/ViewsParser.d.ts +0 -112
- package/dist/model/parser/ViewsParser.js +0 -492
- package/dist/model-change/ModelChanges.d.ts +0 -18
- package/dist/model-change/ModelChanges.js +0 -129
- package/dist/model-change/changeElementStyle.d.ts +0 -16
- package/dist/model-change/changeElementStyle.js +0 -134
- package/dist/model-change/changeViewLayout.d.ts +0 -12
- package/dist/model-change/changeViewLayout.js +0 -28
- package/dist/model-change/removeManualLayoutV1.d.ts +0 -7
- package/dist/model-change/removeManualLayoutV1.js +0 -27
- package/dist/module.d.ts +0 -92
- package/dist/module.js +0 -143
- package/dist/protocol.d.ts +0 -289
- package/dist/protocol.js +0 -123
- package/dist/references/index.d.ts +0 -3
- package/dist/references/index.js +0 -3
- package/dist/references/name-provider.d.ts +0 -9
- package/dist/references/name-provider.js +0 -37
- package/dist/references/scope-computation.d.ts +0 -20
- package/dist/references/scope-computation.js +0 -288
- package/dist/references/scope-provider.d.ts +0 -40
- package/dist/references/scope-provider.js +0 -239
- package/dist/shared/NodeKindProvider.d.ts +0 -15
- package/dist/shared/NodeKindProvider.js +0 -57
- package/dist/shared/WorkspaceSymbolProvider.d.ts +0 -3
- package/dist/shared/WorkspaceSymbolProvider.js +0 -3
- package/dist/shared/index.d.ts +0 -2
- package/dist/shared/index.js +0 -2
- package/dist/test/index.d.ts +0 -1
- package/dist/test/index.js +0 -1
- package/dist/test/testServices.d.ts +0 -64
- package/dist/test/testServices.js +0 -210
- package/dist/utils/disposable.d.ts +0 -8
- package/dist/utils/disposable.js +0 -26
- package/dist/utils/elementRef.d.ts +0 -11
- package/dist/utils/elementRef.js +0 -33
- package/dist/utils/fqnRef.d.ts +0 -11
- package/dist/utils/fqnRef.js +0 -63
- package/dist/utils/index.d.ts +0 -11
- package/dist/utils/index.js +0 -35
- package/dist/utils/printDocs.d.ts +0 -2
- package/dist/utils/printDocs.js +0 -1
- package/dist/utils/projectId.d.ts +0 -4
- package/dist/utils/projectId.js +0 -16
- package/dist/utils/stringHash.d.ts +0 -1
- package/dist/utils/stringHash.js +0 -5
- package/dist/validation/DocumentValidator.d.ts +0 -11
- package/dist/validation/DocumentValidator.js +0 -17
- package/dist/validation/_shared.d.ts +0 -3
- package/dist/validation/_shared.js +0 -26
- package/dist/validation/deployment-checks.d.ts +0 -7
- package/dist/validation/deployment-checks.js +0 -140
- package/dist/validation/dynamic-view.d.ts +0 -6
- package/dist/validation/dynamic-view.js +0 -67
- package/dist/validation/element-ref.d.ts +0 -4
- package/dist/validation/element-ref.js +0 -12
- package/dist/validation/element.d.ts +0 -4
- package/dist/validation/element.js +0 -49
- package/dist/validation/imports.d.ts +0 -4
- package/dist/validation/imports.js +0 -46
- package/dist/validation/index.d.ts +0 -15
- package/dist/validation/index.js +0 -167
- package/dist/validation/property-checks.d.ts +0 -7
- package/dist/validation/property-checks.js +0 -108
- package/dist/validation/relation.d.ts +0 -6
- package/dist/validation/relation.js +0 -141
- package/dist/validation/specification.d.ts +0 -12
- package/dist/validation/specification.js +0 -190
- package/dist/validation/view-checks.d.ts +0 -4
- package/dist/validation/view-checks.js +0 -46
- package/dist/validation/view-predicates/fqn-expr-with.d.ts +0 -4
- package/dist/validation/view-predicates/fqn-expr-with.js +0 -43
- package/dist/validation/view-predicates/fqn-ref-expr.d.ts +0 -4
- package/dist/validation/view-predicates/fqn-ref-expr.js +0 -51
- package/dist/validation/view-predicates/incoming.d.ts +0 -4
- package/dist/validation/view-predicates/incoming.js +0 -16
- package/dist/validation/view-predicates/index.d.ts +0 -6
- package/dist/validation/view-predicates/index.js +0 -6
- package/dist/validation/view-predicates/outgoing.d.ts +0 -4
- package/dist/validation/view-predicates/outgoing.js +0 -20
- package/dist/validation/view-predicates/relation-expr.d.ts +0 -4
- package/dist/validation/view-predicates/relation-expr.js +0 -46
- package/dist/validation/view-predicates/relation-with.d.ts +0 -4
- package/dist/validation/view-predicates/relation-with.js +0 -16
- package/dist/validation/view.d.ts +0 -4
- package/dist/validation/view.js +0 -42
- package/dist/view-utils/assignNavigateTo.d.ts +0 -2
- package/dist/view-utils/assignNavigateTo.js +0 -27
- package/dist/view-utils/index.d.ts +0 -2
- package/dist/view-utils/index.js +0 -2
- package/dist/view-utils/manual-layout.d.ts +0 -13
- package/dist/view-utils/manual-layout.js +0 -149
- package/dist/views/ConfigurableLayouter.d.ts +0 -7
- package/dist/views/ConfigurableLayouter.js +0 -51
- package/dist/views/LikeC4ManualLayouts.d.ts +0 -42
- package/dist/views/LikeC4ManualLayouts.js +0 -209
- package/dist/views/LikeC4Views.d.ts +0 -89
- package/dist/views/LikeC4Views.js +0 -216
- package/dist/views/index.d.ts +0 -4
- package/dist/views/index.js +0 -11
- package/dist/workspace/AstNodeDescriptionProvider.d.ts +0 -7
- package/dist/workspace/AstNodeDescriptionProvider.js +0 -18
- package/dist/workspace/IndexManager.d.ts +0 -10
- package/dist/workspace/IndexManager.js +0 -26
- package/dist/workspace/LangiumDocuments.d.ts +0 -29
- package/dist/workspace/LangiumDocuments.js +0 -104
- package/dist/workspace/ProjectsManager.d.ts +0 -134
- package/dist/workspace/ProjectsManager.js +0 -610
- package/dist/workspace/WorkspaceManager.d.ts +0 -31
- package/dist/workspace/WorkspaceManager.js +0 -132
- package/dist/workspace/index.d.ts +0 -5
- package/dist/workspace/index.js +0 -5
|
@@ -1,288 +0,0 @@
|
|
|
1
|
-
import { nonexhaustive } from '@likec4/core';
|
|
2
|
-
import { DefaultScopeComputation, MultiMap, } from 'langium';
|
|
3
|
-
import { entries, filter, flatMap, forEachObj, groupBy, isNullish, isTruthy, pipe } from 'remeda';
|
|
4
|
-
import { ast } from '../ast';
|
|
5
|
-
import { logWarnError } from '../logger';
|
|
6
|
-
function uniqueDescriptions(descs) {
|
|
7
|
-
return pipe(descs, groupBy(desc => `${desc.type}.${desc.name}`), entries(), flatMap(([_, descs]) => descs.length === 1 ? descs : []));
|
|
8
|
-
}
|
|
9
|
-
export class LikeC4ScopeComputation extends DefaultScopeComputation {
|
|
10
|
-
constructor(services) {
|
|
11
|
-
super(services);
|
|
12
|
-
}
|
|
13
|
-
async computeExports(document, _cancelToken) {
|
|
14
|
-
const docExports = [];
|
|
15
|
-
try {
|
|
16
|
-
const { specifications, models, views, globals, likec4lib, deployments, } = document.parseResult.value;
|
|
17
|
-
// Process library
|
|
18
|
-
this.exportLibrary(likec4lib, docExports, document);
|
|
19
|
-
// Process specification
|
|
20
|
-
this.exportSpecification(specifications, docExports, document);
|
|
21
|
-
// Process models
|
|
22
|
-
this.exportModel(models, docExports, document);
|
|
23
|
-
// Process views
|
|
24
|
-
this.exportViews(views, docExports, document);
|
|
25
|
-
// Process global
|
|
26
|
-
this.exportGlobals(globals, docExports, document);
|
|
27
|
-
this.exportDeployments(deployments, docExports, document);
|
|
28
|
-
}
|
|
29
|
-
catch (e) {
|
|
30
|
-
logWarnError(e);
|
|
31
|
-
}
|
|
32
|
-
return docExports;
|
|
33
|
-
}
|
|
34
|
-
exportViews(modelViews, docExports, document) {
|
|
35
|
-
const views = modelViews?.flatMap(m => m.views);
|
|
36
|
-
if (isNullish(views) || views.length === 0) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
for (const viewAst of views) {
|
|
40
|
-
try {
|
|
41
|
-
if (isTruthy(viewAst.name)) {
|
|
42
|
-
docExports.push(this.descriptions.createDescription(viewAst, viewAst.name, document));
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
catch (e) {
|
|
46
|
-
logWarnError(e);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
exportGlobals(globals, docExports, document) {
|
|
51
|
-
if (isNullish(globals) || globals.length === 0) {
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
for (const globalPredicateAst of globals.flatMap(g => g.predicates)) {
|
|
55
|
-
try {
|
|
56
|
-
const id = globalPredicateAst;
|
|
57
|
-
if (isTruthy(id.name)) {
|
|
58
|
-
docExports.push(this.descriptions.createDescription(id, id.name, document));
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
catch (e) {
|
|
62
|
-
logWarnError(e);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
for (const globalStyleAst of globals.flatMap(g => g.styles)) {
|
|
66
|
-
try {
|
|
67
|
-
const id = globalStyleAst.id;
|
|
68
|
-
if (isTruthy(id.name)) {
|
|
69
|
-
docExports.push(this.descriptions.createDescription(id, id.name, document));
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
catch (e) {
|
|
73
|
-
logWarnError(e);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
exportModel(models, docExports, document) {
|
|
78
|
-
if (isNullish(models) || models.length === 0) {
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
for (const elAst of models.flatMap(m => m.elements)) {
|
|
82
|
-
try {
|
|
83
|
-
if (ast.isElement(elAst) && isTruthy(elAst.name)) {
|
|
84
|
-
docExports.push(this.descriptions.createDescription(elAst, elAst.name, document));
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
catch (e) {
|
|
88
|
-
logWarnError(e);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
exportLibrary(likec4lib, docExports, document) {
|
|
93
|
-
if (isNullish(likec4lib)) {
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
try {
|
|
97
|
-
for (const iconAst of likec4lib.flatMap(l => l.icons)) {
|
|
98
|
-
docExports.push(this.descriptions.createDescription(iconAst, iconAst.name, document));
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
catch (e) {
|
|
102
|
-
logWarnError(e);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
exportSpecification(specifications, docExports, document) {
|
|
106
|
-
if (isNullish(specifications) || specifications.length === 0) {
|
|
107
|
-
return;
|
|
108
|
-
}
|
|
109
|
-
for (const spec of specifications.flatMap(s => [
|
|
110
|
-
...s.elements,
|
|
111
|
-
...s.relationships,
|
|
112
|
-
...s.deploymentNodes,
|
|
113
|
-
...s.tags,
|
|
114
|
-
...s.colors,
|
|
115
|
-
])) {
|
|
116
|
-
try {
|
|
117
|
-
switch (true) {
|
|
118
|
-
case ast.isSpecificationDeploymentNodeKind(spec):
|
|
119
|
-
case ast.isSpecificationElementKind(spec): {
|
|
120
|
-
if (isTruthy(spec.kind.name)) {
|
|
121
|
-
docExports.push(this.descriptions.createDescription(spec.kind, spec.kind.name, document));
|
|
122
|
-
}
|
|
123
|
-
continue;
|
|
124
|
-
}
|
|
125
|
-
case ast.isSpecificationTag(spec): {
|
|
126
|
-
if (isTruthy(spec.tag.name)) {
|
|
127
|
-
docExports.push(this.descriptions.createDescription(spec.tag, spec.tag.name, document));
|
|
128
|
-
}
|
|
129
|
-
continue;
|
|
130
|
-
}
|
|
131
|
-
case ast.isSpecificationRelationshipKind(spec): {
|
|
132
|
-
if (isTruthy(spec.kind.name)) {
|
|
133
|
-
docExports.push(this.descriptions.createDescription(spec.kind, spec.kind.name, document));
|
|
134
|
-
}
|
|
135
|
-
continue;
|
|
136
|
-
}
|
|
137
|
-
case ast.isSpecificationColor(spec): {
|
|
138
|
-
if (isTruthy(spec.name.name)) {
|
|
139
|
-
docExports.push(this.descriptions.createDescription(spec.name, spec.name.name, document));
|
|
140
|
-
}
|
|
141
|
-
continue;
|
|
142
|
-
}
|
|
143
|
-
// Thow error if not exhaustive
|
|
144
|
-
default:
|
|
145
|
-
nonexhaustive(spec);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
catch (e) {
|
|
149
|
-
logWarnError(e);
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
exportDeployments(modelDeployments, docExports, document) {
|
|
154
|
-
const nodes = modelDeployments?.flatMap(m => m.elements);
|
|
155
|
-
if (isNullish(nodes) || nodes.length === 0) {
|
|
156
|
-
return;
|
|
157
|
-
}
|
|
158
|
-
for (const node of nodes) {
|
|
159
|
-
try {
|
|
160
|
-
if (ast.isDeploymentNode(node) && isTruthy(node.name)) {
|
|
161
|
-
docExports.push(this.descriptions.createDescription(node, node.name, document));
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
catch (e) {
|
|
165
|
-
logWarnError(e);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
computeLocalScopes(document, _cancelToken) {
|
|
170
|
-
return new Promise(resolve => {
|
|
171
|
-
const root = document.parseResult.value;
|
|
172
|
-
const descendants = [];
|
|
173
|
-
const scopes = new MultiMap();
|
|
174
|
-
for (const model of root.models) {
|
|
175
|
-
try {
|
|
176
|
-
descendants.push(...this.processContainer(model, scopes, document));
|
|
177
|
-
}
|
|
178
|
-
catch (e) {
|
|
179
|
-
logWarnError(e);
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
for (const deployment of root.deployments) {
|
|
183
|
-
try {
|
|
184
|
-
descendants.push(...this.processDeployments(deployment, scopes, document));
|
|
185
|
-
}
|
|
186
|
-
catch (e) {
|
|
187
|
-
logWarnError(e);
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
for (const imports of root.imports.flatMap(i => i.imports)) {
|
|
191
|
-
try {
|
|
192
|
-
let imported = imports;
|
|
193
|
-
while (imported) {
|
|
194
|
-
descendants.push(this.descriptions.createDescription(imported, imported.imported.$refText));
|
|
195
|
-
imported = imported.prev;
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
catch (e) {
|
|
199
|
-
logWarnError(e);
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
uniqueDescriptions(descendants).forEach(desc => {
|
|
203
|
-
scopes.add(root, desc);
|
|
204
|
-
});
|
|
205
|
-
resolve(scopes);
|
|
206
|
-
});
|
|
207
|
-
}
|
|
208
|
-
processContainer(container, scopes, document) {
|
|
209
|
-
const localScope = new MultiMap();
|
|
210
|
-
const descedants = [];
|
|
211
|
-
for (const el of container.elements) {
|
|
212
|
-
if (ast.isRelation(el)) {
|
|
213
|
-
continue;
|
|
214
|
-
}
|
|
215
|
-
let subcontainer;
|
|
216
|
-
if (ast.isElement(el)) {
|
|
217
|
-
if (isTruthy(el.name)) {
|
|
218
|
-
localScope.add(el.name, this.descriptions.createDescription(el, el.name, document));
|
|
219
|
-
}
|
|
220
|
-
subcontainer = el.body;
|
|
221
|
-
if (subcontainer) {
|
|
222
|
-
scopes.add(subcontainer, this.descriptions.createDescription(el, 'this', document));
|
|
223
|
-
scopes.add(subcontainer, this.descriptions.createDescription(el, 'it', document));
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
else if (ast.isExtendElement(el)) {
|
|
227
|
-
subcontainer = el.body;
|
|
228
|
-
}
|
|
229
|
-
if (subcontainer && subcontainer.elements.length > 0) {
|
|
230
|
-
try {
|
|
231
|
-
descedants.push(...this.processContainer(subcontainer, scopes, document));
|
|
232
|
-
}
|
|
233
|
-
catch (e) {
|
|
234
|
-
logWarnError(e);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
if (descedants.length) {
|
|
239
|
-
pipe(descedants, filter(desc => !localScope.has(desc.name)), groupBy(desc => desc.name), forEachObj((descs, name) => {
|
|
240
|
-
if (descs.length === 1) {
|
|
241
|
-
localScope.add(name, descs[0]);
|
|
242
|
-
}
|
|
243
|
-
}));
|
|
244
|
-
}
|
|
245
|
-
const local = [...localScope.values()];
|
|
246
|
-
scopes.addAll(container, local);
|
|
247
|
-
return local;
|
|
248
|
-
}
|
|
249
|
-
processDeployments(container, scopes, document) {
|
|
250
|
-
const localScope = new MultiMap();
|
|
251
|
-
const descedants = [];
|
|
252
|
-
for (const el of container.elements) {
|
|
253
|
-
if (ast.isDeploymentRelation(el)) {
|
|
254
|
-
continue;
|
|
255
|
-
}
|
|
256
|
-
let subcontainer = el.body;
|
|
257
|
-
if (!ast.isExtendDeployment(el)) {
|
|
258
|
-
let name = this.nameProvider.getName(el);
|
|
259
|
-
if (isTruthy(name)) {
|
|
260
|
-
const desc = this.descriptions.createDescription(el, name, document);
|
|
261
|
-
localScope.add(name, desc);
|
|
262
|
-
}
|
|
263
|
-
if (subcontainer) {
|
|
264
|
-
scopes.add(subcontainer, this.descriptions.createDescription(el, 'this', document));
|
|
265
|
-
scopes.add(subcontainer, this.descriptions.createDescription(el, 'it', document));
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
if (subcontainer) {
|
|
269
|
-
try {
|
|
270
|
-
descedants.push(...this.processDeployments(subcontainer, scopes, document));
|
|
271
|
-
}
|
|
272
|
-
catch (e) {
|
|
273
|
-
logWarnError(e);
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
}
|
|
277
|
-
if (descedants.length) {
|
|
278
|
-
pipe(descedants, filter(desc => !localScope.has(desc.name)), groupBy(desc => desc.name), forEachObj((descs, name) => {
|
|
279
|
-
if (descs.length === 1) {
|
|
280
|
-
localScope.add(name, descs[0]);
|
|
281
|
-
}
|
|
282
|
-
}));
|
|
283
|
-
}
|
|
284
|
-
const local = [...localScope.values()];
|
|
285
|
-
scopes.addAll(container, local);
|
|
286
|
-
return local;
|
|
287
|
-
}
|
|
288
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { type ProjectId } from '@likec4/core';
|
|
2
|
-
import { type AstNodeDescription, type ReferenceInfo, type Scope, type Stream, DefaultScopeProvider } from 'langium';
|
|
3
|
-
import { ast } from '../ast';
|
|
4
|
-
import type { DeploymentsIndex, FqnIndex } from '../model';
|
|
5
|
-
import type { LikeC4Services } from '../module';
|
|
6
|
-
import type { IndexManager } from '../workspace';
|
|
7
|
-
export declare class LikeC4ScopeProvider extends DefaultScopeProvider {
|
|
8
|
-
protected deploymentsIndex: DeploymentsIndex;
|
|
9
|
-
protected fqnIndex: FqnIndex;
|
|
10
|
-
protected readonly indexManager: IndexManager;
|
|
11
|
-
constructor(services: LikeC4Services);
|
|
12
|
-
getScope(context: ReferenceInfo): Scope;
|
|
13
|
-
protected genUniqueDescedants(element: ast.Element | ast.DeploymentNode | undefined): Generator<import("../ast").AstNodeDescriptionWithFqn, void, any>;
|
|
14
|
-
protected genScopeExtendElement({ element }: ast.ExtendElement): Generator<AstNodeDescription>;
|
|
15
|
-
protected genScopeElementView({ viewOf, extends: ext }: ast.ElementView): Generator<AstNodeDescription>;
|
|
16
|
-
protected getScopeForStrictFqnRef(projectId: ProjectId, container: ast.StrictFqnRef, context: ReferenceInfo): Scope;
|
|
17
|
-
protected genScopeExtendDeployment({ deploymentNode }: ast.ExtendDeployment): Generator<AstNodeDescription>;
|
|
18
|
-
protected streamForFqnRef(projectId: ProjectId, container: ast.FqnRef, context: ReferenceInfo): Stream<AstNodeDescription>;
|
|
19
|
-
protected genScopeForParentlessFqnRef(projectId: ProjectId, container: ast.FqnRef, context: ReferenceInfo): Generator<AstNodeDescription>;
|
|
20
|
-
/**
|
|
21
|
-
* Computes the scope for a given reference context.
|
|
22
|
-
*
|
|
23
|
-
* @param context - The reference information containing the context for which the scope is being computed.
|
|
24
|
-
* @param referenceType - The type of reference being resolved. Defaults to the reference type derived from the context.
|
|
25
|
-
* @returns A scope containing the relevant AST node descriptions for the given reference context.
|
|
26
|
-
*
|
|
27
|
-
* This method first checks if there are precomputed scopes available in the document. If not, it falls back to the global scope.
|
|
28
|
-
* It then iterates through the container hierarchy, collecting relevant scopes based on the reference type and container type.
|
|
29
|
-
* Finally, it combines the collected scopes with the global scope to produce the final scope.
|
|
30
|
-
*/
|
|
31
|
-
protected computeScope(projectId: ProjectId, context: ReferenceInfo, referenceType?: string): Generator<AstNodeDescription>;
|
|
32
|
-
/**
|
|
33
|
-
* Create a global scope filtered for the given reference type.
|
|
34
|
-
*/
|
|
35
|
-
protected getProjectScope(projectId: ProjectId, referenceType: string, context: ReferenceInfo): Scope;
|
|
36
|
-
/**
|
|
37
|
-
* Create a global scope filtered for the given reference type.
|
|
38
|
-
*/
|
|
39
|
-
protected getGlobalScope(referenceType: string, context: ReferenceInfo): Scope;
|
|
40
|
-
}
|
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
import { nonexhaustive } from '@likec4/core';
|
|
2
|
-
import { AstUtils, DefaultScopeProvider, EMPTY_SCOPE, EMPTY_STREAM, MapScope, stream, StreamScope, } from 'langium';
|
|
3
|
-
import { ast, isFqnRefInsideGlobals, isFqnRefInsideModel } from '../ast';
|
|
4
|
-
import { logWarnError } from '../logger';
|
|
5
|
-
import { projectIdFrom } from '../utils';
|
|
6
|
-
import { elementRef, readStrictFqn } from '../utils/elementRef';
|
|
7
|
-
const { getDocument } = AstUtils;
|
|
8
|
-
export class LikeC4ScopeProvider extends DefaultScopeProvider {
|
|
9
|
-
deploymentsIndex;
|
|
10
|
-
fqnIndex;
|
|
11
|
-
indexManager;
|
|
12
|
-
constructor(services) {
|
|
13
|
-
super(services);
|
|
14
|
-
this.indexManager = services.shared.workspace.IndexManager;
|
|
15
|
-
this.fqnIndex = services.likec4.FqnIndex;
|
|
16
|
-
this.deploymentsIndex = services.likec4.DeploymentsIndex;
|
|
17
|
-
}
|
|
18
|
-
getScope(context) {
|
|
19
|
-
try {
|
|
20
|
-
const projectId = projectIdFrom(context.container);
|
|
21
|
-
const referenceType = this.reflection.getReferenceType(context);
|
|
22
|
-
try {
|
|
23
|
-
const container = context.container;
|
|
24
|
-
if (ast.isFqnRef(container)) {
|
|
25
|
-
return new StreamScope(this.streamForFqnRef(projectId, container, context));
|
|
26
|
-
}
|
|
27
|
-
if (ast.isStrictFqnRef(container)) {
|
|
28
|
-
return this.getScopeForStrictFqnRef(projectId, container, context);
|
|
29
|
-
}
|
|
30
|
-
if (referenceType !== ast.Element) {
|
|
31
|
-
return this.getProjectScope(projectId, referenceType, context);
|
|
32
|
-
}
|
|
33
|
-
if (ast.isImported(container)) {
|
|
34
|
-
const projectId = projectIdFrom(container);
|
|
35
|
-
return new StreamScope(this.fqnIndex.rootElements(projectId));
|
|
36
|
-
}
|
|
37
|
-
if (ast.isStrictFqnElementRef(container) && context.property === 'el') {
|
|
38
|
-
const parent = container.parent;
|
|
39
|
-
if (!parent) {
|
|
40
|
-
return this.getProjectScope(projectId, referenceType, context);
|
|
41
|
-
}
|
|
42
|
-
return new StreamScope(this.fqnIndex.directChildrenOf(projectId, readStrictFqn(parent)));
|
|
43
|
-
}
|
|
44
|
-
return new StreamScope(stream(this.computeScope(projectId, context)));
|
|
45
|
-
}
|
|
46
|
-
catch (e) {
|
|
47
|
-
logWarnError(e);
|
|
48
|
-
return this.getProjectScope(projectId, referenceType, context);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
catch (e) {
|
|
52
|
-
logWarnError(e);
|
|
53
|
-
return EMPTY_SCOPE;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
// we need lazy resolving here
|
|
57
|
-
*genUniqueDescedants(element) {
|
|
58
|
-
if (!element) {
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
const projectId = projectIdFrom(element);
|
|
62
|
-
if (ast.isElement(element)) {
|
|
63
|
-
const fqn = this.fqnIndex.getFqn(element);
|
|
64
|
-
yield* this.fqnIndex.uniqueDescedants(projectId, fqn);
|
|
65
|
-
return;
|
|
66
|
-
}
|
|
67
|
-
if (ast.isDeploymentNode(element)) {
|
|
68
|
-
const fqn = this.deploymentsIndex.getFqn(element);
|
|
69
|
-
yield* this.deploymentsIndex.uniqueDescedants(projectId, fqn);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
*genScopeExtendElement({ element }) {
|
|
73
|
-
if (element.el.$nodeDescription) {
|
|
74
|
-
yield element.el.$nodeDescription;
|
|
75
|
-
yield {
|
|
76
|
-
...element.el.$nodeDescription,
|
|
77
|
-
name: 'this',
|
|
78
|
-
};
|
|
79
|
-
yield {
|
|
80
|
-
...element.el.$nodeDescription,
|
|
81
|
-
name: 'it',
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
// we make extended element resolvable inside ExtendElementBody
|
|
85
|
-
yield* this.genUniqueDescedants(elementRef(element));
|
|
86
|
-
}
|
|
87
|
-
*genScopeElementView({ viewOf, extends: ext }) {
|
|
88
|
-
if (viewOf) {
|
|
89
|
-
// If we have "view of parent.target"
|
|
90
|
-
// we make "target" resolvable inside ElementView
|
|
91
|
-
if (viewOf.modelElement.value.$nodeDescription) {
|
|
92
|
-
yield viewOf.modelElement.value.$nodeDescription;
|
|
93
|
-
}
|
|
94
|
-
yield* this.genUniqueDescedants(elementRef(viewOf));
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
if (ext) {
|
|
98
|
-
const view = ext.view.ref;
|
|
99
|
-
if (view) {
|
|
100
|
-
yield* this.genScopeElementView(view);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
getScopeForStrictFqnRef(projectId, container, context) {
|
|
105
|
-
const parent = container.parent;
|
|
106
|
-
if (!parent) {
|
|
107
|
-
return this.getProjectScope(projectId, ast.DeploymentNode, context);
|
|
108
|
-
}
|
|
109
|
-
return new StreamScope(this.deploymentsIndex
|
|
110
|
-
.directChildrenOf(projectId, readStrictFqn(parent))
|
|
111
|
-
.filter(desc => this.reflection.isSubtype(desc.type, ast.DeploymentNode)));
|
|
112
|
-
}
|
|
113
|
-
*genScopeExtendDeployment({ deploymentNode }) {
|
|
114
|
-
if (deploymentNode.value.$nodeDescription) {
|
|
115
|
-
yield deploymentNode.value.$nodeDescription;
|
|
116
|
-
}
|
|
117
|
-
const target = deploymentNode.value.ref;
|
|
118
|
-
if (target && ast.isDeploymentNode(target)) {
|
|
119
|
-
yield* this.genUniqueDescedants(target);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
streamForFqnRef(projectId, container, context) {
|
|
123
|
-
const parent = container.parent;
|
|
124
|
-
if (!parent) {
|
|
125
|
-
return stream(this.genScopeForParentlessFqnRef(projectId, container, context));
|
|
126
|
-
}
|
|
127
|
-
const parentRef = parent.value.ref;
|
|
128
|
-
if (!parentRef) {
|
|
129
|
-
return EMPTY_STREAM;
|
|
130
|
-
}
|
|
131
|
-
if (ast.isImported(parentRef)) {
|
|
132
|
-
return stream(this.genUniqueDescedants(parentRef.imported.ref));
|
|
133
|
-
}
|
|
134
|
-
if (ast.isDeploymentNode(parentRef)) {
|
|
135
|
-
return stream(this.genUniqueDescedants(parentRef));
|
|
136
|
-
}
|
|
137
|
-
if (ast.isDeployedInstance(parentRef)) {
|
|
138
|
-
const target = parentRef.target.modelElement.value.ref;
|
|
139
|
-
// dprint-ignore
|
|
140
|
-
const resolvedTarget = ast.isImported(target)
|
|
141
|
-
? target.imported.ref
|
|
142
|
-
: ast.isElement(target)
|
|
143
|
-
? target
|
|
144
|
-
: undefined;
|
|
145
|
-
return stream(this.genUniqueDescedants(resolvedTarget));
|
|
146
|
-
}
|
|
147
|
-
if (ast.isElement(parentRef)) {
|
|
148
|
-
return stream(this.genUniqueDescedants(parentRef));
|
|
149
|
-
}
|
|
150
|
-
return nonexhaustive(parentRef);
|
|
151
|
-
}
|
|
152
|
-
*genScopeForParentlessFqnRef(projectId, container, context) {
|
|
153
|
-
if (AstUtils.hasContainerOfType(container, ast.isElementRef) ||
|
|
154
|
-
isFqnRefInsideModel(container)) {
|
|
155
|
-
// Inside model scope we only need to resolve elements
|
|
156
|
-
yield* this.computeScope(projectId, context, ast.Element);
|
|
157
|
-
}
|
|
158
|
-
else if (isFqnRefInsideGlobals(container)) {
|
|
159
|
-
yield* this.computeScope(projectId, context, ast.Element);
|
|
160
|
-
yield* this.computeScope(projectId, context, ast.DeploymentNode);
|
|
161
|
-
yield* this.computeScope(projectId, context, ast.DeployedInstance);
|
|
162
|
-
}
|
|
163
|
-
else {
|
|
164
|
-
// First preference for deployment nodes
|
|
165
|
-
yield* this.computeScope(projectId, context, ast.DeploymentNode);
|
|
166
|
-
// Second preference for deployed instances
|
|
167
|
-
yield* this.computeScope(projectId, context, ast.DeployedInstance);
|
|
168
|
-
// Third preference for elements if we are in deployment view
|
|
169
|
-
if (AstUtils.hasContainerOfType(container, ast.isDeploymentViewBody)) {
|
|
170
|
-
yield* this.computeScope(projectId, context, ast.Element);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
const doc = getDocument(container);
|
|
174
|
-
const precomputed = doc.precomputedScopes;
|
|
175
|
-
// Fourth preference for imported models
|
|
176
|
-
if (precomputed) {
|
|
177
|
-
yield* precomputed.values().filter(nd => this.reflection.isSubtype(nd.type, ast.Imported));
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
/**
|
|
181
|
-
* Computes the scope for a given reference context.
|
|
182
|
-
*
|
|
183
|
-
* @param context - The reference information containing the context for which the scope is being computed.
|
|
184
|
-
* @param referenceType - The type of reference being resolved. Defaults to the reference type derived from the context.
|
|
185
|
-
* @returns A scope containing the relevant AST node descriptions for the given reference context.
|
|
186
|
-
*
|
|
187
|
-
* This method first checks if there are precomputed scopes available in the document. If not, it falls back to the global scope.
|
|
188
|
-
* It then iterates through the container hierarchy, collecting relevant scopes based on the reference type and container type.
|
|
189
|
-
* Finally, it combines the collected scopes with the global scope to produce the final scope.
|
|
190
|
-
*/
|
|
191
|
-
*computeScope(projectId, context, referenceType = this.reflection.getReferenceType(context)) {
|
|
192
|
-
const isElementReference = this.reflection.isSubtype(referenceType, ast.Element);
|
|
193
|
-
const isDeploymentReference = this.reflection.isSubtype(referenceType, ast.DeploymentElement);
|
|
194
|
-
const doc = getDocument(context.container);
|
|
195
|
-
const precomputed = doc.precomputedScopes;
|
|
196
|
-
if (!precomputed) {
|
|
197
|
-
yield* this.getProjectScope(projectId, referenceType, context).getAllElements();
|
|
198
|
-
return;
|
|
199
|
-
}
|
|
200
|
-
const byReferenceType = (desc) => this.reflection.isSubtype(desc.type, referenceType);
|
|
201
|
-
let container = context.container;
|
|
202
|
-
while (container) {
|
|
203
|
-
const elements = precomputed.get(container).filter(byReferenceType);
|
|
204
|
-
if (elements.length > 0) {
|
|
205
|
-
yield* elements;
|
|
206
|
-
}
|
|
207
|
-
if (isDeploymentReference && ast.isExtendDeploymentBody(container)) {
|
|
208
|
-
yield* this.genScopeExtendDeployment(container.$container);
|
|
209
|
-
}
|
|
210
|
-
if (isElementReference && ast.isExtendElementBody(container)) {
|
|
211
|
-
yield* this.genScopeExtendElement(container.$container);
|
|
212
|
-
}
|
|
213
|
-
if (isElementReference && ast.isElementViewBody(container)) {
|
|
214
|
-
yield* this.genScopeElementView(container.$container);
|
|
215
|
-
}
|
|
216
|
-
container = container.$container;
|
|
217
|
-
}
|
|
218
|
-
yield* this.getProjectScope(projectId, referenceType, context).getAllElements();
|
|
219
|
-
}
|
|
220
|
-
/**
|
|
221
|
-
* Create a global scope filtered for the given reference type.
|
|
222
|
-
*/
|
|
223
|
-
getProjectScope(projectId, referenceType, context) {
|
|
224
|
-
if (referenceType === ast.LibIcon) {
|
|
225
|
-
return super.getGlobalScope(referenceType, context);
|
|
226
|
-
}
|
|
227
|
-
return this.globalScopeCache.get(`${projectId}::${referenceType}`, () => new MapScope(this.indexManager.projectElements(projectId, referenceType)));
|
|
228
|
-
}
|
|
229
|
-
/**
|
|
230
|
-
* Create a global scope filtered for the given reference type.
|
|
231
|
-
*/
|
|
232
|
-
getGlobalScope(referenceType, context) {
|
|
233
|
-
if (referenceType === ast.LibIcon) {
|
|
234
|
-
return super.getGlobalScope(referenceType, context);
|
|
235
|
-
}
|
|
236
|
-
const projectId = projectIdFrom(context.container);
|
|
237
|
-
return this.getProjectScope(projectId, referenceType, context);
|
|
238
|
-
}
|
|
239
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { type AstNode, type AstNodeDescription } from 'langium';
|
|
2
|
-
import type { LangiumSharedServices, NodeKindProvider as LspNodeKindProvider } from 'langium/lsp';
|
|
3
|
-
import { CompletionItemKind, SymbolKind } from 'vscode-languageserver-types';
|
|
4
|
-
export declare class NodeKindProvider implements LspNodeKindProvider {
|
|
5
|
-
private services;
|
|
6
|
-
constructor(services: LangiumSharedServices);
|
|
7
|
-
/**
|
|
8
|
-
* Returns a `SymbolKind` as used by `WorkspaceSymbolProvider` or `DocumentSymbolProvider`.
|
|
9
|
-
*/
|
|
10
|
-
getSymbolKind(node: AstNode | AstNodeDescription): SymbolKind;
|
|
11
|
-
/**
|
|
12
|
-
* Returns a `CompletionItemKind` as used by the `CompletionProvider`.
|
|
13
|
-
*/
|
|
14
|
-
getCompletionItemKind(node: AstNode | AstNodeDescription): CompletionItemKind;
|
|
15
|
-
}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { isAstNode } from 'langium';
|
|
2
|
-
import { CompletionItemKind, SymbolKind } from 'vscode-languageserver-types';
|
|
3
|
-
import { ast } from '../ast';
|
|
4
|
-
export class NodeKindProvider {
|
|
5
|
-
services;
|
|
6
|
-
constructor(services) {
|
|
7
|
-
this.services = services;
|
|
8
|
-
}
|
|
9
|
-
/**
|
|
10
|
-
* Returns a `SymbolKind` as used by `WorkspaceSymbolProvider` or `DocumentSymbolProvider`.
|
|
11
|
-
*/
|
|
12
|
-
// prettier-ignore
|
|
13
|
-
getSymbolKind(node) {
|
|
14
|
-
const nodeType = isAstNode(node) ? node.$type : node.type;
|
|
15
|
-
const hasType = (...types) => types.some(t => this.services.AstReflection.isSubtype(nodeType, t));
|
|
16
|
-
switch (true) {
|
|
17
|
-
case hasType(ast.Element, ast.ExtendElement, ast.DeploymentNode, ast.DeployedInstance, ast.Imported):
|
|
18
|
-
return SymbolKind.Constructor;
|
|
19
|
-
case hasType(ast.Model, ast.ModelViews, ast.ModelDeployments, ast.Globals, ast.SpecificationRule):
|
|
20
|
-
return SymbolKind.Namespace;
|
|
21
|
-
case hasType(ast.LikeC4View):
|
|
22
|
-
return SymbolKind.Class;
|
|
23
|
-
case hasType(ast.Tag, ast.LibIcon, ast.CustomColor, ast.SpecificationTag):
|
|
24
|
-
return SymbolKind.EnumMember;
|
|
25
|
-
case hasType(ast.RelationshipKind, ast.SpecificationRelationshipKind):
|
|
26
|
-
return SymbolKind.Event;
|
|
27
|
-
case hasType(ast.ElementKind, ast.DeploymentNodeKind, ast.SpecificationElementKind, ast.SpecificationDeploymentNodeKind):
|
|
28
|
-
return SymbolKind.TypeParameter;
|
|
29
|
-
}
|
|
30
|
-
return SymbolKind.Field;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Returns a `CompletionItemKind` as used by the `CompletionProvider`.
|
|
34
|
-
*/
|
|
35
|
-
getCompletionItemKind(node) {
|
|
36
|
-
const nodeType = isAstNode(node) ? node.$type : node.type;
|
|
37
|
-
const hasType = (...types) => types.some(t => this.services.AstReflection.isSubtype(nodeType, t));
|
|
38
|
-
switch (true) {
|
|
39
|
-
case hasType(ast.CustomColor):
|
|
40
|
-
return CompletionItemKind.Color;
|
|
41
|
-
case hasType(ast.Element, ast.DeploymentNode, ast.DeployedInstance, ast.ExtendElement, ast.Imported):
|
|
42
|
-
return CompletionItemKind.Constructor;
|
|
43
|
-
case hasType(ast.Model, ast.ModelViews, ast.ModelDeployments, ast.Globals, ast.SpecificationRule):
|
|
44
|
-
return CompletionItemKind.Module;
|
|
45
|
-
case hasType(ast.LikeC4View):
|
|
46
|
-
return CompletionItemKind.Class;
|
|
47
|
-
case hasType(ast.Tag, ast.LibIcon, ast.CustomColor, ast.SpecificationTag):
|
|
48
|
-
return CompletionItemKind.EnumMember;
|
|
49
|
-
case hasType(ast.RelationshipKind, ast.SpecificationRelationshipKind):
|
|
50
|
-
return CompletionItemKind.Event;
|
|
51
|
-
case hasType(ast.ElementKind, ast.SpecificationElementKind, ast.DeploymentNodeKind, ast.SpecificationDeploymentNodeKind):
|
|
52
|
-
return CompletionItemKind.TypeParameter;
|
|
53
|
-
default:
|
|
54
|
-
return CompletionItemKind.Reference;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
package/dist/shared/index.d.ts
DELETED
package/dist/shared/index.js
DELETED
package/dist/test/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './testServices';
|
package/dist/test/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './testServices';
|