@likec4/language-server 1.43.0 → 1.44.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/browser/package.json +1 -1
- package/browser-worker/package.json +1 -1
- package/dist/LikeC4LanguageServices.d.ts +12 -19
- package/dist/LikeC4LanguageServices.js +182 -0
- package/dist/Rpc.js +245 -0
- package/dist/ast.d.ts +5 -1
- package/dist/ast.js +253 -0
- package/dist/browser-worker.js +4 -0
- package/dist/browser.js +35 -0
- package/dist/bundled.js +42 -0
- package/dist/bundled.mjs +3542 -3896
- package/dist/documentation/documentation-provider.js +51 -0
- package/dist/documentation/index.js +1 -0
- package/dist/empty.js +2 -0
- package/dist/filesystem/ChokidarWatcher.js +97 -0
- package/dist/filesystem/FileSystemWatcher.js +14 -0
- package/dist/filesystem/LikeC4FileSystem.d.ts +1 -2
- package/dist/filesystem/LikeC4FileSystem.js +126 -0
- package/dist/filesystem/index.d.ts +26 -0
- package/dist/filesystem/index.js +29 -0
- package/dist/formatting/LikeC4Formatter.js +637 -0
- package/dist/formatting/utils.js +18 -0
- package/dist/generated/ast.js +2155 -0
- package/dist/generated/{grammar.mjs → grammar.js} +6 -2
- package/dist/generated/module.d.ts +6 -1
- package/dist/generated/module.js +27 -0
- package/dist/generated-lib/{icons.mjs → icons.js} +11 -7
- package/dist/index.d.ts +7 -0
- package/dist/index.js +53 -0
- package/dist/{likec4lib.mjs → likec4lib.js} +3 -3
- package/dist/logger.js +81 -0
- package/dist/lsp/CodeActionProvider.d.ts +14 -0
- package/dist/lsp/CodeActionProvider.js +33 -0
- package/dist/lsp/CodeLensProvider.js +44 -0
- package/dist/lsp/CompletionProvider.d.ts +3 -1
- package/dist/lsp/CompletionProvider.js +200 -0
- package/dist/lsp/DocumentHighlightProvider.js +10 -0
- package/dist/lsp/DocumentLinkProvider.js +58 -0
- package/dist/lsp/DocumentSymbolProvider.js +306 -0
- package/dist/lsp/HoverProvider.js +106 -0
- package/dist/lsp/RenameProvider.js +6 -0
- package/dist/lsp/SemanticTokenProvider.js +257 -0
- package/dist/lsp/index.d.ts +1 -0
- package/dist/lsp/index.js +9 -0
- package/dist/mcp/MCPServerFactory.js +73 -0
- package/dist/mcp/NoopLikeC4MCPServer.js +17 -0
- package/dist/mcp/interfaces.js +5 -0
- package/dist/mcp/server/StdioLikeC4MCPServer.js +47 -0
- package/dist/mcp/server/StreamableLikeC4MCPServer.js +145 -0
- package/dist/mcp/server/WithMCPServer.js +56 -0
- package/dist/mcp/tools/_common.d.ts +8 -7
- package/dist/mcp/tools/_common.js +49 -0
- package/dist/mcp/tools/find-relationships.d.ts +7 -8
- package/dist/mcp/tools/find-relationships.js +150 -0
- package/dist/mcp/tools/list-projects.d.ts +3 -3
- package/dist/mcp/tools/list-projects.js +62 -0
- package/dist/mcp/tools/open-view.d.ts +6 -7
- package/dist/mcp/tools/open-view.js +52 -0
- package/dist/mcp/tools/read-deployment.d.ts +6 -7
- package/dist/mcp/tools/read-deployment.js +132 -0
- package/dist/mcp/tools/read-element.d.ts +6 -7
- package/dist/mcp/tools/read-element.js +194 -0
- package/dist/mcp/tools/read-project-summary.d.ts +5 -6
- package/dist/mcp/tools/read-project-summary.js +176 -0
- package/dist/mcp/tools/read-view.d.ts +6 -7
- package/dist/mcp/tools/read-view.js +203 -0
- package/dist/mcp/tools/search-element.d.ts +3 -3
- package/dist/mcp/tools/search-element.js +177 -0
- package/dist/mcp/utils.d.ts +2 -2
- package/dist/mcp/utils.js +48 -0
- package/dist/model/builder/MergedExtends.js +74 -0
- package/dist/model/builder/MergedSpecification.js +175 -0
- package/dist/model/builder/buildModel.js +176 -0
- package/dist/model/deployments-index.js +102 -0
- package/dist/model/fqn-index.js +250 -0
- package/dist/model/index.js +6 -0
- package/dist/model/model-builder.d.ts +13 -11
- package/dist/model/model-builder.js +234 -0
- package/dist/model/model-locator.d.ts +6 -5
- package/dist/model/model-locator.js +240 -0
- package/dist/model/model-parser-where.js +81 -0
- package/dist/model/model-parser.d.ts +309 -304
- package/dist/model/model-parser.js +119 -0
- package/dist/model/parser/Base.d.ts +2 -2
- package/dist/model/parser/Base.js +367 -0
- package/dist/model/parser/DeploymentModelParser.d.ts +2 -2
- package/dist/model/parser/DeploymentModelParser.js +176 -0
- package/dist/model/parser/DeploymentViewParser.d.ts +3 -3
- package/dist/model/parser/DeploymentViewParser.js +86 -0
- package/dist/model/parser/FqnRefParser.d.ts +2 -2
- package/dist/model/parser/FqnRefParser.js +382 -0
- package/dist/model/parser/GlobalsParser.d.ts +6 -6
- package/dist/model/parser/GlobalsParser.js +84 -0
- package/dist/model/parser/ImportsParser.d.ts +11 -12
- package/dist/model/parser/ImportsParser.js +24 -0
- package/dist/model/parser/ModelParser.d.ts +2 -2
- package/dist/model/parser/ModelParser.js +165 -0
- package/dist/model/parser/PredicatesParser.d.ts +2 -2
- package/dist/model/parser/PredicatesParser.js +45 -0
- package/dist/model/parser/SpecificationParser.d.ts +2 -2
- package/dist/model/parser/SpecificationParser.js +109 -0
- package/dist/model/parser/ValueConverter.js +12 -0
- package/dist/model/parser/ViewsParser.d.ts +3 -3
- package/dist/model/parser/ViewsParser.js +477 -0
- package/dist/model-change/ModelChanges.d.ts +6 -3
- package/dist/model-change/ModelChanges.js +102 -0
- package/dist/model-change/changeElementStyle.js +134 -0
- package/dist/model-change/changeViewLayout.d.ts +2 -2
- package/dist/model-change/changeViewLayout.js +28 -0
- package/dist/model-change/removeManualLayoutV1.d.ts +7 -0
- package/dist/model-change/removeManualLayoutV1.js +27 -0
- package/dist/module.d.ts +10 -5
- package/dist/module.js +143 -0
- package/dist/protocol.d.ts +1 -17
- package/dist/protocol.js +114 -0
- package/dist/references/index.js +3 -0
- package/dist/references/name-provider.js +37 -0
- package/dist/references/scope-computation.js +288 -0
- package/dist/references/scope-provider.d.ts +3 -3
- package/dist/references/scope-provider.js +242 -0
- package/dist/shared/NodeKindProvider.js +57 -0
- package/dist/shared/{WorkspaceSymbolProvider.mjs → WorkspaceSymbolProvider.js} +1 -1
- package/dist/shared/index.js +2 -0
- package/dist/test/index.js +1 -0
- package/dist/test/testServices.d.ts +16 -16
- package/dist/test/testServices.js +210 -0
- package/dist/utils/disposable.js +26 -0
- package/dist/utils/elementRef.d.ts +1 -1
- package/dist/utils/elementRef.js +27 -0
- package/dist/utils/fqnRef.js +63 -0
- package/dist/utils/index.js +35 -0
- package/dist/utils/printDocs.js +1 -0
- package/dist/utils/projectId.js +16 -0
- package/dist/utils/stringHash.js +5 -0
- package/dist/validation/DocumentValidator.js +17 -0
- package/dist/validation/_shared.js +26 -0
- package/dist/validation/deployment-checks.js +140 -0
- package/dist/validation/dynamic-view.js +67 -0
- package/dist/validation/element-ref.js +12 -0
- package/dist/validation/element.js +49 -0
- package/dist/validation/imports.js +46 -0
- package/dist/validation/index.d.ts +1 -1
- package/dist/validation/index.js +157 -0
- package/dist/validation/property-checks.js +108 -0
- package/dist/validation/relation.js +55 -0
- package/dist/validation/specification.js +190 -0
- package/dist/validation/view-predicates/fqn-expr-with.js +43 -0
- package/dist/validation/view-predicates/fqn-ref-expr.js +51 -0
- package/dist/validation/view-predicates/incoming.js +16 -0
- package/dist/validation/view-predicates/index.js +6 -0
- package/dist/validation/view-predicates/outgoing.js +20 -0
- package/dist/validation/view-predicates/relation-expr.js +46 -0
- package/dist/validation/view-predicates/relation-with.js +16 -0
- package/dist/validation/view.d.ts +1 -1
- package/dist/validation/view.js +42 -0
- package/dist/view-utils/assignNavigateTo.js +27 -0
- package/dist/view-utils/index.d.ts +1 -0
- package/dist/view-utils/index.js +2 -0
- package/dist/view-utils/manual-layout.d.ts +6 -0
- package/dist/view-utils/manual-layout.js +151 -0
- package/dist/views/ConfigurableLayouter.js +51 -0
- package/dist/views/LikeC4ManualLayouts.d.ts +28 -0
- package/dist/views/LikeC4ManualLayouts.js +132 -0
- package/dist/views/{likec4-views.d.ts → LikeC4Views.d.ts} +9 -8
- package/dist/views/LikeC4Views.js +200 -0
- package/dist/views/index.d.ts +4 -1
- package/dist/views/index.js +11 -0
- package/dist/workspace/AstNodeDescriptionProvider.js +15 -0
- package/dist/workspace/IndexManager.js +21 -0
- package/dist/workspace/LangiumDocuments.d.ts +1 -1
- package/dist/workspace/LangiumDocuments.js +58 -0
- package/dist/workspace/ProjectsManager.d.ts +8 -3
- package/dist/workspace/ProjectsManager.js +373 -0
- package/dist/workspace/WorkspaceManager.d.ts +3 -2
- package/dist/workspace/WorkspaceManager.js +93 -0
- package/dist/workspace/index.js +5 -0
- package/likec4lib/package.json +1 -1
- package/package.json +25 -24
- package/protocol/package.json +1 -1
- package/dist/LikeC4LanguageServices.mjs +0 -197
- package/dist/Rpc.mjs +0 -296
- package/dist/ast.mjs +0 -221
- package/dist/browser-worker.mjs +0 -2
- package/dist/browser.mjs +0 -32
- package/dist/documentation/documentation-provider.mjs +0 -48
- package/dist/documentation/index.mjs +0 -1
- package/dist/empty.mjs +0 -1
- package/dist/filesystem/ChokidarWatcher.mjs +0 -68
- package/dist/filesystem/FileSystemWatcher.mjs +0 -11
- package/dist/filesystem/LikeC4FileSystem.mjs +0 -64
- package/dist/filesystem/index.mjs +0 -19
- package/dist/formatting/LikeC4Formatter.mjs +0 -511
- package/dist/formatting/utils.mjs +0 -15
- package/dist/generated/ast.mjs +0 -2150
- package/dist/generated/module.mjs +0 -23
- package/dist/index.mjs +0 -50
- package/dist/logger.mjs +0 -82
- package/dist/lsp/CodeLensProvider.mjs +0 -42
- package/dist/lsp/CompletionProvider.mjs +0 -208
- package/dist/lsp/DocumentHighlightProvider.mjs +0 -10
- package/dist/lsp/DocumentLinkProvider.mjs +0 -53
- package/dist/lsp/DocumentSymbolProvider.mjs +0 -287
- package/dist/lsp/HoverProvider.mjs +0 -104
- package/dist/lsp/RenameProvider.mjs +0 -6
- package/dist/lsp/SemanticTokenProvider.mjs +0 -276
- package/dist/lsp/index.mjs +0 -7
- package/dist/mcp/MCPServerFactory.mjs +0 -70
- package/dist/mcp/NoopLikeC4MCPServer.mjs +0 -17
- package/dist/mcp/interfaces.mjs +0 -4
- package/dist/mcp/server/StdioLikeC4MCPServer.mjs +0 -46
- package/dist/mcp/server/StreamableLikeC4MCPServer.mjs +0 -153
- package/dist/mcp/server/WithMCPServer.mjs +0 -58
- package/dist/mcp/tools/_common.mjs +0 -42
- package/dist/mcp/tools/find-relationships.mjs +0 -151
- package/dist/mcp/tools/list-projects.mjs +0 -62
- package/dist/mcp/tools/open-view.mjs +0 -52
- package/dist/mcp/tools/read-deployment.mjs +0 -130
- package/dist/mcp/tools/read-element.mjs +0 -198
- package/dist/mcp/tools/read-project-summary.mjs +0 -178
- package/dist/mcp/tools/read-view.mjs +0 -205
- package/dist/mcp/tools/search-element.mjs +0 -171
- package/dist/mcp/utils.mjs +0 -47
- package/dist/model/builder/MergedExtends.mjs +0 -76
- package/dist/model/builder/MergedSpecification.mjs +0 -205
- package/dist/model/builder/assignTagColors.d.ts +0 -7
- package/dist/model/builder/assignTagColors.mjs +0 -51
- package/dist/model/builder/buildModel.mjs +0 -226
- package/dist/model/deployments-index.mjs +0 -100
- package/dist/model/fqn-index.mjs +0 -243
- package/dist/model/index.mjs +0 -6
- package/dist/model/model-builder.mjs +0 -285
- package/dist/model/model-locator.mjs +0 -239
- package/dist/model/model-parser-where.mjs +0 -81
- package/dist/model/model-parser.mjs +0 -127
- package/dist/model/parser/Base.mjs +0 -376
- package/dist/model/parser/DeploymentModelParser.mjs +0 -212
- package/dist/model/parser/DeploymentViewParser.mjs +0 -95
- package/dist/model/parser/FqnRefParser.mjs +0 -398
- package/dist/model/parser/GlobalsParser.mjs +0 -82
- package/dist/model/parser/ImportsParser.mjs +0 -28
- package/dist/model/parser/ModelParser.mjs +0 -190
- package/dist/model/parser/PredicatesParser.mjs +0 -45
- package/dist/model/parser/SpecificationParser.mjs +0 -120
- package/dist/model/parser/ValueConverter.mjs +0 -12
- package/dist/model/parser/ViewsParser.mjs +0 -490
- package/dist/model-change/ModelChanges.mjs +0 -89
- package/dist/model-change/changeElementStyle.mjs +0 -143
- package/dist/model-change/changeViewLayout.mjs +0 -32
- package/dist/model-change/saveManualLayout.d.ts +0 -11
- package/dist/model-change/saveManualLayout.mjs +0 -27
- package/dist/module.mjs +0 -180
- package/dist/protocol.mjs +0 -65
- package/dist/references/index.mjs +0 -3
- package/dist/references/name-provider.mjs +0 -39
- package/dist/references/scope-computation.mjs +0 -312
- package/dist/references/scope-provider.mjs +0 -239
- package/dist/shared/NodeKindProvider.mjs +0 -110
- package/dist/shared/index.mjs +0 -2
- package/dist/test/index.mjs +0 -1
- package/dist/test/testServices.mjs +0 -200
- package/dist/utils/disposable.mjs +0 -25
- package/dist/utils/elementRef.mjs +0 -20
- package/dist/utils/fqnRef.mjs +0 -57
- package/dist/utils/index.mjs +0 -33
- package/dist/utils/printDocs.mjs +0 -1
- package/dist/utils/projectId.mjs +0 -16
- package/dist/utils/stringHash.mjs +0 -5
- package/dist/validation/DocumentValidator.mjs +0 -16
- package/dist/validation/_shared.mjs +0 -25
- package/dist/validation/deployment-checks.mjs +0 -146
- package/dist/validation/dynamic-view.mjs +0 -67
- package/dist/validation/element-ref.mjs +0 -12
- package/dist/validation/element.mjs +0 -50
- package/dist/validation/imports.mjs +0 -25
- package/dist/validation/index.mjs +0 -180
- package/dist/validation/property-checks.mjs +0 -107
- package/dist/validation/relation.mjs +0 -53
- package/dist/validation/specification.mjs +0 -173
- package/dist/validation/view-predicates/fqn-expr-with.mjs +0 -43
- package/dist/validation/view-predicates/fqn-ref-expr.mjs +0 -53
- package/dist/validation/view-predicates/incoming.mjs +0 -16
- package/dist/validation/view-predicates/index.mjs +0 -6
- package/dist/validation/view-predicates/outgoing.mjs +0 -20
- package/dist/validation/view-predicates/relation-expr.mjs +0 -39
- package/dist/validation/view-predicates/relation-with.mjs +0 -16
- package/dist/validation/view.mjs +0 -25
- package/dist/view-utils/assignNavigateTo.mjs +0 -25
- package/dist/view-utils/index.mjs +0 -1
- package/dist/view-utils/manual-layout.mjs +0 -99
- package/dist/views/configurable-layouter.mjs +0 -51
- package/dist/views/index.mjs +0 -1
- package/dist/views/likec4-views.mjs +0 -166
- package/dist/workspace/AstNodeDescriptionProvider.mjs +0 -17
- package/dist/workspace/IndexManager.mjs +0 -17
- package/dist/workspace/LangiumDocuments.mjs +0 -53
- package/dist/workspace/ProjectsManager.mjs +0 -360
- package/dist/workspace/WorkspaceManager.mjs +0 -83
- package/dist/workspace/index.mjs +0 -5
- /package/dist/views/{configurable-layouter.d.ts → ConfigurableLayouter.d.ts} +0 -0
|
@@ -1,197 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
nonexhaustive
|
|
3
|
-
} from "@likec4/core";
|
|
4
|
-
import { LikeC4Model } from "@likec4/core/model";
|
|
5
|
-
import { loggable } from "@likec4/log";
|
|
6
|
-
import { URI } from "langium";
|
|
7
|
-
import { entries, hasAtLeast, indexBy, map, pipe, prop } from "remeda";
|
|
8
|
-
import { DiagnosticSeverity } from "vscode-languageserver-types";
|
|
9
|
-
import { isLikeC4LangiumDocument } from "./ast.mjs";
|
|
10
|
-
import { logger as mainLogger, logWarnError } from "./logger.mjs";
|
|
11
|
-
import { ProjectsManager } from "./workspace/index.mjs";
|
|
12
|
-
const logger = mainLogger.getChild("LanguageServices");
|
|
13
|
-
export class DefaultLikeC4LanguageServices {
|
|
14
|
-
constructor(services) {
|
|
15
|
-
this.services = services;
|
|
16
|
-
this.builder = services.likec4.ModelBuilder;
|
|
17
|
-
this.projectsManager = services.shared.workspace.ProjectsManager;
|
|
18
|
-
}
|
|
19
|
-
builder;
|
|
20
|
-
projectsManager;
|
|
21
|
-
get views() {
|
|
22
|
-
return this.services.likec4.Views;
|
|
23
|
-
}
|
|
24
|
-
get workspaceUri() {
|
|
25
|
-
return this.services.shared.workspace.WorkspaceManager.workspaceUri;
|
|
26
|
-
}
|
|
27
|
-
projects() {
|
|
28
|
-
const projectsManager = this.services.shared.workspace.ProjectsManager;
|
|
29
|
-
const projectsWithDocs = pipe(
|
|
30
|
-
this.services.shared.workspace.LangiumDocuments.groupedByProject(),
|
|
31
|
-
entries(),
|
|
32
|
-
map(([projectId, docs]) => {
|
|
33
|
-
const id = projectId;
|
|
34
|
-
const { folderUri: folderUri2, config: config2 } = projectsManager.getProject(id);
|
|
35
|
-
return {
|
|
36
|
-
id,
|
|
37
|
-
folder: folderUri2,
|
|
38
|
-
title: config2.title ?? config2.name,
|
|
39
|
-
documents: map(docs, prop("uri")),
|
|
40
|
-
config: config2
|
|
41
|
-
};
|
|
42
|
-
})
|
|
43
|
-
);
|
|
44
|
-
if (hasAtLeast(projectsWithDocs, 2) && projectsManager.defaultProjectId) {
|
|
45
|
-
const idx = projectsWithDocs.findIndex((p) => p.id === projectsManager.defaultProjectId);
|
|
46
|
-
if (idx > 0) {
|
|
47
|
-
const [defaultProject] = projectsWithDocs.splice(idx, 1);
|
|
48
|
-
return [defaultProject, ...projectsWithDocs];
|
|
49
|
-
}
|
|
50
|
-
return projectsWithDocs;
|
|
51
|
-
}
|
|
52
|
-
if (hasAtLeast(projectsWithDocs, 1)) {
|
|
53
|
-
return projectsWithDocs;
|
|
54
|
-
}
|
|
55
|
-
const { folderUri, config } = projectsManager.getProject(ProjectsManager.DefaultProjectId);
|
|
56
|
-
const documents = map(
|
|
57
|
-
this.services.shared.workspace.LangiumDocuments.projectDocuments(ProjectsManager.DefaultProjectId).toArray(),
|
|
58
|
-
prop("uri")
|
|
59
|
-
);
|
|
60
|
-
return [{
|
|
61
|
-
id: ProjectsManager.DefaultProjectId,
|
|
62
|
-
folder: folderUri,
|
|
63
|
-
title: config.title ?? config.name,
|
|
64
|
-
documents,
|
|
65
|
-
config
|
|
66
|
-
}];
|
|
67
|
-
}
|
|
68
|
-
project(projectId) {
|
|
69
|
-
projectId = this.projectsManager.ensureProjectId(projectId);
|
|
70
|
-
const projectsManager = this.services.shared.workspace.ProjectsManager;
|
|
71
|
-
const { folderUri, config } = projectsManager.getProject(projectId);
|
|
72
|
-
const documents = map(
|
|
73
|
-
this.services.shared.workspace.LangiumDocuments.projectDocuments(projectId).toArray(),
|
|
74
|
-
prop("uri")
|
|
75
|
-
);
|
|
76
|
-
return {
|
|
77
|
-
id: projectId,
|
|
78
|
-
folder: folderUri,
|
|
79
|
-
title: config.title ?? config.name,
|
|
80
|
-
documents,
|
|
81
|
-
config
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Diagram is a computed view, layouted using Graphviz
|
|
86
|
-
* Used in React components
|
|
87
|
-
*/
|
|
88
|
-
async diagrams() {
|
|
89
|
-
return await this.views.diagrams();
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Builds LikeC4Model from all documents
|
|
93
|
-
* Only computes view predicates {@link ComputedView} - i.e. no layout
|
|
94
|
-
* Not ready for rendering, but enough to traverse
|
|
95
|
-
*/
|
|
96
|
-
async computedModel(project) {
|
|
97
|
-
const projectId = this.projectsManager.ensureProjectId(project);
|
|
98
|
-
return await this.builder.buildLikeC4Model(projectId);
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Same as {@link computedModel()}, but also applies layout
|
|
102
|
-
* Ready for rendering
|
|
103
|
-
*/
|
|
104
|
-
async layoutedModel(project) {
|
|
105
|
-
const projectId = this.projectsManager.ensureProjectId(project);
|
|
106
|
-
const parsed = await this.builder.parseModel(projectId);
|
|
107
|
-
if (!parsed) {
|
|
108
|
-
throw new Error("Failed to parse model");
|
|
109
|
-
}
|
|
110
|
-
const diagrams = await this.views.diagrams(projectId);
|
|
111
|
-
return LikeC4Model.create({
|
|
112
|
-
...parsed.$data,
|
|
113
|
-
_stage: "layouted",
|
|
114
|
-
views: indexBy(diagrams, prop("id"))
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
getErrors() {
|
|
118
|
-
const docs = this.services.shared.workspace.LangiumDocuments.allExcludingBuiltin.toArray();
|
|
119
|
-
return docs.flatMap((doc) => {
|
|
120
|
-
return (doc.diagnostics ?? []).filter((d) => d.severity === DiagnosticSeverity.Error).map(({ message, range }) => ({
|
|
121
|
-
message,
|
|
122
|
-
line: range.start.line,
|
|
123
|
-
range,
|
|
124
|
-
sourceFsPath: doc.uri.fsPath
|
|
125
|
-
}));
|
|
126
|
-
});
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* TODO Replace with watcher
|
|
130
|
-
*/
|
|
131
|
-
async notifyUpdate({ changed, removed }) {
|
|
132
|
-
if (!changed && !removed) {
|
|
133
|
-
return false;
|
|
134
|
-
}
|
|
135
|
-
const _changed = changed ? URI.file(changed) : void 0;
|
|
136
|
-
const _removed = removed ? URI.file(removed) : void 0;
|
|
137
|
-
const pm = this.services.shared.workspace.ProjectsManager;
|
|
138
|
-
if (_changed && pm.isConfigFile(_changed) || _removed && pm.isConfigFile(_removed)) {
|
|
139
|
-
await pm.reloadProjects();
|
|
140
|
-
return true;
|
|
141
|
-
}
|
|
142
|
-
const mutex = this.services.shared.workspace.WorkspaceLock;
|
|
143
|
-
try {
|
|
144
|
-
let completed = false;
|
|
145
|
-
await mutex.write(async (token) => {
|
|
146
|
-
await this.services.shared.workspace.DocumentBuilder.update(
|
|
147
|
-
_changed ? [_changed] : [],
|
|
148
|
-
_removed ? [_removed] : [],
|
|
149
|
-
token
|
|
150
|
-
);
|
|
151
|
-
completed = !token.isCancellationRequested;
|
|
152
|
-
});
|
|
153
|
-
return completed;
|
|
154
|
-
} catch (e) {
|
|
155
|
-
logger.error(loggable(e));
|
|
156
|
-
return false;
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
locate(params) {
|
|
160
|
-
switch (true) {
|
|
161
|
-
case "element" in params:
|
|
162
|
-
return this.services.likec4.ModelLocator.locateElement(params.element, params.projectId);
|
|
163
|
-
case "relation" in params:
|
|
164
|
-
return this.services.likec4.ModelLocator.locateRelation(params.relation, params.projectId);
|
|
165
|
-
case "view" in params:
|
|
166
|
-
return this.services.likec4.ModelLocator.locateView(params.view, params.projectId);
|
|
167
|
-
case "deployment" in params:
|
|
168
|
-
return this.services.likec4.ModelLocator.locateDeploymentElement(
|
|
169
|
-
params.deployment,
|
|
170
|
-
params.projectId
|
|
171
|
-
);
|
|
172
|
-
default:
|
|
173
|
-
nonexhaustive(params);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* Checks if the specified document should be excluded from processing.
|
|
178
|
-
*/
|
|
179
|
-
isExcluded(doc) {
|
|
180
|
-
try {
|
|
181
|
-
return !isLikeC4LangiumDocument(doc) || this.services.shared.workspace.ProjectsManager.checkIfExcluded(doc);
|
|
182
|
-
} catch (e) {
|
|
183
|
-
logWarnError(e);
|
|
184
|
-
return false;
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
async dispose() {
|
|
188
|
-
logger.debug("disposing LikeC4LanguageServices");
|
|
189
|
-
await this.services.shared.workspace.FileSystemWatcher.dispose();
|
|
190
|
-
if (this.services.mcp.Server.isStarted) {
|
|
191
|
-
await this.services.mcp.Server.stop();
|
|
192
|
-
}
|
|
193
|
-
this.services.Rpc.dispose();
|
|
194
|
-
this.services.likec4.ModelBuilder.dispose();
|
|
195
|
-
logger.debug("LikeC4LanguageServices disposed");
|
|
196
|
-
}
|
|
197
|
-
}
|
package/dist/Rpc.mjs
DELETED
|
@@ -1,296 +0,0 @@
|
|
|
1
|
-
import { filter, flatMap, funnel, indexBy, keys, map, mapValues, pipe, sort } from "remeda";
|
|
2
|
-
import { logger as rootLogger } from "./logger.mjs";
|
|
3
|
-
import { serializableLikeC4ProjectConfig } from "@likec4/config";
|
|
4
|
-
import {
|
|
5
|
-
invariant,
|
|
6
|
-
nonexhaustive
|
|
7
|
-
} from "@likec4/core";
|
|
8
|
-
import { LikeC4Model } from "@likec4/core/model";
|
|
9
|
-
import { Disposable, interruptAndCheck, URI, UriUtils } from "langium";
|
|
10
|
-
import { DiagnosticSeverity } from "vscode-languageserver-protocol";
|
|
11
|
-
import {
|
|
12
|
-
BuildDocuments,
|
|
13
|
-
ChangeView,
|
|
14
|
-
ComputeView,
|
|
15
|
-
DidChangeModelNotification,
|
|
16
|
-
DidRequestOpenViewNotification,
|
|
17
|
-
FetchComputedModel,
|
|
18
|
-
FetchLayoutedModel,
|
|
19
|
-
FetchProjects,
|
|
20
|
-
FetchTelemetryMetrics,
|
|
21
|
-
FetchViewsFromAllProjects,
|
|
22
|
-
GetDocumentTags,
|
|
23
|
-
LayoutView,
|
|
24
|
-
Locate,
|
|
25
|
-
RegisterProject,
|
|
26
|
-
ReloadProjects,
|
|
27
|
-
ValidateLayout
|
|
28
|
-
} from "./protocol.mjs";
|
|
29
|
-
import { ADisposable } from "./utils/index.mjs";
|
|
30
|
-
const logger = rootLogger.getChild("rpc");
|
|
31
|
-
export class Rpc extends ADisposable {
|
|
32
|
-
constructor(services) {
|
|
33
|
-
super();
|
|
34
|
-
this.services = services;
|
|
35
|
-
}
|
|
36
|
-
init() {
|
|
37
|
-
const connection = this.services.shared.lsp.Connection;
|
|
38
|
-
if (!connection) {
|
|
39
|
-
logger.info(`[ServerRpc] no connection, not initializing`);
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
logger.info(`[ServerRpc] init`);
|
|
43
|
-
const likec4Services = this.services.likec4;
|
|
44
|
-
const projects = this.services.shared.workspace.ProjectsManager;
|
|
45
|
-
const LangiumDocuments = this.services.shared.workspace.LangiumDocuments;
|
|
46
|
-
const DocumentBuilder = this.services.shared.workspace.DocumentBuilder;
|
|
47
|
-
const notifyModelParsed = funnel(
|
|
48
|
-
() => {
|
|
49
|
-
logger.debug`sendNotification ${"onDidChangeModel"}`;
|
|
50
|
-
connection.sendNotification(DidChangeModelNotification.type, "").catch((error) => {
|
|
51
|
-
logger.warn(`[ServerRpc] error sending onDidChangeModel:`, { error });
|
|
52
|
-
return;
|
|
53
|
-
});
|
|
54
|
-
},
|
|
55
|
-
{
|
|
56
|
-
triggerAt: "end",
|
|
57
|
-
minQuietPeriodMs: 150,
|
|
58
|
-
maxBurstDurationMs: 500,
|
|
59
|
-
minGapMs: 300
|
|
60
|
-
}
|
|
61
|
-
);
|
|
62
|
-
let isFirstBuild = true;
|
|
63
|
-
this.onDispose(
|
|
64
|
-
likec4Services.ModelBuilder.onModelParsed(() => notifyModelParsed.call()),
|
|
65
|
-
connection.onRequest(FetchComputedModel.req, async ({ projectId, cleanCaches }, cancelToken) => {
|
|
66
|
-
logger.debug`received request ${"fetchComputedModel"} for project ${projectId}`;
|
|
67
|
-
if (cleanCaches) {
|
|
68
|
-
const docs = projectId ? LangiumDocuments.projectDocuments(projectId) : LangiumDocuments.allExcludingBuiltin;
|
|
69
|
-
const uris = docs.toArray().map((d) => d.uri);
|
|
70
|
-
await DocumentBuilder.update(uris, [], cancelToken);
|
|
71
|
-
}
|
|
72
|
-
const likec4model = await likec4Services.ModelBuilder.buildLikeC4Model(projectId, cancelToken);
|
|
73
|
-
if (likec4model !== LikeC4Model.EMPTY) {
|
|
74
|
-
return { model: likec4model.$model };
|
|
75
|
-
}
|
|
76
|
-
return { model: null };
|
|
77
|
-
}),
|
|
78
|
-
connection.onRequest(ComputeView.req, async ({ viewId, projectId }, cancelToken) => {
|
|
79
|
-
const view = await likec4Services.ModelBuilder.computeView(viewId, projectId, cancelToken);
|
|
80
|
-
return { view };
|
|
81
|
-
}),
|
|
82
|
-
connection.onRequest(FetchLayoutedModel.req, async ({ projectId }, cancelToken) => {
|
|
83
|
-
const model = await likec4Services.ModelBuilder.parseModel(projectId, cancelToken);
|
|
84
|
-
if (model === null) {
|
|
85
|
-
return { model: null };
|
|
86
|
-
}
|
|
87
|
-
const diagrams = await likec4Services.Views.diagrams(projectId, cancelToken);
|
|
88
|
-
return {
|
|
89
|
-
model: {
|
|
90
|
-
...model.$data,
|
|
91
|
-
_stage: "layouted",
|
|
92
|
-
views: indexBy(diagrams, (d) => d.id)
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
}),
|
|
96
|
-
connection.onRequest(LayoutView.req, async ({ viewId, projectId }, cancelToken) => {
|
|
97
|
-
logger.debug`received request ${"layoutView"} of ${viewId} from project ${projectId}`;
|
|
98
|
-
const result = await likec4Services.Views.layoutView(viewId, projectId, cancelToken);
|
|
99
|
-
return { result };
|
|
100
|
-
}),
|
|
101
|
-
connection.onRequest(ValidateLayout.Req, async ({ projectId }, cancelToken) => {
|
|
102
|
-
const layouts = await likec4Services.Views.layoutAllViews(projectId, cancelToken);
|
|
103
|
-
const result = reportLayoutDrift(layouts.map((l) => l.diagram));
|
|
104
|
-
return { result };
|
|
105
|
-
}),
|
|
106
|
-
connection.onRequest(FetchProjects.req, async (_cancelToken) => {
|
|
107
|
-
logger.debug`received request ${"FetchProjects"}`;
|
|
108
|
-
const docsByProject = LangiumDocuments.groupedByProject();
|
|
109
|
-
return {
|
|
110
|
-
projects: mapValues(docsByProject, (docs, projectId) => {
|
|
111
|
-
const {
|
|
112
|
-
folderUri,
|
|
113
|
-
config
|
|
114
|
-
} = projects.getProject(projectId);
|
|
115
|
-
return {
|
|
116
|
-
folder: folderUri.toString(),
|
|
117
|
-
config: serializableLikeC4ProjectConfig(config),
|
|
118
|
-
docs: map(docs, (d) => d.uri.toString())
|
|
119
|
-
};
|
|
120
|
-
})
|
|
121
|
-
};
|
|
122
|
-
}),
|
|
123
|
-
connection.onRequest(ReloadProjects.req, async () => {
|
|
124
|
-
logger.debug`received request ${"ReloadProjects"}`;
|
|
125
|
-
await projects.reloadProjects();
|
|
126
|
-
return;
|
|
127
|
-
}),
|
|
128
|
-
connection.onRequest(RegisterProject.req, async (params) => {
|
|
129
|
-
logger.debug`received request ${"RegisterProject"}`;
|
|
130
|
-
const project = await projects.registerProject(params);
|
|
131
|
-
return { id: project.id };
|
|
132
|
-
}),
|
|
133
|
-
connection.onRequest(FetchViewsFromAllProjects.req, async (cancelToken) => {
|
|
134
|
-
logger.debug`received request ${"FetchViewsFromAllProjects"}`;
|
|
135
|
-
const promises = projects.all.map(async (projectId) => {
|
|
136
|
-
const computedViews = await likec4Services.Views.computedViews(projectId, cancelToken);
|
|
137
|
-
return pipe(
|
|
138
|
-
computedViews,
|
|
139
|
-
map((v) => ({
|
|
140
|
-
id: v.id,
|
|
141
|
-
title: v.title ?? v.id,
|
|
142
|
-
projectId
|
|
143
|
-
})),
|
|
144
|
-
sort((a, b) => {
|
|
145
|
-
if (a.id === "index") {
|
|
146
|
-
return -1;
|
|
147
|
-
}
|
|
148
|
-
if (b.id === "index") {
|
|
149
|
-
return 1;
|
|
150
|
-
}
|
|
151
|
-
return a.title.localeCompare(b.title);
|
|
152
|
-
})
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
const results = await Promise.allSettled(promises);
|
|
156
|
-
await interruptAndCheck(cancelToken);
|
|
157
|
-
return {
|
|
158
|
-
views: pipe(
|
|
159
|
-
results,
|
|
160
|
-
filter((r) => r.status === "fulfilled"),
|
|
161
|
-
flatMap((r) => r.value)
|
|
162
|
-
)
|
|
163
|
-
};
|
|
164
|
-
}),
|
|
165
|
-
connection.onRequest(BuildDocuments.Req, async ({ docs }, cancelToken) => {
|
|
166
|
-
const changed = docs.map((d) => URI.parse(d));
|
|
167
|
-
const notChanged = (uri) => changed.every((c) => !UriUtils.equals(c, uri));
|
|
168
|
-
const deleted = LangiumDocuments.allExcludingBuiltin.toArray().filter((d) => notChanged(d.uri)).map((d) => d.uri);
|
|
169
|
-
logger.debug(
|
|
170
|
-
`[ServerRpc] received request to build:
|
|
171
|
-
changed (total ${changed.length}):${docs.map((d) => "\n - " + d).join("")}
|
|
172
|
-
deleted (total ${deleted.length}):${deleted.map((d) => "\n - " + d.toString()).join("\n")}`
|
|
173
|
-
);
|
|
174
|
-
if (!isFirstBuild && changed.length + deleted.length > 0) {
|
|
175
|
-
await Promise.allSettled(
|
|
176
|
-
[...changed, ...deleted].map(async (d) => {
|
|
177
|
-
const uri = d.toString();
|
|
178
|
-
logger.debug(`clear diagnostics for ${uri}`);
|
|
179
|
-
try {
|
|
180
|
-
await connection.sendDiagnostics({
|
|
181
|
-
uri,
|
|
182
|
-
diagnostics: []
|
|
183
|
-
});
|
|
184
|
-
} catch (e) {
|
|
185
|
-
logger.warn(`error clearing diagnostics for ${uri}: ${e}`);
|
|
186
|
-
}
|
|
187
|
-
})
|
|
188
|
-
);
|
|
189
|
-
}
|
|
190
|
-
isFirstBuild = false;
|
|
191
|
-
await interruptAndCheck(cancelToken);
|
|
192
|
-
await DocumentBuilder.update(changed, deleted, cancelToken);
|
|
193
|
-
}),
|
|
194
|
-
connection.onRequest(Locate.Req, (params) => {
|
|
195
|
-
switch (true) {
|
|
196
|
-
case "element" in params:
|
|
197
|
-
return likec4Services.ModelLocator.locateElement(params.element, params.projectId);
|
|
198
|
-
case "relation" in params:
|
|
199
|
-
return likec4Services.ModelLocator.locateRelation(params.relation, params.projectId);
|
|
200
|
-
case "astPath" in params:
|
|
201
|
-
return likec4Services.ModelLocator.locateDynamicViewStep({
|
|
202
|
-
view: params.view,
|
|
203
|
-
astPath: params.astPath,
|
|
204
|
-
projectId: params.projectId
|
|
205
|
-
});
|
|
206
|
-
case "view" in params:
|
|
207
|
-
return likec4Services.ModelLocator.locateView(params.view, params.projectId);
|
|
208
|
-
case "deployment" in params:
|
|
209
|
-
return likec4Services.ModelLocator.locateDeploymentElement(params.deployment, params.projectId);
|
|
210
|
-
default:
|
|
211
|
-
nonexhaustive(params);
|
|
212
|
-
}
|
|
213
|
-
}),
|
|
214
|
-
connection.onRequest(ChangeView.Req, async (request, _cancelToken) => {
|
|
215
|
-
logger.debug`received request ${"changeView"} of ${request.viewId} from project ${request.projectId}`;
|
|
216
|
-
return await likec4Services.ModelChanges.applyChange(request);
|
|
217
|
-
}),
|
|
218
|
-
connection.onRequest(FetchTelemetryMetrics.req, async (cancelToken) => {
|
|
219
|
-
const projectsIds = [...projects.all];
|
|
220
|
-
const promises = projectsIds.map(async (projectId) => {
|
|
221
|
-
const model = await likec4Services.ModelBuilder.buildLikeC4Model(projectId, cancelToken);
|
|
222
|
-
if (model === LikeC4Model.EMPTY) {
|
|
223
|
-
return Promise.reject(new Error(`Model is empty`));
|
|
224
|
-
}
|
|
225
|
-
return {
|
|
226
|
-
elementKinds: keys(model.specification.elements).length,
|
|
227
|
-
deploymentKinds: keys(model.specification.deployments).length,
|
|
228
|
-
relationshipKinds: keys(model.specification.relationships).length,
|
|
229
|
-
tags: keys(model.specification.tags).length,
|
|
230
|
-
customColors: keys(model.specification.customColors ?? {}).length,
|
|
231
|
-
elements: keys(model.$data.elements).length,
|
|
232
|
-
deploymentNodes: [...model.deployment.nodes()].length,
|
|
233
|
-
relationships: keys(model.$data.relations).length,
|
|
234
|
-
views: keys(model.$data.views).length,
|
|
235
|
-
projects: 1
|
|
236
|
-
};
|
|
237
|
-
});
|
|
238
|
-
const results = await Promise.allSettled(promises);
|
|
239
|
-
await interruptAndCheck(cancelToken);
|
|
240
|
-
const values = results.filter((r) => r.status === "fulfilled").map((r) => r.value);
|
|
241
|
-
const metrics = values.length > 0 ? values.reduce((acc, r) => ({
|
|
242
|
-
elementKinds: acc.elementKinds + r.elementKinds,
|
|
243
|
-
deploymentKinds: acc.deploymentKinds + r.deploymentKinds,
|
|
244
|
-
relationshipKinds: acc.relationshipKinds + r.relationshipKinds,
|
|
245
|
-
tags: acc.tags + r.tags,
|
|
246
|
-
customColors: acc.customColors + r.customColors,
|
|
247
|
-
elements: acc.elements + r.elements,
|
|
248
|
-
deploymentNodes: acc.deploymentNodes + r.deploymentNodes,
|
|
249
|
-
relationships: acc.relationships + r.relationships,
|
|
250
|
-
views: acc.views + r.views,
|
|
251
|
-
projects: acc.projects + 1
|
|
252
|
-
})) : null;
|
|
253
|
-
return {
|
|
254
|
-
metrics
|
|
255
|
-
};
|
|
256
|
-
}),
|
|
257
|
-
connection.onRequest(GetDocumentTags.req, async ({ documentUri }, cancelToken) => {
|
|
258
|
-
const tags = await likec4Services.ModelLocator.locateDocumentTags(URI.parse(documentUri), cancelToken);
|
|
259
|
-
return {
|
|
260
|
-
tags
|
|
261
|
-
};
|
|
262
|
-
}),
|
|
263
|
-
Disposable.create(() => {
|
|
264
|
-
notifyModelParsed.cancel();
|
|
265
|
-
})
|
|
266
|
-
);
|
|
267
|
-
function reportLayoutDrift(diagrams) {
|
|
268
|
-
return pipe(
|
|
269
|
-
diagrams,
|
|
270
|
-
filter((d) => !!d.hasLayoutDrift),
|
|
271
|
-
map((d) => {
|
|
272
|
-
const loc = likec4Services.ModelLocator.locateView(d.id);
|
|
273
|
-
invariant(loc, `View ${d.id} not found`);
|
|
274
|
-
return {
|
|
275
|
-
uri: loc.uri,
|
|
276
|
-
viewId: d.id,
|
|
277
|
-
severity: DiagnosticSeverity.Warning,
|
|
278
|
-
message: `Layout drift detected for view '${d.id}'`,
|
|
279
|
-
range: loc.range
|
|
280
|
-
};
|
|
281
|
-
})
|
|
282
|
-
);
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
async openView(params) {
|
|
286
|
-
const lspConnection = this.services.shared.lsp.Connection;
|
|
287
|
-
if (!lspConnection) {
|
|
288
|
-
logger.warn("No LSP connection");
|
|
289
|
-
return;
|
|
290
|
-
}
|
|
291
|
-
await lspConnection.sendNotification(
|
|
292
|
-
DidRequestOpenViewNotification.type,
|
|
293
|
-
params
|
|
294
|
-
);
|
|
295
|
-
}
|
|
296
|
-
}
|
package/dist/ast.mjs
DELETED
|
@@ -1,221 +0,0 @@
|
|
|
1
|
-
import { nonexhaustive } from "@likec4/core/utils";
|
|
2
|
-
import { AstUtils, DocumentState } from "langium";
|
|
3
|
-
import { clamp, isNullish, isTruthy } from "remeda";
|
|
4
|
-
import * as ast from "./generated/ast.mjs";
|
|
5
|
-
import { LikeC4LanguageMetaData } from "./generated/module.mjs";
|
|
6
|
-
export { ast };
|
|
7
|
-
const idattr = Symbol.for("idattr");
|
|
8
|
-
export const ViewOps = {
|
|
9
|
-
writeId(node, id) {
|
|
10
|
-
node[idattr] = id;
|
|
11
|
-
return node;
|
|
12
|
-
},
|
|
13
|
-
readId(node) {
|
|
14
|
-
return node[idattr];
|
|
15
|
-
}
|
|
16
|
-
};
|
|
17
|
-
export const ElementOps = {
|
|
18
|
-
writeId(node, id) {
|
|
19
|
-
if (isNullish(id)) {
|
|
20
|
-
node[idattr] = void 0;
|
|
21
|
-
} else {
|
|
22
|
-
node[idattr] = id;
|
|
23
|
-
}
|
|
24
|
-
return node;
|
|
25
|
-
},
|
|
26
|
-
readId(node) {
|
|
27
|
-
return node[idattr];
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
export function isLikeC4LangiumDocument(doc) {
|
|
31
|
-
return doc.textDocument.languageId === LikeC4LanguageMetaData.languageId;
|
|
32
|
-
}
|
|
33
|
-
export function isParsedLikeC4LangiumDocument(doc) {
|
|
34
|
-
return isLikeC4LangiumDocument(doc) && doc.state == DocumentState.Validated && !!doc.c4Specification && !!doc.c4Elements && !!doc.c4ExtendElements && !!doc.c4ExtendDeployments && !!doc.c4Relations && !!doc.c4Views && !!doc.c4Deployments && !!doc.c4DeploymentRelations && !!doc.c4Imports;
|
|
35
|
-
}
|
|
36
|
-
export function parseMarkdownAsString(node) {
|
|
37
|
-
return node?.markdown || node?.text;
|
|
38
|
-
}
|
|
39
|
-
export function parseAstPercent(value) {
|
|
40
|
-
const opacity = parseFloat(value);
|
|
41
|
-
return isNaN(opacity) ? 100 : clamp(opacity, { min: 0, max: 100 });
|
|
42
|
-
}
|
|
43
|
-
export function parseAstOpacityProperty({ value }) {
|
|
44
|
-
return parseAstPercent(value);
|
|
45
|
-
}
|
|
46
|
-
export function parseAstSizeValue({ value }) {
|
|
47
|
-
switch (value) {
|
|
48
|
-
case "xs":
|
|
49
|
-
case "sm":
|
|
50
|
-
case "md":
|
|
51
|
-
case "lg":
|
|
52
|
-
case "xl":
|
|
53
|
-
return value;
|
|
54
|
-
case "xsmall":
|
|
55
|
-
return "xs";
|
|
56
|
-
case "small":
|
|
57
|
-
return "sm";
|
|
58
|
-
case "medium":
|
|
59
|
-
return "md";
|
|
60
|
-
case "large":
|
|
61
|
-
return "lg";
|
|
62
|
-
case "xlarge":
|
|
63
|
-
return "xl";
|
|
64
|
-
default:
|
|
65
|
-
nonexhaustive(value);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
export function toRelationshipStyle(props, isValid) {
|
|
69
|
-
const result = {};
|
|
70
|
-
if (!props || props.length === 0) {
|
|
71
|
-
return result;
|
|
72
|
-
}
|
|
73
|
-
for (const prop of props) {
|
|
74
|
-
if (!isValid(prop)) {
|
|
75
|
-
continue;
|
|
76
|
-
}
|
|
77
|
-
switch (true) {
|
|
78
|
-
case ast.isColorProperty(prop): {
|
|
79
|
-
const color = toColor(prop);
|
|
80
|
-
if (isTruthy(color)) {
|
|
81
|
-
result.color = color;
|
|
82
|
-
}
|
|
83
|
-
break;
|
|
84
|
-
}
|
|
85
|
-
case ast.isLineProperty(prop): {
|
|
86
|
-
result.line = prop.value;
|
|
87
|
-
break;
|
|
88
|
-
}
|
|
89
|
-
case ast.isArrowProperty(prop): {
|
|
90
|
-
switch (prop.key) {
|
|
91
|
-
case "head": {
|
|
92
|
-
result.head = prop.value;
|
|
93
|
-
break;
|
|
94
|
-
}
|
|
95
|
-
case "tail": {
|
|
96
|
-
result.tail = prop.value;
|
|
97
|
-
break;
|
|
98
|
-
}
|
|
99
|
-
default: {
|
|
100
|
-
nonexhaustive(prop);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
break;
|
|
104
|
-
}
|
|
105
|
-
default: {
|
|
106
|
-
nonexhaustive(prop);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
return result;
|
|
111
|
-
}
|
|
112
|
-
export function toColor(astNode) {
|
|
113
|
-
return astNode?.themeColor ?? astNode?.customColor?.$refText;
|
|
114
|
-
}
|
|
115
|
-
export function toAutoLayout(rule) {
|
|
116
|
-
const rankSep = rule.rankSep;
|
|
117
|
-
const nodeSep = rule.nodeSep;
|
|
118
|
-
let direction;
|
|
119
|
-
switch (rule.direction) {
|
|
120
|
-
case "TopBottom": {
|
|
121
|
-
direction = "TB";
|
|
122
|
-
break;
|
|
123
|
-
}
|
|
124
|
-
case "BottomTop": {
|
|
125
|
-
direction = "BT";
|
|
126
|
-
break;
|
|
127
|
-
}
|
|
128
|
-
case "LeftRight": {
|
|
129
|
-
direction = "LR";
|
|
130
|
-
break;
|
|
131
|
-
}
|
|
132
|
-
case "RightLeft": {
|
|
133
|
-
direction = "RL";
|
|
134
|
-
break;
|
|
135
|
-
}
|
|
136
|
-
default:
|
|
137
|
-
nonexhaustive(rule.direction);
|
|
138
|
-
}
|
|
139
|
-
return {
|
|
140
|
-
direction,
|
|
141
|
-
...nodeSep && { nodeSep },
|
|
142
|
-
...rankSep && { rankSep }
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
export function toAstViewLayoutDirection(c4) {
|
|
146
|
-
switch (c4) {
|
|
147
|
-
case "TB": {
|
|
148
|
-
return "TopBottom";
|
|
149
|
-
}
|
|
150
|
-
case "BT": {
|
|
151
|
-
return "BottomTop";
|
|
152
|
-
}
|
|
153
|
-
case "LR": {
|
|
154
|
-
return "LeftRight";
|
|
155
|
-
}
|
|
156
|
-
case "RL": {
|
|
157
|
-
return "RightLeft";
|
|
158
|
-
}
|
|
159
|
-
default:
|
|
160
|
-
nonexhaustive(c4);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
export function getViewRulePredicateContainer(el) {
|
|
164
|
-
return AstUtils.getContainerOfType(
|
|
165
|
-
el,
|
|
166
|
-
(n) => {
|
|
167
|
-
return ast.isViewRulePredicate(n) || ast.isDeploymentViewRulePredicate(n) || ast.isDynamicViewIncludePredicate(n);
|
|
168
|
-
}
|
|
169
|
-
);
|
|
170
|
-
}
|
|
171
|
-
const _isModel = (astNode) => {
|
|
172
|
-
return ast.isModel(astNode) || ast.isElementBody(astNode) || ast.isExtendElementBody(astNode) || ast.isElementViewBody(astNode) || ast.isDynamicViewBody(astNode) || ast.isElementRef(astNode);
|
|
173
|
-
};
|
|
174
|
-
const _isDeployment = (astNode) => {
|
|
175
|
-
return ast.isModelDeployments(astNode) || ast.isDeploymentViewBody(astNode) || ast.isDeploymentNodeBody(astNode) || ast.isExtendDeploymentBody(astNode) || ast.isDeployedInstanceBody(astNode);
|
|
176
|
-
};
|
|
177
|
-
export function isFqnRefInsideGlobals(astNode) {
|
|
178
|
-
while (true) {
|
|
179
|
-
if (_isDeployment(astNode) || _isModel(astNode)) {
|
|
180
|
-
return false;
|
|
181
|
-
}
|
|
182
|
-
if (ast.isGlobals(astNode) || ast.isModelViews(astNode)) {
|
|
183
|
-
return true;
|
|
184
|
-
}
|
|
185
|
-
if (astNode.$container) {
|
|
186
|
-
astNode = astNode.$container;
|
|
187
|
-
} else {
|
|
188
|
-
return false;
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
export function isFqnRefInsideModel(astNode) {
|
|
193
|
-
while (true) {
|
|
194
|
-
if (_isDeployment(astNode)) {
|
|
195
|
-
return false;
|
|
196
|
-
}
|
|
197
|
-
if (_isModel(astNode)) {
|
|
198
|
-
return true;
|
|
199
|
-
}
|
|
200
|
-
if (astNode.$container) {
|
|
201
|
-
astNode = astNode.$container;
|
|
202
|
-
} else {
|
|
203
|
-
return false;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
export function isFqnRefInsideDeployment(astNode) {
|
|
208
|
-
while (true) {
|
|
209
|
-
if (_isModel(astNode)) {
|
|
210
|
-
return false;
|
|
211
|
-
}
|
|
212
|
-
if (_isDeployment(astNode)) {
|
|
213
|
-
return true;
|
|
214
|
-
}
|
|
215
|
-
if (astNode.$container) {
|
|
216
|
-
astNode = astNode.$container;
|
|
217
|
-
} else {
|
|
218
|
-
return false;
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
}
|