@likec4/language-server 1.46.4 → 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 -4681
- 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 -62
- package/protocol/package.json +2 -2
- package/dist/LikeC4LanguageServices.d.ts +0 -109
- package/dist/LikeC4LanguageServices.js +0 -154
- package/dist/Rpc.d.ts +0 -9
- package/dist/Rpc.js +0 -270
- 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 -11
- package/dist/browser.js +0 -35
- 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 -16
- package/dist/filesystem/ChokidarWatcher.js +0 -108
- 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 -130
- 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 -38
- package/dist/index.js +0 -55
- 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 -11
- package/dist/lsp/CompletionProvider.js +0 -200
- 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 -12
- package/dist/lsp/SemanticTokenProvider.js +0 -264
- 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 -5
- 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 -145
- 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 -12
- package/dist/mcp/tools/find-relationships.js +0 -150
- package/dist/mcp/tools/list-projects.d.ts +0 -6
- package/dist/mcp/tools/list-projects.js +0 -62
- package/dist/mcp/tools/open-view.d.ts +0 -10
- package/dist/mcp/tools/open-view.js +0 -52
- package/dist/mcp/tools/read-deployment.d.ts +0 -10
- package/dist/mcp/tools/read-deployment.js +0 -150
- package/dist/mcp/tools/read-element.d.ts +0 -10
- package/dist/mcp/tools/read-element.js +0 -218
- package/dist/mcp/tools/read-project-summary.d.ts +0 -8
- package/dist/mcp/tools/read-project-summary.js +0 -176
- package/dist/mcp/tools/read-view.d.ts +0 -10
- package/dist/mcp/tools/read-view.js +0 -203
- package/dist/mcp/tools/search-element.d.ts +0 -8
- 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 -52
- package/dist/model/model-builder.js +0 -224
- 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 -372
- 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 -284
- 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 -27
- 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 -25
- package/dist/workspace/LangiumDocuments.js +0 -98
- package/dist/workspace/ProjectsManager.d.ts +0 -130
- package/dist/workspace/ProjectsManager.js +0 -605
- 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,154 +0,0 @@
|
|
|
1
|
-
import { nonexhaustive, } from '@likec4/core';
|
|
2
|
-
import { LikeC4Model } from '@likec4/core/model';
|
|
3
|
-
import { loggable } from '@likec4/log';
|
|
4
|
-
import { URI } from 'langium';
|
|
5
|
-
import { entries, hasAtLeast, indexBy, map, pipe, prop } from 'remeda';
|
|
6
|
-
import { DiagnosticSeverity } from 'vscode-languageserver-types';
|
|
7
|
-
import { logger as mainLogger } from './logger';
|
|
8
|
-
import { ProjectsManager } from './workspace';
|
|
9
|
-
const logger = mainLogger.getChild('LanguageServices');
|
|
10
|
-
/**
|
|
11
|
-
* Public Language Services
|
|
12
|
-
*/
|
|
13
|
-
export class DefaultLikeC4LanguageServices {
|
|
14
|
-
services;
|
|
15
|
-
builder;
|
|
16
|
-
editor;
|
|
17
|
-
projectsManager;
|
|
18
|
-
constructor(services) {
|
|
19
|
-
this.services = services;
|
|
20
|
-
this.builder = services.likec4.ModelBuilder;
|
|
21
|
-
this.projectsManager = services.shared.workspace.ProjectsManager;
|
|
22
|
-
this.editor = services.likec4.ModelChanges;
|
|
23
|
-
}
|
|
24
|
-
get views() {
|
|
25
|
-
return this.services.likec4.Views;
|
|
26
|
-
}
|
|
27
|
-
get workspaceUri() {
|
|
28
|
-
return this.services.shared.workspace.WorkspaceManager.workspaceUri;
|
|
29
|
-
}
|
|
30
|
-
projects() {
|
|
31
|
-
const projectsManager = this.services.shared.workspace.ProjectsManager;
|
|
32
|
-
const projectsWithDocs = pipe(this.services.shared.workspace.LangiumDocuments.groupedByProject(), entries(), map(([projectId, docs]) => {
|
|
33
|
-
const id = projectId;
|
|
34
|
-
const { folderUri, config } = projectsManager.getProject(id);
|
|
35
|
-
return {
|
|
36
|
-
id,
|
|
37
|
-
folder: folderUri,
|
|
38
|
-
title: config.title ?? config.name,
|
|
39
|
-
documents: map(docs, prop('uri')),
|
|
40
|
-
config,
|
|
41
|
-
};
|
|
42
|
-
}));
|
|
43
|
-
// if there are multiple projects and default project is set, ensure it is first
|
|
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(this.services.shared.workspace.LangiumDocuments.projectDocuments(ProjectsManager.DefaultProjectId).toArray(), prop('uri'));
|
|
57
|
-
return [{
|
|
58
|
-
id: ProjectsManager.DefaultProjectId,
|
|
59
|
-
folder: folderUri,
|
|
60
|
-
title: config.title ?? config.name,
|
|
61
|
-
documents,
|
|
62
|
-
config,
|
|
63
|
-
}];
|
|
64
|
-
}
|
|
65
|
-
project(projectId) {
|
|
66
|
-
projectId = this.projectsManager.ensureProjectId(projectId);
|
|
67
|
-
const projectsManager = this.services.shared.workspace.ProjectsManager;
|
|
68
|
-
const { folderUri, config } = projectsManager.getProject(projectId);
|
|
69
|
-
const documents = map(this.services.shared.workspace.LangiumDocuments.projectDocuments(projectId).toArray(), prop('uri'));
|
|
70
|
-
return {
|
|
71
|
-
id: projectId,
|
|
72
|
-
folder: folderUri,
|
|
73
|
-
title: config.title ?? config.name,
|
|
74
|
-
documents,
|
|
75
|
-
config,
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* Diagram is a computed view, layouted using Graphviz
|
|
80
|
-
* If diagram has manual layout, it will be used.
|
|
81
|
-
*/
|
|
82
|
-
async diagrams(project, cancelToken) {
|
|
83
|
-
const projectId = this.projectsManager.ensureProjectId(project);
|
|
84
|
-
return await this.views.diagrams(projectId, cancelToken);
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Builds LikeC4Model from all documents
|
|
88
|
-
* Only computes view predicates {@link ComputedView} - i.e. no layout
|
|
89
|
-
* Not ready for rendering, but enough to traverse
|
|
90
|
-
*/
|
|
91
|
-
async computedModel(project, cancelToken) {
|
|
92
|
-
const projectId = this.projectsManager.ensureProjectId(project);
|
|
93
|
-
return await this.builder.computeModel(projectId, cancelToken);
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Same as {@link computedModel()}, but also applies layout
|
|
97
|
-
* Ready for rendering
|
|
98
|
-
*/
|
|
99
|
-
async layoutedModel(project, cancelToken) {
|
|
100
|
-
const projectId = this.projectsManager.ensureProjectId(project);
|
|
101
|
-
const model = await this.builder.computeModel(projectId, cancelToken);
|
|
102
|
-
if (!model) {
|
|
103
|
-
throw new Error('Failed to compute model, empty project?');
|
|
104
|
-
}
|
|
105
|
-
const layouted = await this.views.layoutAllViews(projectId, cancelToken);
|
|
106
|
-
return LikeC4Model.create({
|
|
107
|
-
...model.$data,
|
|
108
|
-
_stage: 'layouted',
|
|
109
|
-
views: pipe(layouted, map(prop('diagram')), indexBy(prop('id'))),
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
getErrors() {
|
|
113
|
-
const docs = this.services.shared.workspace.LangiumDocuments.allExcludingBuiltin.toArray();
|
|
114
|
-
return docs.flatMap(doc => {
|
|
115
|
-
return (doc.diagnostics ?? [])
|
|
116
|
-
.filter(d => d.severity === DiagnosticSeverity.Error)
|
|
117
|
-
.map(({ message, range }) => ({
|
|
118
|
-
message,
|
|
119
|
-
line: range.start.line,
|
|
120
|
-
range,
|
|
121
|
-
sourceFsPath: doc.uri.fsPath,
|
|
122
|
-
}));
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
locate(params) {
|
|
126
|
-
switch (true) {
|
|
127
|
-
case 'element' in params:
|
|
128
|
-
return this.services.likec4.ModelLocator.locateElement(params.element, params.projectId);
|
|
129
|
-
case 'relation' in params:
|
|
130
|
-
return this.services.likec4.ModelLocator.locateRelation(params.relation, params.projectId);
|
|
131
|
-
case 'view' in params:
|
|
132
|
-
return this.services.likec4.ModelLocator.locateView(params.view, params.projectId);
|
|
133
|
-
case 'deployment' in params:
|
|
134
|
-
return this.services.likec4.ModelLocator.locateDeploymentElement(params.deployment, params.projectId);
|
|
135
|
-
default:
|
|
136
|
-
nonexhaustive(params);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
async dispose() {
|
|
140
|
-
try {
|
|
141
|
-
logger.debug('disposing LikeC4LanguageServices');
|
|
142
|
-
await this.services.shared.workspace.FileSystemWatcher.dispose();
|
|
143
|
-
if (this.services.mcp.Server.isStarted) {
|
|
144
|
-
await this.services.mcp.Server.stop();
|
|
145
|
-
}
|
|
146
|
-
this.services.Rpc.dispose();
|
|
147
|
-
this.services.likec4.ModelBuilder.dispose();
|
|
148
|
-
logger.debug('LikeC4LanguageServices disposed');
|
|
149
|
-
}
|
|
150
|
-
catch (e) {
|
|
151
|
-
logger.error(loggable(e));
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
}
|
package/dist/Rpc.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { LikeC4Services } from './module';
|
|
2
|
-
import { DidRequestOpenViewNotification } from './protocol';
|
|
3
|
-
import { ADisposable } from './utils';
|
|
4
|
-
export declare class Rpc extends ADisposable {
|
|
5
|
-
private services;
|
|
6
|
-
constructor(services: LikeC4Services);
|
|
7
|
-
init(): void;
|
|
8
|
-
openView(params: DidRequestOpenViewNotification.Params): Promise<void>;
|
|
9
|
-
}
|
package/dist/Rpc.js
DELETED
|
@@ -1,270 +0,0 @@
|
|
|
1
|
-
import { filter, funnel, indexBy, keys, map, mapValues, pipe, sort } from 'remeda';
|
|
2
|
-
import { logger as rootLogger } from './logger';
|
|
3
|
-
import { invariant, nonexhaustive, } from '@likec4/core';
|
|
4
|
-
import { LikeC4Model } from '@likec4/core/model';
|
|
5
|
-
import { Disposable, interruptAndCheck, URI, UriUtils } from 'langium';
|
|
6
|
-
import { DiagnosticSeverity } from 'vscode-languageserver-protocol';
|
|
7
|
-
import { BuildDocuments, ChangeView, DidChangeModelNotification, DidChangeSnapshotNotification, DidRequestOpenViewNotification, FetchComputedModel, FetchLayoutedModel, FetchProjects, FetchTelemetryMetrics, FetchViewsFromAllProjects, GetDocumentTags, LayoutView, Locate, RegisterProject, ReloadProjects, ValidateLayout, } from './protocol';
|
|
8
|
-
import { ADisposable } from './utils';
|
|
9
|
-
const logger = rootLogger.getChild('rpc');
|
|
10
|
-
export class Rpc extends ADisposable {
|
|
11
|
-
services;
|
|
12
|
-
constructor(services) {
|
|
13
|
-
super();
|
|
14
|
-
this.services = services;
|
|
15
|
-
}
|
|
16
|
-
init() {
|
|
17
|
-
const connection = this.services.shared.lsp.Connection;
|
|
18
|
-
if (!connection) {
|
|
19
|
-
logger.info(`no connection, skip init ServerRpc`);
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
logger.info(`init ServerRpc`);
|
|
23
|
-
const likec4Services = this.services.likec4;
|
|
24
|
-
const projects = this.services.shared.workspace.ProjectsManager;
|
|
25
|
-
const LangiumDocuments = this.services.shared.workspace.LangiumDocuments;
|
|
26
|
-
const DocumentBuilder = this.services.shared.workspace.DocumentBuilder;
|
|
27
|
-
const notifyModelParsed = funnel((batch) => {
|
|
28
|
-
if (batch > 1) {
|
|
29
|
-
logger.debug `send ${'onDidChangeModel'} (${batch} batched)`;
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
logger.debug `send ${'onDidChangeModel'}`;
|
|
33
|
-
}
|
|
34
|
-
connection.sendNotification(DidChangeModelNotification.type, '').catch(error => {
|
|
35
|
-
logger.warn(`[ServerRpc] error sending onDidChangeModel:`, { error });
|
|
36
|
-
return;
|
|
37
|
-
});
|
|
38
|
-
}, {
|
|
39
|
-
reducer: (accumulator, req) => (accumulator ?? 0) + req,
|
|
40
|
-
triggerAt: 'end',
|
|
41
|
-
minQuietPeriodMs: 200,
|
|
42
|
-
maxBurstDurationMs: 400,
|
|
43
|
-
});
|
|
44
|
-
let isFirstBuild = true;
|
|
45
|
-
this.onDispose(likec4Services.ModelBuilder.onModelParsed(() => notifyModelParsed.call(1)), connection.onRequest(FetchComputedModel.req, async ({ projectId, cleanCaches }, cancelToken) => {
|
|
46
|
-
logger.debug `received request ${'fetchComputedModel'} for project ${projectId} (cleanCaches: ${cleanCaches})`;
|
|
47
|
-
if (cleanCaches) {
|
|
48
|
-
const docs = projectId
|
|
49
|
-
? LangiumDocuments.projectDocuments(projectId)
|
|
50
|
-
: LangiumDocuments.allExcludingBuiltin;
|
|
51
|
-
const uris = docs.toArray().map(d => d.uri);
|
|
52
|
-
await DocumentBuilder.update(uris, [], cancelToken);
|
|
53
|
-
}
|
|
54
|
-
const likec4model = await likec4Services.ModelBuilder.computeModel(projectId, cancelToken);
|
|
55
|
-
if (likec4model !== LikeC4Model.EMPTY) {
|
|
56
|
-
return { model: likec4model.$data };
|
|
57
|
-
}
|
|
58
|
-
return { model: null };
|
|
59
|
-
}), connection.onNotification(DidChangeSnapshotNotification.type, async ({ snapshotUri }) => {
|
|
60
|
-
logger.debug `received notification ${'onDidChangeSnapshot'} for snapshot ${snapshotUri}`;
|
|
61
|
-
const uri = URI.parse(snapshotUri);
|
|
62
|
-
await projects.rebuidProject(projects.belongsTo(uri.path));
|
|
63
|
-
}), connection.onRequest(FetchLayoutedModel.req, async ({ projectId }, cancelToken) => {
|
|
64
|
-
logger.debug `received request ${'fetchLayoutedModel'} for project ${projectId}`;
|
|
65
|
-
const model = await likec4Services.LanguageServices.layoutedModel(projectId);
|
|
66
|
-
if (model === null) {
|
|
67
|
-
return { model: null };
|
|
68
|
-
}
|
|
69
|
-
const diagrams = await likec4Services.Views.diagrams(projectId, cancelToken);
|
|
70
|
-
return {
|
|
71
|
-
model: {
|
|
72
|
-
...model.$data,
|
|
73
|
-
_stage: 'layouted',
|
|
74
|
-
views: indexBy(diagrams, d => d.id),
|
|
75
|
-
},
|
|
76
|
-
};
|
|
77
|
-
}), connection.onRequest(LayoutView.req, async ({ viewId, projectId, layoutType, }, cancelToken) => {
|
|
78
|
-
logger
|
|
79
|
-
.debug `received request ${'layoutView'} for ${viewId} from project ${projectId} (layout type: ${layoutType ?? 'not set'})`;
|
|
80
|
-
const result = await likec4Services.Views.layoutView({
|
|
81
|
-
viewId,
|
|
82
|
-
projectId: projectId,
|
|
83
|
-
layoutType,
|
|
84
|
-
cancelToken,
|
|
85
|
-
});
|
|
86
|
-
return { result };
|
|
87
|
-
}), connection.onRequest(ValidateLayout.req, async ({ projectId }, cancelToken) => {
|
|
88
|
-
logger.debug `received request ${'validateLayout'} for project ${projectId}`;
|
|
89
|
-
const layouts = await likec4Services.Views.layoutAllViews(projectId, cancelToken);
|
|
90
|
-
const result = reportLayoutDrift(layouts.map(l => l.diagram));
|
|
91
|
-
return { result };
|
|
92
|
-
}), connection.onRequest(FetchProjects.req, async () => {
|
|
93
|
-
logger.debug `received request ${'FetchProjects'}`;
|
|
94
|
-
const docsByProject = LangiumDocuments.groupedByProject();
|
|
95
|
-
return {
|
|
96
|
-
projects: mapValues(docsByProject, (docs, projectId) => {
|
|
97
|
-
const { folderUri, config: { name, title, }, } = projects.getProject(projectId);
|
|
98
|
-
return {
|
|
99
|
-
folder: folderUri.toString(),
|
|
100
|
-
config: {
|
|
101
|
-
name,
|
|
102
|
-
title,
|
|
103
|
-
},
|
|
104
|
-
docs: map(docs, d => d.uri.toString()),
|
|
105
|
-
};
|
|
106
|
-
}),
|
|
107
|
-
};
|
|
108
|
-
}), connection.onRequest(ReloadProjects.req, async (cancelToken) => {
|
|
109
|
-
logger.debug `received request ${'ReloadProjects'}`;
|
|
110
|
-
likec4Services.ManualLayouts.clearCaches();
|
|
111
|
-
await projects.reloadProjects(cancelToken);
|
|
112
|
-
return;
|
|
113
|
-
}), connection.onRequest(RegisterProject.req, async (params, cancelToken) => {
|
|
114
|
-
logger.debug `received request ${'RegisterProject'}`;
|
|
115
|
-
const project = await projects.registerProject(params, cancelToken);
|
|
116
|
-
return { id: project.id };
|
|
117
|
-
}), connection.onRequest(FetchViewsFromAllProjects.req, async (cancelToken) => {
|
|
118
|
-
logger.debug `received request ${'FetchViewsFromAllProjects'}`;
|
|
119
|
-
const views = [];
|
|
120
|
-
for (const projectId of projects.all) {
|
|
121
|
-
await interruptAndCheck(cancelToken);
|
|
122
|
-
try {
|
|
123
|
-
const computedViews = await likec4Services.Views.computedViews(projectId, cancelToken);
|
|
124
|
-
views.push(...pipe(computedViews, map(v => ({
|
|
125
|
-
id: v.id,
|
|
126
|
-
title: v.title ?? v.id,
|
|
127
|
-
projectId,
|
|
128
|
-
})), sort((a, b) => {
|
|
129
|
-
if (a.id === 'index') {
|
|
130
|
-
return -1;
|
|
131
|
-
}
|
|
132
|
-
if (b.id === 'index') {
|
|
133
|
-
return 1;
|
|
134
|
-
}
|
|
135
|
-
return a.title.localeCompare(b.title);
|
|
136
|
-
})));
|
|
137
|
-
}
|
|
138
|
-
catch (error) {
|
|
139
|
-
logger.warn(`Failed to fetch views for project ${projectId}:`, { error });
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
return { views };
|
|
143
|
-
}), connection.onRequest(BuildDocuments.req, async ({ docs }, cancelToken) => {
|
|
144
|
-
const changed = docs.map(d => URI.parse(d));
|
|
145
|
-
const notChanged = (uri) => changed.every(c => !UriUtils.equals(c, uri));
|
|
146
|
-
const deleted = LangiumDocuments.allExcludingBuiltin
|
|
147
|
-
.toArray()
|
|
148
|
-
.filter(d => notChanged(d.uri))
|
|
149
|
-
.map(d => d.uri);
|
|
150
|
-
logger.debug(`[ServerRpc] received request to build:
|
|
151
|
-
changed (total ${changed.length}):${docs.map(d => '\n - ' + d).join('')}
|
|
152
|
-
deleted (total ${deleted.length}):${deleted.map(d => '\n - ' + d.toString()).join('\n')}`);
|
|
153
|
-
if (!isFirstBuild && (changed.length + deleted.length) > 0) {
|
|
154
|
-
await Promise.allSettled([...changed, ...deleted].map(async (d) => {
|
|
155
|
-
const uri = d.toString();
|
|
156
|
-
logger.debug(`clear diagnostics for ${uri}`);
|
|
157
|
-
try {
|
|
158
|
-
await connection.sendDiagnostics({
|
|
159
|
-
uri,
|
|
160
|
-
diagnostics: [],
|
|
161
|
-
});
|
|
162
|
-
}
|
|
163
|
-
catch (e) {
|
|
164
|
-
// Ignore
|
|
165
|
-
logger.warn(`error clearing diagnostics for ${uri}: ${e}`);
|
|
166
|
-
}
|
|
167
|
-
}));
|
|
168
|
-
}
|
|
169
|
-
isFirstBuild = false;
|
|
170
|
-
await interruptAndCheck(cancelToken);
|
|
171
|
-
await DocumentBuilder.update(changed, deleted, cancelToken);
|
|
172
|
-
}), connection.onRequest(Locate.req, params => {
|
|
173
|
-
logger.debug `received request ${'locate'}, ${params}`;
|
|
174
|
-
switch (true) {
|
|
175
|
-
case 'element' in params:
|
|
176
|
-
return likec4Services.ModelLocator.locateElement(params.element, params.projectId);
|
|
177
|
-
case 'relation' in params:
|
|
178
|
-
return likec4Services.ModelLocator.locateRelation(params.relation, params.projectId);
|
|
179
|
-
case 'astPath' in params:
|
|
180
|
-
return likec4Services.ModelLocator.locateDynamicViewStep({
|
|
181
|
-
view: params.view,
|
|
182
|
-
astPath: params.astPath,
|
|
183
|
-
projectId: params.projectId,
|
|
184
|
-
});
|
|
185
|
-
case 'view' in params:
|
|
186
|
-
return likec4Services.ModelLocator.locateView(params.view, params.projectId);
|
|
187
|
-
case 'deployment' in params:
|
|
188
|
-
return likec4Services.ModelLocator.locateDeploymentElement(params.deployment, params.projectId);
|
|
189
|
-
default:
|
|
190
|
-
nonexhaustive(params);
|
|
191
|
-
}
|
|
192
|
-
}), connection.onRequest(ChangeView.req, async (request, cancelToken) => {
|
|
193
|
-
logger.debug `received request ${'changeView'} of ${request.viewId} from project ${request.projectId}`;
|
|
194
|
-
const loc = await likec4Services.ModelChanges.applyChange(request);
|
|
195
|
-
const op = request.change.op;
|
|
196
|
-
if (request.projectId &&
|
|
197
|
-
(op === 'save-view-snapshot' || op === 'reset-manual-layout')) {
|
|
198
|
-
await projects.rebuidProject(request.projectId, cancelToken);
|
|
199
|
-
}
|
|
200
|
-
return loc;
|
|
201
|
-
}), connection.onRequest(FetchTelemetryMetrics.req, async (cancelToken) => {
|
|
202
|
-
let metrics = null;
|
|
203
|
-
for (const projectId of projects.all) {
|
|
204
|
-
try {
|
|
205
|
-
const model = await likec4Services.ModelBuilder.computeModel(projectId, cancelToken);
|
|
206
|
-
if (model === LikeC4Model.EMPTY) {
|
|
207
|
-
continue;
|
|
208
|
-
}
|
|
209
|
-
metrics ??= {
|
|
210
|
-
elementKinds: 0,
|
|
211
|
-
deploymentKinds: 0,
|
|
212
|
-
relationshipKinds: 0,
|
|
213
|
-
tags: 0,
|
|
214
|
-
customColors: 0,
|
|
215
|
-
elements: 0,
|
|
216
|
-
deploymentNodes: 0,
|
|
217
|
-
relationships: 0,
|
|
218
|
-
views: 0,
|
|
219
|
-
projects: 0,
|
|
220
|
-
};
|
|
221
|
-
metrics.elementKinds += keys(model.specification.elements).length;
|
|
222
|
-
metrics.deploymentKinds += keys(model.specification.deployments).length;
|
|
223
|
-
metrics.relationshipKinds += keys(model.specification.relationships).length;
|
|
224
|
-
metrics.tags += keys(model.specification.tags).length;
|
|
225
|
-
metrics.customColors += keys(model.specification.customColors ?? {}).length;
|
|
226
|
-
metrics.elements += keys(model.$data.elements).length;
|
|
227
|
-
metrics.deploymentNodes += [...model.deployment.nodes()].length;
|
|
228
|
-
metrics.relationships += keys(model.$data.relations).length;
|
|
229
|
-
metrics.views += keys(model.$data.views).length;
|
|
230
|
-
metrics.projects += 1;
|
|
231
|
-
}
|
|
232
|
-
catch (err) {
|
|
233
|
-
logger.warn(`Error fetching telemetry metrics for project ${projectId}`, { err });
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
await interruptAndCheck(cancelToken);
|
|
237
|
-
return {
|
|
238
|
-
metrics,
|
|
239
|
-
};
|
|
240
|
-
}), connection.onRequest(GetDocumentTags.req, async ({ documentUri }, cancelToken) => {
|
|
241
|
-
const tags = await likec4Services.ModelLocator.locateDocumentTags(URI.parse(documentUri), cancelToken);
|
|
242
|
-
return {
|
|
243
|
-
tags,
|
|
244
|
-
};
|
|
245
|
-
}), Disposable.create(() => {
|
|
246
|
-
notifyModelParsed.cancel();
|
|
247
|
-
}));
|
|
248
|
-
function reportLayoutDrift(diagrams) {
|
|
249
|
-
return pipe(diagrams, filter(d => !!d.hasLayoutDrift), map(d => {
|
|
250
|
-
const loc = likec4Services.ModelLocator.locateView(d.id);
|
|
251
|
-
invariant(loc, `View ${d.id} not found`);
|
|
252
|
-
return {
|
|
253
|
-
uri: loc.uri,
|
|
254
|
-
viewId: d.id,
|
|
255
|
-
severity: DiagnosticSeverity.Warning,
|
|
256
|
-
message: `Layout drift detected for view '${d.id}'`,
|
|
257
|
-
range: loc.range,
|
|
258
|
-
};
|
|
259
|
-
}));
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
async openView(params) {
|
|
263
|
-
const lspConnection = this.services.shared.lsp.Connection;
|
|
264
|
-
if (!lspConnection) {
|
|
265
|
-
logger.warn('No LSP connection');
|
|
266
|
-
return;
|
|
267
|
-
}
|
|
268
|
-
await lspConnection.sendNotification(DidRequestOpenViewNotification.type, params);
|
|
269
|
-
}
|
|
270
|
-
}
|
package/dist/ast.d.ts
DELETED
|
@@ -1,226 +0,0 @@
|
|
|
1
|
-
import type * as c4 from '@likec4/core';
|
|
2
|
-
import { MultiMap } from '@likec4/core/utils';
|
|
3
|
-
import type { AstNode, AstNodeDescription, DiagnosticInfo, LangiumDocument } from 'langium';
|
|
4
|
-
import type { ConditionalPick, MergeExclusive, Simplify, ValueOf, Writable } from 'type-fest';
|
|
5
|
-
import type { Diagnostic } from 'vscode-languageserver-types';
|
|
6
|
-
import type { LikeC4Grammar } from './generated/ast';
|
|
7
|
-
import * as ast from './generated/ast';
|
|
8
|
-
import type { IsValidFn } from './validation';
|
|
9
|
-
export { ast };
|
|
10
|
-
declare module 'langium' {
|
|
11
|
-
interface LangiumDocument {
|
|
12
|
-
likec4ProjectId?: c4.ProjectId;
|
|
13
|
-
}
|
|
14
|
-
interface AstNodeDescription {
|
|
15
|
-
likec4ProjectId?: c4.ProjectId;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
declare const idattr: unique symbol;
|
|
19
|
-
declare module './generated/ast' {
|
|
20
|
-
interface Element {
|
|
21
|
-
[idattr]?: c4.Fqn | undefined;
|
|
22
|
-
}
|
|
23
|
-
interface ElementView {
|
|
24
|
-
[idattr]?: c4.ViewId | undefined;
|
|
25
|
-
}
|
|
26
|
-
interface DynamicView {
|
|
27
|
-
[idattr]?: c4.ViewId | undefined;
|
|
28
|
-
}
|
|
29
|
-
interface DeploymentView {
|
|
30
|
-
[idattr]?: c4.ViewId | undefined;
|
|
31
|
-
}
|
|
32
|
-
interface DeploymentNode {
|
|
33
|
-
[idattr]?: c4.Fqn | undefined;
|
|
34
|
-
}
|
|
35
|
-
interface DeployedInstance {
|
|
36
|
-
[idattr]?: c4.Fqn | undefined;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
export type ParsedElementStyle = {
|
|
40
|
-
shape?: c4.ElementShape;
|
|
41
|
-
icon?: c4.IconUrl;
|
|
42
|
-
color?: c4.Color;
|
|
43
|
-
border?: c4.BorderStyle;
|
|
44
|
-
opacity?: number;
|
|
45
|
-
multiple?: boolean;
|
|
46
|
-
size?: c4.ShapeSize;
|
|
47
|
-
padding?: c4.SpacingSize;
|
|
48
|
-
textSize?: c4.TextSize;
|
|
49
|
-
};
|
|
50
|
-
export interface ParsedAstSpecification {
|
|
51
|
-
tags: Record<c4.Tag, {
|
|
52
|
-
astPath: string;
|
|
53
|
-
color?: c4.ColorLiteral;
|
|
54
|
-
}>;
|
|
55
|
-
elements: Record<c4.ElementKind, c4.ElementSpecification>;
|
|
56
|
-
relationships: Record<c4.RelationshipKind, {
|
|
57
|
-
technology?: string;
|
|
58
|
-
notation?: string;
|
|
59
|
-
color?: c4.Color;
|
|
60
|
-
line?: c4.RelationshipLineType;
|
|
61
|
-
head?: c4.RelationshipArrowType;
|
|
62
|
-
tail?: c4.RelationshipArrowType;
|
|
63
|
-
}>;
|
|
64
|
-
colors: Record<c4.CustomColor, {
|
|
65
|
-
color: c4.ColorLiteral;
|
|
66
|
-
}>;
|
|
67
|
-
deployments: Record<c4.DeploymentKind, c4.ElementSpecification>;
|
|
68
|
-
}
|
|
69
|
-
export interface ParsedAstElement {
|
|
70
|
-
id: c4.Fqn;
|
|
71
|
-
astPath: string;
|
|
72
|
-
kind: c4.ElementKind;
|
|
73
|
-
title: string;
|
|
74
|
-
summary?: c4.MarkdownOrString;
|
|
75
|
-
description?: c4.MarkdownOrString;
|
|
76
|
-
technology?: string;
|
|
77
|
-
tags?: c4.NonEmptyArray<c4.Tag>;
|
|
78
|
-
links?: c4.NonEmptyArray<c4.Link>;
|
|
79
|
-
style: ParsedElementStyle;
|
|
80
|
-
metadata?: {
|
|
81
|
-
[key: string]: string | string[];
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
export interface ParsedAstExtend {
|
|
85
|
-
id: c4.Fqn;
|
|
86
|
-
astPath: string;
|
|
87
|
-
tags?: c4.NonEmptyArray<c4.Tag> | null;
|
|
88
|
-
links?: c4.NonEmptyArray<c4.Link> | null;
|
|
89
|
-
metadata?: {
|
|
90
|
-
[key: string]: string | string[];
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
export interface ParsedAstExtendRelation {
|
|
94
|
-
id: c4.RelationId;
|
|
95
|
-
astPath: string;
|
|
96
|
-
tags?: c4.NonEmptyArray<c4.Tag> | null;
|
|
97
|
-
links?: c4.NonEmptyArray<c4.Link> | null;
|
|
98
|
-
metadata?: {
|
|
99
|
-
[key: string]: string | string[];
|
|
100
|
-
};
|
|
101
|
-
}
|
|
102
|
-
export interface ParsedAstRelation {
|
|
103
|
-
id: c4.RelationId;
|
|
104
|
-
astPath: string;
|
|
105
|
-
source: c4.FqnRef.ModelRef;
|
|
106
|
-
target: c4.FqnRef.ModelRef;
|
|
107
|
-
kind?: c4.RelationshipKind;
|
|
108
|
-
tags?: c4.NonEmptyArray<c4.Tag>;
|
|
109
|
-
title: string;
|
|
110
|
-
description?: c4.MarkdownOrString;
|
|
111
|
-
technology?: string;
|
|
112
|
-
color?: c4.Color;
|
|
113
|
-
line?: c4.RelationshipLineType;
|
|
114
|
-
head?: c4.RelationshipArrowType;
|
|
115
|
-
tail?: c4.RelationshipArrowType;
|
|
116
|
-
links?: c4.NonEmptyArray<c4.Link>;
|
|
117
|
-
navigateTo?: c4.ViewId;
|
|
118
|
-
metadata?: {
|
|
119
|
-
[key: string]: string | string[];
|
|
120
|
-
};
|
|
121
|
-
}
|
|
122
|
-
export type ParsedAstDeployment = Simplify<MergeExclusive<ParsedAstDeployment.Node, ParsedAstDeployment.Instance>>;
|
|
123
|
-
export declare namespace ParsedAstDeployment {
|
|
124
|
-
type Node = c4.DeploymentNode;
|
|
125
|
-
type Instance = Omit<c4.DeployedInstance, 'element'> & {
|
|
126
|
-
readonly element: c4.FqnRef.ModelRef;
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
export type ParsedAstDeploymentRelation = c4.DeploymentRelationship & {
|
|
130
|
-
astPath: string;
|
|
131
|
-
};
|
|
132
|
-
export type ParsedAstGlobals = Writable<c4.ModelGlobals>;
|
|
133
|
-
export interface ParsedAstElementView {
|
|
134
|
-
[c4._type]: 'element';
|
|
135
|
-
id: c4.ViewId;
|
|
136
|
-
viewOf?: c4.Fqn;
|
|
137
|
-
extends?: c4.ViewId;
|
|
138
|
-
astPath: string;
|
|
139
|
-
title: string | null;
|
|
140
|
-
description: c4.MarkdownOrString | null;
|
|
141
|
-
tags: c4.NonEmptyArray<c4.Tag> | null;
|
|
142
|
-
links: c4.NonEmptyArray<c4.Link> | null;
|
|
143
|
-
rules: c4.ElementViewRule[];
|
|
144
|
-
manualLayout?: c4.ViewManualLayout;
|
|
145
|
-
}
|
|
146
|
-
export interface ParsedAstDynamicView {
|
|
147
|
-
[c4._type]: 'dynamic';
|
|
148
|
-
id: c4.ViewId;
|
|
149
|
-
astPath: string;
|
|
150
|
-
title: string | null;
|
|
151
|
-
description: c4.MarkdownOrString | null;
|
|
152
|
-
tags: c4.NonEmptyArray<c4.Tag> | null;
|
|
153
|
-
links: c4.NonEmptyArray<c4.Link> | null;
|
|
154
|
-
steps: c4.DynamicViewStep[];
|
|
155
|
-
rules: Array<c4.DynamicViewRule>;
|
|
156
|
-
variant: c4.DynamicViewDisplayVariant | undefined;
|
|
157
|
-
manualLayout?: c4.ViewManualLayout;
|
|
158
|
-
}
|
|
159
|
-
export interface ParsedAstDeploymentView {
|
|
160
|
-
[c4._type]: 'deployment';
|
|
161
|
-
id: c4.ViewId;
|
|
162
|
-
astPath: string;
|
|
163
|
-
title: string | null;
|
|
164
|
-
description: c4.MarkdownOrString | null;
|
|
165
|
-
tags: c4.NonEmptyArray<c4.Tag> | null;
|
|
166
|
-
links: c4.NonEmptyArray<c4.Link> | null;
|
|
167
|
-
rules: Array<c4.DeploymentViewRule>;
|
|
168
|
-
manualLayout?: c4.ViewManualLayout;
|
|
169
|
-
}
|
|
170
|
-
export type ParsedAstView = ParsedAstElementView | ParsedAstDynamicView | ParsedAstDeploymentView;
|
|
171
|
-
export declare const ViewOps: {
|
|
172
|
-
writeId<T extends ast.LikeC4View>(node: T, id: c4.ViewId): T;
|
|
173
|
-
readId(node: ast.LikeC4View): c4.ViewId | undefined;
|
|
174
|
-
};
|
|
175
|
-
export declare const ElementOps: {
|
|
176
|
-
writeId(node: ast.Element | ast.DeploymentElement, id: c4.Fqn | null): ast.DeploymentElement | ast.Element;
|
|
177
|
-
readId(node: ast.Element | ast.DeploymentElement): c4.Fqn<string> | undefined;
|
|
178
|
-
};
|
|
179
|
-
export interface AstNodeDescriptionWithFqn extends AstNodeDescription {
|
|
180
|
-
likec4ProjectId: c4.ProjectId;
|
|
181
|
-
id: c4.Fqn;
|
|
182
|
-
}
|
|
183
|
-
export type LikeC4AstNode = ValueOf<ConditionalPick<ast.LikeC4AstType, AstNode>>;
|
|
184
|
-
type LikeC4DocumentDiagnostic = Diagnostic & DiagnosticInfo<LikeC4AstNode>;
|
|
185
|
-
export interface LikeC4DocumentProps {
|
|
186
|
-
diagnostics?: Array<LikeC4DocumentDiagnostic>;
|
|
187
|
-
c4Specification?: ParsedAstSpecification;
|
|
188
|
-
c4Elements?: ParsedAstElement[];
|
|
189
|
-
c4ExtendElements?: ParsedAstExtend[];
|
|
190
|
-
c4ExtendDeployments?: ParsedAstExtend[];
|
|
191
|
-
c4ExtendRelations?: ParsedAstExtendRelation[];
|
|
192
|
-
c4Relations?: ParsedAstRelation[];
|
|
193
|
-
c4Globals?: ParsedAstGlobals;
|
|
194
|
-
c4Views?: ParsedAstView[];
|
|
195
|
-
c4Deployments?: ParsedAstDeployment[];
|
|
196
|
-
c4DeploymentRelations?: ParsedAstDeploymentRelation[];
|
|
197
|
-
c4Imports?: MultiMap<c4.ProjectId, c4.Fqn, Set<c4.Fqn>>;
|
|
198
|
-
}
|
|
199
|
-
type LikeC4GrammarDocument = Omit<LangiumDocument<LikeC4Grammar>, 'diagnostics'>;
|
|
200
|
-
export interface LikeC4LangiumDocument extends LikeC4GrammarDocument, LikeC4DocumentProps {
|
|
201
|
-
likec4ProjectId: c4.ProjectId;
|
|
202
|
-
}
|
|
203
|
-
export interface ParsedLikeC4LangiumDocument extends LikeC4GrammarDocument, Required<LikeC4DocumentProps> {
|
|
204
|
-
likec4ProjectId: c4.ProjectId;
|
|
205
|
-
}
|
|
206
|
-
export declare function isLikeC4LangiumDocument(doc: LangiumDocument): doc is LikeC4LangiumDocument;
|
|
207
|
-
export declare function isParsedLikeC4LangiumDocument(doc: LangiumDocument): doc is ParsedLikeC4LangiumDocument;
|
|
208
|
-
export declare function parseMarkdownAsString(node?: ast.MarkdownOrString): string | undefined;
|
|
209
|
-
export declare function parseAstPercent(value: string): number;
|
|
210
|
-
export declare function parseAstOpacityProperty({ value }: ast.OpacityProperty): number;
|
|
211
|
-
export declare function parseAstSizeValue({ value }: {
|
|
212
|
-
value: ast.SizeValue;
|
|
213
|
-
}): 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
|
214
|
-
export declare function toRelationshipStyle(props: ast.RelationshipStyleProperty[] | undefined, isValid: IsValidFn): {
|
|
215
|
-
color?: c4.Color;
|
|
216
|
-
line?: c4.RelationshipLineType;
|
|
217
|
-
head?: c4.RelationshipArrowType;
|
|
218
|
-
tail?: c4.RelationshipArrowType;
|
|
219
|
-
};
|
|
220
|
-
export declare function toColor(astNode: ast.ColorProperty): c4.Color | undefined;
|
|
221
|
-
export declare function toAutoLayout(rule: ast.ViewRuleAutoLayout): c4.ViewRuleAutoLayout;
|
|
222
|
-
export declare function toAstViewLayoutDirection(c4: c4.ViewRuleAutoLayout['direction']): ast.ViewLayoutDirection;
|
|
223
|
-
export declare function getViewRulePredicateContainer<T extends AstNode>(el: T): ast.ViewRulePredicate | ast.DeploymentViewRulePredicate | ast.DynamicViewIncludePredicate | undefined;
|
|
224
|
-
export declare function isFqnRefInsideGlobals(astNode: AstNode): boolean;
|
|
225
|
-
export declare function isFqnRefInsideModel(astNode: AstNode): boolean;
|
|
226
|
-
export declare function isFqnRefInsideDeployment(astNode: AstNode): boolean;
|