@likec4/language-server 1.47.0 → 1.48.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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 -4853
  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 -63
  68. package/protocol/package.json +2 -2
  69. package/dist/LikeC4LanguageServices.d.ts +0 -115
  70. package/dist/LikeC4LanguageServices.js +0 -164
  71. package/dist/Rpc.d.ts +0 -9
  72. package/dist/Rpc.js +0 -276
  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 -10
  78. package/dist/browser.js +0 -34
  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 -19
  88. package/dist/filesystem/ChokidarWatcher.js +0 -133
  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 -140
  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 -37
  108. package/dist/index.js +0 -54
  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 -13
  118. package/dist/lsp/CompletionProvider.js +0 -238
  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 -19
  130. package/dist/lsp/SemanticTokenProvider.js +0 -305
  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 -4
  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 -121
  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 -202
  148. package/dist/mcp/tools/find-relationships.js +0 -150
  149. package/dist/mcp/tools/list-projects.d.ts +0 -194
  150. package/dist/mcp/tools/list-projects.js +0 -62
  151. package/dist/mcp/tools/open-view.d.ts +0 -200
  152. package/dist/mcp/tools/open-view.js +0 -52
  153. package/dist/mcp/tools/read-deployment.d.ts +0 -200
  154. package/dist/mcp/tools/read-deployment.js +0 -150
  155. package/dist/mcp/tools/read-element.d.ts +0 -200
  156. package/dist/mcp/tools/read-element.js +0 -218
  157. package/dist/mcp/tools/read-project-summary.d.ts +0 -198
  158. package/dist/mcp/tools/read-project-summary.js +0 -176
  159. package/dist/mcp/tools/read-view.d.ts +0 -200
  160. package/dist/mcp/tools/read-view.js +0 -203
  161. package/dist/mcp/tools/search-element.d.ts +0 -198
  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 -54
  178. package/dist/model/model-builder.js +0 -233
  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 -382
  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 -289
  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 -33
  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 -29
  310. package/dist/workspace/LangiumDocuments.js +0 -104
  311. package/dist/workspace/ProjectsManager.d.ts +0 -134
  312. package/dist/workspace/ProjectsManager.js +0 -610
  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,164 +0,0 @@
1
- import { nonexhaustive, } from '@likec4/core';
2
- import { computeProjectsView } from '@likec4/core/compute-view';
3
- import { LikeC4Model } from '@likec4/core/model';
4
- import { loggable } from '@likec4/log';
5
- import { URI } from 'langium';
6
- import { entries, hasAtLeast, indexBy, map, pipe, prop } from 'remeda';
7
- import { DiagnosticSeverity } from 'vscode-languageserver-types';
8
- import { logger as mainLogger } from './logger';
9
- import { ProjectsManager } from './workspace';
10
- const logger = mainLogger.getChild('LanguageServices');
11
- /**
12
- * Public Language Services
13
- */
14
- export class DefaultLikeC4LanguageServices {
15
- services;
16
- builder;
17
- editor;
18
- projectsManager;
19
- constructor(services) {
20
- this.services = services;
21
- this.builder = services.likec4.ModelBuilder;
22
- this.projectsManager = services.shared.workspace.ProjectsManager;
23
- this.editor = services.likec4.ModelChanges;
24
- }
25
- get views() {
26
- return this.services.likec4.Views;
27
- }
28
- get workspaceUri() {
29
- return this.services.shared.workspace.WorkspaceManager.workspaceUri;
30
- }
31
- projects() {
32
- const projectsManager = this.services.shared.workspace.ProjectsManager;
33
- const projectsWithDocs = pipe(this.services.shared.workspace.LangiumDocuments.groupedByProject(), entries(), map(([projectId, docs]) => {
34
- const id = projectId;
35
- const { folderUri, config } = projectsManager.getProject(id);
36
- return {
37
- id,
38
- folder: folderUri,
39
- title: config.title ?? config.name,
40
- documents: map(docs, prop('uri')),
41
- config,
42
- };
43
- }));
44
- // if there are multiple projects and default project is set, ensure it is first
45
- if (hasAtLeast(projectsWithDocs, 2) && projectsManager.defaultProjectId) {
46
- const idx = projectsWithDocs.findIndex(p => p.id === projectsManager.defaultProjectId);
47
- if (idx > 0) {
48
- const [defaultProject] = projectsWithDocs.splice(idx, 1);
49
- return [defaultProject, ...projectsWithDocs];
50
- }
51
- return projectsWithDocs;
52
- }
53
- if (hasAtLeast(projectsWithDocs, 1)) {
54
- return projectsWithDocs;
55
- }
56
- const { folderUri, config } = projectsManager.getProject(ProjectsManager.DefaultProjectId);
57
- const documents = map(this.services.shared.workspace.LangiumDocuments.projectDocuments(ProjectsManager.DefaultProjectId).toArray(), prop('uri'));
58
- return [{
59
- id: ProjectsManager.DefaultProjectId,
60
- folder: folderUri,
61
- title: config.title ?? config.name,
62
- documents,
63
- config,
64
- }];
65
- }
66
- project(projectId) {
67
- projectId = this.projectsManager.ensureProjectId(projectId);
68
- const projectsManager = this.services.shared.workspace.ProjectsManager;
69
- const { folderUri, config } = projectsManager.getProject(projectId);
70
- const documents = map(this.services.shared.workspace.LangiumDocuments.projectDocuments(projectId).toArray(), prop('uri'));
71
- return {
72
- id: projectId,
73
- folder: folderUri,
74
- title: config.title ?? config.name,
75
- documents,
76
- config,
77
- };
78
- }
79
- async diagrams(project, cancelToken) {
80
- const projectId = this.projectsManager.ensureProjectId(project);
81
- return await this.views.diagrams(projectId, cancelToken);
82
- }
83
- async computedModel(project, cancelToken) {
84
- const projectId = this.projectsManager.ensureProjectId(project);
85
- return await this.builder.computeModel(projectId, cancelToken);
86
- }
87
- async layoutedModel(project, cancelToken) {
88
- const projectId = this.projectsManager.ensureProjectId(project);
89
- const model = await this.builder.computeModel(projectId, cancelToken);
90
- if (!model) {
91
- throw new Error('Failed to compute model, empty project?');
92
- }
93
- const layouted = await this.views.layoutAllViews(projectId, cancelToken);
94
- return LikeC4Model.create({
95
- ...model.$data,
96
- _stage: 'layouted',
97
- views: pipe(layouted, map(prop('diagram')), indexBy(prop('id'))),
98
- });
99
- }
100
- async projectsOverview(cancelToken) {
101
- const allProjects = this.services.shared.workspace.ProjectsManager.all;
102
- const models = [];
103
- for (const project of allProjects) {
104
- const model = await this.builder.computeModel(project, cancelToken);
105
- if (cancelToken?.isCancellationRequested) {
106
- throw new Error('Operation cancelled');
107
- }
108
- if (model === LikeC4Model.EMPTY) {
109
- logger.debug(`Project ${project} is empty, skipping`);
110
- continue;
111
- }
112
- models.push(model);
113
- }
114
- if (!hasAtLeast(models, 1)) {
115
- throw new Error('No models found');
116
- }
117
- const projectsView = computeProjectsView(models);
118
- return await this.views.layouter.layoutProjectsView(projectsView);
119
- }
120
- getErrors() {
121
- const docs = this.services.shared.workspace.LangiumDocuments.allExcludingBuiltin.toArray();
122
- return docs.flatMap(doc => {
123
- return (doc.diagnostics ?? [])
124
- .filter(d => d.severity === DiagnosticSeverity.Error)
125
- .map(({ message, range }) => ({
126
- message,
127
- line: range.start.line,
128
- range,
129
- sourceFsPath: doc.uri.fsPath,
130
- }));
131
- });
132
- }
133
- locate(params) {
134
- switch (true) {
135
- case 'element' in params:
136
- return this.services.likec4.ModelLocator.locateElement(params.element, params.projectId);
137
- case 'relation' in params:
138
- return this.services.likec4.ModelLocator.locateRelation(params.relation, params.projectId);
139
- case 'view' in params:
140
- return this.services.likec4.ModelLocator.locateView(params.view, params.projectId);
141
- case 'deployment' in params:
142
- return this.services.likec4.ModelLocator.locateDeploymentElement(params.deployment, params.projectId);
143
- default:
144
- nonexhaustive(params);
145
- }
146
- }
147
- async dispose() {
148
- try {
149
- logger.debug('disposing LikeC4LanguageServices');
150
- await this.services.shared.workspace.FileSystemWatcher.dispose();
151
- if (this.services.mcp.Server.isStarted) {
152
- await this.services.mcp.Server.stop();
153
- }
154
- this.services.Rpc.dispose();
155
- this.services.likec4.ModelBuilder.dispose();
156
- }
157
- catch (e) {
158
- logger.error(loggable(e));
159
- }
160
- finally {
161
- logger.debug('LikeC4LanguageServices disposed');
162
- }
163
- }
164
- }
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,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;