@likec4/language-server 1.47.0 → 1.49.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 +2 -2
- package/browser-worker/package.json +2 -2
- package/bundled/package.json +4 -0
- package/dist/THIRD-PARTY-LICENSES.md +178 -0
- package/dist/_chunks/ConfigurableLayouter.mjs +1 -0
- package/dist/_chunks/LikeC4FileSystem.mjs +3 -0
- package/dist/_chunks/LikeC4Views.mjs +34 -0
- package/dist/_chunks/ProjectsManager.mjs +1 -0
- package/dist/_chunks/WithMCPServer.mjs +481 -0
- package/dist/_chunks/icons.mjs +2 -0
- package/dist/_chunks/index.d.mts +3107 -0
- package/dist/_chunks/libs/@msgpack/msgpack.mjs +1 -0
- package/dist/_chunks/libs/eventemitter3.mjs +1 -0
- package/dist/_chunks/libs/fast-equals.mjs +1 -0
- package/dist/_chunks/libs/p-queue.mjs +1 -0
- package/dist/_chunks/libs/parse-ms.mjs +1 -0
- package/dist/_chunks/libs/picomatch.mjs +1 -0
- package/dist/_chunks/libs/pretty-ms.mjs +1 -0
- package/dist/_chunks/libs/remeda.mjs +1 -0
- package/dist/_chunks/libs/strip-indent.mjs +1 -0
- package/dist/_chunks/libs/ufo.mjs +1 -0
- package/dist/_chunks/logger.mjs +1 -0
- package/dist/_chunks/rolldown-runtime.mjs +1 -0
- package/dist/_chunks/utils.mjs +1 -0
- package/dist/browser/index.d.mts +10 -0
- package/dist/browser/index.mjs +1 -0
- package/dist/browser/worker.d.mts +1 -0
- package/dist/browser/worker.mjs +1 -0
- package/dist/bundled.d.mts +27 -0
- package/dist/bundled.mjs +1 -4853
- package/dist/filesystem/index.d.mts +2 -0
- package/dist/filesystem/index.mjs +1 -0
- package/dist/index.d.mts +39 -0
- package/dist/index.mjs +1 -0
- package/dist/likec4lib.d.mts +16 -0
- package/dist/likec4lib.mjs +1 -0
- package/dist/mcp/index.d.mts +2 -0
- package/dist/mcp/index.mjs +1 -0
- package/dist/module.d.mts +126 -0
- package/dist/module.mjs +1 -0
- package/dist/protocol.d.mts +315 -0
- package/dist/protocol.mjs +1 -0
- package/filesystem/package.json +4 -0
- package/likec4lib/package.json +2 -2
- package/mcp/package.json +4 -0
- package/module/package.json +4 -0
- package/package.json +128 -62
- package/protocol/package.json +2 -2
- package/LICENSE +0 -21
- 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
package/dist/Rpc.js
DELETED
|
@@ -1,276 +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
|
-
let project;
|
|
116
|
-
if ('configUri' in params) {
|
|
117
|
-
project = await projects.registerConfigFile(URI.parse(params.configUri), cancelToken);
|
|
118
|
-
}
|
|
119
|
-
else {
|
|
120
|
-
project = await projects.registerProject(params, cancelToken);
|
|
121
|
-
}
|
|
122
|
-
return { id: project.id };
|
|
123
|
-
}), connection.onRequest(FetchViewsFromAllProjects.req, async (cancelToken) => {
|
|
124
|
-
logger.debug `received request ${'FetchViewsFromAllProjects'}`;
|
|
125
|
-
const views = [];
|
|
126
|
-
for (const projectId of projects.all) {
|
|
127
|
-
await interruptAndCheck(cancelToken);
|
|
128
|
-
try {
|
|
129
|
-
const computedViews = await likec4Services.Views.computedViews(projectId, cancelToken);
|
|
130
|
-
views.push(...pipe(computedViews, map(v => ({
|
|
131
|
-
id: v.id,
|
|
132
|
-
title: v.title ?? v.id,
|
|
133
|
-
projectId,
|
|
134
|
-
})), sort((a, b) => {
|
|
135
|
-
if (a.id === 'index') {
|
|
136
|
-
return -1;
|
|
137
|
-
}
|
|
138
|
-
if (b.id === 'index') {
|
|
139
|
-
return 1;
|
|
140
|
-
}
|
|
141
|
-
return a.title.localeCompare(b.title);
|
|
142
|
-
})));
|
|
143
|
-
}
|
|
144
|
-
catch (error) {
|
|
145
|
-
logger.warn(`Failed to fetch views for project ${projectId}:`, { error });
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
return { views };
|
|
149
|
-
}), connection.onRequest(BuildDocuments.req, async ({ docs }, cancelToken) => {
|
|
150
|
-
const changed = docs.map(d => URI.parse(d));
|
|
151
|
-
const notChanged = (uri) => changed.every(c => !UriUtils.equals(c, uri));
|
|
152
|
-
const deleted = LangiumDocuments.allExcludingBuiltin
|
|
153
|
-
.toArray()
|
|
154
|
-
.filter(d => notChanged(d.uri))
|
|
155
|
-
.map(d => d.uri);
|
|
156
|
-
logger.debug(`[ServerRpc] received request to build:
|
|
157
|
-
changed (total ${changed.length}):${docs.map(d => '\n - ' + d).join('')}
|
|
158
|
-
deleted (total ${deleted.length}):${deleted.map(d => '\n - ' + d.toString()).join('\n')}`);
|
|
159
|
-
if (!isFirstBuild && (changed.length + deleted.length) > 0) {
|
|
160
|
-
await Promise.allSettled([...changed, ...deleted].map(async (d) => {
|
|
161
|
-
const uri = d.toString();
|
|
162
|
-
logger.debug(`clear diagnostics for ${uri}`);
|
|
163
|
-
try {
|
|
164
|
-
await connection.sendDiagnostics({
|
|
165
|
-
uri,
|
|
166
|
-
diagnostics: [],
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
catch (e) {
|
|
170
|
-
// Ignore
|
|
171
|
-
logger.warn(`error clearing diagnostics for ${uri}: ${e}`);
|
|
172
|
-
}
|
|
173
|
-
}));
|
|
174
|
-
}
|
|
175
|
-
isFirstBuild = false;
|
|
176
|
-
await interruptAndCheck(cancelToken);
|
|
177
|
-
await DocumentBuilder.update(changed, deleted, cancelToken);
|
|
178
|
-
}), connection.onRequest(Locate.req, params => {
|
|
179
|
-
logger.debug `received request ${'locate'}, ${params}`;
|
|
180
|
-
switch (true) {
|
|
181
|
-
case 'element' in params:
|
|
182
|
-
return likec4Services.ModelLocator.locateElement(params.element, params.projectId);
|
|
183
|
-
case 'relation' in params:
|
|
184
|
-
return likec4Services.ModelLocator.locateRelation(params.relation, params.projectId);
|
|
185
|
-
case 'astPath' in params:
|
|
186
|
-
return likec4Services.ModelLocator.locateDynamicViewStep({
|
|
187
|
-
view: params.view,
|
|
188
|
-
astPath: params.astPath,
|
|
189
|
-
projectId: params.projectId,
|
|
190
|
-
});
|
|
191
|
-
case 'view' in params:
|
|
192
|
-
return likec4Services.ModelLocator.locateView(params.view, params.projectId);
|
|
193
|
-
case 'deployment' in params:
|
|
194
|
-
return likec4Services.ModelLocator.locateDeploymentElement(params.deployment, params.projectId);
|
|
195
|
-
default:
|
|
196
|
-
nonexhaustive(params);
|
|
197
|
-
}
|
|
198
|
-
}), connection.onRequest(ChangeView.req, async (request, cancelToken) => {
|
|
199
|
-
logger.debug `received request ${'changeView'} of ${request.viewId} from project ${request.projectId}`;
|
|
200
|
-
const loc = await likec4Services.ModelChanges.applyChange(request);
|
|
201
|
-
const op = request.change.op;
|
|
202
|
-
if (request.projectId &&
|
|
203
|
-
(op === 'save-view-snapshot' || op === 'reset-manual-layout')) {
|
|
204
|
-
await projects.rebuidProject(request.projectId, cancelToken);
|
|
205
|
-
}
|
|
206
|
-
return loc;
|
|
207
|
-
}), connection.onRequest(FetchTelemetryMetrics.req, async (cancelToken) => {
|
|
208
|
-
let metrics = null;
|
|
209
|
-
for (const projectId of projects.all) {
|
|
210
|
-
try {
|
|
211
|
-
const model = await likec4Services.ModelBuilder.computeModel(projectId, cancelToken);
|
|
212
|
-
if (model === LikeC4Model.EMPTY) {
|
|
213
|
-
continue;
|
|
214
|
-
}
|
|
215
|
-
metrics ??= {
|
|
216
|
-
elementKinds: 0,
|
|
217
|
-
deploymentKinds: 0,
|
|
218
|
-
relationshipKinds: 0,
|
|
219
|
-
tags: 0,
|
|
220
|
-
customColors: 0,
|
|
221
|
-
elements: 0,
|
|
222
|
-
deploymentNodes: 0,
|
|
223
|
-
relationships: 0,
|
|
224
|
-
views: 0,
|
|
225
|
-
projects: 0,
|
|
226
|
-
};
|
|
227
|
-
metrics.elementKinds += keys(model.specification.elements).length;
|
|
228
|
-
metrics.deploymentKinds += keys(model.specification.deployments).length;
|
|
229
|
-
metrics.relationshipKinds += keys(model.specification.relationships).length;
|
|
230
|
-
metrics.tags += keys(model.specification.tags).length;
|
|
231
|
-
metrics.customColors += keys(model.specification.customColors ?? {}).length;
|
|
232
|
-
metrics.elements += keys(model.$data.elements).length;
|
|
233
|
-
metrics.deploymentNodes += [...model.deployment.nodes()].length;
|
|
234
|
-
metrics.relationships += keys(model.$data.relations).length;
|
|
235
|
-
metrics.views += keys(model.$data.views).length;
|
|
236
|
-
metrics.projects += 1;
|
|
237
|
-
}
|
|
238
|
-
catch (err) {
|
|
239
|
-
logger.warn(`Error fetching telemetry metrics for project ${projectId}`, { err });
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
await interruptAndCheck(cancelToken);
|
|
243
|
-
return {
|
|
244
|
-
metrics,
|
|
245
|
-
};
|
|
246
|
-
}), connection.onRequest(GetDocumentTags.req, async ({ documentUri }, cancelToken) => {
|
|
247
|
-
const tags = await likec4Services.ModelLocator.locateDocumentTags(URI.parse(documentUri), cancelToken);
|
|
248
|
-
return {
|
|
249
|
-
tags,
|
|
250
|
-
};
|
|
251
|
-
}), Disposable.create(() => {
|
|
252
|
-
notifyModelParsed.cancel();
|
|
253
|
-
}));
|
|
254
|
-
function reportLayoutDrift(diagrams) {
|
|
255
|
-
return pipe(diagrams, filter(d => !!d.hasLayoutDrift), map(d => {
|
|
256
|
-
const loc = likec4Services.ModelLocator.locateView(d.id);
|
|
257
|
-
invariant(loc, `View ${d.id} not found`);
|
|
258
|
-
return {
|
|
259
|
-
uri: loc.uri,
|
|
260
|
-
viewId: d.id,
|
|
261
|
-
severity: DiagnosticSeverity.Warning,
|
|
262
|
-
message: `Layout drift detected for view '${d.id}'`,
|
|
263
|
-
range: loc.range,
|
|
264
|
-
};
|
|
265
|
-
}));
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
async openView(params) {
|
|
269
|
-
const lspConnection = this.services.shared.lsp.Connection;
|
|
270
|
-
if (!lspConnection) {
|
|
271
|
-
logger.warn('No LSP connection');
|
|
272
|
-
return;
|
|
273
|
-
}
|
|
274
|
-
await lspConnection.sendNotification(DidRequestOpenViewNotification.type, params);
|
|
275
|
-
}
|
|
276
|
-
}
|
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.Element | ast.DeploymentElement;
|
|
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;
|