@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.
Files changed (316) hide show
  1. package/LICENSE +1 -1
  2. package/browser/package.json +2 -2
  3. package/browser-worker/package.json +2 -2
  4. package/bundled/package.json +4 -0
  5. package/dist/LikeC4LanguageServices.d.mts +4 -0
  6. package/dist/LikeC4LanguageServices.mjs +3 -0
  7. package/dist/_chunks/ConfigurableLayouter.mjs +1956 -0
  8. package/dist/_chunks/LikeC4LanguageServices.d.mts +1978 -0
  9. package/dist/_chunks/LikeC4LanguageServices.mjs +725 -0
  10. package/dist/_chunks/ast.d.mts +1444 -0
  11. package/dist/_chunks/ast.mjs +2375 -0
  12. package/dist/_chunks/ast2.mjs +176 -0
  13. package/dist/_chunks/common-exports.mjs +0 -0
  14. package/dist/_chunks/filesystem.mjs +58 -0
  15. package/dist/_chunks/grammar.mjs +8 -0
  16. package/dist/_chunks/icons.mjs +5211 -0
  17. package/dist/_chunks/libs/@hono/node-server.mjs +436 -0
  18. package/dist/_chunks/libs/@msgpack/msgpack.mjs +805 -0
  19. package/dist/_chunks/libs/eventemitter3.mjs +243 -0
  20. package/dist/_chunks/libs/fast-equals.mjs +446 -0
  21. package/dist/_chunks/libs/hono.mjs +1829 -0
  22. package/dist/_chunks/libs/p-queue.mjs +449 -0
  23. package/dist/_chunks/libs/parse-ms.mjs +36 -0
  24. package/dist/_chunks/libs/picomatch.mjs +1673 -0
  25. package/dist/_chunks/libs/pretty-ms.mjs +80 -0
  26. package/dist/_chunks/libs/remeda.mjs +482 -0
  27. package/dist/_chunks/libs/strip-indent.mjs +15 -0
  28. package/dist/_chunks/libs/ufo.mjs +166 -0
  29. package/dist/_chunks/likec4lib.mjs +9 -0
  30. package/dist/_chunks/mcp.mjs +33 -0
  31. package/dist/_chunks/module.mjs +28 -0
  32. package/dist/_chunks/module2.mjs +6576 -0
  33. package/dist/_chunks/protocol.d.mts +311 -0
  34. package/dist/_chunks/protocol.mjs +78 -0
  35. package/dist/_chunks/rolldown-runtime.mjs +42 -0
  36. package/dist/ast.d.mts +4 -0
  37. package/dist/ast.mjs +4 -0
  38. package/dist/browser-worker.d.mts +1 -0
  39. package/dist/browser-worker.mjs +6 -0
  40. package/dist/browser.d.mts +11 -0
  41. package/dist/browser.mjs +27 -0
  42. package/dist/bundled.d.mts +28 -0
  43. package/dist/bundled.mjs +51 -4681
  44. package/dist/common-exports.d.mts +4 -0
  45. package/dist/common-exports.mjs +5 -0
  46. package/dist/filesystem/index.d.mts +4 -0
  47. package/dist/filesystem/index.mjs +3 -0
  48. package/dist/generated/ast.d.mts +2 -0
  49. package/dist/generated/ast.mjs +3 -0
  50. package/dist/generated/grammar.d.mts +6 -0
  51. package/dist/generated/grammar.mjs +3 -0
  52. package/dist/generated/module.d.mts +14 -0
  53. package/dist/generated/module.mjs +3 -0
  54. package/dist/generated-lib/icons.d.mts +4 -0
  55. package/dist/generated-lib/icons.mjs +3 -0
  56. package/dist/index.d.mts +4 -0
  57. package/dist/index.mjs +48 -0
  58. package/dist/likec4lib.d.mts +9 -0
  59. package/dist/likec4lib.mjs +4 -0
  60. package/dist/mcp/index.d.mts +4 -0
  61. package/dist/mcp/index.mjs +3 -0
  62. package/dist/module.d.mts +4 -0
  63. package/dist/module.mjs +3 -0
  64. package/dist/protocol.d.mts +2 -0
  65. package/dist/protocol.mjs +3 -0
  66. package/likec4lib/package.json +2 -2
  67. package/package.json +106 -62
  68. package/protocol/package.json +2 -2
  69. package/dist/LikeC4LanguageServices.d.ts +0 -109
  70. package/dist/LikeC4LanguageServices.js +0 -154
  71. package/dist/Rpc.d.ts +0 -9
  72. package/dist/Rpc.js +0 -270
  73. package/dist/ast.d.ts +0 -226
  74. package/dist/ast.js +0 -264
  75. package/dist/browser-worker.d.ts +0 -1
  76. package/dist/browser-worker.js +0 -4
  77. package/dist/browser.d.ts +0 -11
  78. package/dist/browser.js +0 -35
  79. package/dist/bundled.d.ts +0 -8
  80. package/dist/bundled.js +0 -44
  81. package/dist/documentation/documentation-provider.d.ts +0 -8
  82. package/dist/documentation/documentation-provider.js +0 -51
  83. package/dist/documentation/index.d.ts +0 -1
  84. package/dist/documentation/index.js +0 -1
  85. package/dist/empty.d.ts +0 -2
  86. package/dist/empty.js +0 -2
  87. package/dist/filesystem/ChokidarWatcher.d.ts +0 -16
  88. package/dist/filesystem/ChokidarWatcher.js +0 -108
  89. package/dist/filesystem/FileSystemWatcher.d.ts +0 -19
  90. package/dist/filesystem/FileSystemWatcher.js +0 -14
  91. package/dist/filesystem/LikeC4FileSystem.d.ts +0 -3
  92. package/dist/filesystem/LikeC4FileSystem.js +0 -130
  93. package/dist/filesystem/index.d.ts +0 -55
  94. package/dist/filesystem/index.js +0 -29
  95. package/dist/formatting/LikeC4Formatter.d.ts +0 -59
  96. package/dist/formatting/LikeC4Formatter.js +0 -637
  97. package/dist/formatting/utils.d.ts +0 -6
  98. package/dist/formatting/utils.js +0 -18
  99. package/dist/generated/ast.d.ts +0 -1411
  100. package/dist/generated/ast.js +0 -2207
  101. package/dist/generated/grammar.d.ts +0 -6
  102. package/dist/generated/grammar.js +0 -7
  103. package/dist/generated/module.d.ts +0 -14
  104. package/dist/generated/module.js +0 -27
  105. package/dist/generated-lib/icons.d.ts +0 -1
  106. package/dist/generated-lib/icons.js +0 -18
  107. package/dist/index.d.ts +0 -38
  108. package/dist/index.js +0 -55
  109. package/dist/likec4lib.d.ts +0 -6
  110. package/dist/likec4lib.js +0 -7
  111. package/dist/logger.d.ts +0 -17
  112. package/dist/logger.js +0 -81
  113. package/dist/lsp/CodeActionProvider.d.ts +0 -14
  114. package/dist/lsp/CodeActionProvider.js +0 -33
  115. package/dist/lsp/CodeLensProvider.d.ts +0 -9
  116. package/dist/lsp/CodeLensProvider.js +0 -44
  117. package/dist/lsp/CompletionProvider.d.ts +0 -11
  118. package/dist/lsp/CompletionProvider.js +0 -200
  119. package/dist/lsp/DocumentHighlightProvider.d.ts +0 -9
  120. package/dist/lsp/DocumentHighlightProvider.js +0 -10
  121. package/dist/lsp/DocumentLinkProvider.d.ts +0 -11
  122. package/dist/lsp/DocumentLinkProvider.js +0 -58
  123. package/dist/lsp/DocumentSymbolProvider.d.ts +0 -33
  124. package/dist/lsp/DocumentSymbolProvider.js +0 -317
  125. package/dist/lsp/HoverProvider.d.ts +0 -10
  126. package/dist/lsp/HoverProvider.js +0 -106
  127. package/dist/lsp/RenameProvider.d.ts +0 -5
  128. package/dist/lsp/RenameProvider.js +0 -6
  129. package/dist/lsp/SemanticTokenProvider.d.ts +0 -12
  130. package/dist/lsp/SemanticTokenProvider.js +0 -264
  131. package/dist/lsp/index.d.ts +0 -8
  132. package/dist/lsp/index.js +0 -9
  133. package/dist/mcp/MCPServerFactory.d.ts +0 -8
  134. package/dist/mcp/MCPServerFactory.js +0 -73
  135. package/dist/mcp/NoopLikeC4MCPServer.d.ts +0 -9
  136. package/dist/mcp/NoopLikeC4MCPServer.js +0 -17
  137. package/dist/mcp/interfaces.d.ts +0 -13
  138. package/dist/mcp/interfaces.js +0 -5
  139. package/dist/mcp/server/StdioLikeC4MCPServer.d.ts +0 -16
  140. package/dist/mcp/server/StdioLikeC4MCPServer.js +0 -51
  141. package/dist/mcp/server/StreamableLikeC4MCPServer.d.ts +0 -16
  142. package/dist/mcp/server/StreamableLikeC4MCPServer.js +0 -145
  143. package/dist/mcp/server/WithMCPServer.d.ts +0 -4
  144. package/dist/mcp/server/WithMCPServer.js +0 -54
  145. package/dist/mcp/tools/_common.d.ts +0 -88
  146. package/dist/mcp/tools/_common.js +0 -49
  147. package/dist/mcp/tools/find-relationships.d.ts +0 -12
  148. package/dist/mcp/tools/find-relationships.js +0 -150
  149. package/dist/mcp/tools/list-projects.d.ts +0 -6
  150. package/dist/mcp/tools/list-projects.js +0 -62
  151. package/dist/mcp/tools/open-view.d.ts +0 -10
  152. package/dist/mcp/tools/open-view.js +0 -52
  153. package/dist/mcp/tools/read-deployment.d.ts +0 -10
  154. package/dist/mcp/tools/read-deployment.js +0 -150
  155. package/dist/mcp/tools/read-element.d.ts +0 -10
  156. package/dist/mcp/tools/read-element.js +0 -218
  157. package/dist/mcp/tools/read-project-summary.d.ts +0 -8
  158. package/dist/mcp/tools/read-project-summary.js +0 -176
  159. package/dist/mcp/tools/read-view.d.ts +0 -10
  160. package/dist/mcp/tools/read-view.js +0 -203
  161. package/dist/mcp/tools/search-element.d.ts +0 -8
  162. package/dist/mcp/tools/search-element.js +0 -177
  163. package/dist/mcp/utils.d.ts +0 -18
  164. package/dist/mcp/utils.js +0 -48
  165. package/dist/model/builder/MergedExtends.d.ts +0 -13
  166. package/dist/model/builder/MergedExtends.js +0 -74
  167. package/dist/model/builder/MergedSpecification.d.ts +0 -32
  168. package/dist/model/builder/MergedSpecification.js +0 -175
  169. package/dist/model/builder/buildModel.d.ts +0 -16
  170. package/dist/model/builder/buildModel.js +0 -245
  171. package/dist/model/deployments-index.d.ts +0 -10
  172. package/dist/model/deployments-index.js +0 -102
  173. package/dist/model/fqn-index.d.ts +0 -61
  174. package/dist/model/fqn-index.js +0 -253
  175. package/dist/model/index.d.ts +0 -6
  176. package/dist/model/index.js +0 -6
  177. package/dist/model/model-builder.d.ts +0 -52
  178. package/dist/model/model-builder.js +0 -224
  179. package/dist/model/model-locator.d.ts +0 -39
  180. package/dist/model/model-locator.js +0 -240
  181. package/dist/model/model-parser-where.d.ts +0 -4
  182. package/dist/model/model-parser-where.js +0 -81
  183. package/dist/model/model-parser.d.ts +0 -645
  184. package/dist/model/model-parser.js +0 -133
  185. package/dist/model/parser/Base.d.ts +0 -69
  186. package/dist/model/parser/Base.js +0 -372
  187. package/dist/model/parser/DeploymentModelParser.d.ts +0 -71
  188. package/dist/model/parser/DeploymentModelParser.js +0 -176
  189. package/dist/model/parser/DeploymentViewParser.d.ts +0 -75
  190. package/dist/model/parser/DeploymentViewParser.js +0 -86
  191. package/dist/model/parser/FqnRefParser.d.ts +0 -66
  192. package/dist/model/parser/FqnRefParser.js +0 -382
  193. package/dist/model/parser/GlobalsParser.d.ts +0 -109
  194. package/dist/model/parser/GlobalsParser.js +0 -84
  195. package/dist/model/parser/ImportsParser.d.ts +0 -46
  196. package/dist/model/parser/ImportsParser.js +0 -24
  197. package/dist/model/parser/ModelParser.d.ts +0 -71
  198. package/dist/model/parser/ModelParser.js +0 -209
  199. package/dist/model/parser/PredicatesParser.d.ts +0 -75
  200. package/dist/model/parser/PredicatesParser.js +0 -45
  201. package/dist/model/parser/SpecificationParser.d.ts +0 -53
  202. package/dist/model/parser/SpecificationParser.js +0 -113
  203. package/dist/model/parser/ValueConverter.d.ts +0 -4
  204. package/dist/model/parser/ValueConverter.js +0 -12
  205. package/dist/model/parser/ViewsParser.d.ts +0 -112
  206. package/dist/model/parser/ViewsParser.js +0 -492
  207. package/dist/model-change/ModelChanges.d.ts +0 -18
  208. package/dist/model-change/ModelChanges.js +0 -129
  209. package/dist/model-change/changeElementStyle.d.ts +0 -16
  210. package/dist/model-change/changeElementStyle.js +0 -134
  211. package/dist/model-change/changeViewLayout.d.ts +0 -12
  212. package/dist/model-change/changeViewLayout.js +0 -28
  213. package/dist/model-change/removeManualLayoutV1.d.ts +0 -7
  214. package/dist/model-change/removeManualLayoutV1.js +0 -27
  215. package/dist/module.d.ts +0 -92
  216. package/dist/module.js +0 -143
  217. package/dist/protocol.d.ts +0 -284
  218. package/dist/protocol.js +0 -123
  219. package/dist/references/index.d.ts +0 -3
  220. package/dist/references/index.js +0 -3
  221. package/dist/references/name-provider.d.ts +0 -9
  222. package/dist/references/name-provider.js +0 -37
  223. package/dist/references/scope-computation.d.ts +0 -20
  224. package/dist/references/scope-computation.js +0 -288
  225. package/dist/references/scope-provider.d.ts +0 -40
  226. package/dist/references/scope-provider.js +0 -239
  227. package/dist/shared/NodeKindProvider.d.ts +0 -15
  228. package/dist/shared/NodeKindProvider.js +0 -57
  229. package/dist/shared/WorkspaceSymbolProvider.d.ts +0 -3
  230. package/dist/shared/WorkspaceSymbolProvider.js +0 -3
  231. package/dist/shared/index.d.ts +0 -2
  232. package/dist/shared/index.js +0 -2
  233. package/dist/test/index.d.ts +0 -1
  234. package/dist/test/index.js +0 -1
  235. package/dist/test/testServices.d.ts +0 -64
  236. package/dist/test/testServices.js +0 -210
  237. package/dist/utils/disposable.d.ts +0 -8
  238. package/dist/utils/disposable.js +0 -26
  239. package/dist/utils/elementRef.d.ts +0 -11
  240. package/dist/utils/elementRef.js +0 -27
  241. package/dist/utils/fqnRef.d.ts +0 -11
  242. package/dist/utils/fqnRef.js +0 -63
  243. package/dist/utils/index.d.ts +0 -11
  244. package/dist/utils/index.js +0 -35
  245. package/dist/utils/printDocs.d.ts +0 -2
  246. package/dist/utils/printDocs.js +0 -1
  247. package/dist/utils/projectId.d.ts +0 -4
  248. package/dist/utils/projectId.js +0 -16
  249. package/dist/utils/stringHash.d.ts +0 -1
  250. package/dist/utils/stringHash.js +0 -5
  251. package/dist/validation/DocumentValidator.d.ts +0 -11
  252. package/dist/validation/DocumentValidator.js +0 -17
  253. package/dist/validation/_shared.d.ts +0 -3
  254. package/dist/validation/_shared.js +0 -26
  255. package/dist/validation/deployment-checks.d.ts +0 -7
  256. package/dist/validation/deployment-checks.js +0 -140
  257. package/dist/validation/dynamic-view.d.ts +0 -6
  258. package/dist/validation/dynamic-view.js +0 -67
  259. package/dist/validation/element-ref.d.ts +0 -4
  260. package/dist/validation/element-ref.js +0 -12
  261. package/dist/validation/element.d.ts +0 -4
  262. package/dist/validation/element.js +0 -49
  263. package/dist/validation/imports.d.ts +0 -4
  264. package/dist/validation/imports.js +0 -46
  265. package/dist/validation/index.d.ts +0 -15
  266. package/dist/validation/index.js +0 -167
  267. package/dist/validation/property-checks.d.ts +0 -7
  268. package/dist/validation/property-checks.js +0 -108
  269. package/dist/validation/relation.d.ts +0 -6
  270. package/dist/validation/relation.js +0 -141
  271. package/dist/validation/specification.d.ts +0 -12
  272. package/dist/validation/specification.js +0 -190
  273. package/dist/validation/view-checks.d.ts +0 -4
  274. package/dist/validation/view-checks.js +0 -46
  275. package/dist/validation/view-predicates/fqn-expr-with.d.ts +0 -4
  276. package/dist/validation/view-predicates/fqn-expr-with.js +0 -43
  277. package/dist/validation/view-predicates/fqn-ref-expr.d.ts +0 -4
  278. package/dist/validation/view-predicates/fqn-ref-expr.js +0 -51
  279. package/dist/validation/view-predicates/incoming.d.ts +0 -4
  280. package/dist/validation/view-predicates/incoming.js +0 -16
  281. package/dist/validation/view-predicates/index.d.ts +0 -6
  282. package/dist/validation/view-predicates/index.js +0 -6
  283. package/dist/validation/view-predicates/outgoing.d.ts +0 -4
  284. package/dist/validation/view-predicates/outgoing.js +0 -20
  285. package/dist/validation/view-predicates/relation-expr.d.ts +0 -4
  286. package/dist/validation/view-predicates/relation-expr.js +0 -46
  287. package/dist/validation/view-predicates/relation-with.d.ts +0 -4
  288. package/dist/validation/view-predicates/relation-with.js +0 -16
  289. package/dist/validation/view.d.ts +0 -4
  290. package/dist/validation/view.js +0 -42
  291. package/dist/view-utils/assignNavigateTo.d.ts +0 -2
  292. package/dist/view-utils/assignNavigateTo.js +0 -27
  293. package/dist/view-utils/index.d.ts +0 -2
  294. package/dist/view-utils/index.js +0 -2
  295. package/dist/view-utils/manual-layout.d.ts +0 -13
  296. package/dist/view-utils/manual-layout.js +0 -149
  297. package/dist/views/ConfigurableLayouter.d.ts +0 -7
  298. package/dist/views/ConfigurableLayouter.js +0 -51
  299. package/dist/views/LikeC4ManualLayouts.d.ts +0 -42
  300. package/dist/views/LikeC4ManualLayouts.js +0 -209
  301. package/dist/views/LikeC4Views.d.ts +0 -89
  302. package/dist/views/LikeC4Views.js +0 -216
  303. package/dist/views/index.d.ts +0 -4
  304. package/dist/views/index.js +0 -11
  305. package/dist/workspace/AstNodeDescriptionProvider.d.ts +0 -7
  306. package/dist/workspace/AstNodeDescriptionProvider.js +0 -18
  307. package/dist/workspace/IndexManager.d.ts +0 -10
  308. package/dist/workspace/IndexManager.js +0 -26
  309. package/dist/workspace/LangiumDocuments.d.ts +0 -25
  310. package/dist/workspace/LangiumDocuments.js +0 -98
  311. package/dist/workspace/ProjectsManager.d.ts +0 -130
  312. package/dist/workspace/ProjectsManager.js +0 -605
  313. package/dist/workspace/WorkspaceManager.d.ts +0 -31
  314. package/dist/workspace/WorkspaceManager.js +0 -132
  315. package/dist/workspace/index.d.ts +0 -5
  316. 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;