likec4 1.57.0 → 1.58.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/__app__/codegen/react.mjs +7 -8
- package/__app__/codegen/webcomponent.mjs +70 -881
- package/__app__/src/aichat/index.mjs +8 -1
- package/__app__/src/chunks/AIChat.mjs +959 -0
- package/__app__/src/chunks/DiagramActorProvider.mjs +7638 -0
- package/__app__/src/chunks/LikeC4Styles.mjs +1866 -0
- package/__app__/src/chunks/Markdown.mjs +146 -0
- package/__app__/src/chunks/NavigationPanel.mjs +61 -0
- package/__app__/src/chunks/ProjectsOverview.mjs +540 -0
- package/__app__/src/chunks/adhoc-editor.mjs +3386 -0
- package/__app__/src/chunks/es.mjs +439 -0
- package/__app__/src/chunks/hooks.mjs +145 -0
- package/__app__/src/chunks/libs/@dagrejs/dagre.mjs +1894 -0
- package/__app__/src/chunks/libs/@floating-ui.mjs +2218 -0
- package/__app__/src/chunks/libs/@mantine.mjs +12070 -0
- package/__app__/src/chunks/libs/@tabler/icons-react.mjs +252 -0
- package/__app__/src/chunks/libs/@tanstack-ai.mjs +1768 -0
- package/__app__/src/chunks/libs/@tanstack.mjs +2718 -0
- package/__app__/src/chunks/libs/@xstate/react.mjs +1982 -0
- package/__app__/src/chunks/libs/@xyflow/react.mjs +5256 -0
- package/__app__/src/chunks/libs/bezier-js.mjs +1003 -0
- package/__app__/src/chunks/libs/d3.mjs +2842 -0
- package/__app__/src/chunks/libs/fast-equals.mjs +268 -0
- package/__app__/src/chunks/libs/framer.mjs +5872 -0
- package/__app__/src/chunks/libs/remeda.mjs +642 -0
- package/__app__/src/chunks/libs/zod.mjs +3170 -0
- package/__app__/src/chunks/rolldown-runtime.mjs +23 -0
- package/__app__/src/chunks/styled-system.mjs +1040 -0
- package/__app__/src/fonts.css +1 -1
- package/__app__/src/main.mjs +14816 -14
- package/__app__/src/style.css +1 -1
- package/dist/chunks/enableServer.mjs +1 -1
- package/dist/chunks/filenames.mjs +2 -2
- package/dist/chunks/index2.d.mts +1877 -734
- package/dist/chunks/libs/@chevrotain/gast.mjs +1 -1
- package/dist/chunks/libs/@logtape/logtape.mjs +4 -3
- package/dist/chunks/libs/chevrotain-allstar.mjs +2 -2
- package/dist/chunks/libs/chevrotain.mjs +25 -25
- package/dist/chunks/libs/langium.mjs +1 -1
- package/dist/chunks/libs/merge-error-cause.mjs +1 -1
- package/dist/chunks/libs/pretty-ms.mjs +1 -1
- package/dist/chunks/libs/remeda.mjs +1 -1
- package/dist/chunks/libs/ufo.mjs +1 -1
- package/dist/chunks/libs/unstorage.mjs +1 -1
- package/dist/chunks/libs/which.mjs +1 -1
- package/dist/chunks/libs/zod.mjs +65 -0
- package/dist/chunks/node.mjs +73 -62
- package/dist/chunks/{plugin.mjs → vite-plugin.mjs} +41 -41
- package/dist/cli/index.mjs +184 -144
- package/dist/index.d.mts +1 -1
- package/dist/index.mjs +1 -1
- package/dist/model/index.d.mts +1 -1
- package/dist/vite-plugin/index.mjs +1 -1
- package/dist/vite-plugin/internal/index.d.mts +52 -57
- package/dist/vite-plugin/internal/index.mjs +946 -1
- package/package.json +46 -47
- package/react/index.d.mts +92 -23
- package/react/index.mjs +44551 -42605
- package/__app__/chunks/AIChat2.mjs +0 -2
- package/__app__/chunks/DiagramActorProvider.mjs +0 -10
- package/__app__/chunks/EmbedPage.mjs +0 -1
- package/__app__/chunks/ExportPage.mjs +0 -2
- package/__app__/chunks/LikeC4Diagram.mjs +0 -19
- package/__app__/chunks/LikeC4Styles.mjs +0 -48
- package/__app__/chunks/Markdown.mjs +0 -1
- package/__app__/chunks/NavigationPanel.mjs +0 -1
- package/__app__/chunks/ViewReact.mjs +0 -1
- package/__app__/chunks/adhoc-editor.mjs +0 -1
- package/__app__/chunks/aichat.mjs +0 -1
- package/__app__/chunks/box.mjs +0 -1
- package/__app__/chunks/create-style-context.mjs +0 -1
- package/__app__/chunks/css.mjs +0 -1
- package/__app__/chunks/factory.mjs +0 -1
- package/__app__/chunks/hooks.mjs +0 -1
- package/__app__/chunks/hstack.mjs +0 -1
- package/__app__/chunks/libs/@dagrejs/dagre.mjs +0 -1
- package/__app__/chunks/libs/@floating-ui/core.mjs +0 -1
- package/__app__/chunks/libs/@floating-ui/dom.mjs +0 -1
- package/__app__/chunks/libs/@floating-ui/react.mjs +0 -1
- package/__app__/chunks/libs/@mantine/core.mjs +0 -41
- package/__app__/chunks/libs/@mantine/hooks.mjs +0 -1
- package/__app__/chunks/libs/@nanostores/react.mjs +0 -1
- package/__app__/chunks/libs/@react-hookz/web.mjs +0 -1
- package/__app__/chunks/libs/@tabler/icons-react.mjs +0 -358
- package/__app__/chunks/libs/@tanstack/ai-client.mjs +0 -2
- package/__app__/chunks/libs/@tanstack/ai-react-ui.mjs +0 -1
- package/__app__/chunks/libs/@tanstack/ai-react.mjs +0 -1
- package/__app__/chunks/libs/@tanstack/ai.mjs +0 -2
- package/__app__/chunks/libs/@tanstack/history.mjs +0 -1
- package/__app__/chunks/libs/@tanstack/react-router.mjs +0 -3
- package/__app__/chunks/libs/@tanstack/router-core.mjs +0 -1
- package/__app__/chunks/libs/@xstate/react.mjs +0 -1
- package/__app__/chunks/libs/@xstate/store.mjs +0 -1
- package/__app__/chunks/libs/@xyflow/react.mjs +0 -7
- package/__app__/chunks/libs/@zag-js/anatomy.mjs +0 -1
- package/__app__/chunks/libs/@zag-js/collection.mjs +0 -1
- package/__app__/chunks/libs/@zag-js/core.mjs +0 -1
- package/__app__/chunks/libs/@zag-js/react.mjs +0 -1
- package/__app__/chunks/libs/@zag-js/tree-view.mjs +0 -1
- package/__app__/chunks/libs/bezier-js.mjs +0 -1
- package/__app__/chunks/libs/copy-anything.mjs +0 -1
- package/__app__/chunks/libs/d3-path.mjs +0 -1
- package/__app__/chunks/libs/d3-shape.mjs +0 -1
- package/__app__/chunks/libs/fast-equals.mjs +0 -1
- package/__app__/chunks/libs/framer-motion.mjs +0 -9
- package/__app__/chunks/libs/html-to-image.mjs +0 -2
- package/__app__/chunks/libs/motion-dom.mjs +0 -1
- package/__app__/chunks/libs/nanostores.mjs +0 -1
- package/__app__/chunks/libs/react-error-boundary.mjs +0 -1
- package/__app__/chunks/libs/react-resizable-panels.mjs +0 -1
- package/__app__/chunks/libs/remeda.mjs +0 -1
- package/__app__/chunks/libs/superjson.mjs +0 -1
- package/__app__/chunks/libs/zod.mjs +0 -64
- package/__app__/chunks/rolldown-runtime.mjs +0 -1
- package/__app__/chunks/styles.css.mjs +0 -1
- package/__app__/chunks/txt.mjs +0 -1
- package/__app__/chunks/useLikeC4Project.mjs +0 -1
- package/__app__/src/pages/AdHocViewEditor.mjs +0 -1
- package/__app__/src/pages/EmbedPage.mjs +0 -1
- package/__app__/src/pages/ExportPage.mjs +0 -1
- package/__app__/src/pages/ProjectsOverview.mjs +0 -1
- package/__app__/src/pages/ViewAsD2.mjs +0 -1
- package/__app__/src/pages/ViewAsDot.mjs +0 -1
- package/__app__/src/pages/ViewAsMmd.mjs +0 -1
- package/__app__/src/pages/ViewAsPuml.mjs +0 -1
- package/__app__/src/pages/ViewEditor.mjs +0 -1
- package/__app__/src/pages/ViewReact.mjs +0 -1
- package/dist/chunks/libs/@chevrotain/utils.mjs +0 -1
- package/dist/chunks/libs/@hono/mcp.mjs +0 -70
- package/dist/chunks/libs/@hono/node-server.mjs +0 -1
- package/dist/chunks/libs/@logtape/logtape.d.mts +0 -1023
- package/dist/chunks/libs/@modelcontextprotocol/sdk.mjs +0 -12
- package/dist/chunks/libs/ajv.mjs +0 -1
- package/dist/chunks/libs/ansi-align.mjs +0 -2
- package/dist/chunks/libs/ansi-regex.mjs +0 -1
- package/dist/chunks/libs/ansi-styles.mjs +0 -1
- package/dist/chunks/libs/atomically.mjs +0 -1
- package/dist/chunks/libs/boxen.mjs +0 -22
- package/dist/chunks/libs/conf.mjs +0 -1
- package/dist/chunks/libs/defu.mjs +0 -1
- package/dist/chunks/libs/destr.mjs +0 -1
- package/dist/chunks/libs/find-up-simple.mjs +0 -1
- package/dist/chunks/libs/get-port.mjs +0 -1
- package/dist/chunks/libs/hono.mjs +0 -1
- package/dist/chunks/libs/is-docker.mjs +0 -1
- package/dist/chunks/libs/is-error-instance.mjs +0 -1
- package/dist/chunks/libs/is-inside-container.mjs +0 -1
- package/dist/chunks/libs/is-plain-obj.mjs +0 -1
- package/dist/chunks/libs/isexe.mjs +0 -1
- package/dist/chunks/libs/ky.mjs +0 -3
- package/dist/chunks/libs/p-debounce.mjs +0 -1
- package/dist/chunks/libs/p-limit.mjs +0 -1
- package/dist/chunks/libs/p-timeout.mjs +0 -1
- package/dist/chunks/libs/package-up.mjs +0 -1
- package/dist/chunks/libs/parse-ms.mjs +0 -1
- package/dist/chunks/libs/safe-stringify.mjs +0 -1
- package/dist/chunks/libs/strip-indent.mjs +0 -1
- package/dist/chunks/libs/tinyrainbow.mjs +0 -1
- package/dist/chunks/libs/ts-graphviz.mjs +0 -1
- package/dist/chunks/libs/unctx.mjs +0 -1
- package/dist/chunks/libs/vscode-languageserver.mjs +0 -1
- package/dist/chunks/libs/word-wrap.mjs +0 -12
- package/dist/vite-plugin/internal/chunks/libs/@nanostores/react.mjs +0 -1
- package/dist/vite-plugin/internal/chunks/libs/birpc.mjs +0 -1
- package/dist/vite-plugin/internal/chunks/libs/fast-equals.mjs +0 -1
- package/dist/vite-plugin/internal/chunks/libs/nanostores.mjs +0 -1
- package/dist/vite-plugin/internal/chunks/libs/remeda.mjs +0 -1
- package/dist/vite-plugin/internal/chunks/rolldown-runtime.mjs +0 -1
package/dist/chunks/node.mjs
CHANGED
|
@@ -1,34 +1,45 @@
|
|
|
1
|
-
import{c as e,i as t}from"./rolldown-runtime.mjs";import{a as
|
|
1
|
+
import{c as e,i as t,t as r}from"./rolldown-runtime.mjs";import{a as o,i as s,n as c,r as u,t as d}from"./libs/@logtape/logtape.mjs";import{n as p,t as m}from"./libs/merge-error-cause.mjs";import{$ as h,A as g,B as _,C as v,D as y,E as b,F as x,G as ee,H as S,I as te,J as ne,K as re,L as ie,M as ae,N as oe,O as se,P as ce,Q as le,R as ue,S as de,T as fe,U as C,V as w,W as pe,X as me,Y as T,Z as he,_ as ge,_t as _e,a as ve,at as ye,b as be,bt as xe,c as Se,ct as Ce,d as we,dt as Te,et as Ee,f as De,ft as Oe,g as ke,gt as Ae,h as je,ht as Me,i as Ne,it as Pe,j as Fe,k as Ie,l as Le,lt as Re,m as ze,mt as Be,n as Ve,nt as He,ot as Ue,p as We,pt as Ge,q as Ke,r as qe,rt as Je,s as Ye,st as Xe,t as Ze,tt as Qe,u as $e,ut as et,v as tt,vt as nt,w as rt,x as it,xt as at,y as ot,yt as st,z as ct}from"./libs/langium.mjs";import{a as lt,d as ut,f as dt,i as ft,l as pt,n as mt,o as ht,p as gt,r as _t,t as vt,u as yt}from"./libs/ufo.mjs";import{t as bt}from"./libs/json5.mjs";import{C as xt,E as St,S as E,_ as Ct,b as wt,c as Tt,f as Et,g as Dt,l as Ot,m as kt,t as At,u as jt,x as Mt}from"./libs/zod.mjs";import{a as Nt,c as Pt,n as Ft,r as It,s as Lt,t as Rt}from"./filenames.mjs";import{n as zt,t as Bt}from"./libs/pathe.mjs";import{$ as Vt,A as D,C as k,D as Ht,E as Ut,F as Wt,G as A,H as Gt,I as Kt,J as qt,L as Jt,M as Yt,N as j,O as M,P as Xt,Q as N,R as Zt,S as Qt,T as $t,U as en,V as tn,W as nn,X as P,Y as rn,Z as an,_ as on,a as sn,at as cn,b as ln,c as un,d as dn,et as F,f as fn,g as pn,h as mn,i as hn,it as gn,j as _n,k as vn,l as yn,m as bn,n as xn,nt as Sn,o as Cn,p as wn,q as Tn,r as En,rt as Dn,s as On,t as kn,tt as An,u as jn,v as Mn,w as Nn,x as Pn,y as I}from"./libs/remeda.mjs";import{t as Fn}from"./sequence-view.mjs";import{t as In}from"./libs/@ts-graphviz/core.mjs";import{n as Ln,r as Rn,t as zn}from"./libs/@ts-graphviz/ast.mjs";import{n as Bn,r as Vn,t as Hn}from"./libs/khroma.mjs";import{t as Un}from"./libs/p-queue.mjs";import{t as Wn}from"./libs/which.mjs";import{t as Gn}from"./libs/pretty-ms.mjs";import{t as Kn}from"./libs/picomatch.mjs";import{n as qn,t as Jn}from"./libs/unstorage.mjs";import{basename as Yn,dirname as Xn,relative as Zn,resolve as Qn}from"node:path";import{BorderStyles as $n,ElementShapes as er,IconPositions as tr,LikeC4Styles as nr,RelationshipArrowTypes as rr,Sizes as ir,ThemeColors as ar,assignTagColors as or,computeColorValues as sr}from"@likec4/core/styles";import{Fqn as cr,FqnExpr as lr,FqnRef as L,_stage as ur,_type as dr,exact as fr,isAnyOf as R,isExtendsElementView as pr}from"@likec4/core/types";import*as mr from"@likec4/core";import{DefaultMap as hr,Fqn as gr,FqnExpr as _r,FqnRef as z,GlobalFqn as vr,LikeC4Styles as yr,LinkedList as br,RelationExpr as xr,RichText as Sr,_layout as Cr,_stage as wr,_type as Tr,ancestorsFqn as Er,applyCachedLayout as Dr,applyManualLayout as Or,calcDriftsFromSnapshot as kr,exact as Ar,extractStep as jr,hasProp as Mr,invariant as V,isAncestor as Nr,isAndOperator as Pr,isAnyOf as Fr,isDeploymentNode as Ir,isDeploymentView as Lr,isDynamicView as Rr,isElementView as zr,isGlobalFqn as Br,isNonEmptyArray as Vr,isOrOperator as Hr,isSameHierarchy as Ur,nameFromFqn as Wr,nonNullable as Gr,nonexhaustive as H,preferSummary as Kr,splitGlobalFqn as qr}from"@likec4/core";import{DefaultMap as Jr,DefaultWeakMap as Yr,MultiMap as U,ancestorsFqn as Xr,compareFqnHierarchically as Zr,compareNatural as Qr,compareNaturalHierarchically as $r,delay as ei,hierarchyDistance as ti,ifilter as ni,invariant as W,isNonEmptyArray as ri,isString as ii,memoizeProp as ai,nameFromFqn as oi,nonNullable as si,nonexhaustive as ci,onNextTick as li,parentFqn as ui,promiseNextTick as di,sortNaturalByFqn as fi,sortParentsFirst as pi,stringHash as mi,toArray as hi}from"@likec4/core/utils";import{Graph as gi}from"@likec4/core/utils/graphology";import{Graphviz as _i}from"@hpcc-js/wasm-graphviz";import{LikeC4Model as vi}from"@likec4/core/model";import yi,{SubprocessError as bi}from"nano-spawn";import xi from"node:os";import{mkdirSync as Si,statSync as Ci}from"node:fs";import*as wi from"node:fs/promises";import{unlink as Ti,writeFile as Ei}from"node:fs/promises";import{isColorSupported as Di,isDevelopment as Oi}from"std-env";import{bundleRequire as ki}from"bundle-require";import{formatMessagesSync as Ai}from"esbuild";import{cwd as ji}from"node:process";import{fdir as Mi}from"fdir";import Ni from"chokidar";import{computeAdhocView as Pi,computeProjectsView as Fi,computeView as Ii,resolveRulesExtendedViews as Li}from"@likec4/core/compute-view";function serializeValue(e,t,r,o){if(typeof e?.toJSON==`function`&&(e=e.toJSON()),!(typeof e==`object`&&e))return e;if(t.has(e)){if(!r)return`[Circular]`;let o=t.get(e);return`[Circular ${o===``?`*`:`*${o}`}]`}t.set(e,o);let s=Array.isArray(e)?[]:{};for(let[c,u]of Object.entries(e))s[c]=serializeValue(u,t,r,o===``?c:`${o}.${c}`);return t.delete(e),s}function safeStringify(e,{indentation:t,trace:r}={}){let o=serializeValue(e,new WeakMap,r,``);return JSON.stringify(o,void 0,t)}const parseStack=e=>e.split(`
|
|
2
2
|
`).map(e=>e.trim().replace(`file://`,``));function indent$1(e,t=2){e=Array.isArray(e)?e:e.split(`
|
|
3
|
-
`);let
|
|
4
|
-
`)}t(indent$1,`indent`);function loggable(e){if(typeof e==`string`)return e;if(e instanceof Error){let t=
|
|
5
|
-
`+indent$1(e.slice(1))}return t.message}return
|
|
6
|
-
`),[e]}return e===`error`||e===`err`?[Error(loggable(t))]:[]});return t.length===0?null:t.length===1?t[0]:AggregateError(t)}function errorFromLogRecord(e){let t=getErrorFromLogRecord(e);return t&&typeof e.rawMessage==`string`?
|
|
7
|
-
`):t}function appendErrorToMessage(e,t=!1){let
|
|
8
|
-
`+indent$1(
|
|
9
|
-
`).slice(1))),t&&(
|
|
10
|
-
`+indent$1(
|
|
3
|
+
`);let r=` `.repeat(t);return e.map(e=>`${r}${e}`).join(`
|
|
4
|
+
`)}t(indent$1,`indent`);function loggable(e){if(typeof e==`string`)return e;if(e instanceof Error){let t=m(e);if(t.stack){let e=parseStack(t.stack);return t.message+`
|
|
5
|
+
`+indent$1(e.slice(1))}return t.message}return safeStringify(e,{indentation:` `})}function wrapError(e,t){return p(e,t)}function getErrorFromLogRecord(e){let t=Object.entries(e.properties).flatMap(([e,t])=>{if(t instanceof Error){let e=m(t);return e.stack&&=parseStack(e.stack).join(`
|
|
6
|
+
`),[e]}return e===`error`||e===`err`?[Error(loggable(t))]:[]});return t.length===0?null:t.length===1?t[0]:AggregateError(t)}function errorFromLogRecord(e){let t=getErrorFromLogRecord(e);return t&&typeof e.rawMessage==`string`?p(t,e.rawMessage+`
|
|
7
|
+
`):t}function appendErrorToMessage(e,t=!1){let r=getErrorFromLogRecord(e.record);if(r){let o=r.message;return r.stack&&(o=o+`
|
|
8
|
+
`+indent$1(r.stack.split(`
|
|
9
|
+
`).slice(1))),t&&(o=`${Bi.red}${o}${zi}`),{...e,message:e.message+`
|
|
10
|
+
`+indent$1(o)}}return e}const Ri={trace:`TRACE`,debug:`DEBUG`,info:`INFO `,warning:`WARN `,error:`ERROR`,fatal:`FATAL`};function getMessageOnlyFormatter(){return getTextFormatter({format:({message:e})=>e})}const level=e=>Ri[e];function getTextFormatter(e){let t=e?.format??(({timestamp:e,level:t,category:r,message:o})=>`${e} ${t} ${r} ${o}`);return s({timestamp:`time`,level,category:`.`,...e,format:e=>t(appendErrorToMessage(e))})}const zi=`\x1B[0m`,Bi={red:`\x1B[31m`};function getAnsiColorFormatter(e){let t=e?.format??(({timestamp:e,level:t,category:r,message:o})=>`${e} ${t} ${r} ${o}`);return u({timestamp:`time`,level,categoryStyle:`bold`,categoryColor:`cyan`,category:`.`,levelColors:{trace:`black`,debug:`blue`,info:`green`,warning:`yellow`,error:`red`,fatal:`magenta`},...e,format:e=>t(appendErrorToMessage(e,!0))})}function getConsoleFormatter(e){let t=e?.messageFormatter;return t?e=>{let{properties:r}=e;return r&&Object.keys(r).length>0?[t(e),r]:[t(e)]}:e=>{let{message:t,properties:r}=e;return r&&Object.keys(r).length>0?[...t,r]:t}}function getConsoleSink(e){return c({formatter:getConsoleFormatter(),...e})}function getConsoleStderrSink(e){let t=e?.formatter??getConsoleFormatter();return e=>{let r=t(e);if(typeof r==`string`){let e=r.replace(/\r?\n$/,``);console.error(e)}else console.error(...r)}}const G=o(`likec4`);function createLogger(e){return G.getChild(e)}function configureLogger$1(e){try{let{sinks:t={},loggers:r,...o}=e??{},s={console:getConsoleSink(),...t};d({reset:!0,...o,sinks:s,loggers:[{category:[`logtape`,`meta`],sinks:[`console`],lowestLevel:`warning`},...e?.loggers??[{category:`likec4`,sinks:[`console`],lowestLevel:`debug`}]]})}catch(e){console.error(e)}}t(configureLogger$1,`configureLogger`);function isPlainObject(e){if(typeof e!=`object`||!e)return!1;let t=Object.getPrototypeOf(e);return t!==null&&t!==Object.prototype&&Object.getPrototypeOf(t)!==null||Symbol.iterator in e?!1:Symbol.toStringTag in e?Object.prototype.toString.call(e)===`[object Module]`:!0}function _defu(e,t,r=`.`,o){if(!isPlainObject(t))return _defu(e,{},r,o);let s={...t};for(let t of Object.keys(e)){if(t===`__proto__`||t===`constructor`)continue;let c=e[t];c!=null&&(o&&o(s,t,c,r)||(Array.isArray(c)&&Array.isArray(s[t])?s[t]=[...c,...s[t]]:isPlainObject(c)&&isPlainObject(s[t])?s[t]=_defu(c,s[t],(r?`${r}.`:``)+t.toString(),o):s[t]=c))}return s}function createDefu(e){return(...t)=>t.reduce((t,r)=>_defu(t,r,``,e),{})}const Vi=createDefu();Pe();var Hi={reset:[0,0],bold:[1,22,`\x1B[22m\x1B[1m`],dim:[2,22,`\x1B[22m\x1B[2m`],italic:[3,23],underline:[4,24],inverse:[7,27],hidden:[8,28],strikethrough:[9,29],black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],gray:[90,39],bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],blackBright:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39],bgBlackBright:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]};function i(e){return String(e)}i.open=``,i.close=``;function B(){let e=typeof process<`u`?process:void 0,t=e?.env||{},r=t.FORCE_TTY!==`false`,o=e?.argv||[];return!(`NO_COLOR`in t||o.includes(`--no-color`))&&(`FORCE_COLOR`in t||o.includes(`--color`)||e?.platform===`win32`||r&&t.TERM!==`dumb`||`CI`in t)||typeof window<`u`&&!!window.chrome}function C$1({force:e}={}){let t=e||B(),a=(e,t,r,o)=>{let s=``,c=0;do s+=e.substring(c,o)+r,c=o+t.length,o=e.indexOf(t,c);while(~o);return s+e.substring(c)},l=(e,t,r=e)=>{let n=o=>{let s=String(o),c=s.indexOf(t,e.length);return~c?e+a(s,t,r,c)+t:e+s+t};return n.open=e,n.close=t,n},r={isColorSupported:t},f=e=>`\x1B[${e}m`;for(let e in Hi){let o=Hi[e];r[e]=t?l(f(o[0]),f(o[1]),o[2]):i}return r}t(C$1,`C`);var Ui=C$1();const Wi=t(e=>e.severity===1,`isErrorDiagnostic`);var LikeC4=class{langium;logger;constructor(e,t=G){this.langium=e,this.logger=t}get workspace(){return this.langium.shared.workspace.WorkspaceManager.workspaceUri.fsPath}get workspaceURI(){return this.langium.shared.workspace.WorkspaceManager.workspaceUri}get workspaceURL(){return this.langium.shared.workspace.WorkspaceManager.workspaceURL}get languageServices(){return this.langium.likec4.likec4.LanguageServices}get projectsManager(){return this.langium.shared.workspace.ProjectsManager}get viewsService(){return this.langium.likec4.likec4.Views}get modelBuilder(){return this.langium.likec4.likec4.ModelBuilder}get LangiumDocuments(){return this.langium.shared.workspace.LangiumDocuments}ensureSingleProject(){let e=this.languageServices.projects();if(e.length>1)throw this.logger.error(`Multiple projects found:
|
|
11
11
|
${e.map(e=>` - ${e.folder.fsPath}`).join(`
|
|
12
12
|
`)}
|
|
13
13
|
|
|
14
|
-
Please specify a project folder`),Error(`Multiple projects found`)}async diagrams(e){let t=this.projectsManager.ensureProjectId(e);return await this.viewsService.diagrams(t)}syncComputedModel(e){let t=this.projectsManager.ensureProjectId(e);return this.modelBuilder.unsafeSyncComputeModel(t)}async computedModel(e){let t=this.projectsManager.ensureProjectId(e);return await this.modelBuilder.computeModel(t)}projects(){return
|
|
15
|
-
`);return
|
|
16
|
-
`));this.logger.error(`Invalid ${t.uri.fsPath}\n${
|
|
17
|
-
`)}`);async function handleInitOptions(e,t=
|
|
18
|
-
`);return k(n)&&n>0&&i.length>n&&(i=i.slice(0,n)),i}function wrapWithFont({text:e,maxchars:t,fontsize:n,maxLines:r,bold:i,color:a}){let o=wrap(e,{maxchars:t,maxLines:r,sanitize}).join(`<BR/>`);i&&(o=`<B>${o}</B>`);let s=a?` COLOR="${a}"`:``;return`<FONT POINT-SIZE="${pxToPoints(n)}"${s}>${o}</FONT>`}function maxchars(e){switch(e){case`xs`:case`sm`:return 30;case`md`:return 40;case`lg`:case`xl`:return 55;default:si(e)}}function nodeLabel(e,t){let{sizes:{size:n},values:r}=t.nodeSizes(e.style),i=t.colors(e.color).elements,a=[`sm`,`xs`].includes(n),o=T(e.icon),s=e.style.iconPosition??`left`,c=o&&(s===`left`||s===`right`),l=[wrapWithFont({text:e.title,fontsize:r.textSize,maxchars:maxchars(n),maxLines:a?1:3})];if(n!==`xs`){T(e.technology?.trim())&&l.push(wrapWithFont({text:e.technology,fontsize:Math.ceil(r.textSize*.65),maxchars:c?35:45,maxLines:1,color:i.loContrast}));let t=Sr.from(e.description).text;t&&l.push(wrapWithFont({text:t,fontsize:Math.ceil(r.textSize*.75),maxchars:c?35:45,maxLines:a?3:5,color:i.loContrast}))}if(l.length===1&&o===!1)return`<${l[0]}>`;let u=c?(t,n,i)=>{let a=`<TD ALIGN="TEXT" BALIGN="LEFT">${t}</TD>`;if(n===0){let t=i.length>1?` ROWSPAN="${i.length}"`:``,n=Math.ceil(r.iconSize+16);(e.shape===`queue`||e.shape===`mobile`)&&(n+=20),s===`right`?(a=`<TD${t} WIDTH="16"> </TD>${a}`,a=`${a}<TD${t} WIDTH="${n}"> </TD>`):(a=`<TD${t} WIDTH="${n}"> </TD>${a}`,a=`${a}<TD${t} WIDTH="16"> </TD>`)}return`<TR>${a}</TR>`}:e=>`<TR><TD>${e}</TD></TR>`,d=l.map(u).join(``);if(o&&(s===`top`||s===`bottom`)){let e=`<TR><TD HEIGHT="${Math.ceil(r.iconSize+8)}"> </TD></TR>`;d=s===`top`?`${e}${d}`:`${d}${e}`}return`<<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="4">${d}</TABLE>>`}function compoundLabel(e,t){let n=wrapWithFont({text:e.title.toUpperCase(),maxchars:50,fontsize:11,maxLines:1,bold:!0,color:t});return n.includes(`<BR/>`)?`<<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="0"><TR><TD ALIGN="TEXT" BALIGN="LEFT">${n}</TD></TR></TABLE>>`:`<${n}>`}const Ui=`BGCOLOR="${yr.DEFAULT.relationshipColors.labelBg}A0"`;function edgelabel({label:e,technology:t}){let n=[];return T(e?.trim())&&n.push(wrapWithFont({text:e,maxchars:40,fontsize:14,maxLines:5,bold:e===`[...]`})),T(t?.trim())&&n.push(wrapWithFont({text:`[ ${t} ]`,fontsize:12,maxLines:1,maxchars:40})),n.length===0?null:`<<TABLE BORDER="0" CELLPADDING="3" CELLSPACING="0" ${Ui}>${n.map(e=>`<TR><TD ALIGN="TEXT" BALIGN="LEFT">${e}</TD></TR>`).join(``)}</TABLE>>`}function stepEdgeLabel(e,t){let n=`<TABLE BORDER="0" CELLPADDING="6" ${Ui}><TR><TD WIDTH="20" HEIGHT="20"><FONT POINT-SIZE="${pxToPoints(14)}"><B>${e}</B></FONT></TD></TR></TABLE>`;return T(t?.trim())?`<${[`<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="3">`,`<TR>`,`<TD>${n}</TD>`,`<TD ${Ui} CELLPADDING="3">`,wrapWithFont({text:t,maxchars:40,fontsize:14,maxLines:5}),`</TD>`,`</TR>`,`</TABLE>`].join(``)}>`:`<${n}>`}const Wi=`Arial`,Gi=createLogger(`dot`);var DotPrinter=class{view;styles;ids=new Set;subgraphs=new Map;nodes=new Map;edges=new Map;compoundIds;edgesWithCompounds;viewNodes=new qr(e=>oi(this.view.nodes.find(t=>t.id===e),`Node ${e} not found`));logger=Gi;graphology=new hi({allowSelfLoops:!0,multi:!0,type:`directed`});G;constructor(e,t){this.view=e,this.styles=t,this.compoundIds=new Set(e.nodes.filter(isCompound).map(e=>e.id)),this.edgesWithCompounds=new Set(this.compoundIds.size>0?e.edges.filter(e=>this.compoundIds.has(e.source)||this.compoundIds.has(e.target)).map(e=>e.id):[]);for(let t of e.nodes)this.graphology.addNode(t.id,{origin:t,level:t.level,depth:t.depth??0,modelRef:t.modelRef??null,deploymentRef:t.deploymentRef??null,maxConnectedHierarchyDistance:0});for(let t of e.edges){let e=this.graphology.getNodeAttribute(t.source,`deploymentRef`),n=this.graphology.getNodeAttribute(t.target,`deploymentRef`);(e===null||n===null)&&(e=this.graphology.getNodeAttribute(t.source,`modelRef`),n=this.graphology.getNodeAttribute(t.target,`modelRef`));let r=-1;e!==null&&n!==null&&(r=ei(e,n)),this.graphology.addEdgeWithKey(t.id,t.source,t.target,{origin:t,hierarchyDistance:r,weight:1}),r>this.graphology.getNodeAttribute(t.source,`maxConnectedHierarchyDistance`)&&this.graphology.mergeNodeAttributes(t.source,{maxConnectedHierarchyDistance:r}),r>this.graphology.getNodeAttribute(t.target,`maxConnectedHierarchyDistance`)&&this.graphology.mergeNodeAttributes(t.target,{maxConnectedHierarchyDistance:r})}this.graphology.forEachEdge((e,{hierarchyDistance:t},n,r,i,a)=>{let o=Math.max(i.maxConnectedHierarchyDistance,a.maxConnectedHierarchyDistance);if(o>t)this.graphology.mergeEdgeAttributes(e,{weight:o-t+1});else{let i=this.graphology.directedDegree(n),a=this.graphology.directedDegree(r);i===1&&a===1&&t>1&&this.graphology.mergeEdgeAttributes(e,{weight:t})}});let n=this.G=this.createGraph();this.applyNodeAttributes(n.attributes.node),this.applyEdgeAttributes(n.attributes.edge)}get $defaults(){return this.styles.defaults}get hasEdgesWithCompounds(){return this.edgesWithCompounds.size>0}get defaultRelationshipColors(){let e=this.styles.relationshipColors;return{line:e.line,label:e.label,labelBg:e.labelBg}}postBuild(e){}selectViewNodes(){return this.view.nodes}selectViewEdges(){return this.view.edges}build(){let e=this.G,t=[];for(let n of this.selectViewNodes())if(isCompound(n))O(n.parent)&&t.push(n);else{let t=this.generateGraphvizId(n),r=this.elementToNode(n,e.node(t));this.nodes.set(n.id,r)}let traverseClusters=(e,t)=>{let n=this.generateGraphvizId(e),r=this.elementToSubgraph(e,t.subgraph(n));this.subgraphs.set(e.id,r);for(let t of e.children){let e=this.computedNode(t);if(isCompound(e))traverseClusters(e,r);else{let t=this.getGraphNode(e.id);t&&r.node(t.id)}}};for(let n of t)traverseClusters(n,e);for(let t of this.selectViewEdges()){let n=this.addEdge(t,e);n&&this.edges.set(t.id,n)}return this}print(){return this.build(),this.postBuild(this.G),Fn(this.G,{print:{indentStyle:`space`,indentSize:2}})}enableNewRankIfNeeded(){return this.G.subgraphs.some(e=>!!e.get(P.rank))&&this.G.set(P.newrank,!0),this}createGraph(){let e=this.view.autoLayout,t=e.direction,n=In({[P.likec4_viewId]:this.view.id,[P.bgcolor]:`transparent`,[P.layout]:`dot`,[P.compound]:!0,[P.rankdir]:t,[P.TBbalance]:`min`,[P.splines]:`spline`,[P.outputorder]:`nodesfirst`,[P.nodesep]:pxToInch(e.nodeSep??110),[P.ranksep]:pxToInch(e.rankSep??120),[P.pad]:pxToInch(15),[P.fontname]:Wi});return n.attributes.graph.apply({[P.fontsize]:pxToPoints(this.styles.fontSize()),[P.labeljust]:t===`RL`?`r`:`l`,[P.labelloc]:t===`BT`?`b`:`t`,[P.margin]:50.1}),n}applyNodeAttributes(e){let t=this.styles.elementColors;e.apply({[P.fontname]:Wi,[P.shape]:`rect`,[P.fillcolor]:t.fill,[P.fontcolor]:t.hiContrast,[P.color]:t.stroke,[P.style]:`filled`,[P.penwidth]:0})}applyEdgeAttributes(e){let t=this.defaultRelationshipColors;e.apply({[P.arrowsize]:.75,[P.fontname]:Wi,[P.fontsize]:pxToPoints(14),[P.penwidth]:pxToPoints(2),[P.color]:t.line,[P.fontcolor]:t.label,[P.style]:this.$defaults.relationship.line})}reserveNodeId(e,t=!1){return t?e=`cluster_`+e:e.toLowerCase().startsWith(`cluster`)&&(e=`nd_`+e),this.ids.has(e)?!1:(this.ids.add(e),e)}generateGraphvizId(e){let t=isCompound(e),n=ai(e.id).toLowerCase(),r=this.reserveNodeId(n,t),i=1;for(;r===!1;)r=this.reserveNodeId(n+`_`+ i++,t);return r}elementToSubgraph(e,t){U(isCompound(e),`node should be compound`),U(Ht(e.depth),`node.depth should be defined`);let n=this.styles.colors(e.color).elements,r=compoundLabelColor(n.loContrast);return t.apply({[P.likec4_id]:e.id,[P.likec4_level]:e.level,[P.likec4_depth]:e.depth,[P.fillcolor]:compoundColor(n.fill,e.depth),[P.color]:compoundColor(n.stroke,e.depth),[P.style]:`filled`,[P.margin]:pxToPoints(e.children.length>1?40:32)}),D(e.title.trim())||t.set(P.label,compoundLabel(e,r)),t}elementToNode(e,t){U(!isCompound(e),`node should not be compound`);let n=T(e.icon),{values:{padding:r,sizes:{width:i,height:a}}}=this.styles.nodeSizes(e.style),o=n?8:r;if(t.attributes.apply({[P.likec4_id]:e.id,[P.likec4_level]:e.level,[P.label]:nodeLabel(e,this.styles),[P.margin]:`${pxToInch(o)},${pxToInch(r)}`}),t.attributes.set(P.width,pxToInch(i)),t.attributes.set(P.height,pxToInch(a)),!this.styles.isDefaultColor(e.color)){let n=this.styles.colors(e.color).elements;t.attributes.apply({[P.fillcolor]:n.fill,[P.fontcolor]:n.hiContrast,[P.color]:n.stroke})}switch(e.shape){case`cylinder`:case`storage`:t.attributes.apply({[P.margin]:`${pxToInch(o)},${pxToInch(0)}`,[P.penwidth]:pxToPoints(2),[P.shape]:`cylinder`});break;case`browser`:t.attributes.apply({[P.margin]:`${pxToInch(n?o:o+4)},${pxToInch(r+6)}`});break;case`mobile`:t.attributes.apply({[P.margin]:`${pxToInch(n?o:o+4)},${pxToInch(r)}`});break;case`queue`:t.attributes.apply({[P.width]:pxToInch(i),[P.height]:pxToInch(a-8),[P.margin]:`${pxToInch(n?o:o+4)},${pxToInch(r)}`});break;case`component`:t.attributes.apply({[P.width]:pxToInch(i+10),[P.margin]:`${pxToInch(o+20)},${pxToInch(r)}`});break;default:break}return t}leafElements(e){return e===null?j([...this.selectViewNodes()],e=>!isCompound(e)):this.computedNode(e).children.flatMap(e=>{let t=this.computedNode(e);return isCompound(t)?this.leafElements(t.id):[t]})}descendants(e){return e===null?[...this.selectViewNodes()]:this.computedNode(e).children.flatMap(e=>{let t=this.computedNode(e);return[t,...this.descendants(t.id)]})}computedNode(e){return this.viewNodes.get(e)}getGraphNode(e){return this.nodes.get(e)??null}getSubgraph(e){return this.subgraphs.get(e)??null}edgeEndpoint(e,t){let n=this.computedNode(e),r=this.getGraphNode(e),i;return r?[n,r,void 0]:(U(isCompound(n),`endpoint node should be compound`),i=this.getSubgraph(e)?.id,U(i,`subgraph ${e} not found`),n=oi(t(this.leafElements(e)),`leaf element in ${e} not found`),r=oi(this.getGraphNode(n.id),`source graphviz node ${n.id} not found`),[n,r,i])}findInternalEdges(e){if(e===null)return this.view.edges.slice();let t=this.computedNode(e);return M(this.descendants(e),E(e=>kn(e.inEdges,e.outEdges)),Tn(),Vt(kn(t.inEdges,t.outEdges)),N(e=>this.view.edges.find(t=>t.id===e)),j(T))}assignGroups(){let e=M(this.view.nodes,j(isCompound),N(e=>e.id),Sn(Xr),Dn(),N(e=>({id:e,edges:this.findInternalEdges(e).filter(e=>e.source!==e.target&&!this.compoundIds.has(e.source)&&!this.compoundIds.has(e.target))})),j(({edges:e})=>e.length>1&&e.length<8),on(4)),t=new Set;for(let n of e){let e=n.edges.filter(e=>!t.has(e.source)&&!t.has(e.target));for(let r of e)try{let e=oi(this.getGraphNode(r.source),`Graphviz Node not found for ${r.source}`),i=oi(this.getGraphNode(r.target),`Graphviz Node not found for ${r.target}`);t.add(r.source),t.add(r.target),e.attributes.set(P.group,n.id),i.attributes.set(P.group,n.id)}catch(e){Gi.error(`Failed to assign group to edge ${r.id}`,{error:e})}}return this}},AiLayoutViewPrinter=class extends DotPrinter{aiHints;constructor(e,t,n){super(e,t),this.aiHints=n}createGraph(){let e=super.createGraph();return e.delete(P.TBbalance),e}selectViewNodes(){if(!this.aiHints.nodeOrder)return this.view.nodes;let e=[...this.view.nodes],t=[];for(let n of this.aiHints.nodeOrder){let r=e.findIndex(e=>e.id===n);r!==-1&&t.push(...e.splice(r,1))}return t.push(...e),t}selectViewEdges(){if(!this.aiHints.edgeOrder)return this.view.edges;let e=[...this.view.edges],t=[];for(let n of this.aiHints.edgeOrder){let r=e.findIndex(e=>e.id===n);r!==-1&&t.push(...e.splice(r,1))}return t.push(...e),t}postBuild(e){this.applyNodeRanks().addInvisibleEdges().enableNewRankIfNeeded()}applyNodeRanks(){let e=this.G;for(let t of this.aiHints.ranks){let n=[...new Set(t.nodes)].map(e=>this.getGraphNode(e)).filter(w);if(n.length===0||t.rank===`same`&&n.length===1)continue;let r=e.createSubgraph({[P.rank]:t.rank});for(let e of n)r.node(e.id)}return this}addEdge(e,t){let n=this.aiHints.reverseRank?.includes(e.id)??!1,[r,i]=n?[e.target,e.source]:[e.source,e.target],[,a,o]=this.edgeEndpoint(r,e=>cn(e)),[,s,c]=this.edgeEndpoint(i,wn),l=t.edge([a,s],{[P.likec4_id]:e.id});e.line&&e.line!==`dashed`&&l.attributes.set(P.style,e.line),c&&l.attributes.set(P.lhead,c),o&&l.attributes.set(P.ltail,o);let u=w(c)||w(o),d=edgelabel(e);if(d&&l.attributes.set(u?P.xlabel:P.label,d),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;l.attributes.apply({[P.color]:t.line,[P.fontcolor]:t.label})}let f=this.aiHints.edgeWeight[e.id];f!==void 0&&f!==1&&l.attributes.set(P.weight,f);let p=this.aiHints.edgeMinlen[e.id];return p!==void 0&&p!==1&&l.attributes.set(P.minlen,p),this.aiHints.excludeFromRanking?.includes(e.id)&&l.attributes.set(P.constraint,!1),n&&l.attributes.set(P.dir,`back`),l}addInvisibleEdges(){if(!this.aiHints.invisibleEdges)return this;let e=this.G;for(let{source:t,target:n,...r}of this.aiHints.invisibleEdges){let i=this.getGraphNode(t),a=this.getGraphNode(n);if(!i||!a)continue;let o=`invisible_${t}->${n}`;if(this.edges.has(o)){this.logger.trace`invisible edge ${t} -> ${n} already exists with id ${o}, skipping creation`;continue}this.graphology.addEdgeWithKey(o,t,n,{hierarchyDistance:0,origin:`invisible`,weight:r.weight??1});let s=e.edge([i,a],{[P.style]:`invis`});this.edges.set(o,s),r.minlen!==void 0&&r.minlen!==1&&s.attributes.set(P.minlen,r.minlen),r.weight!==void 0&&r.weight!==1&&s.attributes.set(P.weight,r.weight)}return this}reduceDefaultRankSeparation(){let e=this.view.autoLayout,t=this.G;return Ht(e.rankSep)||!(rn(this.aiHints.edgeMinlen).some(([e,t])=>t>1)||(this.aiHints.invisibleEdges?.some(e=>e.minlen&&e.minlen>1)??!1))||t.set(P.ranksep,pxToInch(80)),this}},DeploymentViewPrinter=class extends DotPrinter{createGraph(){let e=super.createGraph(),t=this.view.autoLayout;return e.delete(P.TBbalance),e.apply({[P.nodesep]:pxToInch(t.nodeSep??130),[P.ranksep]:pxToInch(t.rankSep??130)}),e}postBuild(){let e=this.G;return M(this.view.nodes,N(e=>({node:e,graphvizNode:this.getGraphNode(e.id)})),en(({node:e,graphvizNode:t})=>{if(t!=null)return e.modelRef}),On(),N(e=>e),tn(t=>{t.length<2||e.subgraph({[P.rank]:`same`},e=>{for(let{graphvizNode:n}of t)e.node(oi(n).id)})}),mn(()=>{e.set(P.newrank,!0),e.set(P.clusterrank,`global`),e.delete(P.pack),e.delete(P.packmode)})),this}elementToSubgraph(e,t){let n=super.elementToSubgraph(e,t);return e.children.length>1&&n.set(P.margin,pxToPoints(50)),n}addEdge(e,t){let[n,r]=[e.source,e.target],[i,a,o]=this.edgeEndpoint(n,e=>cn(e)),[s,c,l]=this.edgeEndpoint(r,wn),u=w(l)||w(o),d=t.edge([a,c],{[P.likec4_id]:e.id,[P.style]:e.line??`dashed`});l&&d.attributes.set(P.lhead,l),o&&d.attributes.set(P.ltail,o);let f=this.graphology.getEdgeAttribute(e.id,`weight`);f>1&&!this.graphology.hasDirectedEdge(e.target,e.source)&&d.attributes.set(P.weight,f);let p=edgelabel(e);if(p&&d.attributes.set(u?P.xlabel:P.label,p),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;d.attributes.apply({[P.color]:t.line,[P.fontcolor]:t.label})}let[m,h]=[e.head??this.$defaults.relationship.arrow,e.tail??`none`];return m===`none`&&h===`none`?(d.attributes.apply({[P.arrowtail]:`none`,[P.arrowhead]:`none`,[P.dir]:`none`}),d):e.dir===`both`?(d.attributes.apply({[P.arrowhead]:toArrowType(m),[P.arrowtail]:toArrowType(e.tail??m),[P.dir]:`both`}),!u&&i.modelRef!==s.modelRef&&d.attributes.set(P.constraint,!1),d):(m&&d.attributes.set(P.arrowhead,toArrowType(m)),h!==`none`&&d.attributes.set(P.arrowtail,toArrowType(h)),d)}},DynamicViewPrinter=class extends DotPrinter{postBuild(e){e.delete(P.TBbalance),e.set(P.ordering,`in`)}addEdge(e,t){let{nodes:n}=this.view,[r,i]=e.dir===`back`?[e.target,e.source]:[e.source,e.target],[a,o,s]=this.edgeEndpoint(r,e=>cn(e)),[c,l,u]=this.edgeEndpoint(i,wn),d=t.edge([o,l],{[P.likec4_id]:e.id});if(e.line&&e.line!==this.$defaults.relationship.line&&d.attributes.set(P.style,e.line),u&&d.attributes.set(P.lhead,u),s&&d.attributes.set(P.ltail,s),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;d.attributes.apply({[P.color]:t.line,[P.fontcolor]:t.label})}let f=[e.label?.trim(),e.technology?.trim()].filter(T).join(`
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
14
|
+
Please specify a project folder`),Error(`Multiple projects found`)}async diagrams(e){let t=this.projectsManager.ensureProjectId(e);return await this.viewsService.diagrams(t)}syncComputedModel(e){let t=this.projectsManager.ensureProjectId(e);return this.modelBuilder.unsafeSyncComputeModel(t)}async computedModel(e){let t=this.projectsManager.ensureProjectId(e);return await this.modelBuilder.computeModel(t)}projects(){return I(this.languageServices.projects(),jn(`id`))}async layoutedModel(e){let t=this.projectsManager.ensureProjectId(e);return await this.languageServices.layoutedModel(t)}getErrors(){return[...this.LangiumDocuments.userDocuments].flatMap(e=>(e.diagnostics?.filter(Wi)??[]).map(({message:t,range:r})=>({message:t,line:r.start.line,range:r,sourceFsPath:e.uri.fsPath})))}hasErrors(){return this.LangiumDocuments.userDocuments.some(e=>e.diagnostics&&e.diagnostics.some(Wi))}printErrors(){let e=!1;for(let t of this.LangiumDocuments.userDocuments){let r=t.diagnostics?.filter(Wi)??[];if(!N(r,1))continue;e=!0;let o=F(r,A(e=>{let t=e.range.start.line,r=e.message.split(`
|
|
15
|
+
`);return r.length>5&&(r.length=5,r.push(`...`)),r.map((e,r)=>r===0?` `+Ui.dim(`Line ${t}: `)+Ui.red(e):` `.repeat(10)+Ui.red(e))}),Qt(`
|
|
16
|
+
`));this.logger.error(`Invalid ${t.uri.fsPath}\n${o}`)}return e}documentCount(){return[...this.LangiumDocuments.userDocuments].length}onModelUpdate(e){let t=this.modelBuilder.onModelParsed(t=>e(t));return()=>{t.dispose()}}async format(e){let{projects:t,...r}=e??{},o={...r,...t&&{projectIds:t.map(e=>this.projectsManager.ensureProjectId(e))}};return await this.languageServices.format(o)}async dispose(){await this.languageServices.dispose()}async[Symbol.asyncDispose](){await this.dispose()}};const Gi={printErrors:!0,throwIfInvalid:!1,graphviz:`wasm`,configureLogger:!1,logLevel:void 0},validationErrorsToError=e=>Error(`Invalid model:\n${e.getErrors().map(e=>` ${e.sourceFsPath}:${e.line} ${e.message.slice(0,200)}`).join(`
|
|
17
|
+
`)}`);async function handleInitOptions(e,t=G,r){let o=new LikeC4(e,t),s=r?.throwIfInvalid??Gi.throwIfInvalid,c=r?.printErrors??Gi.printErrors;if((s||c)&&o.hasErrors()){if(s)return await o.dispose(),Promise.reject(validationErrorsToError(o));o.printErrors()}return o}async function createFromSources(e,t,r,o){let s=C.from({scheme:`virtual`,path:`/workspace`}),c={name:`virtual`,uri:s.toString()},u=e.shared.workspace.WorkspaceManager;u.initialize({capabilities:{},processId:null,rootUri:c.uri,workspaceFolders:[c]}),await u.initializeWorkspace([c]);let d=e.shared.ServiceRegistry.all.flatMap(e=>e.LanguageMetaData.fileExtensions),[p,m]=fn(an(r),([e])=>Ft(e));for(let[r,o]of p){let c=S.joinPath(s,r);try{await e.shared.workspace.ProjectsManager.registerProject({configUri:c,config:Nt.parse(o)})}catch(e){t.error(loggable(e))}}let h=F(m,I(([t,r])=>{d.includes(Bt(t))||(t+=`.c4`);let o=S.joinPath(s,t);return e.shared.workspace.LangiumDocuments.createDocument(o,r)}));return await e.shared.workspace.DocumentBuilder.build(h,{validation:!0}),handleInitOptions(e,t,o)}const K=new Proxy(Object.freeze({}),{get:(e,t)=>t});function f(e,t){return(...r)=>{let o=e?this.Digraph:this.Graph,s=r.find(e=>typeof e==`string`),c=r.find(e=>typeof e==`object`),u=r.find(e=>typeof e==`function`),d=new o(s,t,c);return d.with(this),typeof u==`function`&&u(d),d}}function n(e,t=Rn){return Object.freeze({digraph:f.call(t,!0,e),graph:f.call(t,!1,e)})}const Ki=n(!1),qi=Ki.digraph;Ki.graph,n(!0);function O(e,t){return Ln(zn(e,t?.convert),t?.print)}In()
|
|
18
|
+
/*!
|
|
19
|
+
* word-wrap <https://github.com/jonschlinkert/word-wrap>
|
|
20
|
+
*
|
|
21
|
+
* Copyright (c) 2014-2023, Jon Schlinkert.
|
|
22
|
+
* Released under the MIT License.
|
|
23
|
+
*/
|
|
24
|
+
;var Ji=e(r(((e,t)=>{function trimEnd(e){let t=e.length-1,r=e[t];for(;r===` `||r===` `;)r=e[--t];return e.substring(0,t+1)}function trimTabAndSpaces(e){return e.split(`
|
|
25
|
+
`).map(e=>trimEnd(e)).join(`
|
|
26
|
+
`)}t.exports=function(e,t){if(t||={},e==null)return e;var r=t.width||50,o=typeof t.indent==`string`?t.indent:` `,s=t.newline||`
|
|
27
|
+
`+o,c=typeof t.escape==`function`?t.escape:identity,u=`.{1,`+r+`}`;t.cut!==!0&&(u+=`([\\s]+|$)|[^\\s]+?([\\s]+|$)`);var d=new RegExp(u,`g`),p=o+(e.match(d)||[]).map(function(e){return e.slice(-1)===`
|
|
28
|
+
`&&(e=e.slice(0,e.length-1)),c(e)}).join(s);return t.trim===!0&&(p=trimTabAndSpaces(p)),p};function identity(e){return e}}))(),1);function isCompound(e){return e.children.length>0}function toArrowType(e){switch(e){case`open`:return`vee`;default:return e}}function pointToPx(e){return Array.isArray(e)?[pointToPx(e[0]),pointToPx(e[1])]:(W(isFinite(e),`Invalid not finite point value ${e}`),Math.round(e))}const inchToPx=e=>(W(isFinite(e),`Invalid not finite inch value ${e}`),Math.floor(e*72)),pxToInch=e=>Math.ceil(e/72*1e3)/1e3,pxToPoints=e=>Math.ceil(e);pxToPoints(40).toString();function compoundColor(e,t){return Vn(Hn(e,{l:-35-5*t,s:-15-5*t}))}function compoundLabelColor(e){return Vn(Bn(e,.3))}function sanitize(e){return e.trim().replaceAll(`&`,`&`).replaceAll(`<`,`<`).replaceAll(`>`,`>`)}function wrap(e,{maxchars:t,maxLines:r,sanitize:o=Zt()}){let s=(0,Ji.default)(e,{width:t,indent:``,escape:o}).split(`
|
|
29
|
+
`);return Xt(r)&&r>0&&s.length>r&&(s=s.slice(0,r)),s}function wrapWithFont({text:e,maxchars:t,fontsize:r,maxLines:o,bold:s,color:c}){let u=wrap(e,{maxchars:t,maxLines:o,sanitize}).join(`<BR/>`);s&&(u=`<B>${u}</B>`);let d=c?` COLOR="${c}"`:``;return`<FONT POINT-SIZE="${pxToPoints(r)}"${d}>${u}</FONT>`}function maxchars(e){switch(e){case`xs`:case`sm`:return 30;case`md`:return 40;case`lg`:case`xl`:return 55;default:ci(e)}}function nodeLabel(e,t){let{sizes:{size:r},values:o}=t.nodeSizes(e.style),s=t.colors(e.color).elements,c=[`sm`,`xs`].includes(r),u=k(e.icon),d=e.style.iconPosition??`left`,p=u&&(d===`left`||d===`right`),m=[wrapWithFont({text:e.title,fontsize:o.textSize,maxchars:maxchars(r),maxLines:c?1:3})];if(r!==`xs`){k(e.technology?.trim())&&m.push(wrapWithFont({text:e.technology,fontsize:Math.ceil(o.textSize*.65),maxchars:p?35:45,maxLines:1,color:s.loContrast}));let t=Sr.from(e.description).text;t&&m.push(wrapWithFont({text:t,fontsize:Math.ceil(o.textSize*.75),maxchars:p?35:45,maxLines:c?3:5,color:s.loContrast}))}if(m.length===1&&u===!1)return`<${m[0]}>`;let h=p?(t,r,s)=>{let c=`<TD ALIGN="TEXT" BALIGN="LEFT">${t}</TD>`;if(r===0){let t=s.length>1?` ROWSPAN="${s.length}"`:``,r=Math.ceil(o.iconSize+16);(e.shape===`queue`||e.shape===`mobile`)&&(r+=20),d===`right`?(c=`<TD${t} WIDTH="16"> </TD>${c}`,c=`${c}<TD${t} WIDTH="${r}"> </TD>`):(c=`<TD${t} WIDTH="${r}"> </TD>${c}`,c=`${c}<TD${t} WIDTH="16"> </TD>`)}return`<TR>${c}</TR>`}:e=>`<TR><TD>${e}</TD></TR>`,g=m.map(h).join(``);if(u&&(d===`top`||d===`bottom`)){let e=`<TR><TD HEIGHT="${Math.ceil(o.iconSize+8)}"> </TD></TR>`;g=d===`top`?`${e}${g}`:`${g}${e}`}return`<<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="4">${g}</TABLE>>`}function compoundLabel(e,t){let r=wrapWithFont({text:e.title.toUpperCase(),maxchars:50,fontsize:11,maxLines:1,bold:!0,color:t});return r.includes(`<BR/>`)?`<<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="0"><TR><TD ALIGN="TEXT" BALIGN="LEFT">${r}</TD></TR></TABLE>>`:`<${r}>`}const Yi=`BGCOLOR="${yr.DEFAULT.relationshipColors.labelBg}A0"`;function edgelabel({label:e,technology:t}){let r=[];return k(e?.trim())&&r.push(wrapWithFont({text:e,maxchars:40,fontsize:14,maxLines:5,bold:e===`[...]`})),k(t?.trim())&&r.push(wrapWithFont({text:`[ ${t} ]`,fontsize:12,maxLines:1,maxchars:40})),r.length===0?null:`<<TABLE BORDER="0" CELLPADDING="3" CELLSPACING="0" ${Yi}>${r.map(e=>`<TR><TD ALIGN="TEXT" BALIGN="LEFT">${e}</TD></TR>`).join(``)}</TABLE>>`}function stepEdgeLabel(e,t){let r=`<TABLE BORDER="0" CELLPADDING="6" ${Yi}><TR><TD WIDTH="20" HEIGHT="20"><FONT POINT-SIZE="${pxToPoints(14)}"><B>${e}</B></FONT></TD></TR></TABLE>`;return k(t?.trim())?`<${[`<TABLE BORDER="0" CELLPADDING="0" CELLSPACING="3">`,`<TR>`,`<TD>${r}</TD>`,`<TD ${Yi} CELLPADDING="3">`,wrapWithFont({text:t,maxchars:40,fontsize:14,maxLines:5}),`</TD>`,`</TR>`,`</TABLE>`].join(``)}>`:`<${r}>`}const Xi=`Arial`,Zi=createLogger(`dot`);var DotPrinter=class{view;styles;ids=new Set;subgraphs=new Map;nodes=new Map;edges=new Map;compoundIds;edgesWithCompounds;viewNodes=new Jr(e=>si(this.view.nodes.find(t=>t.id===e),`Node ${e} not found`));logger=Zi;graphology=new gi({allowSelfLoops:!0,multi:!0,type:`directed`});G;constructor(e,t){this.view=e,this.styles=t,this.compoundIds=new Set(e.nodes.filter(isCompound).map(e=>e.id)),this.edgesWithCompounds=new Set(this.compoundIds.size>0?e.edges.filter(e=>this.compoundIds.has(e.source)||this.compoundIds.has(e.target)).map(e=>e.id):[]);for(let t of e.nodes)this.graphology.addNode(t.id,{origin:t,level:t.level,depth:t.depth??0,modelRef:t.modelRef??null,deploymentRef:t.deploymentRef??null,maxConnectedHierarchyDistance:0});for(let t of e.edges){let e=this.graphology.getNodeAttribute(t.source,`deploymentRef`),r=this.graphology.getNodeAttribute(t.target,`deploymentRef`);(e===null||r===null)&&(e=this.graphology.getNodeAttribute(t.source,`modelRef`),r=this.graphology.getNodeAttribute(t.target,`modelRef`));let o=-1;e!==null&&r!==null&&(o=ti(e,r)),this.graphology.addEdgeWithKey(t.id,t.source,t.target,{origin:t,hierarchyDistance:o,weight:1}),o>this.graphology.getNodeAttribute(t.source,`maxConnectedHierarchyDistance`)&&this.graphology.mergeNodeAttributes(t.source,{maxConnectedHierarchyDistance:o}),o>this.graphology.getNodeAttribute(t.target,`maxConnectedHierarchyDistance`)&&this.graphology.mergeNodeAttributes(t.target,{maxConnectedHierarchyDistance:o})}this.graphology.forEachEdge((e,{hierarchyDistance:t},r,o,s,c)=>{let u=Math.max(s.maxConnectedHierarchyDistance,c.maxConnectedHierarchyDistance);if(u>t)this.graphology.mergeEdgeAttributes(e,{weight:u-t+1});else{let s=this.graphology.directedDegree(r),c=this.graphology.directedDegree(o);s===1&&c===1&&t>1&&this.graphology.mergeEdgeAttributes(e,{weight:t})}});let r=this.G=this.createGraph();this.applyNodeAttributes(r.attributes.node),this.applyEdgeAttributes(r.attributes.edge)}get $defaults(){return this.styles.defaults}get hasEdgesWithCompounds(){return this.edgesWithCompounds.size>0}get defaultRelationshipColors(){let e=this.styles.relationshipColors;return{line:e.line,label:e.label,labelBg:e.labelBg}}postBuild(e){}selectViewNodes(){return this.view.nodes}selectViewEdges(){return this.view.edges}build(){let e=this.G,t=[];for(let r of this.selectViewNodes())if(isCompound(r))M(r.parent)&&t.push(r);else{let t=this.generateGraphvizId(r),o=this.elementToNode(r,e.node(t));this.nodes.set(r.id,o)}let traverseClusters=(e,t)=>{let r=this.generateGraphvizId(e),o=this.elementToSubgraph(e,t.subgraph(r));this.subgraphs.set(e.id,o);for(let t of e.children){let e=this.computedNode(t);if(isCompound(e))traverseClusters(e,o);else{let t=this.getGraphNode(e.id);t&&o.node(t.id)}}};for(let r of t)traverseClusters(r,e);for(let t of this.selectViewEdges()){let r=this.addEdge(t,e);r&&this.edges.set(t.id,r)}return this}print(){return this.build(),this.postBuild(this.G),O(this.G,{print:{indentStyle:`space`,indentSize:2}})}enableNewRankIfNeeded(){return this.G.subgraphs.some(e=>!!e.get(K.rank))&&this.G.set(K.newrank,!0),this}createGraph(){let e=this.view.autoLayout,t=e.direction,r=qi({[K.likec4_viewId]:this.view.id,[K.bgcolor]:`transparent`,[K.layout]:`dot`,[K.compound]:!0,[K.rankdir]:t,[K.TBbalance]:`min`,[K.splines]:`spline`,[K.outputorder]:`nodesfirst`,[K.nodesep]:pxToInch(e.nodeSep??110),[K.ranksep]:pxToInch(e.rankSep??120),[K.pad]:pxToInch(15),[K.fontname]:Xi});return r.attributes.graph.apply({[K.fontsize]:pxToPoints(this.styles.fontSize()),[K.labeljust]:t===`RL`?`r`:`l`,[K.labelloc]:t===`BT`?`b`:`t`,[K.margin]:50.1}),r}applyNodeAttributes(e){let t=this.styles.elementColors;e.apply({[K.fontname]:Xi,[K.shape]:`rect`,[K.fillcolor]:t.fill,[K.fontcolor]:t.hiContrast,[K.color]:t.stroke,[K.style]:`filled`,[K.penwidth]:0})}applyEdgeAttributes(e){let t=this.defaultRelationshipColors;e.apply({[K.arrowsize]:.75,[K.fontname]:Xi,[K.fontsize]:pxToPoints(14),[K.penwidth]:pxToPoints(2),[K.color]:t.line,[K.fontcolor]:t.label,[K.style]:this.$defaults.relationship.line})}reserveNodeId(e,t=!1){return t?e=`cluster_`+e:e.toLowerCase().startsWith(`cluster`)&&(e=`nd_`+e),this.ids.has(e)?!1:(this.ids.add(e),e)}generateGraphvizId(e){let t=isCompound(e),r=oi(e.id).toLowerCase(),o=this.reserveNodeId(r,t),s=1;for(;o===!1;)o=this.reserveNodeId(r+`_`+ s++,t);return o}elementToSubgraph(e,t){W(isCompound(e),`node should be compound`),W(Ht(e.depth),`node.depth should be defined`);let r=this.styles.colors(e.color).elements,o=compoundLabelColor(r.loContrast);return t.apply({[K.likec4_id]:e.id,[K.likec4_level]:e.level,[K.likec4_depth]:e.depth,[K.fillcolor]:compoundColor(r.fill,e.depth),[K.color]:compoundColor(r.stroke,e.depth),[K.style]:`filled`,[K.margin]:pxToPoints(e.children.length>1?40:32)}),j(e.title.trim())||t.set(K.label,compoundLabel(e,o)),t}elementToNode(e,t){W(!isCompound(e),`node should not be compound`);let r=k(e.icon),{values:{padding:o,sizes:{width:s,height:c}}}=this.styles.nodeSizes(e.style),u=r?8:o;if(t.attributes.apply({[K.likec4_id]:e.id,[K.likec4_level]:e.level,[K.label]:nodeLabel(e,this.styles),[K.margin]:`${pxToInch(u)},${pxToInch(o)}`}),t.attributes.set(K.width,pxToInch(s)),t.attributes.set(K.height,pxToInch(c)),!this.styles.isDefaultColor(e.color)){let r=this.styles.colors(e.color).elements;t.attributes.apply({[K.fillcolor]:r.fill,[K.fontcolor]:r.hiContrast,[K.color]:r.stroke})}switch(e.shape){case`cylinder`:case`storage`:t.attributes.apply({[K.margin]:`${pxToInch(u)},${pxToInch(0)}`,[K.penwidth]:pxToPoints(2),[K.shape]:`cylinder`});break;case`browser`:t.attributes.apply({[K.margin]:`${pxToInch(r?u:u+4)},${pxToInch(o+6)}`});break;case`mobile`:t.attributes.apply({[K.margin]:`${pxToInch(r?u:u+4)},${pxToInch(o)}`});break;case`queue`:t.attributes.apply({[K.width]:pxToInch(s),[K.height]:pxToInch(c-8),[K.margin]:`${pxToInch(r?u:u+4)},${pxToInch(o)}`});break;case`component`:t.attributes.apply({[K.width]:pxToInch(s+10),[K.margin]:`${pxToInch(u+20)},${pxToInch(o)}`});break;default:break}return t}leafElements(e){return e===null?P([...this.selectViewNodes()],e=>!isCompound(e)):this.computedNode(e).children.flatMap(e=>{let t=this.computedNode(e);return isCompound(t)?this.leafElements(t.id):[t]})}descendants(e){return e===null?[...this.selectViewNodes()]:this.computedNode(e).children.flatMap(e=>{let t=this.computedNode(e);return[t,...this.descendants(t.id)]})}computedNode(e){return this.viewNodes.get(e)}getGraphNode(e){return this.nodes.get(e)??null}getSubgraph(e){return this.subgraphs.get(e)??null}edgeEndpoint(e,t){let r=this.computedNode(e),o=this.getGraphNode(e),s;return o?[r,o,void 0]:(W(isCompound(r),`endpoint node should be compound`),s=this.getSubgraph(e)?.id,W(s,`subgraph ${e} not found`),r=si(t(this.leafElements(e)),`leaf element in ${e} not found`),o=si(this.getGraphNode(r.id),`source graphviz node ${r.id} not found`),[r,o,s])}findInternalEdges(e){if(e===null)return this.view.edges.slice();let t=this.computedNode(e);return F(this.descendants(e),A(e=>An(e.inEdges,e.outEdges)),En(),Vt(An(t.inEdges,t.outEdges)),I(e=>this.view.edges.find(t=>t.id===e)),P(k))}assignGroups(){let e=F(this.view.nodes,P(isCompound),I(e=>e.id),Cn(Zr),On(),I(e=>({id:e,edges:this.findInternalEdges(e).filter(e=>e.source!==e.target&&!this.compoundIds.has(e.source)&&!this.compoundIds.has(e.target))})),P(({edges:e})=>e.length>1&&e.length<8),sn(4)),t=new Set;for(let r of e){let e=r.edges.filter(e=>!t.has(e.source)&&!t.has(e.target));for(let o of e)try{let e=si(this.getGraphNode(o.source),`Graphviz Node not found for ${o.source}`),s=si(this.getGraphNode(o.target),`Graphviz Node not found for ${o.target}`);t.add(o.source),t.add(o.target),e.attributes.set(K.group,r.id),s.attributes.set(K.group,r.id)}catch(e){Zi.error(`Failed to assign group to edge ${o.id}`,{error:e})}}return this}},AiLayoutViewPrinter=class extends DotPrinter{aiHints;constructor(e,t,r){super(e,t),this.aiHints=r}createGraph(){let e=super.createGraph();return e.delete(K.TBbalance),e}selectViewNodes(){if(!this.aiHints.nodeOrder)return this.view.nodes;let e=[...this.view.nodes],t=[];for(let r of this.aiHints.nodeOrder){let o=e.findIndex(e=>e.id===r);o!==-1&&t.push(...e.splice(o,1))}return t.push(...e),t}selectViewEdges(){if(!this.aiHints.edgeOrder)return this.view.edges;let e=[...this.view.edges],t=[];for(let r of this.aiHints.edgeOrder){let o=e.findIndex(e=>e.id===r);o!==-1&&t.push(...e.splice(o,1))}return t.push(...e),t}postBuild(e){this.applyNodeRanks().addInvisibleEdges().enableNewRankIfNeeded()}applyNodeRanks(){let e=this.G;for(let t of this.aiHints.ranks){let r=[...new Set(t.nodes)].map(e=>this.getGraphNode(e)).filter(D);if(r.length===0||t.rank===`same`&&r.length===1)continue;let o=e.createSubgraph({[K.rank]:t.rank});for(let e of r)o.node(e.id)}return this}addEdge(e,t){let r=this.aiHints.reverseRank?.includes(e.id)??!1,[o,s]=r?[e.target,e.source]:[e.source,e.target],[,c,u]=this.edgeEndpoint(o,e=>ln(e)),[,d,p]=this.edgeEndpoint(s,Tn),m=t.edge([c,d],{[K.likec4_id]:e.id});e.line&&e.line!==`dashed`&&m.attributes.set(K.style,e.line),p&&m.attributes.set(K.lhead,p),u&&m.attributes.set(K.ltail,u);let h=D(p)||D(u),g=edgelabel(e);if(g&&m.attributes.set(h?K.xlabel:K.label,g),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;m.attributes.apply({[K.color]:t.line,[K.fontcolor]:t.label})}let _=this.aiHints.edgeWeight[e.id];_!==void 0&&_!==1&&m.attributes.set(K.weight,_);let v=this.aiHints.edgeMinlen[e.id];return v!==void 0&&v!==1&&m.attributes.set(K.minlen,v),this.aiHints.excludeFromRanking?.includes(e.id)&&m.attributes.set(K.constraint,!1),r&&m.attributes.set(K.dir,`back`),m}addInvisibleEdges(){if(!this.aiHints.invisibleEdges)return this;let e=this.G;for(let{source:t,target:r,...o}of this.aiHints.invisibleEdges){let s=this.getGraphNode(t),c=this.getGraphNode(r);if(!s||!c)continue;let u=`invisible_${t}->${r}`;if(this.edges.has(u)){this.logger.trace`invisible edge ${t} -> ${r} already exists with id ${u}, skipping creation`;continue}this.graphology.addEdgeWithKey(u,t,r,{hierarchyDistance:0,origin:`invisible`,weight:o.weight??1});let d=e.edge([s,c],{[K.style]:`invis`});this.edges.set(u,d),o.minlen!==void 0&&o.minlen!==1&&d.attributes.set(K.minlen,o.minlen),o.weight!==void 0&&o.weight!==1&&d.attributes.set(K.weight,o.weight)}return this}reduceDefaultRankSeparation(){let e=this.view.autoLayout,t=this.G;return Ht(e.rankSep)||!(an(this.aiHints.edgeMinlen).some(([e,t])=>t>1)||(this.aiHints.invisibleEdges?.some(e=>e.minlen&&e.minlen>1)??!1))||t.set(K.ranksep,pxToInch(80)),this}},DeploymentViewPrinter=class extends DotPrinter{createGraph(){let e=super.createGraph(),t=this.view.autoLayout;return e.delete(K.TBbalance),e.apply({[K.nodesep]:pxToInch(t.nodeSep??130),[K.ranksep]:pxToInch(t.rankSep??130)}),e}postBuild(){let e=this.G;return F(this.view.nodes,I(e=>({node:e,graphvizNode:this.getGraphNode(e.id)})),tn(({node:e,graphvizNode:t})=>{if(t!=null)return e.modelRef}),kn(),I(e=>e),nn(t=>{t.length<2||e.subgraph({[K.rank]:`same`},e=>{for(let{graphvizNode:r}of t)e.node(si(r).id)})}),hn(()=>{e.set(K.newrank,!0),e.set(K.clusterrank,`global`),e.delete(K.pack),e.delete(K.packmode)})),this}elementToSubgraph(e,t){let r=super.elementToSubgraph(e,t);return e.children.length>1&&r.set(K.margin,pxToPoints(50)),r}addEdge(e,t){let[r,o]=[e.source,e.target],[s,c,u]=this.edgeEndpoint(r,e=>ln(e)),[d,p,m]=this.edgeEndpoint(o,Tn),h=D(m)||D(u),g=t.edge([c,p],{[K.likec4_id]:e.id,[K.style]:e.line??`dashed`});m&&g.attributes.set(K.lhead,m),u&&g.attributes.set(K.ltail,u);let _=this.graphology.getEdgeAttribute(e.id,`weight`);_>1&&!this.graphology.hasDirectedEdge(e.target,e.source)&&g.attributes.set(K.weight,_);let v=edgelabel(e);if(v&&g.attributes.set(h?K.xlabel:K.label,v),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;g.attributes.apply({[K.color]:t.line,[K.fontcolor]:t.label})}let[y,b]=[e.head??this.$defaults.relationship.arrow,e.tail??`none`];return y===`none`&&b===`none`?(g.attributes.apply({[K.arrowtail]:`none`,[K.arrowhead]:`none`,[K.dir]:`none`}),g):e.dir===`both`?(g.attributes.apply({[K.arrowhead]:toArrowType(y),[K.arrowtail]:toArrowType(e.tail??y),[K.dir]:`both`}),!h&&s.modelRef!==d.modelRef&&g.attributes.set(K.constraint,!1),g):(y&&g.attributes.set(K.arrowhead,toArrowType(y)),b!==`none`&&g.attributes.set(K.arrowtail,toArrowType(b)),g)}},DynamicViewPrinter=class extends DotPrinter{postBuild(e){e.delete(K.TBbalance),e.set(K.ordering,`in`)}addEdge(e,t){let{nodes:r}=this.view,[o,s]=e.dir===`back`?[e.target,e.source]:[e.source,e.target],[c,u,d]=this.edgeEndpoint(o,e=>ln(e)),[p,m,h]=this.edgeEndpoint(s,Tn),g=t.edge([u,m],{[K.likec4_id]:e.id});if(e.line&&e.line!==this.$defaults.relationship.line&&g.attributes.set(K.style,e.line),h&&g.attributes.set(K.lhead,h),d&&g.attributes.set(K.ltail,d),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;g.attributes.apply({[K.color]:t.line,[K.fontcolor]:t.label})}let _=[e.label?.trim(),e.technology?.trim()].filter(k).join(`
|
|
30
|
+
`),v=stepEdgeLabel(jr(e.id),_);g.attributes.set(K.label,v);let y=r.findIndex(e=>e.id===o);r.findIndex(e=>e.id===s)<y&&e.dir!==`back`&&g.attributes.apply({[K.minlen]:0});let[b,x]=[e.head??this.$defaults.relationship.arrow,e.tail??`none`];return e.dir===`back`?(g.attributes.apply({[K.arrowtail]:toArrowType(b),[K.dir]:`back`}),x!==`none`&&g.attributes.apply({[K.arrowhead]:toArrowType(x),[K.minlen]:0}),g):b===`none`&&x===`none`||b!==`none`&&x!==`none`?(g.attributes.apply({[K.arrowhead]:toArrowType(b),[K.arrowtail]:toArrowType(x),[K.dir]:`both`}),g):b===`none`?(g.attributes.delete(K.arrowhead),g.attributes.apply({[K.arrowtail]:toArrowType(x),[K.minlen]:0,[K.dir]:`back`}),g):(g.attributes.set(K.arrowhead,toArrowType(b)),g)}};const Qi=createLogger(`dot.rank`);var ElementViewPrinter=class extends DotPrinter{postBuild(){this.assignGroups().tileNodesWithoutEdges().applyExplicitRankBlocks().enableNewRankIfNeeded()}tileNodesWithoutEdges(){let e=new Set,t=this.view.nodes.reduce((t,r)=>(isCompound(r)&&(e.add(r.id),t.push(r)),t),[]);for(let e of t){let t=F(e.children,P(e=>!this.compoundIds.has(e)&&this.graphology.degree(e)===0),I(e=>this.computedNode(e)));if(t.length<=2)continue;let r=2;switch(!0){case t.length>11:r=4;break;case t.length>4:r=3;break}let o=si(this.getSubgraph(e.id),`Subgraph not found for ${e.id}`),s=null;Dn(t,r).forEach(e=>{let t=e.length>1?o.createSubgraph({[K.rank]:`same`}):null;e.forEach((e,r)=>{let c=this.getGraphNode(e.id);c&&(t?.node(c.id),r===0&&(s&&o.edge([s,c],{[K.style]:`invis`}),s=c))})})}return this}applyExplicitRankBlocks(){let e=this.view.ranks??[];if(e.length===0)return this;let t=0;for(let r of e){let e=[...new Set(r.nodes)].map(e=>this.getGraphNode(e)).filter(e=>!!e);if(e.length===0)continue;let o=this.G.createSubgraph({[K.rank]:r.type});e.forEach(e=>o.node(e.id)),t+=1,Qi.trace`rank ${r.type} => ${e.map(e=>e.id).join(`, `)}`}return t>0&&this.G.set(`likec4_rankBlocks`,t),this}addEdge(e,t){let[r,o]=e.dir===`back`?[e.target,e.source]:[e.source,e.target],[s,c,u]=this.edgeEndpoint(r,e=>ln(e)),[d,p,m]=this.edgeEndpoint(o,Tn),h=e.parent,g=this.graphology.getEdgeAttributes(e.id),_=t.edge([c,p],{[K.likec4_id]:e.id});e.line&&e.line!==this.$defaults.relationship.line&&_.attributes.set(K.style,e.line),m&&_.attributes.set(K.lhead,m),u&&_.attributes.set(K.ltail,u);let v=D(m)||D(u),y=edgelabel(e);if(y&&_.attributes.set(v?K.xlabel:K.label,y),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;_.attributes.apply({[K.color]:t.line,[K.fontcolor]:t.label})}!this.graphology.hasDirectedEdge(e.target,e.source)&&g.weight>1&&_.attributes.set(K.weight,g.weight);let[b,x]=[e.head??this.$defaults.relationship.arrow,e.tail??`none`];if(e.dir===`back`)return _.attributes.apply({[K.arrowtail]:toArrowType(b),[K.dir]:`back`}),x!==`none`&&_.attributes.apply({[K.arrowhead]:toArrowType(x),[K.dir]:`both`,[K.minlen]:0}),_;if(b===`none`&&x===`none`)return _.attributes.apply({[K.arrowtail]:`none`,[K.arrowhead]:`none`,[K.dir]:`none`,[K.minlen]:0,[K.constraint]:!1}),_;if(b!==`none`&&x!==`none`)return _.attributes.apply({[K.arrowhead]:toArrowType(b),[K.arrowtail]:toArrowType(x),[K.dir]:`both`}),_;if(_.attributes.set(K.arrowhead,toArrowType(b)),x!==`none`&&_.attributes.set(K.arrowtail,toArrowType(x)),this.view.edges.length===1)return _;let ee;return ee=h===null&&s.parent==null&&d.parent==null?this.view.edges.filter(t=>{if(t.id===e.id||t.parent!==null||t.source===e.source&&t.target===e.target||t.source===e.target&&t.target===e.source)return!1;let r=this.computedNode(t.source),o=this.computedNode(t.target);return isCompound(r)||isCompound(o)?!1:r.parent==null&&o.parent==null}):this.findInternalEdges(h).filter(t=>!(t.id===e.id||t.source===e.source&&t.target===e.target||t.source===e.target&&t.target===e.source)),ee.length===0&&(h===null||this.leafElements(h).length<=3)&&_.attributes.set(K.minlen,0),_}};function parseBB(e){let[t,r,o,s]=e?e.split(`,`).map(e=>pointToPx(+e)):[0,0,0,0],c=Math.round(o-t),u=Math.round(r-s);return{x:Math.round(t),y:Math.round(s),width:c,height:u}}function parsePos(e){try{let[t,r]=e.split(`,`);return{x:pointToPx(parseFloat(t)),y:pointToPx(parseFloat(r))}}catch(t){throw Error(`Failed on parsing pos: ${e}`,{cause:t})}}function parseNode(e){let{x:t,y:r}=parsePos(e.pos),o=inchToPx(parseFloat(e.width)),s=inchToPx(parseFloat(e.height));return{x:t-Math.round(o/2),y:r-Math.round(s/2),width:o,height:s}}function parseLabelBbox(e,[t,r]=[0,0]){if(!e||e.length===0)return null;let o=1/0,s=1/0,c=-1/0,u=-1/0,d=13;try{for(let p of e){if(p.op===`F`){d=pointToPx(p.size);continue}if(p.op===`T`){let e=pointToPx(p.pt[0])-t,m=pointToPx(p.width);switch(p.align){case`r`:e-=m;break;case`c`:e-=Math.round(m/2);break}o=Math.min(o,e),c=Math.max(c,e+m);let h=pointToPx(p.pt[1])-r;s=Math.min(s,Math.round(h-d)),u=Math.max(u,h)}}}catch(t){return G.warn(`Failed on parsing label draw ops:
|
|
31
|
+
{labelDrawOps}`,{e:t,labelDrawOps:e}),null}return o===1/0?null:{x:o-2,y:s-2,width:c-o+4,height:u-s+4}}function parseEdgePoints({_draw_:e,likec4_id:t=`???`},r=`<unknown view>`){try{let o=e.filter(e=>e.op.toLowerCase()===`b`);W(N(o,1),`view ${r} edge ${t} should have at least one bezier draw op`),o.length>1&&G.warn(`view ${r} edge ${t} has more than one bezier draw op, using the first one only`);let s=o[0].points.map(e=>pointToPx(e));return W(N(s,2),`view ${r} edge ${t} should have at least two points`),s}catch(o){throw Error(`failed on parsing view ${r} edge ${t} _draw_:\n${JSON.stringify(e,null,2)}`,{cause:o})}}function parseGraphvizEdge(e,{id:t,source:r,target:o,dir:s,label:c,description:u,...d},p){let m=parseLabelBbox(e._ldraw_??e._tldraw_??e._hldraw_),h=e.dir===`back`||s===`back`;return c=c&&m?wrap(c,{maxchars:40,maxLines:5}).join(`
|
|
32
|
+
`):null,{id:t,source:r,target:o,label:c,...k(u)&&{description:u},points:parseEdgePoints(e,p),labelBBox:m,...h?{dir:`back`}:{},...d}}function parseGraphvizJson(e,t){let r=parseBB(e.bb),{nodes:o,edges:s,hasManualLayout:c,...u}=t,d=[],p=[],m;if(m=u._type===`dynamic`?{...u,sequenceLayout:{actors:[],compounds:[],parallelAreas:[],steps:[],bounds:r},[wr]:`layouted`,bounds:r,nodes:d,edges:p}:{...u,[wr]:`layouted`,bounds:r,nodes:d,edges:p},c){let e=m;e[Cr]=`auto`}let h=e.objects??[];for(let e of o){let t=h.find(t=>t.likec4_id===e.id);W(t,`View ${u.id} node ${e.id} not found in graphviz output`);try{let{x:r,y:o,width:s,height:c}=`bb`in t?parseBB(t.bb):parseNode(t),u=[r,o];d.push({...e,x:r,y:o,width:s,height:c,labelBBox:parseLabelBbox(t._ldraw_,u)??{x:r,y:o,width:s,height:c}})}catch(r){throw Error(`Failed on parsing node ${e.id}:\n${JSON.stringify(t,null,2)}`,{cause:r})}}let g=e.edges??[];for(let e of s){let t=g.find(t=>t.likec4_id===e.id);if(!t){G.warn`View ${u.id} edge ${e.id} not found in graphviz output, skipping`;continue}p.push(parseGraphvizEdge(t,e,u.id))}return m}function parseGraphvizJsonOfProjectsView(e,t){return parseGraphvizJson(e,t)}var $i=class ProjectsViewPrinter extends DotPrinter{static toDot(e){return new ProjectsViewPrinter(e).print()}constructor(e){super(e,nr.DEFAULT)}createGraph(){let e=super.createGraph();return e.apply({[K.nodesep]:pxToInch(100),[K.ranksep]:pxToInch(100)}),e.delete(K.TBbalance),e}elementToNode(e,t){return t.attributes.apply({[K.likec4_id]:e.id,[K.likec4_project]:e.projectId}),super.elementToNode(e,t)}addEdge(e,t){let r=si(this.getGraphNode(e.source),`Node not found for ${e.source}`),o=si(this.getGraphNode(e.target),`Node not found for ${e.target}`),s=this.graphology.getEdgeAttributes(e.id),c=t.edge([r,o],{[K.likec4_id]:e.id,[K.likec4_project]:e.projectId});e.line&&e.line!==this.$defaults.relationship.line&&c.attributes.set(K.style,e.line),!this.graphology.hasDirectedEdge(e.target,e.source)&&s.weight>1&&c.attributes.set(K.weight,s.weight);let u=edgelabel(e);if(u&&c.attributes.set(K.label,u),e.color&&e.color!==this.$defaults.relationship.color){let t=this.styles.colors(e.color).relationships;c.attributes.apply({[K.color]:t.line,[K.fontcolor]:t.label})}return c}},Node=class{value;next;constructor(e){this.value=e}},Queue=class{#e;#t;#n;constructor(){this.clear()}enqueue(e){let t=new Node(e);this.#e?(this.#t.next=t,this.#t=t):(this.#e=t,this.#t=t),this.#n++}dequeue(){let e=this.#e;if(e)return this.#e=this.#e.next,this.#n--,this.#e||(this.#t=void 0),e.value}peek(){if(this.#e)return this.#e.value}clear(){this.#e=void 0,this.#t=void 0,this.#n=0}get size(){return this.#n}*[Symbol.iterator](){let e=this.#e;for(;e;)yield e.value,e=e.next}*drain(){for(;this.#e;)yield this.dequeue()}};function pLimit(e){let t=!1;if(typeof e==`object`&&({concurrency:e,rejectOnClear:t=!1}=e),validateConcurrency(e),typeof t!=`boolean`)throw TypeError("Expected `rejectOnClear` to be a boolean");let r=new Queue,o=0,resumeNext=()=>{o<e&&r.size>0&&(o++,r.dequeue().run())},next=()=>{o--,resumeNext()},run=async(e,t,r)=>{let o=(async()=>e(...r))();t(o);try{await o}catch{}next()},enqueue=(t,s,c,u)=>{let d={reject:c};new Promise(e=>{d.run=e,r.enqueue(d)}).then(run.bind(void 0,t,s,u)),o<e&&resumeNext()},generator=(e,...t)=>new Promise((r,o)=>{enqueue(e,r,o,t)});return Object.defineProperties(generator,{activeCount:{get:()=>o},pendingCount:{get:()=>r.size},clearQueue:{value(){if(!t){r.clear();return}let e=AbortSignal.abort().reason;for(;r.size>0;)r.dequeue().reject(e)}},concurrency:{get:()=>e,set(t){validateConcurrency(t),e=t,queueMicrotask(()=>{for(;o<e&&r.size>0;)resumeNext()})}},map:{async value(e,t){let r=Array.from(e,(e,r)=>this(t,e,r));return Promise.all(r)}}}),generator}function validateConcurrency(e){if(!((Number.isInteger(e)||e===1/0)&&e>0))throw TypeError("Expected `concurrency` to be a number from 1 and up")}const ea=pLimit(1);var ta=class GraphvizWasmAdapter{static opsCount=0;get name(){return`wasm`}get concurrency(){return 1}dispose(){_i.unload()}[Symbol.dispose](){this.dispose()}async attempt(e,t,r){return await ea(async()=>{let o=G.getChild([`layouter`,`wasm`,e,`_`,yn(4).toLowerCase()]);try{o.trace`execute`;let e=await r();return++GraphvizWasmAdapter.opsCount>=20&&(GraphvizWasmAdapter.opsCount=0,o.trace`reached 20 operations, unloading wasm`,_i.unload()),e}catch(e){o.trace(`FAILED DOT
|
|
33
|
+
`+t);let r=loggable(e);if(r.includes(`syntax error`))throw e;o.warn(r),GraphvizWasmAdapter.opsCount=0,_i.unload()}return o.warn(`Retrying...`),await ei(30,300),await r()})}async unflatten(e){return await this.attempt(`unflatten`,e,async()=>(await _i.load()).unflatten(e,1,!1,3).replaceAll(/\t\[/g,` [`).replaceAll(/\t/g,` `))}async acyclic(e){return await this.attempt(`acyclic`,e,async()=>{let t=(await _i.load()).acyclic(e,!0);return t.acyclic&&t.outFile||e})}async layoutJson(e){return await this.attempt(`layout`,e,async()=>(await _i.load()).layout(e,`json`,void 0,{yInvert:!0}))}async svg(e){return await this.attempt(`svg`,e,async()=>(await _i.load()).layout(e,`svg`))}};const getPrinter=({view:e,styles:t})=>{switch(!0){case Rr(e):return new DynamicViewPrinter(e,t);case Lr(e):return new DeploymentViewPrinter(e,t);case zr(e):return new ElementViewPrinter(e,t);default:ci(e)}},na=G.getChild(`layouter`);function normalizeDot(e){return e.split(`
|
|
23
34
|
`).filter(e=>!(e.includes(`margin`)&&e.includes(`50.1`))).join(`
|
|
24
|
-
`)}var GraphvizLayouter=class{graphviz;constructor(e){this.graphviz=e??new
|
|
25
|
-
`+e),
|
|
26
|
-
`+
|
|
27
|
-
{stderr}`,{command:
|
|
28
|
-
`+
|
|
29
|
-
{stderr}`,{command:
|
|
30
|
-
`+
|
|
31
|
-
{stderr}`,{command:
|
|
35
|
+
`)}var GraphvizLayouter=class{graphviz;constructor(e){this.graphviz=e??new ta,na.trace`created with port ${this.graphviz.name}`}dispose(){this.graphviz.dispose()}[Symbol.dispose](){this.dispose()}get graphvizPort(){return this.graphviz}changePort(e){this.graphviz.dispose(),this.graphviz=e,na.trace`change port to ${this.graphviz.name}`}printToDot(e,t){return normalizeDot((t?new AiLayoutViewPrinter(e.view,e.styles,t):getPrinter(e)).print())}newScopedLogger(e){return na.getChild([e,`_`,yn(4).toLowerCase()])}async dotToJson(e){let t=this.newScopedLogger(`dotToJson`),r;try{r=await this.graphviz.layoutJson(e)}catch(r){throw t.error(loggable(r)),t.error(`Failed to convert DOT to JSON:
|
|
36
|
+
`+e),r}try{return JSON.parse(r)}catch(o){throw t.error(loggable(o)),t.error`Failed to parse JSON:\n${r}\n. Generated from DOT:\n${e}`,o}}async layout(e){let t=this.newScopedLogger(`layout`);try{t.trace`layouting view ${e.view.id}...`;let r=await this.dot(e),{view:o}=e,s=parseGraphvizJson(await this.dotToJson(r),o);return Rr(s)&&Object.assign(s,{sequenceLayout:Fn(s)}),r=normalizeDot(r),t.trace`layouting view ${e.view.id} done`,{dot:r,diagram:s}}catch(r){throw t.warn(loggable(r)),wrapError(r,`Error during layout: ${e.view.id}`)}}async aiLayout({view:e,styles:t},r){let o=this.newScopedLogger(`ai-layout`);try{o.trace`layouting view ${e.id} using AI hints...`;let s=new AiLayoutViewPrinter(e,t,r).print(),c=parseGraphvizJson(await this.dotToJson(s),e);return Rr(c)&&Object.assign(c,{sequenceLayout:Fn(c)}),s=normalizeDot(s),o.trace`layouting view ${e.id} done`,{dot:s,diagram:c}}catch(t){throw o.warn(loggable(t)),wrapError(t,`Error during AI layout: ${e.id}`)}}async svg(e){let t=await this.dot(e);return t=normalizeDot(t),{svg:await this.graphviz.svg(t),dot:t}}async dot(e){let t=this.newScopedLogger(`dot`);t.trace`generating dot for view ${e.view.id}`;let r=getPrinter(e).print();if(!zr(e.view))return normalizeDot(r);try{t.trace`unflattening dot`,r=await this.graphviz.unflatten(r)}catch(r){t.warn(`Error during unflatten: ${e.view.id}`,{error:r})}return normalizeDot(r)}async layoutProjectsView(e){let t=this.newScopedLogger(`layoutProjectsView`);t.debug`layouting projects overview...`;let r=new $i(e).print();try{r=await this.graphviz.unflatten(r)}catch(e){t.warn(`Error during unflatten of projects view`,{error:e})}let o=await this.dotToJson(r);return t.debug`layouting ${`projects overview`}`,parseGraphvizJsonOfProjectsView(o,e)}};const ra=G.getChild([`layouter-queue`]);var QueueGraphvizLayoter=class extends GraphvizLayouter{queue;isProcessingBatch=!1;constructor(e){super(e?.graphviz),this.queue=new Un({concurrency:e?.concurrency??this.graphvizPort.concurrency,timeout:e?.timeout??2e4,throwOnTimeout:e?.throwOnTimeout??!0})}async runInQueue(e){let t=ra.getChild([`run`,yn(3)]);return this.isProcessingBatch?(t.debug`waiting for batch to finish`,await this.queue.onIdle(),await di(),t.trace`try runInQueue again`,await this.runInQueue(e)):(await this.waitForQueueToShrink(this.queue.concurrency,t),ra.trace`add task to queue`,await this.queue.add(e))}changePort(e){super.changePort(e),this.queue.concurrency!==e.concurrency&&(this.queue.concurrency=this.graphvizPort.concurrency,ra.debug`set queue concurrency to ${this.graphvizPort.concurrency}`)}async layout(e){let t=await this.runInQueue(async()=>await super.layout(e));if(!t)throw Error(`QueueGraphvizLayoter: layout failed`);return t}async layoutProjectsView(e){let t=await this.runInQueue(async()=>await super.layoutProjectsView(e));if(!t)throw Error(`QueueGraphvizLayoter: layoutProjectsView failed`);return t}async batchLayout(e){let t=ra.getChild([`batch`,yn(3)]);if(this.isProcessingBatch)return t.trace`wait for previous layouts to finish`,await this.queue.onIdle(),await di(),e.cancelToken?.isCancellationRequested?(t.trace`cancellation requested`,[]):(t.trace`retry`,await this.batchLayout(e));let r=this.queue.concurrency;t.debug`starting, batch size: ${e.batch.length}, concurrency: ${r}`,this.isProcessingBatch=!0;let o=[];try{for(let s of e.batch)if(t.trace`add task for view ${s.view.id}`,this.queue.add(async()=>(r<=2&&await di(),await super.layout(s))).then(t=>{if(!t){e.onError?.(s,Error(`Layout queue returned null for view ${s.view.id}`));return}o.push(t),e.onSuccess?.(s,t)}).catch(r=>{t.error(`Fail layout view ${s.view.id}`,{err:r}),e.onError?.(s,r)}),await this.waitForQueueToShrink(r,t),e.cancelToken?.isCancellationRequested){t.debug`cancellation requested`;break}}finally{let e=this.queue.pending+this.queue.size;e>0&&(t.trace`waiting ${e} tasks to finish`,await this.queue.onIdle()),t.debug`batch layout done`,this.isProcessingBatch=!1}return o}async waitForQueueToShrink(e=this.queue.concurrency,t=ra){this.queue.size>e+2&&(t.trace`limit reached. queue size: ${this.queue.size}, running: ${this.queue.pending}, waiting shrink to ${e}`,await this.queue.onSizeLessThan(e+1))}dispose(){this.queue.clear(),super.dispose()}},ia=e(Wn(),1);const aa=G.getChild([`graphviz`,`binary`]);var GraphvizBinaryAdapter=class{_dotpath;_unflattenpath;constructor(e,t){this._dotpath=e,this._unflattenpath=t}get name(){return`binary`}dispose(){}[Symbol.dispose](){}get concurrency(){return Math.max(1,xi.availableParallelism()-2)}get dotpath(){return this._dotpath??ai(this,`_dotpath`,()=>{let e=ia.default.sync(`dot`);return aa.debug`Found ${e}`,e})}get unflattenpath(){return this._unflattenpath??ai(this,`_unflattenpath`,()=>{let e=ia.default.sync(`unflatten`);return aa.debug`Found ${e}`,e})}async unflatten(e){let t,r=aa.getChild([`unflatten`,yn(4)]);try{let o=await yi(this.unflattenpath,[`-l`,`1`,`-c`,`3`],{timeout:1e4,stdin:{string:e}});t=o.stdout,j(o.stderr)?r.trace(`{command} succeeded in {durationMs}ms`,{command:o.command,durationMs:Math.round(o.durationMs)}):r.warn(`{command} has stderr:
|
|
37
|
+
`+o.stderr,{command:o.command})}catch(o){r.debug(`FAILED DOT`,{dot:e}),r.error(loggable(o)),o instanceof bi&&!j(o.stdout)&&(r.warn(`{command} returned result but failed with exitcode {exitCode}:
|
|
38
|
+
{stderr}`,{command:o.command,exitCode:o.exitCode,stderr:o.stderr}),t=o.stdout)}return t&&(e=t.replaceAll(/\t\[/g,` [`).replaceAll(/\t/g,` `)),e}async layoutJson(e){let t=aa.getChild([`layoutJson`,yn(4)]),r;try{let o=await yi(this.dotpath,[`-Tjson`,`-y`],{timeout:1e4,stdin:{string:e}});r=o.stdout,j(o.stderr)?t.trace(`{command} succeeded in {durationMs}ms`,{command:o.command,durationMs:Math.round(o.durationMs)}):t.warn(`{command} has stderr:
|
|
39
|
+
`+o.stderr,{command:o.command})}catch(o){if(t.debug(`FAILED DOT`,{dot:e}),t.error(loggable(o)),o instanceof bi&&!j(o.stdout))t.warn(`{command} returned result but failed with exitcode {exitCode}:
|
|
40
|
+
{stderr}`,{command:o.command,exitCode:o.exitCode,stderr:o.stderr}),r=o.stdout;else throw o}return r}async acyclic(e){return Promise.reject(Error(`Method not implemented.`))}async svg(e){let t=aa.getChild([`svg`,yn(4)]),r;try{let o=await yi(this.dotpath,[`-Tsvg`,`-y`],{timeout:1e4,stdin:{string:e}});r=o.stdout,j(o.stderr)?t.trace(`{command} succeeded in {durationMs}ms`,{command:o.command,durationMs:Math.round(o.durationMs)}):t.warn(`{command} has stderr:
|
|
41
|
+
`+o.stderr,{command:o.command})}catch(o){if(t.debug(`FAILED DOT`,{dot:e}),t.error(loggable(o)),o instanceof bi&&!j(o.stdout))t.warn(`{command} returned result but failed with exitcode {exitCode}:
|
|
42
|
+
{stderr}`,{command:o.command,exitCode:o.exitCode,stderr:o.stderr}),r=o.stdout;else throw o}return r}};const q=G.getChild(`server`);function logWarnError(e){q.warn(loggable(e))}function getTelemetrySink(e){let t=getMessageOnlyFormatter();return r=>{try{switch(r.level){case`error`:case`fatal`:{let o=r.category.join(`.`);if(o===`likec4.config`)break;let s=errorFromLogRecord(r);s?e.telemetry.logEvent({eventName:`error`,message:`${s.name}: ${s.message}`,category:o,...s.stack&&{stack:s.stack}}):e.telemetry.logEvent({eventName:`error`,message:t(r),category:o});break}}}catch(e){console.error(`Error while logging to LSP connection:`,e)}}}var oa=ot(),sa=tt();function configureLanguageServerLogger({lspConnection:e,enableTelemetry:t=!!e,useStdErr:r=!1,logLevel:o=Oi?`debug`:`warning`,nonBlocking:s=!1,colors:c=!1}={}){let u=!!e&&t&&!Oi;configureLogger$1({reset:!0,sinks:{console:r?getConsoleStderrSink({formatter:getTextFormatter()}):getConsoleSink({formatter:c?getAnsiColorFormatter():getTextFormatter(),nonBlocking:s}),...u&&{telemetry:getTelemetrySink(e)}},loggers:[{category:[`likec4`],sinks:[`console`,...u?[`telemetry`]:[]],lowestLevel:o}]}),q.trace(`logger configured`)}const ca=Lt.pick({extends:!0,styles:!0}).loose(),normalizeExtends=e=>e?Array.isArray(e)?e:[e]:[],parseJsonConfig=async e=>{let t=await wi.readFile(e,`utf-8`),r;try{r=bt.parse(t.trim()||`{}`)}catch(t){throw wrapError(t,`${e}:`)}if(!r||typeof r!=`object`||Array.isArray(r))throw Error(`${e}: Config must be a JSON object`);let o=ca.safeParse(r);if(!o.success)throw Error(`${e}: Invalid config\n`+At.prettifyError(o.error));return o.data},loadJsonConfigs=async(e,t)=>{if(t.includes(e)){let r=t.indexOf(e),o=[...t.slice(r),e].join(` -> `);throw Error(`Config extends cycle detected: ${o}`)}let r=await parseJsonConfig(e),o=normalizeExtends(r.extends),s=[...t,e],c=[];for(let t of o){let r=Qn(Xn(e),t);c.push(...await loadJsonConfigs(r,s))}return[...c,r]};async function loadConfig(e){e=typeof e==`string`?e:e.fsPath,G.getChild(`config`).debug`Loading config: ${Zn(ji(),e)}`;let t=Xn(e),r=Yn(e),o={name:Yn(t)};if(Ft(r)){let t=await loadJsonConfigs(Qn(e),[]);V(N(t,1),`Expect at least one config`);let r=pn(ln(t),[`extends`,`styles`]),s=t.map(e=>e.styles).filter(D),c=s.length>0?Vi({},...s.reverse()):void 0;return Pt({...o,...r,...c?{styles:c}:{}})}V(It(r),`Invalid name for config file: ${e}`);let{mod:s}=await ki({filepath:e,cwd:t,esbuildOptions:{resolveExtensions:[`.ts`,`.mts`,`.cts`,`.mjs`,`.js`,`.cjs`],plugins:[{name:`likec4-config`,setup(e){e.onResolve({filter:/^@?likec4\/config$/},e=>({path:e.path,namespace:`likec4-config`})),e.onEnd(e=>{let t=Ai(e.errors,{kind:`error`});for(let e of t)G.error(e)}),e.onLoad({filter:/.*/,namespace:`likec4-config`},e=>({contents:`
|
|
32
43
|
// Mock implementation to allow loading config files without bundling @likec4/config
|
|
33
44
|
function mock(x) { return x }
|
|
34
45
|
export {
|
|
@@ -37,57 +48,57 @@ export {
|
|
|
37
48
|
mock as defineStyle,
|
|
38
49
|
mock as defineTheme,
|
|
39
50
|
mock as defineThemeColor,
|
|
40
|
-
}`,loader:`js`}))}}]}});return Pt(Object.assign(r,i?.default??i))}const na={aws:`activate.alexa-for-business.amplify.apache-mxnet-on-aws.api-gateway.app-config.app-flow.app-mesh.app-runner.app-stream.app-sync.application-auto-scaling.application-composer.application-cost-profiler.application-discovery-service.application-migration-service.artifact.athena.audit-manager.augmented-ai-a2i.aurora.auto-scaling.backint-agent.backup.batch.billing-conductor.bottlerocket.braket.budgets.certificate-manager.chatbot.chime-sdk.chime-voice-connector.chime.clean-rooms.client-vpn.cloud-control-api.cloud-development-kit.cloud-directory.cloud-formation.cloud-front.cloud-hsm.cloud-map.cloud-search.cloud-shell.cloud-trail.cloud-wan.cloud-watch.cloud9.code-artifact.code-build.code-catalyst.code-commit.code-deploy.code-guru.code-pipeline.code-star.code-whisperer.cognito.command-line-interface.comprehend-medical.comprehend.compute-optimizer.config.connect.console-mobile-application.control-tower.corretto.cost-and-usage-report.cost-explorer.data-exchange.data-pipeline.data-sync.data-zone.database-migration-service.deep-composer.deep-learning-amis.deep-learning-containers.deep-lens.deep-racer.detective.dev-ops-guru.device-farm.direct-connect.directory-service.distro-for-open-telemetry.document-db.dynamo-db.ec2-auto-scaling.ec2-image-builder.ec2.ecs-anywhere.efs.eks-anywhere.eks-cloud.eks-distro.elasti-cache.elastic-beanstalk.elastic-block-store.elastic-container-registry.elastic-container-service.elastic-disaster-recovery.elastic-fabric-adapter.elastic-inference.elastic-kubernetes-service.elastic-load-balancing.elastic-transcoder.elemental-appliances-software.elemental-conductor.elemental-delta.elemental-link.elemental-live.elemental-media-connect.elemental-media-convert.elemental-media-live.elemental-media-package.elemental-media-store.elemental-media-tailor.elemental-server.emr.event-bridge.express-workflows.fargate.fault-injection-simulator.file-cache.fin-space.firewall-manager.forecast.fraud-detector.free-rtos.fsx-for-lustre.fsx-for-net-app-ontap.fsx-for-open-zfs.fsx-for-wfs.fsx.game-kit.game-lift.game-sparks.genomics-cli.global-accelerator.glue-data-brew.glue-elastic-views.glue.ground-station.guard-duty.health-lake.honeycode.iam-identity-center.identity-and-access-management.inspector.interactive-video-service.io-t-1-click.io-t-analytics.io-t-button.io-t-core.io-t-device-defender.io-t-device-management.io-t-edu-kit.io-t-events.io-t-express-link.io-t-fleet-wise.io-t-greengrass.io-t-robo-runner.io-t-site-wise.io-t-things-graph.io-t-twin-maker.iq.kendra.key-management-service.keyspaces.kinesis-data-analytics.kinesis-data-streams.kinesis-firehose.kinesis-video-streams.kinesis.lake-formation.lambda.launch-wizard.lex.license-manager.lightsail.local-zones.location-service.lookout-for-equipment.lookout-for-metrics.lookout-for-vision.lumberyard.macie.mainframe-modernization.managed-blockchain.managed-grafana.managed-service-for-prometheus.managed-services.managed-streaming-for-apache-kafka.managed-workflows-for-apache-airflow.management-console.marketplace-dark.marketplace-light.memory-db-for-redis.migration-evaluator.migration-hub.monitron.mq.neptune.network-firewall.neuron.nice-dcv.nice-engin-frame.nimble-studio.nitro-enclaves.omics.open-3d-engine.open-search-service.ops-works.organizations.outposts-family.outposts-rack.outposts-servers.panorama.parallel-cluster.personal-health-dashboard.personalize.pinpoint-apis.pinpoint.polly.private-5g.private-certificate-authority.private-link.professional-services.proton.quantum-ledger-database.quick-sight.rds-on-vmware.rds.re-post.red-hat-open-shift-service-on-aws.redshift.rekognition.reserved-instance-reporting.resilience-hub.resource-access-manager.resource-explorer.robo-maker.route-53.s3-on-outposts.sage-maker-ground-truth.sage-maker-studio-lab.sage-maker.savings-plans.secrets-manager.security-hub.security-lake.server-migration-service.serverless-application-repository.service-catalog.service-management-connector.shield.signer.sim-space-weaver.simple-email-service.simple-notification-service.simple-queue-service.simple-storage-service-glacier.simple-storage-service.site-to-site-vpn.snowball-edge.snowball.snowcone.snowmobile.step-functions.storage-gateway.sumerian.supply-chain.support.systems-manager.tensor-flow-on-aws.textract.thinkbox-deadline.thinkbox-frost.thinkbox-krakatoa.thinkbox-sequoia.thinkbox-stoke.thinkbox-xmesh.timestream.tools-and-sdks.torch-serve.training-certification.transcribe.transfer-family.transit-gateway.translate.trusted-advisor.verified-access.verified-permissions.virtual-private-cloud.vmware-cloud-on-aws.vpc-lattice.waf.wavelength.well-architected-tool.wickr.work-docs-sdk.work-docs.work-link.work-mail.work-spaces-family.x-ray`.split(`.`),azure:`abs-member.active-directory-connect-health.activity-log.administrative-units.advisor.ai-at-edge.ai-studio.aks-automatic.aks-istio.alerts.all-resources.analysis-services.anomaly-detector.api-center.api-connections.api-management-services.api-proxy.app-compliance-automation.app-configuration.app-registrations.app-service-certificates.app-service-domains.app-service-environments.app-service-plans.app-services.app-space-component.app-space.applens.application-gateway-containers.application-gateways.application-group.application-insights.application-security-groups.aquila.arc-data-services.arc-kubernetes.arc-machines.arc-postgre-sql.arc-sql-managed-instance.arc-sql-server.atm-multistack.auto-scale.automanaged-vm.automation-accounts.availability-sets.avs-vm.azure-a.azure-ad-b2c.azure-api-for-fhir.azure-applied-ai-services.azure-arc.azure-attestation.azure-backup-center.azure-blockchain-service.azure-center-for-sap.azure-chaos-studio.azure-cloud-shell.azure-communication-services.azure-communications-gateway.azure-compute-galleries.azure-consumption-commitment.azure-cosmos-db.azure-data-catalog.azure-data-explorer-clusters.azure-database-maria-db-server.azure-database-migration-services.azure-database-my-sql-server.azure-database-postgre-sql-server-group.azure-database-postgre-sql-server.azure-databox-gateway.azure-databricks.azure-deployment-environments.azure-dev-ops.azure-dev-tunnels.azure-edge-hardware-center.azure-experimentation-studio.azure-fileshares.azure-firewall-manager.azure-firewall-policy.azure-hcp-cache.azure-hpc-workbenches.azure-hybrid-center.azure-information-protection.azure-io-t-operations.azure-lighthouse.azure-load-testing.azure-managed-grafana.azure-managed-redis.azure-maps-accounts.azure-media-service.azure-migrate.azure-monitor-dashboard.azure-monitor-pipeline.azure-monitors-for-sap-solutions.azure-net-app-files.azure-network-function-manager-functions.azure-network-function-manager.azure-object-understanding.azure-open-ai.azure-operator-5g-core.azure-operator-insights.azure-operator-nexus.azure-operator-service-manager.azure-orbital.azure-programmable-connectivity.azure-purview-accounts.azure-quotas.azure-red-hat-open-shift.azure-sentinel.azure-service-bus.azure-sphere.azure-spring-apps.azure-sql-edge.azure-sql-server-stretch-databases.azure-sql-vm.azure-sql.azure-stack-edge.azure-stack-hci-sizer.azure-stack.azure-storage-mover.azure-support-center-blue.azure-sustainability.azure-synapse-analytics.azure-token-service.azure-video-indexer.azure-virtual-desktop.azure-vmware-solution.azure-workbooks.azurite.backlog.backup-vault.bare-metal-infrastructure.bastions.batch-accounts.batch-ai.biz-talk.blob-block.blob-page.blockchain-applications.blueprints.bonsai.bot-services.branch.breeze.browser.bug.builds.business-process-tracking.cache-redis.cache.capacity-reservation-groups.capacity.cdn-profiles.central-service-instance-for-sap.ceres.change-analysis.client-apps.cloud-services-classic.cloud-services-extended-support.cloud-test.code-optimization.code.cognitive-search.cognitive-services-decisions.cognitive-services.collaborative-service.commit.community-images.compliance-center.compliance.compute-fleet.computer-vision.conditional-access.confidential-ledgers.connected-cache.connected-vehicle-platform.connections.consortium.container-apps-environments.container-instances.container-registries.container-services-deprecated.content-moderators.content-safety.controls-horizontal.controls.cost-alerts.cost-analysis.cost-budgets.cost-export.cost-management-and-billing.cost-management.counter.cubes.custom-ip-prefix.custom-vision.customer-lockbox-for-microsoft-azure.dashboard-hub.dashboard.data-box.data-collection-rules.data-factories.data-lake-analytics.data-lake-storage-gen1.data-lake-store-gen1.data-share-invitations.data-shares.data-virtualization.database-instance-for-sap.ddo-s-protection-plans.dedicated-hsm.defender-cm-local-manager.defender-dcs-controller.defender-distributer-control-system.defender-engineering-station.defender-external-management.defender-freezer-monitor.defender-historian.defender-hmi.defender-industrial-packaging-system.defender-industrial-printer.defender-industrial-robot.defender-industrial-scale-system.defender-marquee.defender-meter.defender-plc.defender-pneumatic-device.defender-programable-board.defender-relay.defender-robot-controller.defender-rtu.defender-sensor.defender-slot.defender-web-guiding-system.detonation.dev-console.dev-ops-starter.dev-test-labs.device-compliance.device-configuration.device-enrollment.device-provisioning-services.device-security-apple.device-security-google.device-security-windows.device-update-io-t-hub.devices.diagnostics-settings.digital-twins.disk-encryption-sets.disk-pool.disks-classic.disks-snapshots.disks.dns-multistack.dns-private-resolver.dns-security-policy.dns-zones.download.e-books.edge-actions.edge-management.edge-storage-accelerator.education.elastic-job-agents.elastic-san.endpoint-analytics.engage-center-connect.enterprise-applications.entra-connect-health.entra-connect-sync.entra-connect.entra-domain-services.entra-global-secure-access.entra-id-protection.entra-identity-custom-roles.entra-identity-licenses.entra-identity-risky-signins.entra-identity-risky-users.entra-identity-roles-and-administrators.entra-internet-access.entra-managed-identities.entra-private-access.entra-privleged-identity-management.entra-verified-id.error.event-grid-domains.event-grid-subscriptions.event-grid-topics.event-hub-clusters.event-hubs.exchange-access.exchange-on-premises-access.express-route-circuits.express-route-direct.express-route-traffic-collector.extended-security-updates.extensions.external-id-modified.external-id.external-identities.face-apis.feature-previews.fhir-service.fiji.file.files.firewalls.folder-blank.folder-website.form-recognizers.frd-qa.free-services.front-door-and-cdn-profiles.ftp.function-apps.gear.genomics-accounts.genomics.globe-error.globe-success.globe-warning.groups.guide.hd-insight-clusters.hdi-aks-cluster.heart.help-and-support.host-groups.host-pools.hosts.hybrid-connectivity-hub.ic-m-troubleshooting.identity-governance.identity-multi-factor-authentication.identity-secure-score.image-definitions.image-templates.image-versions.image.images.immersive-readers.import-export-jobs.industrial-io-t.information.infrastructure-backup.input-output.instance-pools.integration-accounts.integration-environments.integration-service-environments.internet-analyzer-profiles.intune-app-protection.intune-for-education.intune-trends.intune.io-t-central-applications.io-t-edge.io-t-hub.ip-address-manager.ip-groups.journey-hub.key-vaults.keys.kubernetes-fleet-manager.kubernetes-services.lab-accounts.lab-services.landing-zone.language-understanding.language.launch-portal.learn.load-balancer-hub.load-balancers.load-test.load-testing.local-network-gateways.location.log-analytics-query-pack.log-analytics-workspaces.log-streaming.logic-apps-custom-connector.logic-apps-template.logic-apps.machine-learning-studio-classic-web-services.machine-learning-studio-web-service-plans.machine-learning-studio-workspaces.machine-learning.machines-azure-arc.maintenance-configuration.managed-applications-center.managed-database.managed-desktop.managed-dev-ops-pools.managed-file-shares.managed-identities.managed-instance-apache-cassandra.managed-service-fabric.management-groups.management-portal.marketplace-management.marketplace.med-tech-service.media-file.media.mesh-applications.metrics-advisor.metrics.microsoft-defender-easm.microsoft-defender-for-cloud.microsoft-defender-for-io-t.microsoft-dev-box.mindaro.mission-landing-zone.mobile-engagement.mobile-networks.mobile.modular-data-center.module.monitor-health-models.monitor.multi-tenancy.multifactor-authentication.my-customers.nat.network-foundation-hub.network-interfaces.network-managers.network-security-groups.network-security-hub.network-security-perimeters.network-watcher.notification-hub-namespaces.notification-hubs.offers.on-premises-data-gateways.open-supply-chain-platform.operation-log-classic.oracle-database.os-images-classic.osconfig.outbound-connection.partner-namespace.partner-registration.partner-topic.peering-service.peerings.personalizers.planetary-computer-pro.plans.policy.power-bi-embedded.power-platform.power-up.power.powershell.preview-features.private-endpoints.private-link-service.private-link-services.private-link.process-explorer.production-ready-database.promethus.proximity-placement-groups.public-ip-addresses-classic.public-ip-addresses.public-ip-prefixes.qn-a-makers.quickstart-center.recent.recovery-services-vaults.region-management.relays.remote-rendering.reservations.reserved-capacity.reserved-ip-addresses-classic.resource-explorer.resource-graph-explorer.resource-group-list.resource-groups.resource-guard.resource-linked.resource-management-private-link.resource-mover.resources-provider.restore-points-collections.restore-points.route-filters.route-tables.rtos.savings-plans.scheduler-job-collections.scheduler.scvmm-management-servers.search-grid.search.security-baselines.security.send-grid-accounts.server-farm.serverless-search.service-catalog-mad.service-endpoint-policies.service-fabric-clusters.service-group-relationships.service-groups.service-health.service-providers.shared-image-galleries.signal-r.software-as-a-service.software-updates.solutions.sonic-dash.spatial-anchor-accounts.speech-services.spot-vm.spot-vmss.sql-data-warehouses.sql-database-fleet-manager.sql-database.sql-elastic-pools.sql-managed-instance.sql-server-registries.sql-server.ssd.ssh-keys.ssis-lift-and-shift-ir.stack-hci-premium.static-apps.stor-simple-data-managers.stor-simple-device-managers.storage-accounts-classic.storage-accounts.storage-actions.storage-azure-files.storage-container.storage-explorer.storage-functions.storage-hubs.storage-queue.storage-sync-services.stream-analytics-jobs.subnet.subscriptions.system-topic.table.tag.tags.targets-management.template-specs.templates.tenant-properties.tenant-status.test-base.tfs-vc-repository.time-series-data-sets.time-series-insights-access-policies.time-series-insights-environments.time-series-insights-event-sources.toolbox.toolchain-orchestrator.traffic-manager-profiles.translator-text.troubleshoot.universal-print.update-management-center.updates.user-privacy.user-settings.user-subscriptions.users.verifiable-credentials.verification-as-a-service.versions.video-analyzers.virtual-clusters.virtual-enclaves.virtual-instance-for-sap.virtual-machine.virtual-machines-classic.virtual-network-gateways.virtual-networks-classic.virtual-networks.virtual-router.virtual-visits-builder.virtual-wan-hub.virtual-wans.vm-app-definitions.vm-app-versions.vm-image-version.vm-images-classic.vm-scale-sets.vpnclient-windows.wac-installer.wac.web-app-database.web-application-firewall-policies-waf.web-jobs.web-slots.web-test.website-power.website-staging.windows-notification-services.windows10-core-services.workbooks.worker-container-app.workflow.workload-orchestration.workspace-gateway.workspaces`.split(`.`),gcp:`access-context-manager.administration.advanced-agent-modeling.advanced-solutions-lab.agent-assist.ai-hub.ai-platform-unified.ai-platform.analytics-hub.anthos-config-management.anthos-service-mesh.anthos.api-analytics.api-monetization.api.apigee-api-platform.apigee-sense.app-engine.artifact-registry.asset-inventory.assured-workloads.auto-ml-natural-language.auto-ml-tables.auto-ml-translation.auto-ml-video-intelligence.auto-ml-vision.auto-ml.bare-metal-solutions.batch.beyondcorp.big-query.bigtable.billing.binary-authorization.catalog.certificate-authority-service.certificate-manager.cloud-api-gateway.cloud-apis.cloud-armor.cloud-asset-inventory.cloud-audit-logs.cloud-build.cloud-cdn.cloud-code.cloud-composer.cloud-data-fusion.cloud-deploy.cloud-deployment-manager.cloud-dns.cloud-domains.cloud-ekm.cloud-endpoints.cloud-external-ip-addresses.cloud-firewall-rules.cloud-for-marketing.cloud-functions.cloud-generic.cloud-gpu.cloud-healthcare-api.cloud-healthcare-marketplace.cloud-hsm.cloud-ids.cloud-inference-api.cloud-interconnect.cloud-jobs-api.cloud-load-balancing.cloud-logging.cloud-media-edge.cloud-monitoring.cloud-nat.cloud-natural-language-api.cloud-network.cloud-ops.cloud-optimization-ai-fleet-routing-api.cloud-optimization-ai.cloud-router.cloud-routes.cloud-run-for-anthos.cloud-run.cloud-scheduler.cloud-security-scanner.cloud-shell.cloud-spanner.cloud-sql.cloud-storage.cloud-tasks.cloud-test-lab.cloud-tpu.cloud-translation-api.cloud-vision-api.cloud-vpn.compute-engine.configuration-management.connectivity-test.connectors.contact-center-ai.container-optimized-os.container-registry.data-catalog.data-labeling.data-layers.data-loss-prevention-api.data-qn-a.data-studio.data-transfer.database-migration-service.dataflow.datalab.dataplex.datapol.dataprep.dataproc-metastore.dataproc.datashare.datastore.datastream.debugger.developer-portal.dialogflow-cx.dialogflow-insights.dialogflow.document-ai.early-access-center.error-reporting.eventarc.filestore.financial-services-marketplace.firestore.fleet-engine.free-trial.game-servers.gce-systems-management.genomics.gke-on-prem.google-cloud-marketplace.google-kubernetes-engine.google-maps-platform.healthcare-nlp-api.home.identity-and-access-management.identity-aware-proxy.identity-platform.iot-core.iot-edge.key-access-justifications.key-management-service.kuberun.launcher.local-ssd.looker.managed-service-for-microsoft-active-directory.media-translation-api.memorystore.migrate-for-anthos.migrate-for-compute-engine.my-cloud.network-connectivity-center.network-intelligence-center.network-security.network-tiers.network-topology.onboarding.os-configuration-management.os-inventory-management.os-patch-management.partner-interconnect.partner-portal.performance-dashboard.permissions.persistent-disk.phishing-protection.policy-analyzer.premium-network-tier.private-connectivity.private-service-connect.producer-portal.profiler.project.pub-sub.quantum-engine.quotas.real-world-insights.recommendations-ai.release-notes.retail-api.risk-manager.runtime-config.secret-manager.security-command-center.security-health-advisor.security-key-enforcement.security.service-discovery.speech-to-text.stackdriver.standard-network-tier.stream-suite.support.tensorflow-enterprise.text-to-speech.tools-for-powershell.trace.traffic-director.transfer-appliance.transfer.user-preferences.vertex-ai.video-intelligence-api.virtual-private-cloud.visual-inspection.vmware-engine.web-risk.web-security-scanner.workflows.workload-identity-pool`.split(`.`),tech:`100tb.500px.aarch64.active-campaign-icon.active-campaign.adobe-after-effects.adobe-animate.adobe-dreamweaver.adobe-icon.adobe-illustrator.adobe-incopy.adobe-indesign.adobe-lightroom.adobe-photoshop.adobe-premiere-pro.adobe-premiere.adobe-xd.adobe.adonis-js.adonisjs-icon.adroll.adyen.aerogear.aerospike-icon.aerospike.after-effects.aha.airbnb-icon.airbnb.airbrake.airflow-icon.airflow.airtable.aix.akamai.akka.alfresco.algolia.alpinejs-icon.alpinejs.altair.amazon-chime.amazon-connect.amazon-web-services.amd.amex-digital.amex.amp-icon.amp.ampersand.amplication-icon.amplication.amplitude-icon.amplitude.anaconda.analog.android-icon.android-studio.android-vertical.android.angellist.angular-icon.angular-js.angular.ansible.ant-design.anthropic-icon.anthropic.apache-camel.apache-cloudstack.apache-flink-icon.apache-flink.apache-spark.apache-superset-icon.apache-superset.apache.apiary.apidog-icon.apidog.apl.apollostack.apostrophe.appbaseio-icon.appbaseio.appcelerator.appcenter-icon.appcenter.appcircle-icon.appcircle.appcode.appdynamics-icon.appdynamics.appium.apple-app-store.apple-pay.apple-safari.apple.applitools-icon.applitools.appsignal-icon.appsignal.apptentive.appveyor.appwrite-icon.appwrite.arangodb-icon.arangodb.arc.architect-icon.architect.archlinux.arduino.argo-icon.argo.argocd.arm.armory-icon.armory.asana-icon.asana.asciidoctor.assembla-icon.assembla.astro-icon.astro.astronomer.async-api-icon.async-api.atlassian.atom-icon.atom.atomic-icon.atomic.atomicojs-icon.atomicojs.aurelia.aurora.auth0-icon.auth0.authy.autodesk-maya.autodesk-shot-grid.autoit.autoprefixer.ava.awesome.awk.aws-amplify.aws-api-gateway.aws-app-mesh.aws-appflow.aws-appsync.aws-athena.aws-aurora.aws-backup.aws-batch.aws-certificate-manager.aws-cloudformation.aws-cloudfront.aws-cloudsearch.aws-cloudtrail.aws-cloudwatch.aws-codebuild.aws-codecommit.aws-codedeploy.aws-codepipeline.aws-codestar.aws-cognito.aws-config.aws-documentdb.aws-dynamodb.aws-ec2.aws-ecs.aws-eks.aws-elastic-beanstalk.aws-elasticache.aws-elb.aws-eventbridge.aws-fargate.aws-glacier.aws-glue.aws-iam.aws-keyspaces.aws-kinesis.aws-kms.aws-lake-formation.aws-lambda.aws-lightsail.aws-mq.aws-msk.aws-neptune.aws-open-search.aws-opsworks.aws-quicksight.aws-rds.aws-redshift.aws-route53.aws-s3.aws-secrets-manager.aws-ses.aws-shield.aws-sns.aws-sqs.aws-step-functions.aws-systems-manager.aws-timestream.aws-vpc.aws-waf.aws-xray.aws.axios.azios.azure-devops.azure-sql-database.azure.babel.backbone-icon.backbone-js.backbone.backerkit.baker-street.balena.ballerina.bamboo.basecamp-icon.basecamp.basekit.baseline.bash-icon.bash.batch.beats.behance.bem-2.bem.bigpanda.bing.biomejs-icon.biomejs.bitbar.bitbucket.bitcoin.bitnami.bitrise-icon.bitrise.blender.blitzjs-icon.blitzjs.blocs.blogger.blossom.blueprint.bluesky.bluetooth.booqable-icon.booqable.bootstrap.bosun.botanalytics.bourbon.bower.box.brackets.brainjs.branch-icon.branch.brandfolder-icon.brandfolder.brave.braze-icon.braze.broadcom-icon.broadcom.broccoli.brotli.browserify-icon.browserify.browserling.browserslist.browserstack.browsersync.brunch.bubble-icon.bubble.buck.buddy.buffer.bugherd-icon.bugherd.bugsee.bugsnag.builder-io-icon.builder-io.buildkite-icon.buildkite.bulma.bun.bunny-net-icon.bunny-net.c.cachet.cairo-graphics.cake-php.cakephp-icon.calibre-icon.calibre.campaignmonitor-icon.campaignmonitor.canjs.canva.capacitor.capacitorjs-icon.capacitorjs.capistrano.carbide.cardano-icon.cardano.cassandra.cent-os.centos-icon.certbot.ceylon.chai.chalk.chargebee-icon.chargebee.chartjs.chef.chevereto.chroma.chromatic-icon.chromatic.chrome-web-store.chrome.cinder.circle-ci.cirrus-ci.cirrus.clarity.claude-icon.claude.clio-lang.clion.cljs.clojure-script.clojure.close.cloud9.cloudacademy-icon.cloudacademy.cloudcraft.cloudflare-icon.cloudflare-workers-icon.cloudflare-workers.cloudflare.cloudinary-icon.cloudinary.cloudlinux.cmake.cobalt.cockpit.cocoapods.coda-icon.coda.codacy.code-igniter.code-pen.codeac.codebase.codebeat.codecademy.codeception.codeclimate-icon.codeclimate.codecov-icon.codecov.codefactor-icon.codefactor.codeigniter-icon.codepen-icon.codersrank-icon.codersrank.coderwall.codesandbox-icon.codesandbox.codesee-icon.codesee.codio.codium-icon.codium.coffee-script.commitizen.compass.componentkit.compose-multiplatform.compose.composer.conan-io.concourse.concretecms-icon.concretecms.conda.confluence.consul.contao.contentful.convox-icon.convox.copyleft-pirate.copyleft.corda.cordova.cosmosdb.couchbase.couchdb-icon.couchdb.coursera.coveralls.cpanel.cplusplus.craftcms.crashlytics.crateio.create-react-app.createjs.crossplane-icon.crossplane.crucible.crystal.csharp.css3-official.css3.cssnext.cube-icon.cube.cucumber.curl.customerio-icon.customerio.cyclejs.cypress-icon.cypress.d3.d3js.dailydev-icon.dailydev.daisy-ui-icon.daisy-ui.danfo.dart.dashlane-icon.dashlane.data-grip.data-spell.data-station.database-labs.datadog-icon.datadog.datasette-icon.datasette.datocms-icon.datocms.dbeaver.dbt-icon.dbt.dcos-icon.dcos.debian.delighted-icon.delighted.deno.dependabot.deployhq-icon.deployhq.derby.descript-icon.descript.designernews.deviantart-icon.deviantart.devicon.dgraph-icon.dgraph.dialogflow.digital-ocean-icon.digital-ocean.dimer.dinersclub.discord-icon.discord-js.discord.discourse-icon.discourse.discover.disqus.django-icon.django-rest.django.dockbit.docker-icon.docker.doctrine.docusaurus.dojo-icon.dojo-toolkit.dojo.dolt.dotnet.dovetail-icon.dovetail.dreamhost.dribbble-icon.dribbble.drift.drip.drizzle-icon.drizzle.drone-icon.drone.drools-icon.drools.dropbox.dropmark.dropwizard.dropzone.drupal-icon.drupal.duckduckgo.dynatrace-icon.dynatrace.dyndns.ebanx.eclipse-ceylon.eclipse-icon.eclipse-ide.eclipse-vert-x.eclipse.ecma.edgedb.edgio-icon.edgio.editorconfig.effect-icon.effect.effector.egghead.elasticbeats.elasticpath-icon.elasticpath.elasticsearch.electron.element.elemental-ui.elementary.eleventy-11ty.eleventy.elixir.ello.elm-classic.elm.elo.emacs-classic.emacs.embedded-c.embedly.ember-js.ember-tomster.ember.emmet.enact.engine-yard-icon.engine-yard.envato.envoy-icon.envoy.envoyer.eraser-icon.eraser.erlang.esbuild.esdoc.eslint-old.eslint.eta-icon.eta.etcd.ethereum-color.ethereum.ethers.ethnio.eventbrite-icon.eventbrite.eventsentry.evergreen-icon.evergreen.expo-icon.expo.express.fabric.facebook.faker.falcor.fast-api.fastapi-icon.fastify-icon.fastify.fastlane.fastly.fauna-icon.fauna.feathers.feathersjs.fedora.fetch.ffmpeg-icon.ffmpeg.figma.file-zilla.firebase-icon.firebase.firefox.flannel.flarum.flask.flat-ui.flattr-icon.flattr.fleep.flickr-icon.flickr.flight.floodio.flow.flowxo.floydhub.flutter.flux.fluxxor.fly-icon.fly.fogbugz-icon.fogbugz.fomo-icon.fomo.font-awesome.forestadmin-icon.forestadmin.forever.formkeep.fortran.foundation.foundationdb-icon.foundationdb.framer.framework7-icon.framework7.freebsd.freedcamp-icon.freedcamp.freedomdefined.fresh.frontapp.fsharp.fuchsia.galliumos.game-analytics-icon.game-analytics.ganache-icon.ganache.gatling.gatsby.gazebo.gcc.geekbot.geetest-icon.geetest.gentoo.getyourguide.ghost.giantswarm.gimp.gin.git-icon.git.gitboard.gitbook.github-actions.github-codespaces.github-copilot.github-icon.github-octocat.github.gitkraken.gitlab-icon.gitlab.gitpod.gitter.gitup.glamorous-icon.glamorous.gleam.glimmerjs.glint.glitch-icon.glitch.gnome-icon.gnome.gnu-emacs.gnu-net.gnu.gnupg-icon.gnupg.go-land.go.gocd.godot-engine.godot-icon.godot.gohorse.google-360suite.google-admob.google-ads.google-adsense.google-analytics.google-bard-icon.google-bard.google-calendar.google-cloud-functions.google-cloud-run.google-cloud.google-data-studio.google-developers.google-domains-icon.google-domains.google-drive.google-fit.google-gemini.google-gmail.google-home.google-icon.google-keep.google-maps.google-marketing-platform.google-meet.google-one.google-optimize.google-palm.google-pay.google-photos.google-play-console-icon.google-play-console.google-play-icon.google-play.google-search-console.google-tag-manager.google-workspace.google.gopher.gradio-icon.gradio.gradle.grafana.grails.grammarly-icon.grammarly.graphene.graphql.grav.gravatar-icon.gravatar.graylog-icon.graylog.greensock-icon.greensock.gridsome-icon.gridsome.grommet.groovehq.groovy.grove.growth-book-icon.growth-book.grpc.grunt.gruntjs.gulp.gulpjs.gunicorn.gunjs.gusto.gwt.hack.hacker-one.hadoop.haiku-icon.haiku.haml.hanami.handlebars.hapi.hardhat-icon.hardhat.harness-icon.harness.harvester.hashicorp-icon.hashicorp-vault.hashicorp.hashnode-icon.hashnode.haskell-icon.haskell.hasura-icon.hasura.haxe.haxl.hbase.hcaptcha-icon.hcaptcha.headlessui-icon.headlessui.heap-icon.heap.helm.helpscout-icon.helpscout.hermes.heroku-icon.heroku-redis.heroku.hexo.hhvm.hibernate.highcharts.hipercard.homebrew.hono.hookstate.hootsuite-icon.hootsuite.hosted-graphite.hostgator-icon.hostgator.hotjar-icon.hotjar.houndci.html5-boilerplate.html5.htmx-icon.htmx.httpie-icon.httpie.hubspot.hugging-face-icon.hugging-face.huggy.hugo.humongous.hyper.hyperapp.ibm-spss-statistics.ibm.ie10.ieee.ietf.ifttt.imagemin.imba-icon.imba.immer-icon.immer.immutable.impala.importio-icon.importio.incident-icon.incident.infer.inferno.influxdb-icon.influxdb.ink.inkscape.insomnia.instagram-icon.instagram.intel.intellij-idea.intercom-icon.intercom.internet-computer-icon.internet-computer.internetexplorer.invision-icon.invision.ionic-icon.ionic.ios.iron-icon.iron.itsalive-icon.itsalive.jade.jaeger.jamstack-icon.jamstack.jasmine.java.javascript.jcb.jeet.jekyll.jenkins.jest.jetbrains-icon.jetbrains-space-icon.jetbrains-space.jetbrains.jfrog.jhipster-icon.jhipster.jira-align.jira.joomla.jotai.jquery-mobile.jquery.jruby.jsbin.jsdelivr.jsdom.jsfiddle.json-ld.json-schema-icon.json-schema.json.jspm.jss.juju.jule.julia.junit.jupyter.jwt-icon.jwt.k3os.k3s.kafka-icon.kafka.kaggle.kaios.kallithea.karate.karma.katalon-icon.katalon.kde.keen.kemal.keras.keycdn-icon.keycdn.keydb-icon.keydb.keystonejs.khan-academy-icon.khan-academy.kibana.kickstarter-icon.kickstarter.kinto-icon.kinto.kirby-icon.kirby.knex-js.knex.knockout.koa.kong-icon.kong.kops.koreio.kotlin-icon.kotlin.kraken.krakenjs.ktor-icon.ktor.kubernetes.kustomer.labview.languagetool.laravel.lastfm.lateral-icon.lateral.latex.launchdarkly-icon.launchdarkly.launchrock.leaflet.leankit-icon.leankit.lerna.less-js.less.lets-cloud.letsencrypt.leveldb.lexical-icon.lexical.liftweb.lighthouse.lightstep-icon.lightstep.lighttpd.linear-icon.linear.linkedin-icon.linkedin.linkerd.linode.linux-mint.linux-tux.linux.liquibase.lit-icon.lit.litmus.livewire.llvm.loader.lodash.logentries.logstash.lookback.looker-icon.looker.loom-icon.loom.loopback-icon.loopback.losant.lua.lucene-net.lucene.lumen.mac-os.madge.maestro.mageia.magento.mailchimp-freddie.mailchimp.maildeveloper.mailgun-icon.mailgun.mailjet-icon.mailjet.malinajs.manjaro.mantine-icon.mantine.mapbox-icon.mapbox.maps-me.mapzen-icon.mapzen.mariadb-icon.mariadb.marionette.markdown.marko.marvel.mastercard.mastodon-icon.mastodon.material-ui.materialize.materializecss.matlab.matomo-icon.matomo.matplotlib-icon.matplotlib.matter-icon.matter.mattermost-icon.mattermost.mautic-icon.mautic.maven.mdn.mdx.medium-icon.medium.medusa-icon.medusa.meilisearch.memcached.memgraph.mention.mercurial.mesos.messenger.meta-icon.meta.metabase.metamask-icon.metamask.meteor-icon.meteor-js.meteor.micro-icon.micro-python.micro.microcosm.micron-icon.micron.microsoft-azure.microsoft-edge.microsoft-icon.microsoft-onedrive.microsoft-power-bi.microsoft-sql-server.microsoft-teams.microsoft-windows-icon.microsoft-windows.microsoft.mida-icon.mida.middleman.midjourney.milligram.million-icon.million.milvus-icon.milvus.mindsdb-icon.mindsdb.minitab.mint-lang.mio.miro-icon.miro.mist.mistral-ai-icon.mistral-ai.mithril.mixmax.mixpanel.mlab.mob-x.mocha.mockflow-icon.mockflow.modernizr.modx-icon.modx.moleculer.momentjs.monday-icon.monday.monero.mongodb-icon.mongodb.mongoose-js.mono.moodle.moon.mootools.morpheus-icon.morpheus.mozilla.mparticle-icon.mparticle.mps-icon.mps.ms-dos.msw-icon.msw.multipass.mysql-icon.mysql.naiveui.namecheap.nano.nanonets.nasm.nativescript.nats-icon.nats.neat.neo4j.neon-icon.neon.neovim.nerog.nestjs.net-core.net.netbeans.netflix-icon.netflix.netlify-icon.netlify.network-x.neverinstall-icon.neverinstall.new-relic-icon.new-relic.new4j.nextjs-icon.nextjs.nginx.ngrok.nhibernate.nhost-icon.nhost.nightwatch.nim-lang.nim.nimble.nix.nocodb.nodal.node-sass.nodebots.nodejs-icon-alt.nodejs-icon.nodejs.nodemon.nodeos.nodewebkit.nomad-icon.nomad.notion-icon.notion.noysi.npm-icon.npm.nuclide.nuget.num-py.nuxt-icon.nuxt-js.nuxt.nvidia.nvm.nx.oauth.objective-c.observablehq.obsidian-icon.obsidian.ocaml.octodns.octopus-deploy.oh-my-zsh.okta-icon.okta.olark.onesignal.open-al.open-api.open-cl.open-cv.open-gl.open-graph.open-stack.open-suse.open-telemetry.open-zeppelin-icon.open-zeppelin.openai-icon.openai.openapi-icon.opencart.opencollective.openframeworks.openjs-foundation-icon.openjs-foundation.openlayers.opensearch-icon.opensearch.openshift.opensource.openstack-icon.opentelemetry-icon.opera.opsgenie.optimizely-icon.optimizely.oracle.oreilly.origami.origin.oshw.osquery.overloop-icon.overloop.p5js.packer.pagekit.pagekite.pagerduty-icon.pagerduty.panda.pandacss-icon.pandacss.pandas-icon.pandas.parcel-icon.parcel.parse.parsehub.partytown-icon.partytown.passbolt-icon.passbolt.passport.patreon.payload.paypal.peer5.pepperoni.percona.percy-icon.percy.perf-rocks.perl.perplexity-icon.perplexity.pf-sense.phalcon.phoenix-framework.phoenix.photon-engine.php-alt.php-storm.php.pinecone-icon.pinecone.pinia.pinterest.pipedream.pipedrive.pipefy.pivotal-tracker.pixijs.pkg.planetscale.planless-icon.planless.plasmic.plastic-scm.platformio.play.playwright.playwrite.ploty.pluralsight-icon.pluralsight.pm2-icon.pm2.pnpm.pocket-base.podman.poeditor.polygon.polymer.portainer.postcss.postgraphile.postgresql.posthog-icon.posthog.postman-icon.postman.pouchdb.powershell.preact.precursor.prerender-icon.prerender.prestashop-icon.prestashop.presto-icon.presto.prettier.prisma.prismic-icon.prismic.processing.processwire-icon.processwire.productboard-icon.productboard.producthunt.progress.prometheus.promises.proofy.protoio.protonet.protractor.prott.pug.pulumi-icon.pulumi.pumpkindb.puppet-icon.puppet.puppeteer.purescript-icon.purescript.pushbullet.pusher-icon.pusher.putty.pwa.pycharm.pypi.pyscript.pytest.python-poetry.python.pytorch-icon.pytorch.pyup.q.qdrant-icon.qdrant.qlik.qodana.qt.qualcomm.quarkus-icon.quarkus.quasar.quay.quobyte.quora.qwik-icon.qwik.r-lang.r.rabbitmq-icon.rabbitmq.rackspace-icon.rackspace.rails.ramda.raml.rancher-icon.rancher.raphael.raspberry-pi.rax.reach.react-bootstrap.react-query-icon.react-query.react-router.react-spring.react-styleguidist.react.reactivex.realm.reapp.reasonml-icon.reasonml.recaptcha.recoil-icon.recoil.red-cube-s-epic-compiler-thingy-programming-re-ct.reddit-icon.reddit.redhat-icon.redhat.redis.redsmin.redux-observable.redux-saga.redux.redwoodjs.reindex.relay.release.remix-icon.remix.ren-py.renovatebot.replay-icon.replay.replit-icon.replit.require.rescript-icon.rescript.rest-li.rethinkdb.retool-icon.retool.riak.rider.riot.risingwave-icon.risingwave.robot-operating-system-ros.rocket-chat-icon.rocket-chat.rocksdb.rocky-linux-icon.rocky-linux.rollbar-icon.rollbar.rollupjs.rome-icon.rome.ros.rsa.rsmq.rspec.rstudio.rubocop.ruby-mine.ruby-on-rails.ruby.rubygems.rum.runscope.rush-icon.rush.rust.rxdb.safari.sagui.sails.salesforce.sameroom.samsung.sanity.sap.sass-doc.sass.saucelabs.scala.scaledrone.scalingo.scribd-icon.scribd.sdl.seaborn-icon.seaborn.section-icon.section.segment-icon.segment.selenium.sema-software.semantic-release.semantic-ui.semaphoreci.sencha.sendgrid-icon.sendgrid.seneca.sensu-icon.sensu.sentry-icon.sentry.sequelize.serverless.sherlock-icon.sherlock.shields.shipit.shogun.shopify.shopware.shortcut-icon.shortcut.sidekiq-icon.sidekiq.signal.sigstore-icon.sigstore.sinatra.singlestore-icon.singlestore.sitepoint.sk-hynix.skaffolder.sketch.skylight.skype.slack-icon.slack.slides.slidev.slim.smartling.smashingmagazine.snap-svg.snaplet-icon.snaplet.snowflake-icon.snowflake.snowpack.snyk.socket-io.solarwinds.solid.solidity.solidjs-icon.solidjs.solr.sonarcloud-icon.sonarcloud.sonarlint-icon.sonarlint.sonarqube.soundcloud.sourcegraph.sourcetree.spark.sparkpost.speakerdeck.speedcurve.spidermonkey-icon.spidermonkey.spinnaker.splunk.spotify-icon.spotify.spree.spring-icon.spring.sql-developer.sqlalchemy.sqlite.square.squarespace.ssh.sst-icon.sst.stability-ai-icon.stability-ai.stackbit-icon.stackbit.stackblitz-icon.stackblitz.stackoverflow-icon.stackoverflow.stackshare.stata.stately-icon.stately.statuspage.stdlib-icon.stdlib.steam.stenciljs-icon.stenciljs.stetho.stickermule.stigg-icon.stigg.stimulus-icon.stimulus.stitch.stoplight.storyblocks-icon.storyblocks.storyblok-icon.storyblok.storybook-icon.storybook.strapi-icon.strapi.streamlit.strider.stripe.struts.styleci.stylefmt.stylelint.stylis.stylus.stytch.sublimetext-icon.sublimetext.subversion.sugarss.supabase-icon.supabase.supertokens-icon.supertokens.surge.surrealdb-icon.surrealdb.survicate-icon.survicate.suse.susy.svelte-icon.svelte-kit.svelte.svg.svgator.swagger.swc.swift.swiftype.swimm.swr.symfony.sysdig-icon.sysdig.t3.tableau-icon.tableau.taiga.tailwindcss-icon.tailwindcss.tapcart-icon.tapcart.taskade-icon.taskade.tastejs.tauri.tealium.teamcity.teamgrid.teamwork-icon.teamwork.telegram.tensorflow.terminal.terraform-icon.terraform.terser-icon.terser.testcafe.testing-library.testlodge.tex.the-algorithms.threejs.thymeleaf-icon.thymeleaf.tidal-icon.tidal.tiktok-icon.tiktok.titanium-sdk.tnw.todoist-icon.todoist.todomvc.tomcat.toml.tor-browser.tor.tortoise-git.tower.traackr.trac.traefik-mesh.traefik-proxy.travis-ci-monochrome.travis-ci.treasuredata-icon.treasuredata.treehouse-icon.treehouse.trello.trpc.truffle-icon.truffle.tsmc.tsnode.tsuru.tumblr-icon.tumblr.tunein.tuple.turbopack-icon.turbopack.turborepo-icon.turborepo.turret.twilio-icon.twilio.twitch.twitter.typeform-icon.typeform.typeorm.typescript-icon-round.typescript-icon.typescript.typesense-icon.typesense.typo3-icon.typo3.ubuntu.udacity-icon.udacity.udemy-icon.udemy.uikit.uml.umu.unbounce-icon.unbounce.undertow.unionpay.unitjs.unito-icon.unito.unity.unix.unjs.unocss.unrealengine-icon.unrealengine.upcase.upstash-icon.upstash.upwork.user-testing-icon.user-testing.uservoice-icon.uservoice.uwsgi.v8-ignition.v8-turbofan.v8.vaadin.vaddy.vagrant-icon.vagrant.vala.vault-icon.vault.vector.vercel-icon.vercel.verdaccio-icon.verdaccio.vernemq.veutify.vim.vimeo-icon.vimeo.visa.visaelectron.visual-studio-code.visual-studio.vite.vitejs.vitess.vitest.vivaldi-icon.vivaldi.vlang.vmware.void.volar.vorejs.vscode.vsphere.vue-storefront.vue.vuetifyjs.vueuse.vulkan.vultr-icon.vultr.vwo.vyper.w3c.waffle-icon.waffle.wagtail.wakatime.walkme.watchman.waypoint-icon.waypoint.wayscript-icon.wayscript.wearos.weave.web-dev-icon.web-dev.web3js.webassembly.webcomponents.webdriverio.webflow.webgpu.webhint-icon.webhint.webhooks.webix-icon.webix.webkit.weblate.webmin.webpack.webplatform.webrtc.websocket.webstorm.webtorrent.weebly.whalar-icon.whalar.whatsapp-icon.whatsapp-monochrome-icon.whatsapp.whatwg.wicket-icon.wicket.wifi.wildfly.windi-css.windows11.windows8.winglang-icon.winglang.wire.wix.wmr.woo-commerce.woocommerce-icon.woopra.wordpress-icon-alt.wordpress-icon.wordpress.workboard.workos-icon.workos.workplace-icon.workplace.wpengine.wufoo.x.xamarin.xampp.xata-icon.xata.xcart.xcode.xero.xml.xray-for-jira.xstate.xtend.xwiki-icon.xwiki.yahoo.yaml.yammer.yandex-ru.yarn.ycombinator.yeoman.yii-framework.yii.youtrack.youtube-icon.youtube.yugabyte-icon.yugabyte.yuno-host.zabbix.zapier.zend-framework.zendesk-icon.zendesk.zenhub-icon.zenhub.zeplin.zeroheight-icon.zeroheight.zig.zod.zoho.zoom-icon.zoom.zorin-os.zsh.zube.zulip-icon.zulip.zwave`.split(`.`),bootstrap:`0-circle-fill.0-circle.0-square-fill.0-square.1-circle-fill.1-circle.1-square-fill.1-square.123.2-circle-fill.2-circle.2-square-fill.2-square.3-circle-fill.3-circle.3-square-fill.3-square.4-circle-fill.4-circle.4-square-fill.4-square.5-circle-fill.5-circle.5-square-fill.5-square.6-circle-fill.6-circle.6-square-fill.6-square.7-circle-fill.7-circle.7-square-fill.7-square.8-circle-fill.8-circle.8-square-fill.8-square.9-circle-fill.9-circle.9-square-fill.9-square.activity.airplane-engines-fill.airplane-engines.airplane-fill.airplane.alarm-fill.alarm.alexa.align-bottom.align-center.align-end.align-middle.align-start.align-top.alipay.alphabet-uppercase.alphabet.alt.amazon.amd.android.android2.app-indicator.app.apple.archive-fill.archive.arrow-90deg-down.arrow-90deg-left.arrow-90deg-right.arrow-90deg-up.arrow-bar-down.arrow-bar-left.arrow-bar-right.arrow-bar-up.arrow-clockwise.arrow-counterclockwise.arrow-down-circle-fill.arrow-down-circle.arrow-down-left-circle-fill.arrow-down-left-circle.arrow-down-left-square-fill.arrow-down-left-square.arrow-down-left.arrow-down-right-circle-fill.arrow-down-right-circle.arrow-down-right-square-fill.arrow-down-right-square.arrow-down-right.arrow-down-short.arrow-down-square-fill.arrow-down-square.arrow-down-up.arrow-down.arrow-left-circle-fill.arrow-left-circle.arrow-left-right.arrow-left-short.arrow-left-square-fill.arrow-left-square.arrow-left.arrow-repeat.arrow-return-left.arrow-return-right.arrow-right-circle-fill.arrow-right-circle.arrow-right-short.arrow-right-square-fill.arrow-right-square.arrow-right.arrow-through-heart-fill.arrow-through-heart.arrow-up-circle-fill.arrow-up-circle.arrow-up-left-circle-fill.arrow-up-left-circle.arrow-up-left-square-fill.arrow-up-left-square.arrow-up-left.arrow-up-right-circle-fill.arrow-up-right-circle.arrow-up-right-square-fill.arrow-up-right-square.arrow-up-right.arrow-up-short.arrow-up-square-fill.arrow-up-square.arrow-up.arrows-angle-contract.arrows-angle-expand.arrows-collapse-vertical.arrows-collapse.arrows-expand-vertical.arrows-expand.arrows-fullscreen.arrows-move.arrows-vertical.arrows.aspect-ratio-fill.aspect-ratio.asterisk.at.award-fill.award.back.backpack-fill.backpack.backpack2-fill.backpack2.backpack3-fill.backpack3.backpack4-fill.backpack4.backspace-fill.backspace-reverse-fill.backspace-reverse.backspace.badge-3d-fill.badge-3d.badge-4k-fill.badge-4k.badge-8k-fill.badge-8k.badge-ad-fill.badge-ad.badge-ar-fill.badge-ar.badge-cc-fill.badge-cc.badge-hd-fill.badge-hd.badge-sd-fill.badge-sd.badge-tm-fill.badge-tm.badge-vo-fill.badge-vo.badge-vr-fill.badge-vr.badge-wc-fill.badge-wc.bag-check-fill.bag-check.bag-dash-fill.bag-dash.bag-fill.bag-heart-fill.bag-heart.bag-plus-fill.bag-plus.bag-x-fill.bag-x.bag.balloon-fill.balloon-heart-fill.balloon-heart.balloon.ban-fill.ban.bandaid-fill.bandaid.bank.bank2.bar-chart-fill.bar-chart-line-fill.bar-chart-line.bar-chart-steps.bar-chart.basket-fill.basket.basket2-fill.basket2.basket3-fill.basket3.battery-charging.battery-full.battery-half.battery.behance.bell-fill.bell-slash-fill.bell-slash.bell.bezier.bezier2.bicycle.bing.binoculars-fill.binoculars.blockquote-left.blockquote-right.bluetooth.body-text.book-fill.book-half.book.bookmark-check-fill.bookmark-check.bookmark-dash-fill.bookmark-dash.bookmark-fill.bookmark-heart-fill.bookmark-heart.bookmark-plus-fill.bookmark-plus.bookmark-star-fill.bookmark-star.bookmark-x-fill.bookmark-x.bookmark.bookmarks-fill.bookmarks.bookshelf.boombox-fill.boombox.bootstrap-fill.bootstrap-icons.bootstrap-reboot.bootstrap.border-all.border-bottom.border-center.border-inner.border-left.border-middle.border-outer.border-right.border-style.border-top.border-width.border.bounding-box-circles.bounding-box.box-arrow-down-left.box-arrow-down-right.box-arrow-down.box-arrow-in-down-left.box-arrow-in-down-right.box-arrow-in-down.box-arrow-in-left.box-arrow-in-right.box-arrow-in-up-left.box-arrow-in-up-right.box-arrow-in-up.box-arrow-left.box-arrow-right.box-arrow-up-left.box-arrow-up-right.box-arrow-up.box-fill.box-seam-fill.box-seam.box.box2-fill.box2-heart-fill.box2-heart.box2.boxes.braces-asterisk.braces.bricks.briefcase-fill.briefcase.brightness-alt-high-fill.brightness-alt-high.brightness-alt-low-fill.brightness-alt-low.brightness-high-fill.brightness-high.brightness-low-fill.brightness-low.brilliance.broadcast-pin.broadcast.browser-chrome.browser-edge.browser-firefox.browser-safari.brush-fill.brush.bucket-fill.bucket.bug-fill.bug.building-add.building-check.building-dash.building-down.building-exclamation.building-fill-add.building-fill-check.building-fill-dash.building-fill-down.building-fill-exclamation.building-fill-gear.building-fill-lock.building-fill-slash.building-fill-up.building-fill-x.building-fill.building-gear.building-lock.building-slash.building-up.building-x.building.buildings-fill.buildings.bullseye.bus-front-fill.bus-front.c-circle-fill.c-circle.c-square-fill.c-square.cake-fill.cake.cake2-fill.cake2.calculator-fill.calculator.calendar-check-fill.calendar-check.calendar-date-fill.calendar-date.calendar-day-fill.calendar-day.calendar-event-fill.calendar-event.calendar-fill.calendar-heart-fill.calendar-heart.calendar-minus-fill.calendar-minus.calendar-month-fill.calendar-month.calendar-plus-fill.calendar-plus.calendar-range-fill.calendar-range.calendar-week-fill.calendar-week.calendar-x-fill.calendar-x.calendar.calendar2-check-fill.calendar2-check.calendar2-date-fill.calendar2-date.calendar2-day-fill.calendar2-day.calendar2-event-fill.calendar2-event.calendar2-fill.calendar2-heart-fill.calendar2-heart.calendar2-minus-fill.calendar2-minus.calendar2-month-fill.calendar2-month.calendar2-plus-fill.calendar2-plus.calendar2-range-fill.calendar2-range.calendar2-week-fill.calendar2-week.calendar2-x-fill.calendar2-x.calendar2.calendar3-event-fill.calendar3-event.calendar3-fill.calendar3-range-fill.calendar3-range.calendar3-week-fill.calendar3-week.calendar3.calendar4-event.calendar4-range.calendar4-week.calendar4.camera-fill.camera-reels-fill.camera-reels.camera-video-fill.camera-video-off-fill.camera-video-off.camera-video.camera.camera2.capslock-fill.capslock.capsule-pill.capsule.car-front-fill.car-front.card-checklist.card-heading.card-image.card-list.card-text.caret-down-fill.caret-down-square-fill.caret-down-square.caret-down.caret-left-fill.caret-left-square-fill.caret-left-square.caret-left.caret-right-fill.caret-right-square-fill.caret-right-square.caret-right.caret-up-fill.caret-up-square-fill.caret-up-square.caret-up.cart-check-fill.cart-check.cart-dash-fill.cart-dash.cart-fill.cart-plus-fill.cart-plus.cart-x-fill.cart-x.cart.cart2.cart3.cart4.cash-coin.cash-stack.cash.cassette-fill.cassette.cast.cc-circle-fill.cc-circle.cc-square-fill.cc-square.chat-dots-fill.chat-dots.chat-fill.chat-heart-fill.chat-heart.chat-left-dots-fill.chat-left-dots.chat-left-fill.chat-left-heart-fill.chat-left-heart.chat-left-quote-fill.chat-left-quote.chat-left-text-fill.chat-left-text.chat-left.chat-quote-fill.chat-quote.chat-right-dots-fill.chat-right-dots.chat-right-fill.chat-right-heart-fill.chat-right-heart.chat-right-quote-fill.chat-right-quote.chat-right-text-fill.chat-right-text.chat-right.chat-square-dots-fill.chat-square-dots.chat-square-fill.chat-square-heart-fill.chat-square-heart.chat-square-quote-fill.chat-square-quote.chat-square-text-fill.chat-square-text.chat-square.chat-text-fill.chat-text.chat.check-all.check-circle-fill.check-circle.check-lg.check-square-fill.check-square.check.check2-all.check2-circle.check2-square.check2.chevron-bar-contract.chevron-bar-down.chevron-bar-expand.chevron-bar-left.chevron-bar-right.chevron-bar-up.chevron-compact-down.chevron-compact-left.chevron-compact-right.chevron-compact-up.chevron-contract.chevron-double-down.chevron-double-left.chevron-double-right.chevron-double-up.chevron-down.chevron-expand.chevron-left.chevron-right.chevron-up.circle-fill.circle-half.circle-square.circle.clipboard-check-fill.clipboard-check.clipboard-data-fill.clipboard-data.clipboard-fill.clipboard-heart-fill.clipboard-heart.clipboard-minus-fill.clipboard-minus.clipboard-plus-fill.clipboard-plus.clipboard-pulse.clipboard-x-fill.clipboard-x.clipboard.clipboard2-check-fill.clipboard2-check.clipboard2-data-fill.clipboard2-data.clipboard2-fill.clipboard2-heart-fill.clipboard2-heart.clipboard2-minus-fill.clipboard2-minus.clipboard2-plus-fill.clipboard2-plus.clipboard2-pulse-fill.clipboard2-pulse.clipboard2-x-fill.clipboard2-x.clipboard2.clock-fill.clock-history.clock.cloud-arrow-down-fill.cloud-arrow-down.cloud-arrow-up-fill.cloud-arrow-up.cloud-check-fill.cloud-check.cloud-download-fill.cloud-download.cloud-drizzle-fill.cloud-drizzle.cloud-fill.cloud-fog-fill.cloud-fog.cloud-fog2-fill.cloud-fog2.cloud-hail-fill.cloud-hail.cloud-haze-fill.cloud-haze.cloud-haze2-fill.cloud-haze2.cloud-lightning-fill.cloud-lightning-rain-fill.cloud-lightning-rain.cloud-lightning.cloud-minus-fill.cloud-minus.cloud-moon-fill.cloud-moon.cloud-plus-fill.cloud-plus.cloud-rain-fill.cloud-rain-heavy-fill.cloud-rain-heavy.cloud-rain.cloud-slash-fill.cloud-slash.cloud-sleet-fill.cloud-sleet.cloud-snow-fill.cloud-snow.cloud-sun-fill.cloud-sun.cloud-upload-fill.cloud-upload.cloud.clouds-fill.clouds.cloudy-fill.cloudy.code-slash.code-square.code.coin.collection-fill.collection-play-fill.collection-play.collection.columns-gap.columns.command.compass-fill.compass.cone-striped.cone.controller.cookie.copy.cpu-fill.cpu.credit-card-2-back-fill.credit-card-2-back.credit-card-2-front-fill.credit-card-2-front.credit-card-fill.credit-card.crop.crosshair.crosshair2.cup-fill.cup-hot-fill.cup-hot.cup-straw.cup.currency-bitcoin.currency-dollar.currency-euro.currency-exchange.currency-pound.currency-rupee.currency-yen.cursor-fill.cursor-text.cursor.dash-circle-dotted.dash-circle-fill.dash-circle.dash-lg.dash-square-dotted.dash-square-fill.dash-square.dash.database-add.database-check.database-dash.database-down.database-exclamation.database-fill-add.database-fill-check.database-fill-dash.database-fill-down.database-fill-exclamation.database-fill-gear.database-fill-lock.database-fill-slash.database-fill-up.database-fill-x.database-fill.database-gear.database-lock.database-slash.database-up.database-x.database.device-hdd-fill.device-hdd.device-ssd-fill.device-ssd.diagram-2-fill.diagram-2.diagram-3-fill.diagram-3.diamond-fill.diamond-half.diamond.dice-1-fill.dice-1.dice-2-fill.dice-2.dice-3-fill.dice-3.dice-4-fill.dice-4.dice-5-fill.dice-5.dice-6-fill.dice-6.disc-fill.disc.discord.display-fill.display.displayport-fill.displayport.distribute-horizontal.distribute-vertical.door-closed-fill.door-closed.door-open-fill.door-open.dot.download.dpad-fill.dpad.dribbble.dropbox.droplet-fill.droplet-half.droplet.duffle-fill.duffle.ear-fill.ear.earbuds.easel-fill.easel.easel2-fill.easel2.easel3-fill.easel3.egg-fill.egg-fried.egg.eject-fill.eject.emoji-angry-fill.emoji-angry.emoji-astonished-fill.emoji-astonished.emoji-dizzy-fill.emoji-dizzy.emoji-expressionless-fill.emoji-expressionless.emoji-frown-fill.emoji-frown.emoji-grimace-fill.emoji-grimace.emoji-grin-fill.emoji-grin.emoji-heart-eyes-fill.emoji-heart-eyes.emoji-kiss-fill.emoji-kiss.emoji-laughing-fill.emoji-laughing.emoji-neutral-fill.emoji-neutral.emoji-smile-fill.emoji-smile-upside-down-fill.emoji-smile-upside-down.emoji-smile.emoji-sunglasses-fill.emoji-sunglasses.emoji-surprise-fill.emoji-surprise.emoji-tear-fill.emoji-tear.emoji-wink-fill.emoji-wink.envelope-arrow-down-fill.envelope-arrow-down.envelope-arrow-up-fill.envelope-arrow-up.envelope-at-fill.envelope-at.envelope-check-fill.envelope-check.envelope-dash-fill.envelope-dash.envelope-exclamation-fill.envelope-exclamation.envelope-fill.envelope-heart-fill.envelope-heart.envelope-open-fill.envelope-open-heart-fill.envelope-open-heart.envelope-open.envelope-paper-fill.envelope-paper-heart-fill.envelope-paper-heart.envelope-paper.envelope-plus-fill.envelope-plus.envelope-slash-fill.envelope-slash.envelope-x-fill.envelope-x.envelope.eraser-fill.eraser.escape.ethernet.ev-front-fill.ev-front.ev-station-fill.ev-station.exclamation-circle-fill.exclamation-circle.exclamation-diamond-fill.exclamation-diamond.exclamation-lg.exclamation-octagon-fill.exclamation-octagon.exclamation-square-fill.exclamation-square.exclamation-triangle-fill.exclamation-triangle.exclamation.exclude.explicit-fill.explicit.exposure.eye-fill.eye-slash-fill.eye-slash.eye.eyedropper.eyeglasses.facebook.fan.fast-forward-btn-fill.fast-forward-btn.fast-forward-circle-fill.fast-forward-circle.fast-forward-fill.fast-forward.feather.feather2.file-arrow-down-fill.file-arrow-down.file-arrow-up-fill.file-arrow-up.file-bar-graph-fill.file-bar-graph.file-binary-fill.file-binary.file-break-fill.file-break.file-check-fill.file-check.file-code-fill.file-code.file-diff-fill.file-diff.file-earmark-arrow-down-fill.file-earmark-arrow-down.file-earmark-arrow-up-fill.file-earmark-arrow-up.file-earmark-bar-graph-fill.file-earmark-bar-graph.file-earmark-binary-fill.file-earmark-binary.file-earmark-break-fill.file-earmark-break.file-earmark-check-fill.file-earmark-check.file-earmark-code-fill.file-earmark-code.file-earmark-diff-fill.file-earmark-diff.file-earmark-easel-fill.file-earmark-easel.file-earmark-excel-fill.file-earmark-excel.file-earmark-fill.file-earmark-font-fill.file-earmark-font.file-earmark-image-fill.file-earmark-image.file-earmark-lock-fill.file-earmark-lock.file-earmark-lock2-fill.file-earmark-lock2.file-earmark-medical-fill.file-earmark-medical.file-earmark-minus-fill.file-earmark-minus.file-earmark-music-fill.file-earmark-music.file-earmark-pdf-fill.file-earmark-pdf.file-earmark-person-fill.file-earmark-person.file-earmark-play-fill.file-earmark-play.file-earmark-plus-fill.file-earmark-plus.file-earmark-post-fill.file-earmark-post.file-earmark-ppt-fill.file-earmark-ppt.file-earmark-richtext-fill.file-earmark-richtext.file-earmark-ruled-fill.file-earmark-ruled.file-earmark-slides-fill.file-earmark-slides.file-earmark-spreadsheet-fill.file-earmark-spreadsheet.file-earmark-text-fill.file-earmark-text.file-earmark-word-fill.file-earmark-word.file-earmark-x-fill.file-earmark-x.file-earmark-zip-fill.file-earmark-zip.file-earmark.file-easel-fill.file-easel.file-excel-fill.file-excel.file-fill.file-font-fill.file-font.file-image-fill.file-image.file-lock-fill.file-lock.file-lock2-fill.file-lock2.file-medical-fill.file-medical.file-minus-fill.file-minus.file-music-fill.file-music.file-pdf-fill.file-pdf.file-person-fill.file-person.file-play-fill.file-play.file-plus-fill.file-plus.file-post-fill.file-post.file-ppt-fill.file-ppt.file-richtext-fill.file-richtext.file-ruled-fill.file-ruled.file-slides-fill.file-slides.file-spreadsheet-fill.file-spreadsheet.file-text-fill.file-text.file-word-fill.file-word.file-x-fill.file-x.file-zip-fill.file-zip.file.files-alt.files.filetype-aac.filetype-ai.filetype-bmp.filetype-cs.filetype-css.filetype-csv.filetype-doc.filetype-docx.filetype-exe.filetype-gif.filetype-heic.filetype-html.filetype-java.filetype-jpg.filetype-js.filetype-json.filetype-jsx.filetype-key.filetype-m4p.filetype-md.filetype-mdx.filetype-mov.filetype-mp3.filetype-mp4.filetype-otf.filetype-pdf.filetype-php.filetype-png.filetype-ppt.filetype-pptx.filetype-psd.filetype-py.filetype-raw.filetype-rb.filetype-sass.filetype-scss.filetype-sh.filetype-sql.filetype-svg.filetype-tiff.filetype-tsx.filetype-ttf.filetype-txt.filetype-wav.filetype-woff.filetype-xls.filetype-xlsx.filetype-xml.filetype-yml.film.filter-circle-fill.filter-circle.filter-left.filter-right.filter-square-fill.filter-square.filter.fingerprint.fire.flag-fill.flag.floppy-fill.floppy.floppy2-fill.floppy2.flower1.flower2.flower3.folder-check.folder-fill.folder-minus.folder-plus.folder-symlink-fill.folder-symlink.folder-x.folder.folder2-open.folder2.fonts.forward-fill.forward.front.fuel-pump-diesel-fill.fuel-pump-diesel.fuel-pump-fill.fuel-pump.fullscreen-exit.fullscreen.funnel-fill.funnel.gear-fill.gear-wide-connected.gear-wide.gear.gem.gender-ambiguous.gender-female.gender-male.gender-neuter.gender-trans.geo-alt-fill.geo-alt.geo-fill.geo.gift-fill.gift.git.github.gitlab.globe-americas.globe-asia-australia.globe-central-south-asia.globe-europe-africa.globe.globe2.google-play.google.gpu-card.graph-down-arrow.graph-down.graph-up-arrow.graph-up.grid-1x2-fill.grid-1x2.grid-3x2-gap-fill.grid-3x2-gap.grid-3x2.grid-3x3-gap-fill.grid-3x3-gap.grid-3x3.grid-fill.grid.grip-horizontal.grip-vertical.h-circle-fill.h-circle.h-square-fill.h-square.hammer.hand-index-fill.hand-index-thumb-fill.hand-index-thumb.hand-index.hand-thumbs-down-fill.hand-thumbs-down.hand-thumbs-up-fill.hand-thumbs-up.handbag-fill.handbag.hash.hdd-fill.hdd-network-fill.hdd-network.hdd-rack-fill.hdd-rack.hdd-stack-fill.hdd-stack.hdd.hdmi-fill.hdmi.headphones.headset-vr.headset.heart-arrow.heart-fill.heart-half.heart-pulse-fill.heart-pulse.heart.heartbreak-fill.heartbreak.hearts.heptagon-fill.heptagon-half.heptagon.hexagon-fill.hexagon-half.hexagon.highlighter.highlights.hospital-fill.hospital.hourglass-bottom.hourglass-split.hourglass-top.hourglass.house-add-fill.house-add.house-check-fill.house-check.house-dash-fill.house-dash.house-door-fill.house-door.house-down-fill.house-down.house-exclamation-fill.house-exclamation.house-fill.house-gear-fill.house-gear.house-heart-fill.house-heart.house-lock-fill.house-lock.house-slash-fill.house-slash.house-up-fill.house-up.house-x-fill.house-x.house.houses-fill.houses.hr.hurricane.hypnotize.image-alt.image-fill.image.images.inbox-fill.inbox.inboxes-fill.inboxes.incognito.indent.infinity.info-circle-fill.info-circle.info-lg.info-square-fill.info-square.info.input-cursor-text.input-cursor.instagram.intersect.journal-album.journal-arrow-down.journal-arrow-up.journal-bookmark-fill.journal-bookmark.journal-check.journal-code.journal-medical.journal-minus.journal-plus.journal-richtext.journal-text.journal-x.journal.journals.joystick.justify-left.justify-right.justify.kanban-fill.kanban.key-fill.key.keyboard-fill.keyboard.ladder.lamp-fill.lamp.laptop-fill.laptop.layer-backward.layer-forward.layers-fill.layers-half.layers.layout-sidebar-inset-reverse.layout-sidebar-inset.layout-sidebar-reverse.layout-sidebar.layout-split.layout-text-sidebar-reverse.layout-text-sidebar.layout-text-window-reverse.layout-text-window.layout-three-columns.layout-wtf.life-preserver.lightbulb-fill.lightbulb-off-fill.lightbulb-off.lightbulb.lightning-charge-fill.lightning-charge.lightning-fill.lightning.line.link-45deg.link.linkedin.list-check.list-columns-reverse.list-columns.list-nested.list-ol.list-stars.list-task.list-ul.list.lock-fill.lock.luggage-fill.luggage.lungs-fill.lungs.magic.magnet-fill.magnet.mailbox-flag.mailbox.mailbox2-flag.mailbox2.map-fill.map.markdown-fill.markdown.marker-tip.mask.mastodon.medium.megaphone-fill.megaphone.memory.menu-app-fill.menu-app.menu-button-fill.menu-button-wide-fill.menu-button-wide.menu-button.menu-down.menu-up.messenger.meta.mic-fill.mic-mute-fill.mic-mute.mic.microsoft-teams.microsoft.minecart-loaded.minecart.modem-fill.modem.moisture.moon-fill.moon-stars-fill.moon-stars.moon.mortarboard-fill.mortarboard.motherboard-fill.motherboard.mouse-fill.mouse.mouse2-fill.mouse2.mouse3-fill.mouse3.music-note-beamed.music-note-list.music-note.music-player-fill.music-player.newspaper.nintendo-switch.node-minus-fill.node-minus.node-plus-fill.node-plus.noise-reduction.nut-fill.nut.nvidia.nvme-fill.nvme.octagon-fill.octagon-half.octagon.opencollective.optical-audio-fill.optical-audio.option.outlet.p-circle-fill.p-circle.p-square-fill.p-square.paint-bucket.palette-fill.palette.palette2.paperclip.paragraph.pass-fill.pass.passport-fill.passport.patch-check-fill.patch-check.patch-exclamation-fill.patch-exclamation.patch-minus-fill.patch-minus.patch-plus-fill.patch-plus.patch-question-fill.patch-question.pause-btn-fill.pause-btn.pause-circle-fill.pause-circle.pause-fill.pause.paypal.pc-display-horizontal.pc-display.pc-horizontal.pc.pci-card-network.pci-card-sound.pci-card.peace-fill.peace.pen-fill.pen.pencil-fill.pencil-square.pencil.pentagon-fill.pentagon-half.pentagon.people-fill.people.percent.person-add.person-arms-up.person-badge-fill.person-badge.person-bounding-box.person-check-fill.person-check.person-circle.person-dash-fill.person-dash.person-down.person-exclamation.person-fill-add.person-fill-check.person-fill-dash.person-fill-down.person-fill-exclamation.person-fill-gear.person-fill-lock.person-fill-slash.person-fill-up.person-fill-x.person-fill.person-gear.person-heart.person-hearts.person-lines-fill.person-lock.person-plus-fill.person-plus.person-raised-hand.person-rolodex.person-slash.person-square.person-standing-dress.person-standing.person-up.person-vcard-fill.person-vcard.person-video.person-video2.person-video3.person-walking.person-wheelchair.person-workspace.person-x-fill.person-x.person.phone-fill.phone-flip.phone-landscape-fill.phone-landscape.phone-vibrate-fill.phone-vibrate.phone.pie-chart-fill.pie-chart.piggy-bank-fill.piggy-bank.pin-angle-fill.pin-angle.pin-fill.pin-map-fill.pin-map.pin.pinterest.pip-fill.pip.play-btn-fill.play-btn.play-circle-fill.play-circle.play-fill.play.playstation.plug-fill.plug.plugin.plus-circle-dotted.plus-circle-fill.plus-circle.plus-lg.plus-slash-minus.plus-square-dotted.plus-square-fill.plus-square.plus.postage-fill.postage-heart-fill.postage-heart.postage.postcard-fill.postcard-heart-fill.postcard-heart.postcard.power.prescription.prescription2.printer-fill.printer.projector-fill.projector.puzzle-fill.puzzle.qr-code-scan.qr-code.question-circle-fill.question-circle.question-diamond-fill.question-diamond.question-lg.question-octagon-fill.question-octagon.question-square-fill.question-square.question.quora.quote.r-circle-fill.r-circle.r-square-fill.r-square.radar.radioactive.rainbow.receipt-cutoff.receipt.reception-0.reception-1.reception-2.reception-3.reception-4.record-btn-fill.record-btn.record-circle-fill.record-circle.record-fill.record.record2-fill.record2.recycle.reddit.regex.repeat-1.repeat.reply-all-fill.reply-all.reply-fill.reply.rewind-btn-fill.rewind-btn.rewind-circle-fill.rewind-circle.rewind-fill.rewind.robot.rocket-fill.rocket-takeoff-fill.rocket-takeoff.rocket.router-fill.router.rss-fill.rss.rulers.safe-fill.safe.safe2-fill.safe2.save-fill.save.save2-fill.save2.scissors.scooter.screwdriver.sd-card-fill.sd-card.search-heart-fill.search-heart.search.segmented-nav.send-arrow-down-fill.send-arrow-down.send-arrow-up-fill.send-arrow-up.send-check-fill.send-check.send-dash-fill.send-dash.send-exclamation-fill.send-exclamation.send-fill.send-plus-fill.send-plus.send-slash-fill.send-slash.send-x-fill.send-x.send.server.shadows.share-fill.share.shield-check.shield-exclamation.shield-fill-check.shield-fill-exclamation.shield-fill-minus.shield-fill-plus.shield-fill-x.shield-fill.shield-lock-fill.shield-lock.shield-minus.shield-plus.shield-shaded.shield-slash-fill.shield-slash.shield-x.shield.shift-fill.shift.shop-window.shop.shuffle.sign-dead-end-fill.sign-dead-end.sign-do-not-enter-fill.sign-do-not-enter.sign-intersection-fill.sign-intersection-side-fill.sign-intersection-side.sign-intersection-t-fill.sign-intersection-t.sign-intersection-y-fill.sign-intersection-y.sign-intersection.sign-merge-left-fill.sign-merge-left.sign-merge-right-fill.sign-merge-right.sign-no-left-turn-fill.sign-no-left-turn.sign-no-parking-fill.sign-no-parking.sign-no-right-turn-fill.sign-no-right-turn.sign-railroad-fill.sign-railroad.sign-stop-fill.sign-stop-lights-fill.sign-stop-lights.sign-stop.sign-turn-left-fill.sign-turn-left.sign-turn-right-fill.sign-turn-right.sign-turn-slight-left-fill.sign-turn-slight-left.sign-turn-slight-right-fill.sign-turn-slight-right.sign-yield-fill.sign-yield.signal.signpost-2-fill.signpost-2.signpost-fill.signpost-split-fill.signpost-split.signpost.sim-fill.sim-slash-fill.sim-slash.sim.sina-weibo.skip-backward-btn-fill.skip-backward-btn.skip-backward-circle-fill.skip-backward-circle.skip-backward-fill.skip-backward.skip-end-btn-fill.skip-end-btn.skip-end-circle-fill.skip-end-circle.skip-end-fill.skip-end.skip-forward-btn-fill.skip-forward-btn.skip-forward-circle-fill.skip-forward-circle.skip-forward-fill.skip-forward.skip-start-btn-fill.skip-start-btn.skip-start-circle-fill.skip-start-circle.skip-start-fill.skip-start.skype.slack.slash-circle-fill.slash-circle.slash-lg.slash-square-fill.slash-square.slash.sliders.sliders2-vertical.sliders2.smartwatch.snapchat.snow.snow2.snow3.sort-alpha-down-alt.sort-alpha-down.sort-alpha-up-alt.sort-alpha-up.sort-down-alt.sort-down.sort-numeric-down-alt.sort-numeric-down.sort-numeric-up-alt.sort-numeric-up.sort-up-alt.sort-up.soundwave.sourceforge.speaker-fill.speaker.speedometer.speedometer2.spellcheck.spotify.square-fill.square-half.square.stack-overflow.stack.star-fill.star-half.star.stars.steam.stickies-fill.stickies.sticky-fill.sticky.stop-btn-fill.stop-btn.stop-circle-fill.stop-circle.stop-fill.stop.stoplights-fill.stoplights.stopwatch-fill.stopwatch.strava.stripe.subscript.substack.subtract.suit-club-fill.suit-club.suit-diamond-fill.suit-diamond.suit-heart-fill.suit-heart.suit-spade-fill.suit-spade.suitcase-fill.suitcase-lg-fill.suitcase-lg.suitcase.suitcase2-fill.suitcase2.sun-fill.sun.sunglasses.sunrise-fill.sunrise.sunset-fill.sunset.superscript.symmetry-horizontal.symmetry-vertical.table.tablet-fill.tablet-landscape-fill.tablet-landscape.tablet.tag-fill.tag.tags-fill.tags.taxi-front-fill.taxi-front.telegram.telephone-fill.telephone-forward-fill.telephone-forward.telephone-inbound-fill.telephone-inbound.telephone-minus-fill.telephone-minus.telephone-outbound-fill.telephone-outbound.telephone-plus-fill.telephone-plus.telephone-x-fill.telephone-x.telephone.tencent-qq.terminal-dash.terminal-fill.terminal-plus.terminal-split.terminal-x.terminal.text-center.text-indent-left.text-indent-right.text-left.text-paragraph.text-right.text-wrap.textarea-resize.textarea-t.textarea.thermometer-half.thermometer-high.thermometer-low.thermometer-snow.thermometer-sun.thermometer.threads-fill.threads.three-dots-vertical.three-dots.thunderbolt-fill.thunderbolt.ticket-detailed-fill.ticket-detailed.ticket-fill.ticket-perforated-fill.ticket-perforated.ticket.tiktok.toggle-off.toggle-on.toggle2-off.toggle2-on.toggles.toggles2.tools.tornado.train-freight-front-fill.train-freight-front.train-front-fill.train-front.train-lightrail-front-fill.train-lightrail-front.translate.transparency.trash-fill.trash.trash2-fill.trash2.trash3-fill.trash3.tree-fill.tree.trello.triangle-fill.triangle-half.triangle.trophy-fill.trophy.tropical-storm.truck-flatbed.truck-front-fill.truck-front.truck.tsunami.tv-fill.tv.twitch.twitter-x.twitter.type-bold.type-h1.type-h2.type-h3.type-h4.type-h5.type-h6.type-italic.type-strikethrough.type-underline.type.ubuntu.ui-checks-grid.ui-checks.ui-radios-grid.ui-radios.umbrella-fill.umbrella.unindent.union.unity.universal-access-circle.universal-access.unlock-fill.unlock.upc-scan.upc.upload.usb-c-fill.usb-c.usb-drive-fill.usb-drive.usb-fill.usb-micro-fill.usb-micro.usb-mini-fill.usb-mini.usb-plug-fill.usb-plug.usb-symbol.usb.valentine.valentine2.vector-pen.view-list.view-stacked.vignette.vimeo.vinyl-fill.vinyl.virus.virus2.voicemail.volume-down-fill.volume-down.volume-mute-fill.volume-mute.volume-off-fill.volume-off.volume-up-fill.volume-up.vr.wallet-fill.wallet.wallet2.watch.water.webcam-fill.webcam.wechat.whatsapp.wifi-1.wifi-2.wifi-off.wifi.wikipedia.wind.window-dash.window-desktop.window-dock.window-fullscreen.window-plus.window-sidebar.window-split.window-stack.window-x.window.windows.wordpress.wrench-adjustable-circle-fill.wrench-adjustable-circle.wrench-adjustable.wrench.x-circle-fill.x-circle.x-diamond-fill.x-diamond.x-lg.x-octagon-fill.x-octagon.x-square-fill.x-square.x.xbox.yelp.yin-yang.youtube.zoom-in.zoom-out`.split(`.`)},ra=Object.keys(na),ia=na,aa=[`likec4lib {`,` icons {`,...[...Object.entries(na)].flatMap(([e,t])=>t.map(t=>e+`:`+t)).map(e=>` `+e),` }`,`}`].join(`
|
|
41
|
-
`),oa=`likec4builtin`,sa=`${oa}:///likec4/lib/icons.c4`;function isLikeC4Builtin(e){return(`uri`in e?e.uri:e).scheme===oa}function isNotLikeC4Builtin(e){return!isLikeC4Builtin(e)}var ADisposable=class{toDispose=[];isDisposed=!1;onDispose(...e){this.toDispose.push(...e)}dispose(){this.throwIfDisposed(),this.isDisposed=!0;let e;for(;e=this.toDispose.pop();)try{e.dispose()}catch(e){logWarnError(e)}}throwIfDisposed(){if(this.isDisposed)throw Error(`This has already been disposed`)}};const ca=`AnyProperty`;function isAnyProperty(e){return q.isInstance(e,ca)}const la=`ColorLiteral`;function isColorLiteral(e){return q.isInstance(e,la)}const ua=`DeploymentElement`;function isDeploymentElement(e){return q.isInstance(e,ua)}const da=`DeploymentNodeOrElementKind`,fa=`DeploymentViewRule`;function isDeploymentViewRule(e){return q.isInstance(e,fa)}const pa=`DynamicViewProperty`,ma=`DynamicViewRule`;function isDynamicViewRule(e){return q.isInstance(e,ma)}const ha=`DynamicViewStep`;function isDynamicViewStep(e){return q.isInstance(e,ha)}const ga=`ElementProperty`;function isElementProperty(e){return q.isInstance(e,ga)}const _a=`ExpressionV2`;function isExpressionV2(e){return q.isInstance(e,_a)}const va=`FqnExpr`;function isFqnExpr(e){return q.isInstance(e,va)}const ya=`FqnExprOrWhere`;function isFqnExprOrWhere(e){return q.isInstance(e,ya)}const ba=`FqnExprOrWith`;function isFqnExprOrWith(e){return q.isInstance(e,ba)}const xa=`FqnReferenceable`,Sa=`LikeC4View`;function isLikeC4View(e){return q.isInstance(e,Sa)}const Ca=`MetadataProperty`;function isMetadataProperty(e){return q.isInstance(e,Ca)}const wa=`MetadataValue`,Ta=`Referenceable`,Ea=`RelationExpr`;function isRelationExpr(e){return q.isInstance(e,Ea)}const Da=`RelationExprOrWhere`;function isRelationExprOrWhere(e){return q.isInstance(e,Da)}const Oa=`RelationExprOrWith`;function isRelationExprOrWith(e){return q.isInstance(e,Oa)}const ka=`RelationProperty`,Aa=`RelationshipStyleProperty`;function isRelationshipStyleProperty(e){return q.isInstance(e,Aa)}const ja=`SizeProperty`;function isSizeProperty(e){return q.isInstance(e,ja)}const Ma=`StringProperty`;function isStringProperty(e){return q.isInstance(e,Ma)}const Na=`StyleProperty`;function isStyleProperty(e){return q.isInstance(e,Na)}const Pa=`ViewProperty`;function isViewProperty(e){return q.isInstance(e,Pa)}const Fa=`ViewRule`;function isViewRule(e){return q.isInstance(e,Fa)}const Ia=`ViewRuleStyleOrGlobalRef`;function isViewRuleStyleOrGlobalRef(e){return q.isInstance(e,Ia)}const La=`WhereElement`;function isWhereElement(e){return q.isInstance(e,La)}const Ra=`WhereElementExpression`;function isWhereElementExpression(e){return q.isInstance(e,Ra)}const za=`WhereExpression`,Ba=`WhereKindEqual`;function isWhereKindEqual(e){return q.isInstance(e,Ba)}const Va=`WhereMetadataEqual`;function isWhereMetadataEqual(e){return q.isInstance(e,Va)}const Ha=`WhereRelation`;function isWhereRelation(e){return q.isInstance(e,Ha)}const Ua=`WhereRelationExpression`;function isWhereRelationExpression(e){return q.isInstance(e,Ua)}const Wa=`WhereTagEqual`;function isWhereTagEqual(e){return q.isInstance(e,Wa)}const Ga=`AbstractDynamicStep`,Ka=`ArrowProperty`;function isArrowProperty(e){return q.isInstance(e,Ka)}const qa=`BorderProperty`;function isBorderProperty(e){return q.isInstance(e,qa)}const Ja=`ColorProperty`;function isColorProperty(e){return q.isInstance(e,Ja)}const Ya=`CustomColor`,Xa=`CustomElementProperties`;function isCustomElementProperties(e){return q.isInstance(e,Xa)}const Za=`CustomRelationProperties`;function isCustomRelationProperties(e){return q.isInstance(e,Za)}const Qa=`DeployedInstance`;function isDeployedInstance(e){return q.isInstance(e,Qa)}const $a=`DeployedInstanceBody`;function isDeployedInstanceBody(e){return q.isInstance(e,$a)}const eo=`DeploymentNode`;function isDeploymentNode$1(e){return q.isInstance(e,eo)}t(isDeploymentNode$1,`isDeploymentNode`);const to=`DeploymentNodeBody`;function isDeploymentNodeBody(e){return q.isInstance(e,to)}const no=`DeploymentNodeKind`;function isDeploymentNodeKind(e){return q.isInstance(e,no)}const ro=`DeploymentRelation`;function isDeploymentRelation(e){return q.isInstance(e,ro)}const io=`DeploymentRelationBody`;function isDeploymentRelationBody(e){return q.isInstance(e,io)}const ao=`DeploymentView`;function isDeploymentView$1(e){return q.isInstance(e,ao)}t(isDeploymentView$1,`isDeploymentView`);const oo=`DeploymentViewBody`;function isDeploymentViewBody(e){return q.isInstance(e,oo)}const so=`DeploymentViewRulePredicate`;function isDeploymentViewRulePredicate(e){return q.isInstance(e,so)}const co=`DeploymentViewRuleStyle`;function isDeploymentViewRuleStyle(e){return q.isInstance(e,co)}const lo=`DirectedRelationExpr`;function isDirectedRelationExpr(e){return q.isInstance(e,lo)}const uo=`DynamicView`;function isDynamicView$1(e){return q.isInstance(e,uo)}t(isDynamicView$1,`isDynamicView`);const fo=`DynamicViewBody`;function isDynamicViewBody(e){return q.isInstance(e,fo)}const po=`DynamicViewDisplayVariantProperty`;function isDynamicViewDisplayVariantProperty(e){return q.isInstance(e,po)}const mo=`DynamicViewGlobalPredicateRef`;function isDynamicViewGlobalPredicateRef(e){return q.isInstance(e,mo)}const ho=`DynamicViewIncludePredicate`;function isDynamicViewIncludePredicate(e){return q.isInstance(e,ho)}const go=`DynamicViewParallelSteps`;function isDynamicViewParallelSteps(e){return q.isInstance(e,go)}const _o=`DynamicViewRef`,vo=`Element`;function isElement(e){return q.isInstance(e,vo)}const yo=`ElementBody`;function isElementBody(e){return q.isInstance(e,yo)}const bo=`ElementKind`;function isElementKind(e){return q.isInstance(e,bo)}const xo=`ElementKindExpression`;function isElementKindExpression(e){return q.isInstance(e,xo)}const So=`ElementRef`;function isElementRef(e){return q.isInstance(e,So)}const Co=`ElementStringProperty`;function isElementStringProperty(e){return q.isInstance(e,Co)}const wo=`ElementStyleProperty`;function isElementStyleProperty(e){return q.isInstance(e,wo)}const To=`ElementTagExpression`;function isElementTagExpression(e){return q.isInstance(e,To)}const Eo=`ElementView`;function isElementView$1(e){return q.isInstance(e,Eo)}t(isElementView$1,`isElementView`);const Do=`ElementViewBody`;function isElementViewBody(e){return q.isInstance(e,Do)}const Oo=`ElementViewRef`,ko=`Expressions`;function isExpressions(e){return q.isInstance(e,ko)}const Ao=`ExtendDeployment`;function isExtendDeployment(e){return q.isInstance(e,Ao)}const jo=`ExtendDeploymentBody`;function isExtendDeploymentBody(e){return q.isInstance(e,jo)}const Mo=`ExtendElement`;function isExtendElement(e){return q.isInstance(e,Mo)}const No=`ExtendElementBody`;function isExtendElementBody(e){return q.isInstance(e,No)}const Po=`ExtendRelation`;function isExtendRelation(e){return q.isInstance(e,Po)}const Fo=`ExtendRelationBody`;function isExtendRelationBody(e){return q.isInstance(e,Fo)}const Io=`FqnExpressions`;function isFqnExpressions(e){return q.isInstance(e,Io)}const Lo=`FqnExprWhere`;function isFqnExprWhere(e){return q.isInstance(e,Lo)}const Ro=`FqnExprWith`;function isFqnExprWith(e){return q.isInstance(e,Ro)}const zo=`FqnRef`;function isFqnRef(e){return q.isInstance(e,zo)}const Bo=`FqnRefExpr`;function isFqnRefExpr(e){return q.isInstance(e,Bo)}const Vo=`GlobalDynamicPredicateGroup`;function isGlobalDynamicPredicateGroup(e){return q.isInstance(e,Vo)}const Ho=`GlobalPredicateGroup`;function isGlobalPredicateGroup(e){return q.isInstance(e,Ho)}const Uo=`Globals`;function isGlobals(e){return q.isInstance(e,Uo)}const Wo=`GlobalStyle`;function isGlobalStyle(e){return q.isInstance(e,Wo)}const Go=`GlobalStyleGroup`;function isGlobalStyleGroup(e){return q.isInstance(e,Go)}const Ko=`GlobalStyleId`,qo=`HexColor`;function isHexColor(e){return q.isInstance(e,qo)}const Jo=`IconColorProperty`;function isIconColorProperty(e){return q.isInstance(e,Jo)}const Yo=`IconPositionProperty`;function isIconPositionProperty(e){return q.isInstance(e,Yo)}const Xo=`IconProperty`;function isIconProperty(e){return q.isInstance(e,Xo)}const Zo=`IconSizeProperty`;function isIconSizeProperty(e){return q.isInstance(e,Zo)}const Qo=`Imported`;function isImported(e){return q.isInstance(e,Qo)}const $o=`ImportsFromPoject`;function isImportsFromPoject(e){return q.isInstance(e,$o)}const es=`IncomingRelationExpr`;function isIncomingRelationExpr(e){return q.isInstance(e,es)}const ts=`InOutRelationExpr`;function isInOutRelationExpr(e){return q.isInstance(e,ts)}const ns=`LibIcon`;function isLibIcon(e){return q.isInstance(e,ns)}const rs=`LikeC4Grammar`;function isLikeC4Grammar(e){return q.isInstance(e,rs)}const is=`LikeC4Lib`;function isLikeC4Lib(e){return q.isInstance(e,is)}const as=`LineProperty`;function isLineProperty(e){return q.isInstance(e,as)}const os=`LinkProperty`;function isLinkProperty(e){return q.isInstance(e,os)}const ss=`MarkdownOrString`;function isMarkdownOrString(e){return q.isInstance(e,ss)}const cs=`MetadataArray`;function isMetadataArray(e){return q.isInstance(e,cs)}const ls=`MetadataAttribute`;function isMetadataAttribute(e){return q.isInstance(e,ls)}const us=`MetadataBody`;function isMetadataBody(e){return q.isInstance(e,us)}const ds=`Model`;function isModel(e){return q.isInstance(e,ds)}const fs=`ModelDeployments`;function isModelDeployments(e){return q.isInstance(e,fs)}const ps=`ModelViews`;function isModelViews(e){return q.isInstance(e,ps)}const ms=`MultipleProperty`;function isMultipleProperty(e){return q.isInstance(e,ms)}const hs=`NavigateToProperty`;function isNavigateToProperty(e){return q.isInstance(e,hs)}const gs=`NotationProperty`;function isNotationProperty(e){return q.isInstance(e,gs)}const _s=`NotesProperty`;function isNotesProperty(e){return q.isInstance(e,_s)}const vs=`OpacityProperty`;function isOpacityProperty(e){return q.isInstance(e,vs)}const ys=`OutgoingRelationExpr`;function isOutgoingRelationExpr(e){return q.isInstance(e,ys)}const bs=`PaddingSizeProperty`;function isPaddingSizeProperty(e){return q.isInstance(e,bs)}const xs=`Relation`;function isRelation(e){return q.isInstance(e,xs)}const Ss=`RelationBody`;function isRelationBody(e){return q.isInstance(e,Ss)}const Cs=`RelationExprWhere`;function isRelationExprWhere(e){return q.isInstance(e,Cs)}const ws=`RelationExprWith`;function isRelationExprWith(e){return q.isInstance(e,ws)}const Ts=`RelationKindDotRef`;function isRelationKindDotRef(e){return q.isInstance(e,Ts)}const Es=`RelationNavigateToProperty`;function isRelationNavigateToProperty(e){return q.isInstance(e,Es)}const Ds=`RelationshipKind`;function isRelationshipKind(e){return q.isInstance(e,Ds)}const Os=`RelationStringProperty`;function isRelationStringProperty(e){return q.isInstance(e,Os)}const ks=`RelationStyleProperty`;function isRelationStyleProperty(e){return q.isInstance(e,ks)}const As=`RGBAColor`;function isRGBAColor(e){return q.isInstance(e,As)}const js=`ShapeProperty`;function isShapeProperty(e){return q.isInstance(e,js)}const Ms=`ShapeSizeProperty`;function isShapeSizeProperty(e){return q.isInstance(e,Ms)}const Ns=`SpecificationColor`;function isSpecificationColor(e){return q.isInstance(e,Ns)}const Ps=`SpecificationDeploymentNodeKind`;function isSpecificationDeploymentNodeKind(e){return q.isInstance(e,Ps)}const Fs=`SpecificationElementKind`;function isSpecificationElementKind(e){return q.isInstance(e,Fs)}const Is=`SpecificationElementStringProperty`;function isSpecificationElementStringProperty(e){return q.isInstance(e,Is)}const Ls=`SpecificationRelationshipKind`;function isSpecificationRelationshipKind(e){return q.isInstance(e,Ls)}const Rs=`SpecificationRelationshipStringProperty`;function isSpecificationRelationshipStringProperty(e){return q.isInstance(e,Rs)}const zs=`SpecificationRule`;function isSpecificationRule(e){return q.isInstance(e,zs)}const Bs=`SpecificationTag`;function isSpecificationTag(e){return q.isInstance(e,Bs)}const Vs=`StrictFqnElementRef`;function isStrictFqnElementRef(e){return q.isInstance(e,Vs)}const Hs=`StrictFqnRef`;function isStrictFqnRef(e){return q.isInstance(e,Hs)}function isTag(e){return q.isInstance(e,`Tag`)}const Us=`TagRef`;function isTagRef(e){return q.isInstance(e,Us)}const Ws=`Tags`;function isTags(e){return q.isInstance(e,Ws)}const Gs=`TextSizeProperty`;function isTextSizeProperty(e){return q.isInstance(e,Gs)}const Ks=`ViewRef`,qs=`ViewRuleAncestors`;function isViewRuleAncestors(e){return q.isInstance(e,qs)}const Js=`ViewRuleAutoLayout`;function isViewRuleAutoLayout(e){return q.isInstance(e,Js)}const Ys=`ViewRuleGlobalPredicateRef`;function isViewRuleGlobalPredicateRef(e){return q.isInstance(e,Ys)}const Xs=`ViewRuleGlobalStyle`;function isViewRuleGlobalStyle(e){return q.isInstance(e,Xs)}const Zs=`ViewRuleGroup`;function isViewRuleGroup(e){return q.isInstance(e,Zs)}const Qs=`ViewRulePredicate`;function isViewRulePredicate(e){return q.isInstance(e,Qs)}const $s=`ViewRuleRank`;function isViewRuleRank(e){return q.isInstance(e,$s)}const ec=`ViewRuleStyle`;function isViewRuleStyle(e){return q.isInstance(e,ec)}const tc=`ViewStringProperty`;function isViewStringProperty(e){return q.isInstance(e,tc)}const nc=`WhereBinaryExpression`;function isWhereBinaryExpression(e){return q.isInstance(e,nc)}const rc=`WhereElementKind`;function isWhereElementKind(e){return q.isInstance(e,rc)}const ic=`WhereElementMetadata`;function isWhereElementMetadata(e){return q.isInstance(e,ic)}const ac=`WhereElementNegation`;function isWhereElementNegation(e){return q.isInstance(e,ac)}const oc=`WhereElementTag`;function isWhereElementTag(e){return q.isInstance(e,oc)}const sc=`WhereRelationKind`;function isWhereRelationKind(e){return q.isInstance(e,sc)}const cc=`WhereRelationMetadata`;function isWhereRelationMetadata(e){return q.isInstance(e,cc)}const lc=`WhereRelationNegation`;function isWhereRelationNegation(e){return q.isInstance(e,lc)}const uc=`WhereRelationParticipantKind`;function isWhereRelationParticipantKind(e){return q.isInstance(e,uc)}const dc=`WhereRelationParticipantMetadata`;function isWhereRelationParticipantMetadata(e){return q.isInstance(e,dc)}const fc=`WhereRelationParticipantTag`;function isWhereRelationParticipantTag(e){return q.isInstance(e,fc)}const pc=`WhereRelationTag`;function isWhereRelationTag(e){return q.isInstance(e,pc)}const mc=`WildcardExpression`;function isWildcardExpression(e){return q.isInstance(e,mc)}const hc=`DynamicStepChain`;function isDynamicStepChain(e){return q.isInstance(e,hc)}const gc=`DynamicStepSingle`;function isDynamicStepSingle(e){return q.isInstance(e,gc)}var LikeC4AstReflection=class extends Se{getAllTypes(){return[Ga,ca,Ka,qa,la,Ja,Ya,Xa,Za,Qa,$a,ua,eo,to,no,da,ro,io,ao,oo,fa,so,co,lo,hc,gc,uo,fo,po,mo,ho,go,pa,_o,ma,ha,vo,yo,bo,xo,ga,So,Co,wo,To,Eo,Do,Oo,_a,ko,Ao,jo,Mo,No,`ExtendElementProperty`,Po,Fo,`ExtendRelationProperty`,va,ya,ba,Lo,Ro,Io,zo,Bo,xa,Vo,Ho,Wo,Go,Ko,Uo,qo,Jo,Yo,Xo,Zo,Qo,$o,ts,es,ns,rs,is,Sa,as,os,ss,cs,ls,us,Ca,wa,ds,fs,`ModelReferenceable`,ps,ms,hs,gs,_s,vs,ys,bs,As,Ta,xs,Ss,Ea,Da,Oa,Cs,ws,Ts,Es,ka,Os,ks,Ds,Aa,js,Ms,ja,Ns,Ps,Fs,Is,Ls,Rs,zs,Bs,Vs,Hs,Ma,Na,`Tag`,Us,Ws,Gs,Pa,Ks,Fa,qs,Js,Ys,Xs,Zs,Qs,$s,ec,Ia,tc,nc,La,Ra,rc,ic,ac,oc,za,Ba,Va,Ha,Ua,sc,cc,lc,uc,dc,fc,pc,Wa,mc]}computeIsSubtype(e,t){switch(e){case Ka:case as:return this.isSubtype(Aa,t);case qa:case Jo:case Yo:case ms:case vs:case js:return this.isSubtype(Na,t);case Ja:return this.isSubtype(`RelationshipStyleProperty`,t)||this.isSubtype(`StyleProperty`,t);case Qa:case eo:return this.isSubtype(`DeploymentElement`,t)||this.isSubtype(`Referenceable`,t);case no:case bo:return this.isSubtype(da,t);case ao:case uo:case Eo:return this.isSubtype(Sa,t);case so:case co:case qs:return this.isSubtype(fa,t);case lo:case es:case ts:case ys:return this.isSubtype(Ea,t);case hc:case gc:return this.isSubtype(`AbstractDynamicStep`,t)||this.isSubtype(`DynamicViewStep`,t);case po:return this.isSubtype(pa,t);case mo:case ho:return this.isSubtype(ma,t);case pa:case ga:case hs:case ka:case Aa:case Ma:case Na:return this.isSubtype(ca,t);case vo:return this.isSubtype(`FqnReferenceable`,t)||this.isSubtype(`ModelReferenceable`,t)||this.isSubtype(`Referenceable`,t);case xo:case To:case Bo:case mc:return this.isSubtype(va,t);case Co:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`StringProperty`,t);case wo:return this.isSubtype(ga,t);case Ao:case Mo:case Ta:return this.isSubtype(xa,t);case va:case Lo:return this.isSubtype(ya,t);case ya:case Ro:return this.isSubtype(ba,t);case ba:case Oa:return this.isSubtype(_a,t);case qo:case As:return this.isSubtype(la,t);case Xo:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`StyleProperty`,t);case Zo:case bs:case Ms:case Gs:return this.isSubtype(`SizeProperty`,t)||this.isSubtype(`StyleProperty`,t);case Qo:return this.isSubtype(`ModelReferenceable`,t)||this.isSubtype(`Referenceable`,t);case os:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`ExtendElementProperty`,t)||this.isSubtype(`ExtendRelationProperty`,t)||this.isSubtype(`RelationProperty`,t)||this.isSubtype(`ViewProperty`,t);case ss:case cs:return this.isSubtype(wa,t);case ls:case Is:case Rs:return this.isSubtype(Ma,t);case us:return this.isSubtype(Ca,t);case Ca:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`ExtendElementProperty`,t)||this.isSubtype(`ExtendRelationProperty`,t)||this.isSubtype(`RelationProperty`,t);case gs:case _s:return this.isSubtype(`AnyProperty`,t)||this.isSubtype(`StringProperty`,t);case Ea:case Cs:return this.isSubtype(Da,t);case Da:case ws:return this.isSubtype(Oa,t);case Es:case ks:return this.isSubtype(ka,t);case Os:return this.isSubtype(`RelationProperty`,t)||this.isSubtype(`StringProperty`,t);case Pa:return this.isSubtype(`AnyProperty`,t)||this.isSubtype(`DynamicViewProperty`,t);case Js:return this.isSubtype(`DeploymentViewRule`,t)||this.isSubtype(`DynamicViewRule`,t)||this.isSubtype(`ViewRule`,t);case Ys:case Zs:case Qs:case $s:return this.isSubtype(Fa,t);case Xs:case ec:return this.isSubtype(Ia,t);case Ia:return this.isSubtype(`DynamicViewRule`,t)||this.isSubtype(`ViewRule`,t);case tc:return this.isSubtype(`StringProperty`,t)||this.isSubtype(`ViewProperty`,t);case nc:return this.isSubtype(`WhereElementExpression`,t)||this.isSubtype(`WhereRelationExpression`,t);case La:case ac:return this.isSubtype(Ra,t);case Ra:case Ua:return this.isSubtype(za,t);case rc:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereKindEqual`,t);case ic:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereMetadataEqual`,t);case oc:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereTagEqual`,t);case Ha:case lc:return this.isSubtype(Ua,t);case sc:case uc:return this.isSubtype(`WhereKindEqual`,t)||this.isSubtype(`WhereRelation`,t);case cc:case dc:return this.isSubtype(`WhereMetadataEqual`,t)||this.isSubtype(`WhereRelation`,t);case fc:case pc:return this.isSubtype(`WhereRelation`,t)||this.isSubtype(`WhereTagEqual`,t);default:return!1}}getReferenceType(e){let t=`${e.container.$type}:${e.property}`;switch(t){case`AbstractDynamicStep:kind`:case`DeploymentRelation:kind`:case`DynamicStepChain:kind`:case`DynamicStepSingle:kind`:case`ExtendRelation:kind`:case`OutgoingRelationExpr:kind`:case`Relation:kind`:case`RelationKindDotRef:kind`:case`WhereRelationKind:value`:return Ds;case`ColorProperty:customColor`:case`IconColorProperty:customColor`:return Ya;case`DeploymentNode:kind`:return no;case`DynamicViewGlobalPredicateRef:predicate`:return Vo;case`DynamicViewRef:view`:return uo;case`Element:kind`:case`ElementKindExpression:kind`:return bo;case`ElementViewRef:view`:return Eo;case`FqnRef:value`:case`StrictFqnRef:value`:return Ta;case`IconProperty:libicon`:return ns;case`Imported:imported`:case`StrictFqnElementRef:el`:return vo;case`TagRef:tag`:return`Tag`;case`ViewRef:view`:return Sa;case`ViewRuleGlobalPredicateRef:predicate`:return Ho;case`ViewRuleGlobalStyle:style`:return Ko;case`WhereElementKind:value`:case`WhereRelationParticipantKind:value`:return da;default:throw Error(`${t} is not a valid reference id.`)}}getTypeMetaData(e){switch(e){case Ga:return{name:Ga,properties:[{name:`custom`},{name:`dotKind`},{name:`kind`},{name:`target`},{name:`title`}]};case Ka:return{name:Ka,properties:[{name:`key`},{name:`value`}]};case qa:return{name:qa,properties:[{name:`key`},{name:`value`}]};case Ja:return{name:Ja,properties:[{name:`customColor`},{name:`key`},{name:`themeColor`}]};case Ya:return{name:Ya,properties:[{name:`name`}]};case Xa:return{name:Xa,properties:[{name:`props`,defaultValue:[]}]};case Za:return{name:Za,properties:[{name:`props`,defaultValue:[]}]};case Qa:return{name:Qa,properties:[{name:`body`},{name:`name`},{name:`summary`},{name:`target`},{name:`title`}]};case $a:return{name:$a,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case eo:return{name:eo,properties:[{name:`body`},{name:`kind`},{name:`name`},{name:`summary`},{name:`title`}]};case to:return{name:to,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case no:return{name:no,properties:[{name:`name`}]};case ro:return{name:ro,properties:[{name:`body`},{name:`description`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`tags`},{name:`target`},{name:`technology`},{name:`title`}]};case io:return{name:io,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case ao:return{name:ao,properties:[{name:`body`},{name:`name`}]};case oo:return{name:oo,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`tags`}]};case so:return{name:so,properties:[{name:`expr`},{name:`isInclude`,defaultValue:!1}]};case co:return{name:co,properties:[{name:`props`,defaultValue:[]},{name:`targets`}]};case lo:return{name:lo,properties:[{name:`source`},{name:`target`}]};case uo:return{name:uo,properties:[{name:`body`},{name:`name`}]};case fo:return{name:fo,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`steps`,defaultValue:[]},{name:`tags`}]};case po:return{name:po,properties:[{name:`key`},{name:`value`}]};case mo:return{name:mo,properties:[{name:`predicate`}]};case ho:return{name:ho,properties:[{name:`exprs`}]};case go:return{name:go,properties:[{name:`steps`,defaultValue:[]}]};case _o:return{name:_o,properties:[{name:`view`}]};case vo:return{name:vo,properties:[{name:`body`},{name:`kind`},{name:`name`},{name:`props`,defaultValue:[]}]};case yo:return{name:yo,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case bo:return{name:bo,properties:[{name:`name`}]};case xo:return{name:xo,properties:[{name:`isEqual`,defaultValue:!1},{name:`kind`}]};case So:return{name:So,properties:[{name:`modelElement`}]};case Co:return{name:Co,properties:[{name:`key`},{name:`value`}]};case wo:return{name:wo,properties:[{name:`key`},{name:`props`,defaultValue:[]}]};case To:return{name:To,properties:[{name:`isEqual`,defaultValue:!1},{name:`tag`}]};case Eo:return{name:Eo,properties:[{name:`body`},{name:`extends`},{name:`name`},{name:`viewOf`}]};case Do:return{name:Do,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`tags`}]};case Oo:return{name:Oo,properties:[{name:`view`}]};case ko:return{name:ko,properties:[{name:`prev`},{name:`value`}]};case Ao:return{name:Ao,properties:[{name:`body`},{name:`deploymentNode`}]};case jo:return{name:jo,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case Mo:return{name:Mo,properties:[{name:`body`},{name:`element`}]};case No:return{name:No,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case Po:return{name:Po,properties:[{name:`body`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};case Fo:return{name:Fo,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case Io:return{name:Io,properties:[{name:`prev`},{name:`value`}]};case Lo:return{name:Lo,properties:[{name:`subject`},{name:`where`}]};case Ro:return{name:Ro,properties:[{name:`custom`},{name:`subject`}]};case zo:return{name:zo,properties:[{name:`parent`},{name:`value`}]};case Bo:return{name:Bo,properties:[{name:`ref`},{name:`selector`}]};case Vo:return{name:Vo,properties:[{name:`name`},{name:`predicates`,defaultValue:[]}]};case Ho:return{name:Ho,properties:[{name:`name`},{name:`predicates`,defaultValue:[]}]};case Uo:return{name:Uo,properties:[{name:`name`},{name:`predicates`,defaultValue:[]},{name:`styles`,defaultValue:[]}]};case Wo:return{name:Wo,properties:[{name:`id`},{name:`props`,defaultValue:[]},{name:`targets`}]};case Go:return{name:Go,properties:[{name:`id`},{name:`styles`,defaultValue:[]}]};case Ko:return{name:Ko,properties:[{name:`name`}]};case qo:return{name:qo,properties:[{name:`hex`}]};case Jo:return{name:Jo,properties:[{name:`customColor`},{name:`key`},{name:`themeColor`}]};case Yo:return{name:Yo,properties:[{name:`key`},{name:`value`}]};case Xo:return{name:Xo,properties:[{name:`key`},{name:`libicon`},{name:`value`}]};case Zo:return{name:Zo,properties:[{name:`key`},{name:`value`}]};case Qo:return{name:Qo,properties:[{name:`imported`},{name:`prev`}]};case $o:return{name:$o,properties:[{name:`imports`},{name:`project`}]};case es:return{name:es,properties:[{name:`to`}]};case ts:return{name:ts,properties:[{name:`inout`}]};case ns:return{name:ns,properties:[{name:`name`}]};case rs:return{name:rs,properties:[{name:`deployments`,defaultValue:[]},{name:`globals`,defaultValue:[]},{name:`imports`,defaultValue:[]},{name:`likec4lib`,defaultValue:[]},{name:`models`,defaultValue:[]},{name:`specifications`,defaultValue:[]},{name:`views`,defaultValue:[]}]};case is:return{name:is,properties:[{name:`icons`,defaultValue:[]}]};case as:return{name:as,properties:[{name:`key`},{name:`value`}]};case os:return{name:os,properties:[{name:`key`},{name:`title`},{name:`value`}]};case ss:return{name:ss,properties:[{name:`markdown`},{name:`text`}]};case cs:return{name:cs,properties:[{name:`values`,defaultValue:[]}]};case ls:return{name:ls,properties:[{name:`boolValue`,defaultValue:!1},{name:`key`},{name:`value`}]};case us:return{name:us,properties:[{name:`props`,defaultValue:[]}]};case ds:return{name:ds,properties:[{name:`elements`,defaultValue:[]},{name:`name`}]};case fs:return{name:fs,properties:[{name:`elements`,defaultValue:[]},{name:`name`}]};case ps:return{name:ps,properties:[{name:`folder`},{name:`name`},{name:`styles`,defaultValue:[]},{name:`views`,defaultValue:[]}]};case ms:return{name:ms,properties:[{name:`key`},{name:`value`,defaultValue:!1}]};case hs:return{name:hs,properties:[{name:`key`},{name:`value`}]};case gs:return{name:gs,properties:[{name:`key`},{name:`value`}]};case _s:return{name:_s,properties:[{name:`key`},{name:`value`}]};case vs:return{name:vs,properties:[{name:`key`},{name:`value`}]};case ys:return{name:ys,properties:[{name:`dotKind`},{name:`from`},{name:`isBidirectional`,defaultValue:!1},{name:`kind`}]};case bs:return{name:bs,properties:[{name:`key`},{name:`value`}]};case xs:return{name:xs,properties:[{name:`body`},{name:`description`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`tags`},{name:`target`},{name:`technology`},{name:`title`}]};case Ss:return{name:Ss,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case Cs:return{name:Cs,properties:[{name:`subject`},{name:`where`}]};case ws:return{name:ws,properties:[{name:`custom`},{name:`subject`}]};case Ts:return{name:Ts,properties:[{name:`kind`}]};case Es:return{name:Es,properties:[{name:`key`},{name:`value`}]};case Ds:return{name:Ds,properties:[{name:`name`}]};case Os:return{name:Os,properties:[{name:`key`},{name:`value`}]};case ks:return{name:ks,properties:[{name:`key`},{name:`props`,defaultValue:[]}]};case As:return{name:As,properties:[{name:`alpha`},{name:`blue`},{name:`green`},{name:`red`}]};case js:return{name:js,properties:[{name:`key`},{name:`value`}]};case Ms:return{name:Ms,properties:[{name:`key`},{name:`value`}]};case Ns:return{name:Ns,properties:[{name:`color`},{name:`name`}]};case Ps:return{name:Ps,properties:[{name:`kind`},{name:`props`,defaultValue:[]},{name:`tags`}]};case Fs:return{name:Fs,properties:[{name:`kind`},{name:`props`,defaultValue:[]},{name:`tags`}]};case Is:return{name:Is,properties:[{name:`key`},{name:`value`}]};case Ls:return{name:Ls,properties:[{name:`kind`},{name:`props`,defaultValue:[]}]};case Rs:return{name:Rs,properties:[{name:`key`},{name:`value`}]};case zs:return{name:zs,properties:[{name:`colors`,defaultValue:[]},{name:`deploymentNodes`,defaultValue:[]},{name:`elements`,defaultValue:[]},{name:`name`},{name:`relationships`,defaultValue:[]},{name:`tags`,defaultValue:[]}]};case Bs:return{name:Bs,properties:[{name:`color`},{name:`tag`}]};case Vs:return{name:Vs,properties:[{name:`el`},{name:`parent`}]};case Hs:return{name:Hs,properties:[{name:`parent`},{name:`value`}]};case`Tag`:return{name:`Tag`,properties:[{name:`name`}]};case Us:return{name:Us,properties:[{name:`tag`}]};case Ws:return{name:Ws,properties:[{name:`prev`},{name:`values`,defaultValue:[]}]};case Gs:return{name:Gs,properties:[{name:`key`},{name:`value`}]};case Ks:return{name:Ks,properties:[{name:`view`}]};case qs:return{name:qs,properties:[{name:`key`},{name:`value`,defaultValue:!1}]};case Js:return{name:Js,properties:[{name:`direction`},{name:`nodeSep`},{name:`rankSep`}]};case Ys:return{name:Ys,properties:[{name:`predicate`}]};case Xs:return{name:Xs,properties:[{name:`style`}]};case Zs:return{name:Zs,properties:[{name:`groupRules`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`title`}]};case Qs:return{name:Qs,properties:[{name:`exprs`},{name:`isInclude`,defaultValue:!1}]};case $s:return{name:$s,properties:[{name:`targets`},{name:`value`}]};case ec:return{name:ec,properties:[{name:`props`,defaultValue:[]},{name:`targets`}]};case tc:return{name:tc,properties:[{name:`key`},{name:`value`}]};case nc:return{name:nc,properties:[{name:`left`},{name:`operator`},{name:`right`}]};case rc:return{name:rc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case ic:return{name:ic,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case ac:return{name:ac,properties:[{name:`value`}]};case oc:return{name:oc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case sc:return{name:sc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case cc:return{name:cc,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case lc:return{name:lc,properties:[{name:`value`}]};case uc:return{name:uc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case dc:return{name:dc,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case fc:return{name:fc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case pc:return{name:pc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case mc:return{name:mc,properties:[{name:`isWildcard`,defaultValue:!1}]};case hc:return{name:hc,properties:[{name:`custom`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};case gc:return{name:gc,properties:[{name:`custom`},{name:`dotKind`},{name:`isBackward`,defaultValue:!1},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};default:return{name:e,properties:[]}}}};const q=new LikeC4AstReflection;let _c;const LikeC4Grammar=()=>_c??=it(`{"$type":"Grammar","isDeclared":true,"name":"LikeC4","rules":[{"$type":"ParserRule","entry":true,"name":"LikeC4Grammar","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"imports","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@16"},"arguments":[]}},{"$type":"Assignment","feature":"specifications","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@8"},"arguments":[]}},{"$type":"Assignment","feature":"models","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@19"},"arguments":[]}},{"$type":"Assignment","feature":"views","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@44"},"arguments":[]}},{"$type":"Assignment","feature":"globals","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@124"},"arguments":[]}},{"$type":"Assignment","feature":"deployments","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@109"},"arguments":[]}},{"$type":"Assignment","feature":"likec4lib","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@1"},"arguments":[]}}],"cardinality":"*"},"definesHiddenTokens":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LikeC4Lib","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"likec4lib"},{"$type":"Keyword","value":"{"},{"$type":"Keyword","value":"icons"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"icons","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@2"},"arguments":[]},"cardinality":"+"},{"$type":"Keyword","value":"}"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LibIcon","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@162"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Tag","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationshipKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomColor","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNodeKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRule","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"specification"}},{"$type":"Keyword","value":"{"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@9"},"arguments":[]}},{"$type":"Assignment","feature":"tags","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@12"},"arguments":[]}},{"$type":"Assignment","feature":"relationships","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@14"},"arguments":[]}},{"$type":"Assignment","feature":"colors","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@13"},"arguments":[]}},{"$type":"Assignment","feature":"deploymentNodes","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@11"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationElementKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"element"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@3"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@10"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationElementStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"notation"},{"$type":"Keyword","value":"summary"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationDeploymentNodeKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"deploymentNode"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@7"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@10"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationTag","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"tag"},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@4"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Group","elements":[{"$type":"Keyword","value":"color"},{"$type":"Assignment","feature":"color","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@159"},"arguments":[]}}],"cardinality":"?"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationColor","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"color"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@6"},"arguments":[]}},{"$type":"Assignment","feature":"color","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@159"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRelationshipKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"relationship"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@5"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@15"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRelationshipStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"notation"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ImportsFromPoject","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"import"},{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"imports","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@17"},"arguments":[]}},{"$type":"Keyword","value":"}"}]},{"$type":"Assignment","feature":"imports","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@17"},"arguments":[]}}]},{"$type":"Keyword","value":"from"},{"$type":"Assignment","feature":"project","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Imported","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"imported","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Imported"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"imported","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Tags","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]},"cardinality":"+"},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Tags"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]},"cardinality":"*"}],"cardinality":"*"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Model","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"model"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@24"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@27"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Element","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}}]}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@21"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@23"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@134"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"summary"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElement","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"element","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@31"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@25"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElementBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@26"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElementProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@28"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@29"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelationProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementRef","definition":{"$type":"Assignment","feature":"modelElement","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StrictFqnElementRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"el","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"StrictFqnElementRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"el","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StrictFqnRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"StrictFqnRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Relation","parameters":[{"$type":"Parameter","name":"isExplicit"}],"definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","guardCondition":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@34/parameters@0"}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}}]},{"$type":"Group","guardCondition":{"$type":"Negation","value":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@34/parameters@0"}}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]},"cardinality":"?"}]}]},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"description","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"technology","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@35"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"wildcard":false},{"$type":"ParserRule","name":"RelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@36"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@37"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@81"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@38"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"description"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationStyleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"style"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataProperty","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@40"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@41"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataAttribute","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@42"},"arguments":[]}},{"$type":"Assignment","feature":"boolValue","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataValue","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@43"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataArray","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"["},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"]"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ModelViews","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"views"}},{"$type":"Assignment","feature":"folder","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"views","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@45"},"arguments":[]}},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LikeC4ViewRule","returnType":{"$ref":"#/types@2"},"definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@46"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@47"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@118"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"extends"},{"$type":"Assignment","feature":"extends","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@49"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Keyword","value":"of"},{"$type":"Assignment","feature":"viewOf","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}}]}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@51"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"dynamic"},{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@52"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@2"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@46"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@47"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@58"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@53"},"arguments":[]},"cardinality":"*"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"steps","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@63"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@65"},"arguments":[]}]}},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@62"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@54"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewDisplayVariantProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"variant"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@155"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@56"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewLayoutDirection","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"TopBottom"},{"$type":"Keyword","value":"LeftRight"},{"$type":"Keyword","value":"BottomTop"},{"$type":"Keyword","value":"RightLeft"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@69"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@61"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@59"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleRank","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"rank"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@60"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RankValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"same"},{"$type":"Keyword","value":"min"},{"$type":"Keyword","value":"max"},{"$type":"Keyword","value":"source"},{"$type":"Keyword","value":"sink"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"group"},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@141"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@132"},"arguments":[]}]},"cardinality":"*"},{"$type":"Assignment","feature":"groupRules","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@61"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@70"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@71"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewParallelSteps","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"parallel"},{"$type":"Keyword","value":"par"}]},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"steps","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@65"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"DynamicViewStepTarget","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@79"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewStep","returnType":{"$ref":"#/types@5"},"definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@66"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicStepChain","returnType":{"$ref":"#/interfaces@1"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@67"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","type":{"$ref":"#/interfaces@2"},"feature":"source","operator":"="},{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@64"},"arguments":[]}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicStepSingle","returnType":{"$ref":"#/interfaces@1"},"definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isBackward","operator":"?=","terminal":{"$type":"Keyword","value":"<-"}},{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@64"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRulePredicate","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isInclude","operator":"?=","terminal":{"$type":"Keyword","value":"include"}},{"$type":"Keyword","value":"exclude"}]},{"$type":"Assignment","feature":"exprs","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGlobalPredicateRef","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"predicate"},{"$type":"Assignment","feature":"predicate","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@125"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewIncludePredicate","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"include"},{"$type":"Assignment","feature":"exprs","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewGlobalPredicateRef","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"predicate"},{"$type":"Assignment","feature":"predicate","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@126"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGlobalStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"style","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@127"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleStyleOrGlobalRef","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@72"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@73"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleAutoLayout","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"autoLayout"},{"$type":"Assignment","feature":"direction","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@57"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"rankSep","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Assignment","feature":"nodeSep","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NotationProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"notation"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NotesProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"notes"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomElementProperties","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@80"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@23"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@77"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomRelationProperties","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@81"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@37"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@77"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NavigateToProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"navigateTo"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@48"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationNavigateToProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"navigateTo"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@50"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Expressions","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@83"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Expressions"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@83"},"arguments":[]},"cardinality":"?"}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExpressionV2","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@86"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@84"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExprOrWith","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@85"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExprWith"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"with"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@78"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExprOrWhere","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExprWhere"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"where"},{"$type":"Assignment","feature":"where","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExprOrWith","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@87"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"RelationExprWith"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"with"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@79"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExprOrWhere","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@90"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"RelationExprWhere"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"where"},{"$type":"Assignment","feature":"where","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExpr","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WildcardExpression"}},{"$type":"Assignment","feature":"isWildcard","operator":"?=","terminal":{"$type":"Keyword","value":"*"}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"ElementTagExpression"}},{"$type":"Keyword","value":"element.tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@168"},"arguments":[]},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"ElementKindExpression"}},{"$type":"Keyword","value":"element.kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@168"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@89"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnRefExpr","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"ref","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Assignment","feature":"selector","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@178"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@179"},"arguments":[]}]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExpr","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@91"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@93"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"InOutRelationExpr","inferredType":{"$type":"InferredType","name":"RelationExpr"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@92"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"InOutRelationExpr"},"feature":"inout","operator":"="},{"$type":"Keyword","value":"->"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IncomingRelationExpr","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"->"},{"$type":"Assignment","feature":"to","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DirectedRelationExpr","inferredType":{"$type":"InferredType","name":"RelationExpr"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@94"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"DirectedRelationExpr"},"feature":"source","operator":"="},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"OutgoingRelationExpr","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"from","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isBidirectional","operator":"?=","terminal":{"$type":"Keyword","value":"<->"}},{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExpressions","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExpressions"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]},"cardinality":"?"}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementExpression","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@97"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementOr","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@98"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"or"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@98"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementAnd","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@99"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"and"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@99"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementPrimary","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"("},{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]},{"$type":"Keyword","value":")"}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@100"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@101"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementNegation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"not"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElement","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementTag"}},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementKind"}},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@6"},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementMetadata"}},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataFilterValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationExpression","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@104"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationOr","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@105"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"or"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@105"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationAnd","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@106"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"and"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@106"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationPrimary","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"("},{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]},{"$type":"Keyword","value":")"}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@107"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@108"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationNegation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"not"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelation","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationTag"}},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationKind"}},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationMetadata"}},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantTag"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantKind"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantMetadata"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ModelDeployments","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"deployment"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@114"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNode","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@7"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@7"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"summary","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@111"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNodeBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@112"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeployedInstance","definition":{"$type":"Group","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]}],"cardinality":"?"},{"$type":"Keyword","value":"instanceOf"},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"summary","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@113"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeployedInstanceBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendDeployment","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"deploymentNode","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@33"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@115"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendDeploymentBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@26"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@112"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentRelation","parameters":[{"$type":"Parameter","name":"isExplicit"}],"definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","guardCondition":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@116/parameters@0"}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}}]},{"$type":"Group","guardCondition":{"$type":"Negation","value":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@116/parameters@0"}}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]},"cardinality":"?"}]}]},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"description","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"technology","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@117"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentRelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@36"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"deployment"},{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@119"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@120"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@123"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@122"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@121"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleAncestors","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"includeAncestors"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRuleStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRulePredicate","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isInclude","operator":"?=","terminal":{"$type":"Keyword","value":"include"}},{"$type":"Keyword","value":"exclude"}]},{"$type":"Assignment","feature":"expr","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Globals","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"global"}},{"$type":"Keyword","value":"{"},{"$type":"Group","elements":[{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@125"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@126"},"arguments":[]}]},"cardinality":"*"},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@128"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@129"},"arguments":[]}]},"cardinality":"*"}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalPredicateGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"predicateGroup"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalDynamicPredicateGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"dynamicPredicateGroup"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@70"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyleId","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"id","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@127"},"arguments":[]}},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyleGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"styleGroup"},{"$type":"Assignment","feature":"id","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@127"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@72"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LinkProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"link"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@163"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ColorProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"color"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"themeColor","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]}},{"$type":"Assignment","feature":"customColor","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"OpacityProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"opacity"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@185"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MultipleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"multiple"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"icon"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"libicon","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@2"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@162"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"none"},{"$type":"RuleCall","rule":{"$ref":"#/rules@163"},"arguments":[]}]}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconColorProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconColor"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"themeColor","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]}},{"$type":"Assignment","feature":"customColor","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconSize"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconPositionValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"left"},{"$type":"Keyword","value":"right"},{"$type":"Keyword","value":"top"},{"$type":"Keyword","value":"bottom"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconPositionProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconPosition"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@137"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ShapeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"shape"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"BorderStyleValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"Keyword","value":"none"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"BorderProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"border"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@140"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SizeValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"xs"},{"$type":"Keyword","value":"sm"},{"$type":"Keyword","value":"md"},{"$type":"Keyword","value":"lg"},{"$type":"Keyword","value":"xl"},{"$type":"Keyword","value":"xsmall"},{"$type":"Keyword","value":"small"},{"$type":"Keyword","value":"medium"},{"$type":"Keyword","value":"large"},{"$type":"Keyword","value":"xlarge"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ShapeSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"size"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"PaddingSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"padding"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"TextSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"textSize"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StyleProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@139"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@141"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@132"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@134"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@135"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@143"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@144"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@145"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@136"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@138"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementStyleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"style"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LineProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"line"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ArrowProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"head"},{"$type":"Keyword","value":"tail"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationshipStyleProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@148"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@149"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"TagRef","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@180"},"arguments":[]},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@4"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationKindDotRef","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@182"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LineOptions","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"solid"},{"$type":"Keyword","value":"dashed"},{"$type":"Keyword","value":"dotted"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ArrowType","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"none"},{"$type":"Keyword","value":"normal"},{"$type":"Keyword","value":"onormal"},{"$type":"Keyword","value":"dot"},{"$type":"Keyword","value":"odot"},{"$type":"Keyword","value":"diamond"},{"$type":"Keyword","value":"odiamond"},{"$type":"Keyword","value":"crow"},{"$type":"Keyword","value":"open"},{"$type":"Keyword","value":"vee"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewDisplayVariantValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"diagram"},{"$type":"Keyword","value":"sequence"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ThemeColor","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"primary"},{"$type":"Keyword","value":"secondary"},{"$type":"Keyword","value":"muted"},{"$type":"Keyword","value":"slate"},{"$type":"Keyword","value":"blue"},{"$type":"Keyword","value":"indigo"},{"$type":"Keyword","value":"sky"},{"$type":"Keyword","value":"red"},{"$type":"Keyword","value":"gray"},{"$type":"Keyword","value":"green"},{"$type":"Keyword","value":"amber"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementShape","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"rectangle"},{"$type":"Keyword","value":"component"},{"$type":"Keyword","value":"person"},{"$type":"Keyword","value":"browser"},{"$type":"Keyword","value":"mobile"},{"$type":"Keyword","value":"cylinder"},{"$type":"Keyword","value":"storage"},{"$type":"Keyword","value":"queue"},{"$type":"Keyword","value":"bucket"},{"$type":"Keyword","value":"document"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Participant","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"source"},{"$type":"Keyword","value":"target"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ColorLiteral","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@160"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@161"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RGBAColor","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"rgba"},{"$type":"Keyword","value":"rgb"}]},{"$type":"Keyword","value":"("},{"$type":"Assignment","feature":"red","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"green","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"blue","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"alpha","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@188"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@185"},"arguments":[]}]},"cardinality":"?"},{"$type":"Keyword","value":")"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"HexColor","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@180"},"arguments":[]},{"$type":"Assignment","feature":"hex","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@191"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconId","dataType":"string","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@174"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Uri","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@175"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@176"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@177"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MarkdownOrString","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"markdown","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@186"},"arguments":[]}},{"$type":"Assignment","feature":"text","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomColorId","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]},{"$type":"Keyword","value":"element"},{"$type":"Keyword","value":"model"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Id","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@155"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@137"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@60"},"arguments":[]},{"$type":"Keyword","value":"element"},{"$type":"Keyword","value":"model"},{"$type":"Keyword","value":"group"},{"$type":"Keyword","value":"node"},{"$type":"Keyword","value":"deployment"},{"$type":"Keyword","value":"instance"},{"$type":"Keyword","value":"relationship"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"EqOperator","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@183"},"arguments":[]}]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"is"}},{"$type":"Assignment","feature":"not","operator":"?=","terminal":{"$type":"Keyword","value":"not"},"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"IsEqual","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isEqual","operator":"?=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@183"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"TerminalRule","hidden":true,"name":"BLOCK_COMMENT","definition":{"$type":"RegexToken","regex":"/\\\\/\\\\*[\\\\s\\\\S]*?\\\\*\\\\//"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"LINE_COMMENT","definition":{"$type":"RegexToken","regex":"/\\\\/\\\\/[^\\\\n\\\\r]*/"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"WS","definition":{"$type":"RegexToken","regex":"/[\\\\t ]+/"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"NL","definition":{"$type":"RegexToken","regex":"/[\\\\r\\\\n]+/"},"fragment":false},{"$type":"TerminalRule","name":"BOOLEAN","type":{"$type":"ReturnType","name":"boolean"},"definition":{"$type":"RegexToken","regex":"/\\\\b(true|false)\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"LIB_ICON","definition":{"$type":"RegexToken","regex":"/(aws|azure|bootstrap|gcp|tech):[-\\\\w]*/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_WITH_SCHEMA","definition":{"$type":"RegexToken","regex":"/\\\\w+:\\\\/{2}\\\\S+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_RELATIVE","definition":{"$type":"RegexToken","regex":"/\\\\.{0,2}\\\\/[^\\\\/]\\\\S+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_ALIAS","definition":{"$type":"RegexToken","regex":"/@[a-zA-Z0-9_-]*\\\\/[^\\\\s]+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"DotUnderscore","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\._(?![_a-zA-Z])/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"DotWildcard","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\.\\\\*{1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Hash","definition":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"#"}},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"StickyDot","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\./"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Dot","definition":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"."}},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"NotEqual","definition":{"$type":"RegexToken","regex":"/\\\\!\\\\={1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Eq","definition":{"$type":"RegexToken","regex":"/\\\\={1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Percent","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+%/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"MarkdownString","definition":{"$type":"TerminalAlternatives","elements":[{"$type":"TerminalGroup","elements":[{"$type":"CharacterRange","left":{"$type":"Keyword","value":"'''"}},{"$type":"UntilToken","terminal":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"'''"}}}]},{"$type":"TerminalGroup","elements":[{"$type":"CharacterRange","left":{"$type":"Keyword","value":"\\"\\"\\""}},{"$type":"UntilToken","terminal":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"\\"\\"\\""}}}]}]},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"String","definition":{"$type":"RegexToken","regex":"/\\"(?:[^\\"\\\\\\\\]|\\\\\\\\.)*\\"|'(?:[^'\\\\\\\\]|\\\\\\\\.)*'/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Float","type":{"$type":"ReturnType","name":"number"},"definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+\\\\.\\\\d+\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Number","type":{"$type":"ReturnType","name":"number"},"definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"IdTerminal","definition":{"$type":"RegexToken","regex":"/([a-zA-Z]|_+[a-zA-Z0-9])[-\\\\w]*/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Hex","definition":{"$type":"RegexToken","regex":"/[a-fA-F0-9]{3,}(?![-_g-zG-Z])/"},"fragment":false,"hidden":false}],"types":[{"$type":"Type","name":"ModelReferenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@17"}}]}},{"$type":"Type","name":"Referenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@110"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@112"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@17"}}]}},{"$type":"Type","name":"LikeC4View","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@46"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@47"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@118"}}]}},{"$type":"Type","name":"StringProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@23"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@56"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@37"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@41"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@10"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@15"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@76"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@77"}}]}},{"$type":"Type","name":"AnyProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/types@3"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@55"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@53"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@22"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@36"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@150"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@76"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@77"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@80"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@146"}}]}},{"$type":"Type","name":"DynamicViewStep","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@2"}}]}},{"$type":"Type","name":"DeploymentNodeOrElementKind","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@3"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@7"}}]}},{"$type":"Type","name":"WhereTagEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@0/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@0/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@3/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereKindEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@1/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@1/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@4/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereMetadataEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@2/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@2/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@5/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereExpression","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@96"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@103"}}]}},{"$type":"Type","name":"DeploymentElement","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@110"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@112"}}]}},{"$type":"Type","name":"FqnReferenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/types@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@24"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@114"}}]}},{"$type":"Type","name":"SizeProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@143"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@144"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@145"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@136"}}]}}],"interfaces":[{"$type":"Interface","name":"AbstractDynamicStep","attributes":[{"$type":"TypeAttribute","name":"kind","isOptional":true,"type":{"$type":"ReferenceType","referenceType":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@5"}}}},{"$type":"TypeAttribute","name":"dotKind","isOptional":true,"type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@152"}}},{"$type":"TypeAttribute","name":"target","type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@30"}},"isOptional":false},{"$type":"TypeAttribute","name":"title","isOptional":true,"type":{"$type":"SimpleType","primitiveType":"string"}},{"$type":"TypeAttribute","name":"custom","isOptional":true,"type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@79"}}}],"superTypes":[]},{"$type":"Interface","name":"DynamicStepSingle","superTypes":[{"$ref":"#/interfaces@0"}],"attributes":[{"$type":"TypeAttribute","name":"source","type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@30"}},"isOptional":false},{"$type":"TypeAttribute","name":"isBackward","isOptional":true,"type":{"$type":"SimpleType","primitiveType":"boolean"}}]},{"$type":"Interface","name":"DynamicStepChain","superTypes":[{"$ref":"#/interfaces@0"}],"attributes":[{"$type":"TypeAttribute","name":"source","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@2"}}]},"isOptional":false}]}],"definesHiddenTokens":false,"hiddenTokens":[],"imports":[],"usedGrammars":[]}`),vc={languageId:`likec4`,fileExtensions:[`.c4`,`.likec4`,`.like-c4`],caseInsensitive:!1,mode:`production`},yc={skipValidations:!0,recoveryEnabled:!0,nodeLocationTracking:`full`},bc={AstReflection:()=>new LikeC4AstReflection},xc={Grammar:()=>LikeC4Grammar(),LanguageMetaData:()=>vc,parser:{ParserConfig:()=>yc}},Sc=Symbol.for(`idattr`),Cc={writeId(e,t){return e[Sc]=t,e},readId(e){return e[Sc]}},wc={writeId(e,t){return O(t)?e[Sc]=void 0:e[Sc]=t,e},readId(e){return e[Sc]}};function isLikeC4LangiumDocument(e){return e?.textDocument.languageId===vc.languageId}function isLikeC4UserDocument(e){return isLikeC4LangiumDocument(e)&&isNotLikeC4Builtin(e)}function parseMarkdownAsString(e){return e?.markdown||e?.text}function parseAstPercent(e){let t=parseFloat(e);return isNaN(t)?100:xn(t,{min:0,max:100})}function parseAstOpacityProperty({value:e}){return parseAstPercent(e)}function parseAstSizeValue({value:e}){switch(e){case`xs`:case`sm`:case`md`:case`lg`:case`xl`:return e;case`xsmall`:return`xs`;case`small`:return`sm`;case`medium`:return`md`;case`large`:return`lg`;case`xlarge`:return`xl`;default:si(e)}}function parseAstIconPositionValue({value:e}){switch(e){case`left`:case`right`:case`top`:case`bottom`:return e;default:si(e)}}function toRelationshipStyle(e,t){let n={};if(!e||e.length===0)return n;for(let r of e)if(t(r))switch(!0){case isColorProperty(r):{let e=toColor(r);T(e)&&(n.color=e);break}case isLineProperty(r):n.line=r.value;break;case isArrowProperty(r):switch(r.key){case`head`:n.head=r.value;break;case`tail`:n.tail=r.value;break;default:si(r)}break;default:si(r)}return n}function toColor(e){return e?.themeColor??e?.customColor?.$refText}function toAutoLayout(e){let t=e.rankSep,n=e.nodeSep,r;switch(e.direction){case`TopBottom`:r=`TB`;break;case`BottomTop`:r=`BT`;break;case`LeftRight`:r=`LR`;break;case`RightLeft`:r=`RL`;break;default:si(e.direction)}return{direction:r,...n&&{nodeSep:n},...t&&{rankSep:t}}}function toAstViewLayoutDirection(e){switch(e){case`TB`:return`TopBottom`;case`BT`:return`BottomTop`;case`LR`:return`LeftRight`;case`RL`:return`RightLeft`;default:si(e)}}function getViewRulePredicateContainer(e){return et(e,e=>isViewRulePredicate(e)||isDeploymentViewRulePredicate(e)||isDynamicViewIncludePredicate(e))}const _isModel=e=>isModel(e)||isElementBody(e)||isExtendElementBody(e)||isElementViewBody(e)||isDynamicViewBody(e)||isElementRef(e),Tc=t(e=>isModelDeployments(e)||isDeploymentViewBody(e)||isDeploymentNodeBody(e)||isExtendDeploymentBody(e)||isDeployedInstanceBody(e),`_isDeployment`);function isFqnRefInsideGlobals(e){for(;;){if(Tc(e)||_isModel(e))return!1;if(isGlobals(e)||isModelViews(e))return!0;if(e.$container)e=e.$container;else return!1}}function isFqnRefInsideModel(e){for(;;){if(Tc(e))return!1;if(_isModel(e))return!0;if(e.$container)e=e.$container;else return!1}}function isFqnRefInsideDeployment(e){for(;;){if(_isModel(e))return!1;if(Tc(e))return!0;if(e.$container)e=e.$container;else return!1}}function elementRef(e){try{let t=isStrictFqnElementRef(e)?e.el.ref:e.modelElement.value.ref;return t?.$type===`Imported`&&(t=t.imported.ref),t?.$type===`Element`?t:void 0}catch{return}}function readStrictFqn(e){let t=[e.$type===`StrictFqnRef`?e.value.$refText:e.el.$refText],n=e.parent;for(;n;)t.push(n.$type===`StrictFqnRef`?n.value.$refText:n.el.$refText),n=n.parent;return t.length===1?t[0]:t.reverse().join(`.`)}function referenceableParent(e){for(;e.parent;)e=e.parent;return e.value.ref??null}function instanceRef(e){let t;for(;t=e.value?.ref;){if(isDeploymentNode$1(t))return null;if(isDeployedInstance(t))return t;if(O(e.parent))return null;e=e.parent}return null}function importsRef(e){let t=referenceableParent(e);return t?.$type===`Imported`?t:null}function isReferenceToDeploymentModel(e){let t;for(;t=e.value?.ref;){if(isDeploymentElement(t))return!0;if(O(e.parent))return!1;e=e.parent}return!1}var AstNodeDescriptionProvider=class extends h{services;constructor(e){super(e),this.services=e}createDescription(e,t,n){n??=x(e);let r=super.createDescription(e,t,n);return isLikeC4Builtin(n.uri)||(n.likec4ProjectId??=this.services.shared.workspace.ProjectsManager.ownerProjectId(n),r.likec4ProjectId=n.likec4ProjectId),r}},IndexManager=class extends pe{services;constructor(e){super(e),this.services=e}async updateContent(e,t){e.likec4ProjectId=this.services.workspace.ProjectsManager.ownerProjectId(e),await super.updateContent(e,t)}projectElements(e,t,n){let r=this.services.workspace.ProjectsManager;return S(this.symbolIndex.keys()).filter(t=>n&&!n.has(t)?!1:r.isIncluded(e,t)).flatMap(e=>this.getFileDescriptions(e,t))}};const Ec=Qr(`/`),Dc=t((e,t)=>Ec(e.uri.path,t.uri.path),`ensureOrder`);var LangiumDocuments=class extends p{services;constructor(e){super(e),this.services=e}get projectsManager(){return this.services.workspace.ProjectsManager}addDocument(e){let t=e.uri.toString();if(this.documentMap.has(t))throw Error(`A document with the URI '${t}' is already present.`);let n=[...this.documentMap.values(),e].sort(Dc);this.documentMap.clear();for(let e of n)this.documentMap.set(e.uri.toString(),e);isLikeC4UserDocument(e)&&(e.likec4ProjectId=this.projectsManager.ownerProjectId(e))}getDocument(e){let t=super.getDocument(e);return isLikeC4UserDocument(t)&&(t.likec4ProjectId=this.projectsManager.ownerProjectId(t)),t}get userDocuments(){return S(this.documentMap.values()).filter(e=>isLikeC4UserDocument(e)&&!this.projectsManager.isExcluded(e))}get all(){return S(this.documentMap.values()).map(e=>(isLikeC4UserDocument(e)&&(e.likec4ProjectId=this.projectsManager.ownerProjectId(e)),e))}projectDocuments(e){let t=this.services.workspace.ProjectsManager;return S(this.documentMap.values()).filter(n=>isLikeC4UserDocument(n)&&t.isIncluded(e,n)?(n.likec4ProjectId=e,!0):!1)}groupedByProject(){let e=this.services.workspace.ProjectsManager;return M(this.userDocuments.toArray(),N(t=>(t.likec4ProjectId=e.ownerProjectId(t),t)),en(An(`likec4ProjectId`)))}resetProjectIds(){let e=[];for(let t of this.documentMap.values())delete t.likec4ProjectId,isLikeC4UserDocument(t)&&!this.projectsManager.isExcluded(t)&&e.push(t.uri);return e}},Oc=e(Gn(),1);const J=G.getChild(`projects`);function isLangiumDocument(e){return typeof e==`object`&&`uri`in e&&`textDocument`in e}function normalizeUri(e){return isLangiumDocument(e)?e.uri.toString():typeof e==`string`?_t(e,{acceptRelative:!1,strict:!0})?e:v.file(e).toString():e.toString()}const kc=Qr(`/`,!0),compareUri=(e,t)=>kc(gt(e.path),gt(t.path));function isParentFolderFor(e){return t=>e.startsWith(ri(t)?t:t.folder)}function _overlaps(e,t){let n=ri(e)?e:e.folder,r=ri(t)?t:t.folder;return n===r||n.startsWith(r)||r.startsWith(n)}function overlaps(...e){return sn(_overlaps,e)}function _includes(e,t){return t.startsWith(e.folder)||e.includePaths?.some(isParentFolderFor(t))?!_excludes(e,t):!1}function _excludes(e,t){return e.exclude?.(dt(t))??!1}function includes(...e){return sn(_includes,e)}function excludes(...e){return sn(_excludes,e)}function ProjectFolder(e){return e=normalizeUri(e),pt(e)}const compareProjectByFolder=(e,t)=>compareUri(e.folderUri,t.folderUri);function ensureProjectsOrder(e){return e.length<=1?e:Sn(e,compareProjectByFolder)}const Ac={id:`default`,config:{name:`default`,exclude:[`**/node_modules/**`]},exclude:(0,Oc.default)(`**/node_modules/**`,{dot:!0}),includeConfig:{paths:[],maxDepth:3,fileThreshold:30}};function isExcludedByDefault(e){return Ac.exclude(dt(e))}function parseRegisterOptions(e){if(`configUri`in e){U(!Yt(e.configUri),`configUri is emptyish`);let t=v.isUri(e.configUri)?e.configUri:v.parse(normalizeUri(e.configUri)),n=ProjectFolder(_.dirname(t));return{configUri:t,folder:n,folderUri:v.parse(n)}}U(!Yt(e.folderUri),`folderUri is emptyish`);let t=ProjectFolder(e.folderUri),n=v.parse(t);return{configUri:_.joinPath(n,`likec4.config.json`),folder:t,folderUri:n}}var jc=class ProjectsManager{services;static DefaultProjectId=Ac.id;#e=[];#t=void 0;#n=void 0;#r=[];#i=new qr(e=>{if(e===ProjectsManager.DefaultProjectId){let t=this.getWorkspaceFolder(),n=_.joinPath(t,`likec4.config.json`),r=ProjectFolder(t);return{id:e,config:Ac.config,folder:r,folderUri:v.parse(r),configUri:n,exclude:Ac.exclude,includeConfig:{...Ac.includeConfig}}}return oi(this.#r.find(t=>t.id===e),`Project ${e} not found`)});#a=new qr(e=>{if(this.isExcludedByWorkspace(e))return!0;let t=this.#o.get(e);return t?excludes(t,e)?!this.#r.some(includes(e)):!1:isExcludedByDefault(e)});#o=new qr(e=>{if(this.#r.length===0)return null;let t=isParentFolderFor(e);return this.#r.find(t)??this.#r.find(includes(e))??null});constructor(e){this.services=e,J.trace`created`}isExcludedByWorkspace(e){return this.#n?(v.isUri(e)&&(e=normalizeUri(e)),this.#n(dt(e))):!1}setWorkspaceExcludePatterns(e){try{if(!Array.isArray(e)){this.#n=void 0;return}let t=M(e,j(T),N(e=>(!zt(e)&&!e.startsWith(`**`)&&(e=ht(`**`,e)),e)));if(!A(t,1)){this.#n=void 0;return}J.debug`set workspace exclude patterns: ${t}`,this.#n=(0,Oc.default)(t,{dot:!0})}catch(e){J.warn(`Failed to set workspace exclude patterns`,{error:e}),this.#n=void 0}}get defaultProjectId(){if(this.#t)return this.#t;if(!(this.#r.length>1))return A(this.#r,1)?this.#r[0].id:ProjectsManager.DefaultProjectId}set defaultProjectId(e){if(e!==this.#t){if(this.#t=void 0,!e||e===ProjectsManager.DefaultProjectId){J.debug`reset default project ID`;return}U(this.#r.find(t=>t.id===e),`Project "${e}" not found`),J.debug`set default project ID to ${e}`,this.#t=e}}get default(){return this.#i.get(this.defaultProjectId??ProjectsManager.DefaultProjectId)}get all(){if(A(this.#r,1)){let e=[...N(this.#r,An(`id`)),Ac.id];if(this.#t){let t=e.findIndex(e=>e===this.#t);t>0&&(e.splice(t,1),e.unshift(this.#t))}return e}return[Ac.id]}getProject(e){let t=typeof e==`string`?e:e.likec4ProjectId??this.ownerProjectId(e);return this.#i.get(t)}findOverlaped(e){if(this.#r.length===0)return[];let t=overlaps(ProjectFolder(e)),isInsideOrIncludes=e=>t(e)||!!e.includePaths&&!!nn(e.includePaths,t);return this.#r.filter(isInsideOrIncludes)}ensureProjectId(e){return e===ProjectsManager.DefaultProjectId?this.defaultProjectId??ProjectsManager.DefaultProjectId:e?(U(this.#r.some(t=>e===t.id),`Project ID ${e} is not registered`),e):oi(this.defaultProjectId,()=>`Specify exact project, known: [${N(this.#r,An(`id`)).join(`, `)}]`)}ensureProject(e){return e=this.ensureProjectId(e),this.getProject(e)}hasMultipleProjects(){return this.#r.length>1}isExcluded(...e){let t=e.length===1?e[0]:e[1];return isLangiumDocument(t)&&isLikeC4Builtin(t)?!0:e.length===1?this.#a.get(normalizeUri(t)):excludes(this.#i.get(e[0]),normalizeUri(t))}isIncluded(e,t){let n=normalizeUri(t);return this.isExcludedByWorkspace(n)?!1:A(this.#r,1)?e===ProjectsManager.DefaultProjectId?!this.#o.get(n)&&!isExcludedByDefault(n):includes(this.#i.get(e),n):!isExcludedByDefault(n)}async registerConfigFile(e,t){if(this.isExcludedByWorkspace(e))throw Error(`Skipping project config, path ${e.fsPath} is excluded by editor settings`);if(isExcludedByDefault(normalizeUri(e)))throw Error(`Failed to register project config, path ${e.fsPath} is excluded by default: ${Ac.config.exclude.map(e=>`"${e}"`).join(`, `)}`);try{let n=await this.services.workspace.FileSystemProvider.loadProjectConfig(e);return await this.registerProject({config:n,configUri:e},t)}catch(t){if(!ie(t))throw wrapError(t,`Failed to register project config ${e.fsPath}:\n`);return Promise.reject(t)}}async registerProject(e,t){let n=Nt.validate(e.config),{configUri:r,folder:i,folderUri:a}=parseRegisterOptions(e),o=Nt.normalizeInclude(n.include),s=this.#r.find(e=>e.folder===i);return s?(s.config.name!==n.name&&(J.info`project name changed from ${s.config.name} to ${n.name}`,J.info`remove ${s.id}`,s.id=this.uniqueProjectId(n.name),J.info`add ${s.id}`),this.warnIfConfigOverride(s,r),s.config=n,s.folder=i,s.folderUri=a,s.configUri=r,s.includeConfig=o):(s={id:this.uniqueProjectId(n.name),config:n,folder:i,configUri:r,folderUri:a,includeConfig:o},this.#r=ensureProjectsOrder([...this.#r,s]),J.info`add ${s.id}`),safeCall(()=>this.updateIncludesExcludes(s)),this.isInitiatingOrReloading?s:(this.resetCaches(),this.notifyListeners(),await this.rebuildProject(s.id,t).catch(e=>ie(e)?Promise.reject(e):(J.warn(`Failed to rebuild project {projectId} after config change`,{projectId:s.id,error:e}),Promise.resolve())),s)}ownerProjectId(e){return this.#o.get(normalizeUri(e))?.id??this.#t??ProjectsManager.DefaultProjectId}relativePath(e){let t=normalizeUri(e),n=this.#o.get(t);return n?_.relative(n.folderUri,v.parse(t)):t}get isInitiatingOrReloading(){return!!this.#s||!this.services.workspace.WorkspaceManager.isReady}#s=null;async reloadProjects(e){return this.#s?(J.debug`reload projects is already in progress, waiting`,await this.#s.catch(()=>{})):(J.debug`schedule reload projects`,this.#s=Promise.resolve().then(()=>this._reloadProjects(e)).catch(e=>(ie(e)||J.warn(`Failed to reload projects`,{error:e}),Promise.reject(e))).finally(()=>{this.#s=null}),await this.#s)}async _reloadProjects(e){let t=this.services.workspace.WorkspaceManager.workspaceFolders;if(!t||t.length===0){J.warn(`Failed to reloadProjects, no workspace folders found`);return}J.debug`start reload projects`;let n=[];for(let e of t){let t=v.parse(e.uri);J.debug`scan projects in ${t.fsPath}`;try{let e=await this.services.workspace.FileSystemProvider.scanProjectFiles(t);for(let r of e)J.debug`found config ${_.relative(t,r.uri)}`,n.push(r.uri)}catch(e){J.warn(`Failed on scanProjectFiles in {folder}`,{folder:t.fsPath,error:e})}}if(n.length===0){if(this.#r.length===0){J.warning(`No config files found`);return}J.warning(`no config files found, but {count} projects were registered before`,{count:this.#r.length}),J.warning(`reset`)}n.sort(compareUri);let r=new Map(this.#r.map(e=>[e.configUri.toString(),e]));this.#r=[],this.#i.clear();for(let e of n)try{await this.registerConfigFile(e)}catch(t){J.warn(loggable(t));let n=r.get(e.toString());n&&(J.debug`Update failed, restore project ${n.id}`,await this.registerProject(n).catch(e=>{J.warn(`fail to restore project ${n.id}, ignoring`,{error:e})}))}this.resetCaches(),this.notifyListeners(),await this.services.workspace.WorkspaceManager.rebuildAll(e)}uniqueProjectId(e){let t=new Set(N(this.#r,An(`id`))),n=e;if(!t.has(n))return n;J.warn`Project "${e}" already exists, generating unique ID`;let r=1;for(;t.has(n);)n=`${e}-${r++}`;return n}resetCaches(){J.trace(`resetCaches`),this.#t&&!this.#r.some(e=>e.id===this.#t)&&(this.#t=void 0),this.#i.clear(),this.#o.clear(),this.#a.clear()}async rebuildProject(e,t){let n=this.#r.find(t=>t.id===e);if(!n)return e===ProjectsManager.DefaultProjectId?J.info`Rebuilding all documents `:J.warn`Project ${e} not found, rebuilding all`,await this.services.workspace.WorkspaceManager.rebuildAll(t);let r=J.getChild(n.id),_includes=e=>includes(n,normalizeUri(e)),i=this.services.workspace.LangiumDocuments.userDocuments.filter(_includes).map(e=>e.uri).toArray();if(i.length===0){r.trace`no documents found for project ${n.id}, skipping rebuild`;return}r.info`rebuild project documents: ${i.length}`,this.resetCaches(),await this.services.workspace.DocumentBuilder.update(i,[],t).catch(e=>{r.warn(`Failed to rebuild project`,{error:e})})}getAllIncludePaths(){let e=[];for(let t of this.#r)if(t.includePaths)for(let n of t.includePaths)e.push({projectId:t.id,includePath:n.uri,includeConfig:t.includeConfig});return e}onProjectsUpdate(e){return this.#e.push(e),g.create(()=>{let t=this.#e.indexOf(e);t>=0&&this.#e.splice(t,1)})}getWorkspaceFolder(){try{return this.services.workspace.WorkspaceManager.workspaceUri}catch(e){return J.warn(`Failed to get workspace URI, using default folder`,{error:e}),v.file(`/`)}}notifyListeners(){for(let e of this.#e)try{e()}catch(e){J.warn(loggable(e))}}updateIncludesExcludes(e){let t=e.config;switch(delete e.includePaths,delete e.exclude,!0){case O(t.exclude):e.exclude=Ac.exclude;break;case t.exclude&&A(t.exclude,1):e.exclude=(0,Oc.default)(N(t.exclude,t=>(!ft(t)&&!t.startsWith(`**`)&&(t=ht(`**`,t)),vt(lt(e.folderUri.path,t)))),{contains:!0,dot:!0});break}let n=e.includeConfig.paths;if(!A(n,1))return e;e.includePaths=N(n,t=>{let n=_.resolvePath(e.folderUri,t);return{uri:n,folder:ProjectFolder(n)}}),J.debug`project ${e.id} include paths: ${e.includePaths.map(e=>e.uri.fsPath).join(`, `)}`;for(let t of e.includePaths)for(let n of this.#r)n.id!==e.id&&(overlaps(t,n)&&J.warn(`Project "{projectId}" include path "{includePath}" overlaps with project "{otherProjectId}" folder. Files in overlapping areas will only belong to one project.`,{projectId:e.id,includePath:t.folder,otherProjectId:n.id}),n.includePaths?.forEach(r=>{overlaps(t,r)&&J.warn(`Project "{projectId}" include path "{includePath}" overlaps with project "{otherProjectId}" include path "{otherIncludePath}". Files in overlapping areas will only belong to one project.`,{projectId:e.id,includePath:t.folder,otherProjectId:n.id,otherIncludePath:r.folder})}));return e}warnIfConfigOverride(e,t){try{let[n,r]=N([e.configUri,t],_.basename);n!==r&&J.warn`config ${r} overrides ${n} in folder ${e.folder}`}catch{}}};function hasLikeC4Ext(e){return vc.fileExtensions.some(t=>e!==t&&e.endsWith(t))}const Mc=[`node_modules`,`.git`,`.svn`,`.yarn`,`.pnpm`];function isNodeModulesOrRepo(e){return Mc.includes(e)}function insideNodeModulesOrRepo(e){for(let t of Mc)if(e.includes(t))return!0;return!1}const Nc=Qr(`/`);function ensureOrder(e,t){return Nc(e.uri.path,t.uri.path)}var LikeC4WorkspaceManager=class extends rt{services;documentFactory;fileSystemProvider;#e=!1;#t=[];initialBuildOptions={eagerLinking:!0,validation:!0};constructor(e){super(e),this.services=e,this.documentFactory=e.workspace.LangiumDocumentFactory,this.fileSystemProvider=e.workspace.FileSystemProvider}get isReady(){return this.#e}async performStartup(e){try{this.#e=!1,await this.readExcludeConfig(),this.folders??=e;let t=[];for(let n of e)try{let e=v.parse(n.uri),r=await this.fileSystemProvider.scanProjectFiles(e);t.push(...r),this.services.workspace.FileSystemWatcher.watch(e.fsPath)}catch(e){logWarnError(e)}let n=this.services.workspace.ProjectsManager,r=0;for(let e of t)try{await n.registerConfigFile(e.uri),r++}catch(e){logWarnError(e)}return t.length!==r&&G.warn`loaded ${r} projects out of ${t.length}`,await super.performStartup(e)}finally{this.#e=!0}}async loadAdditionalDocuments(e,t){t(this.documentFactory.fromString(aa,v.parse(sa)));let n=this.services.workspace.ProjectsManager.getAllIncludePaths(),r=_n(e=>this.services.workspace.ProjectsManager.isExcludedByWorkspace(e.uri)),i=0,a=[];for(let{projectId:e,includePath:t,includeConfig:i}of n)try{G.debug`scanning include path ${t.fsPath} for project ${e}`;let n=M(await this.fileSystemProvider.readDirectory(t,{recursive:!0,maxDepth:i.maxDepth}),j(r));a.push(...n),n.length===0?G.trace`no files found in include path ${t.fsPath}`:G.debug`loaded ${n.length} files from include path ${t.fsPath}`}catch(e){G.warn(`Failed to scan include path ${t.fsPath}`,{error:e})}for(let e of bn(a,e=>e.uri.path))try{t(await this.langiumDocuments.getOrCreateDocument(e.uri)),i++}catch(t){G.warn(`Failed to load document ${e.uri.fsPath}`,{error:t})}if(n.length>0&&i>0){let e=Math.min(...n.map(e=>e.includeConfig.fileThreshold));i>e?G.warn(`Loaded ${i} files from include paths (threshold: ${e}). Large include directories may slow workspace initialization. Consider adjusting "include.fileThreshold" or "include.maxDepth" in your project configuration.`):G.info`loaded ${i} total files from ${n.length} include paths`}}async traverseFolder(e,t,n,r){let i=await this.fileSystemProvider.readDirectory(t,{recursive:!0});for(let t of i)if(this.includeEntry(e,t,n)){if(t.isDirectory){await this.traverseFolder(e,t.uri,n,r);continue}try{r(await this.langiumDocuments.getOrCreateDocument(t.uri))}catch(e){G.warn(`Failed to load document {path}`,{error:e,path:t.uri.fsPath})}}}includeEntry(e,t,n){let r=_.basename(t.uri);return t.isDirectory?!(isNodeModulesOrRepo(r)||this.services.workspace.ProjectsManager.isExcludedByWorkspace(t.uri)):t.isFile?(n.fileExtensions.includes(_.extname(t.uri))||n.fileNames.includes(r))&&!this.services.workspace.ProjectsManager.isExcludedByWorkspace(t.uri):!1}workspace(){return this.folders&&A(this.folders,1)?this.folders[0]:null}async rebuildAll(e){let t=this.services.workspace.LangiumDocuments.resetProjectIds();G.info(`invalidate and rebuild all {docs} documents`,{docs:t.length}),this.forceCleanCaches(),await this.documentBuilder.update(t,[],e)}get workspaceUri(){let e=this.workspace();return z(e,`Workspace not initialized`),v.parse(e.uri)}get workspaceURL(){let e=this.workspace();return z(e,`Workspace not initialized`),new URL(e.uri)}forceCleanCaches(){for(let e of this.#t)e();this.services.workspace.ManualLayouts.clearCaches(),this.services.workspace.Cache.clear()}onForceCleanCache(e){return this.#t.push(e),g.create(()=>{this.#t=this.#t.filter(t=>t!==e)})}async readExcludeConfig(){if(!this.services.lsp.Connection){G.debug`no LSP connection, skipping initial configuration read`;return}let e=this.services.workspace.ConfigurationProvider,wait=e=>Kn(e,{milliseconds:1e3,message:!1});try{G.trace`waiting for ConfigurationProvider ready...`,await wait(e.ready),G.trace`ConfigurationProvider ready, reading exclude patterns...`;let t=await wait(e.getConfiguration(`likec4`,`exclude`));t?(G.trace`exclude configuration found ${t}`,this.services.workspace.ProjectsManager.setWorkspaceExcludePatterns(t)):G.trace(`no initial exclude configuration found`)}catch(e){G.warn(`Failed to read initial exclude configuration`,{error:e})}}};function projectIdFrom(e){if(isImported(e)){for(;e.$type===`Imported`&&e.$container;)e=e.$container;z(isImportsFromPoject(e))}if(isImportsFromPoject(e))return e.project;let t=at(e)?x(e):e;return t.likec4ProjectId?t.likec4ProjectId:(G.warn`Document ${t.uri.fsPath} does not have a project ID assigned, this may lead to unexpected behavior.`,jc.DefaultProjectId)}function stringHash$1(...e){return pi(e.length>1?e.join(`:::`):e[0])}t(stringHash$1,`stringHash`);function safeCall(e){try{return e()}catch(e){G.trace(`Safe call failed`,{error:e});return}}function performanceNow(){try{return globalThis.performance.now()}catch{return Date.now()}}function performanceMark(){let e=performanceNow();return{get ms(){return performanceNow()-e},get pretty(){return Wn(performanceNow()-e)}}}const Pc=G.getChild(`manual-layouts`),Fc=`.likec4.snap`,isManualLayoutFile=e=>e!==Fc&&e.endsWith(Fc);function fileName(e){return`${e}${Fc}`}function viewIdFromURI(e){let t=_.basename(e);return isManualLayoutFile(t)?t.slice(0,-12):null}function getManualLayoutsOutDir(e){return _.resolvePath(e.folderUri,e.config.manualLayouts?.outDir??`.likec4`)}const Ic={manualLayouts:e=>new DefaultLikeC4ManualLayouts(e)},Lc=`file://./`;var DefaultLikeC4ManualLayouts=class{services;cache;listeners=[];#e=Vn(1);constructor(e){this.services=e,this.cache=new Fe,ci(()=>{e.workspace.ProjectsManager.onProjectsUpdate(()=>{this.clearCaches()})})}async handleFileSystemUpdate(e){let t=e.update??e.delete,n=viewIdFromURI(t)??void 0,r=this.services.workspace.ProjectsManager.ownerProjectId(t);if(this.cache.delete(r),`delete`in e){this.triggerUpdate(Ar({removed:t,projectId:r,viewId:n}));return}let i=this.services.workspace.ProjectsManager.getProject(r);if(!n){let e=await this.readSnapshot(t,i);e?n=e.id:(Pc.error(`Snapshot ${t.fsPath} does not exist or is invalid`),n=`index`)}this.triggerUpdate({updated:t,projectId:r,viewId:n})}onManualLayoutUpdate(e){return this.listeners.push(e),{dispose:()=>{let t=this.listeners.indexOf(e);t!==-1&&this.listeners.splice(t,1)}}}async readManualLayouts(e){let t=Pc.getChild(e.id),n=this.services.workspace.FileSystemProvider,r=getManualLayoutsOutDir(e),i=[],a=`${r.toString()}`;try{let o=await n.scanDirectory(r,isManualLayoutFile);if(o.length===0)return null;o.sort((e,t)=>e.uri.path.localeCompare(t.uri.path));for(let r of o)try{let t=await n.readFile(r.uri),o=bt.parse(t);a=pi(a+r.uri.toString()+t);let s=this.resolveIconPathsAfterRead(o,e.folderUri);i.push({...s,_layout:`manual`})}catch(e){t.warn(`Failed to read view snapshot ${r.uri.fsPath}`,{err:e})}i.length&&t.trace`read manual layouts for ${e.id}, found ${i.length}`}catch(n){t.warn(`Failed to read manual layouts for ${e.folderUri.fsPath}`,{err:n})}if(i.length===0)return null;let o=Jt(i,An(`id`));return{hash:a,views:o}}async readSnapshot(e,t){let n=this.services.workspace.FileSystemProvider;try{let r=await n.readFile(e),i=bt.parse(r);if(!t){let n=this.services.workspace.ProjectsManager.ownerProjectId(e);t=this.services.workspace.ProjectsManager.getProject(n)}return{...this.resolveIconPathsAfterRead(i,t.folderUri),_layout:`manual`}}catch(t){return Pc.warn(`Failed to read view snapshot ${e.fsPath}`,{err:t}),null}}async read(e){return await this.#e(async()=>{let t=this.cache.get(e.id);if(t!==void 0)return Pc.trace`cache hit project ${e.id}`,t;let n=await this.readManualLayouts(e);return this.cache.set(e.id,n),n})}async write(e,t){this.cache.delete(e.id);let n=Pc.getChild(e.id),r=getManualLayoutsOutDir(e),i=_.joinPath(r,fileName(t.id));if(`manualLayout`in t){let{manualLayout:e,...n}=t;t=n}let a=bt.stringify(this.normalizeIconPathsForWrite(t,e.folderUri),{space:2,quote:`'`}),o={uri:i.toString(),range:d.create(ue.create(0,0),ue.create(a.split(`
|
|
42
|
-
`).length-1,1))};
|
|
43
|
-
`),this.triggerUpdate({updated:
|
|
44
|
-
`)}case isElement(e):{let t=
|
|
45
|
-
`):void 0}default:return e}}catch(e){logWarnError(e)}}};function areOverlap(e,t){return[e,t]=compareRanges(e,t)>0?[t,e]:[e,t],isInRagne(e.range,t.range.start)}function compareRanges(e,t){let n=e.range.start.line-t.range.start.line;return n===0?e.range.start.character-t.range.start.character:n}function isInRagne(e,t){return!(t.line<e.start.line||t.line>e.end.line||t.line==e.start.line&&t.character<e.start.character||t.line==e.end.line&&t.character>e.end.character)}function isMultiline(e){return!!e&&e.range.start.line!=e.range.end.line}const X={newLine:Le.newLine({allowMore:!0}),oneSpace:Le.oneSpace(),noSpace:Le.noSpace(),indent:Le.indent({allowMore:!0}),noIndent:Le.noIndent()};var LikeC4Formatter=class extends Ce{options={quoteStyle:`auto`};extendedFormattingCommands=[];constructor(e){super(),e.shared.workspace.ConfigurationProvider.onConfigurationSectionUpdate(e=>this.onConfigurationUpdate(e.configuration.formatting))}doDocumentFormat(e,t,n){this.extendedFormattingCommands=[];let r=super.doDocumentFormat(e,t,n);return this.doExtendedFormatting(r),r}format(e){this.removeIndentFromTopLevelStatements(e),this.indentContentInBraces(e),this.normalizeQuotes(e),this.formatImports(e),this.formatSpecificationRule(e),this.formatGlobals(e),this.formatElementDeclaration(e),this.formatExtendElement(e),this.formatRelation(e),this.formatMetadataProperty(e),this.formatDeploymentNodeDeclaration(e),this.formatDeployedInstance(e),this.formatDeploymentRelation(e),this.formatExtendDeployment(e),this.formatView(e),this.formatViewRuleGroup(e),this.formatViewRuleGlobalStyle(e),this.formatViewRuleGlobalPredicate(e),this.formatIncludeExcludeExpressions(e),this.formatWhereExpression(e),this.formatWhereRelationExpression(e),this.formatWhereElementExpression(e),this.formatRelationExpression(e),this.formatAutolayoutProperty(e),this.formatWithPredicate(e),this.formatViewRuleStyle(e),this.formatLeafProperty(e),this.formatLinkProperty(e),this.formatNavigateToProperty(e),this.formatTags(e)}formatTags(e){this.on(e,isTags,(e,t)=>{let n=Xe(e.$cstNode,`values`).filter(T).slice(1);t.cst(n).prepend(X.oneSpace),t.keywords(`,`).prepend(X.noSpace).append(X.oneSpace)})}formatDeploymentRelation(e){this.on(e,isDeploymentRelation,(e,t)=>{let n=e?.source?.$cstNode?[e?.source?.$cstNode]:[];t.cst(n).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace),t.keywords(`-[`).append(X.noSpace),t.nodes(...j([e.target,e.tags],T)).prepend(X.oneSpace),t.properties(`title`,`description`,`technology`).prepend(X.oneSpace)})}formatExtendDeployment(e){this.on(e,isExtendDeployment,(e,t)=>{t.keywords(`extend`).append(X.oneSpace)})}formatRelation(e){this.on(e,e=>isRelation(e)||isDeploymentRelation(e),(e,t)=>{let n=e?.source?.$cstNode?[e?.source?.$cstNode]:[];t.cst(n).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace),t.keywords(`-[`).append(X.noSpace),t.nodes(...j([e.target,e.tags],T)).prepend(X.oneSpace),t.properties(`title`,`description`,`technology`).prepend(X.oneSpace)}),this.on(e,isDynamicViewStep,(e,t)=>{t.keywords(`->`,`<-`).surround(X.oneSpace),t.property(`dotKind`).prepend(X.oneSpace).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace).append(X.oneSpace),t.keywords(`-[`).prepend(X.oneSpace).append(X.noSpace),t.properties(`title`).prepend(X.oneSpace),(isDynamicStepChain(e)&&isMultiline(e.$cstNode)||isDynamicStepSingle(e)&&isDynamicStepChain(e.$container)&&isMultiline(e.$container.$cstNode))&&(t.property(`dotKind`).prepend(Le.indent({allowLess:!1,allowMore:!0,priority:2})),t.keywords(`->`,`-[`).prepend(Le.indent({allowLess:!1,allowMore:!0,priority:2})),e.custom?.$cstNode&&isMultiline(e.custom.$cstNode)&&t.property(`custom`).prepend({options:{allowLess:!1,allowMore:!0,priority:2},moves:[{tabs:1}]}))})}removeIndentFromTopLevelStatements(e){isLikeC4Grammar(e.$container)&&this.getNodeFormatter(e).keywords(`specification`,`model`,`views`,`likec4lib`,`global`,`deployments`,`import`).prepend(X.noIndent)}indentContentInBraces(e){if(isLikeC4Lib(e)||isSpecificationRule(e)||isSpecificationElementKind(e)||isSpecificationRelationshipKind(e)||isSpecificationDeploymentNodeKind(e)||isGlobals(e)||isGlobalStyle(e)||isGlobalStyleGroup(e)||isGlobalPredicateGroup(e)||isGlobalDynamicPredicateGroup(e)||isGlobalStyleGroup(e)||isModel(e)||isElementBody(e)||isExtendElementBody(e)||isRelationBody(e)||isRelationStyleProperty(e)||isMetadataBody(e)||isModelViews(e)||isElementViewBody(e)||isDynamicViewBody(e)||isDeploymentViewBody(e)||isViewRuleStyle(e)||isViewRuleGroup(e)||isCustomElementProperties(e)||isCustomRelationProperties(e)||isElementStyleProperty(e)||isDynamicViewParallelSteps(e)||isModelDeployments(e)||isDeploymentNodeBody(e)||isDeploymentRelationBody(e)||isDeployedInstanceBody(e)||isExtendDeploymentBody(e)){let t=this.getNodeFormatter(e),n=t.keywords(`{`);n.prepend(X.noIndent).prepend(X.oneSpace);let r=isMultiline(e.$cstNode),i=t.keywords(`}`),a=t.interior(n,i),o=null;for(let e of a.nodes){if(!r){t.cst([e]).surround(X.oneSpace);continue}(!o||!areOverlap(o,e))&&t.cst([e]).prepend(Le.newLine({allowMore:!0})).prepend(X.indent),o=e}r?i.prepend(X.noIndent).prepend(Le.newLine({allowMore:!0})):i.prepend(Le.oneSpace({allowLess:!0}))}}appendKeywordsWithSpace(e){this.on(e,isElementKind)?.keywords(`element`).append(X.oneSpace)}formatView(e){this.on(e,isElementView$1,(e,t)=>{(e.extends||e.viewOf||e.name)&&t.keywords(`view`).append(X.oneSpace),t.keywords(`of`,`extends`).surround(X.oneSpace)}),this.on(e,isDynamicView$1)?.keywords(`dynamic`,`view`).append(X.oneSpace),this.on(e,isDeploymentView$1)?.keywords(`deployment`,`view`).append(X.oneSpace)}formatLeafProperty(e){if(isElementStringProperty(e)||isRelationStringProperty(e)||isViewStringProperty(e)||isNotationProperty(e)||isNotesProperty(e)||isSpecificationElementStringProperty(e)||isSpecificationRelationshipStringProperty(e)||isColorProperty(e)||isLineProperty(e)||isArrowProperty(e)||isIconProperty(e)||isShapeProperty(e)||isBorderProperty(e)||isOpacityProperty(e)||isMultipleProperty(e)||isIconColorProperty(e)||isIconSizeProperty(e)||isIconPositionProperty(e)||isShapeSizeProperty(e)||isPaddingSizeProperty(e)||isTextSizeProperty(e)){let t=this.getNodeFormatter(e),n=t.keyword(`:`),r=t.keywords(`title`,`description`,`technology`,`summary`,`notation`,`notes`,`color`,`line`,`head`,`tail`,`icon`,`iconColor`,`iconSize`,`iconPosition`,`shape`,`border`,`opacity`,`multiple`,`size`,`padding`,`textSize`);n.nodes.length===0?r.append(X.oneSpace):n.prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)}}formatLinkProperty(e){this.on(e,isLinkProperty,(e,t)=>{t.keyword(`link`).append(X.oneSpace),t.property(`value`).append(X.oneSpace),t.keyword(`:`).prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)})}formatNavigateToProperty(e){this.on(e,isNavigateToProperty)?.property(`key`).append(X.oneSpace)}formatAutolayoutProperty(e){this.on(e,isViewRuleAutoLayout,(e,t)=>{t.keyword(`autoLayout`).append(X.oneSpace),t.property(`rankSep`).prepend(X.oneSpace),t.property(`nodeSep`).prepend(X.oneSpace)})}formatMetadataProperty(e){this.on(e,isMetadataAttribute,(e,t)=>{t.property(`key`).append(X.oneSpace),t.keyword(`:`).prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)})}formatElementDeclaration(e){this.on(e,isElement,(e,t)=>{let n=Ue(e.$cstNode,`kind`),r=Ue(e.$cstNode,`name`);r&&n&&(compareRanges(r,n)>0?t.cst([n]).append(X.oneSpace):(t.cst([r]).append(X.oneSpace),t.cst([n]).prepend(X.oneSpace))),t.properties(`props`).prepend(X.oneSpace)})}formatExtendElement(e){this.on(e,isExtendElement,(e,t)=>{t.keywords(`extend`).append(X.oneSpace)})}formatGlobals(e){this.on(e,isGlobalStyle,(e,t)=>{t.keyword(`style`).append(X.oneSpace),t.property(`id`).append(X.oneSpace)}),this.on(e,isGlobalStyleGroup,(e,t)=>{t.keyword(`styleGroup`).append(X.oneSpace)}),this.on(e,isGlobalPredicateGroup,(e,t)=>{t.keyword(`predicateGroup`).append(X.oneSpace)}),this.on(e,isGlobalDynamicPredicateGroup,(e,t)=>{t.keyword(`dynamicPredicateGroup`).append(X.oneSpace)})}formatImports(e){this.on(e,isImportsFromPoject,(e,t)=>{t.keyword(`import`).append(X.oneSpace),t.keywords(`{`,`}`,`from`).surround(X.oneSpace)}),this.on(e,isImported,(e,t)=>{t.keywords(`,`).prepend(X.noSpace).append(X.oneSpace)})}formatSpecificationRule(e){if((isSpecificationElementKind(e)||isSpecificationRelationshipKind(e)||isSpecificationTag(e)||isSpecificationDeploymentNodeKind(e))&&this.getNodeFormatter(e).keywords(`element`,`relationship`,`tag`,`deploymentNode`).append(X.oneSpace),isSpecificationColor(e)){let t=this.getNodeFormatter(e);t.keyword(`color`).append(X.oneSpace),t.property(`name`).append(X.oneSpace)}}formatWithPredicate(e){(isFqnExprWith(e)||isRelationExprWith(e))&&this.getNodeFormatter(e).keyword(`with`).prepend(X.oneSpace)}formatDeploymentNodeDeclaration(e){this.on(e,isDeploymentNode$1,(e,t)=>{let n=Ue(e.$cstNode,`kind`),r=Ue(e.$cstNode,`name`);r&&n&&(compareRanges(r,n)>0?t.cst([n]).append(X.oneSpace):(t.cst([r]).append(X.oneSpace),t.cst([n]).prepend(X.oneSpace))),t.properties(`title`).prepend(X.oneSpace)})}formatDeployedInstance(e){this.on(e,isDeployedInstance,(e,t)=>{let n=e.$cstNode?.content.find(e=>e.text===`=`);n&&t.cst([n]).surround(X.oneSpace),t.keyword(`instanceOf`).append(X.oneSpace),t.property(`title`).prepend(X.oneSpace)})}formatViewRuleGlobalStyle(e){this.on(e,isViewRuleGlobalStyle,(e,t)=>{t.keywords(`global`,`style`).append(X.oneSpace)})}formatViewRuleGlobalPredicate(e){let t=this.getNodeFormatter(e);(isViewRuleGlobalPredicateRef(e)||isDynamicViewGlobalPredicateRef(e))&&t.keywords(`global`,`predicate`).append(X.oneSpace)}formatViewRuleGroup(e){this.on(e,isViewRuleGroup,(e,t)=>{t.keyword(`group`).append(X.oneSpace)})}formatViewRuleStyle(e){this.on(e,isViewRuleStyle)?.keyword(`style`).append(X.oneSpace),this.on(e,isDeploymentViewRuleStyle)?.keyword(`style`).append(X.oneSpace),this.on(e,isExpressions)?.keyword(`,`).prepend(X.noSpace).append(X.oneSpace),this.on(e,isFqnExpressions)?.keyword(`,`).prepend(X.noSpace).append(X.oneSpace)}formatWhereExpression(e){(isRelationExprWhere(e)||isFqnExprWhere(e))&&this.getNodeFormatter(e).keyword(`where`).append(X.oneSpace)}formatWhereRelationExpression(e){if(this.on(e,isWhereRelationExpression,(e,t)=>{t.property(`operator`).surround(X.oneSpace)}),this.on(e,isWhereRelationNegation,(e,t)=>{t.keyword(`not`).append(X.oneSpace)}),isWhereRelation(e)){let t=this.getNodeFormatter(e);t.property(`operator`).surround(X.oneSpace),t.property(`not`).surround(X.oneSpace)}}formatWhereElementExpression(e){if(this.on(e,isWhereElementExpression,(e,t)=>{t.property(`operator`).surround(X.oneSpace)}),this.on(e,isWhereElementNegation,(e,t)=>{t.keyword(`not`).append(X.oneSpace)}),isWhereElement(e)){let t=this.getNodeFormatter(e);t.property(`operator`).surround(X.oneSpace),t.property(`not`).surround(X.oneSpace)}}formatIncludeExcludeExpressions(e){if(isDynamicViewRule(e)||isViewRulePredicate(e)||isDeploymentViewRulePredicate(e)){let t=this.getNodeFormatter(e);(!e.$cstNode||!isMultiline(e.$cstNode))&&t.keywords(`include`,`exclude`).append(X.oneSpace)}if(isExpressions(e)){let t=this.getNodeFormatter(e),n=this.findPredicateExpressionRoot(e),r=n?.$cstNode&&isMultiline(n?.$cstNode);r&&t.property(`value`).prepend(X.indent),t.keyword(`,`).prepend(X.noSpace).append(r?X.newLine:X.oneSpace)}}formatRelationExpression(e){this.on(e,isIncomingRelationExpr,(e,t)=>{t.keyword(`->`).append(X.oneSpace)}),this.on(e,isInOutRelationExpr,(e,t)=>{t.keyword(`->`).prepend(X.oneSpace)}),this.on(e,isOutgoingRelationExpr,(e,t)=>{t.keywords(`->`,`<->`).prepend(X.oneSpace),t.keywords(`-[`).prepend(X.oneSpace).append(X.noSpace),t.keywords(`]->`).prepend(X.noSpace).append(X.oneSpace),t.property(`dotKind`).prepend(X.oneSpace).append(X.oneSpace)}),this.on(e,isDirectedRelationExpr,(e,t)=>{t.property(`target`).prepend(X.oneSpace)})}findPredicateExpressionRoot(e){let t=e.$container;for(;;){if(!t||isDynamicViewRule(t)||isViewRulePredicate(t)||isDeploymentViewRulePredicate(t))return t;t=t.$container}}on(e,t,n){let r=t(e)?this.getNodeFormatter(e):void 0;return n&&r&&n(e,r),r}doExtendedFormatting(e){let t=this.quotesNormalizerFactory(this.extendedFormattingCommands);for(let n of this.extendedFormattingCommands)switch(n.type){case`normalizeQuotes`:t(n,e);break;default:V(n.type)}}normalizeQuotes(e){if(this.options.quoteStyle===`ignore`)return;let t=null;if(isMetadataAttribute(e)){let n=e.value;isMetadataArray(n)?t=this.getNodeFormatter(n).nodes(...n.values):n&&(t=this.getNodeFormatter(e).property(`value`))}else t=this.on(e,isStringProperty)?.property(`value`);t??=this.on(e,isElement)?.properties(`props`),t??=this.on(e,isImportsFromPoject)?.properties(`project`),t??=this.on(e,isRelation)?.properties(`title`,`technology`),t??=this.on(e,isViewRuleGroup)?.properties(`title`),t??=this.on(e,isDynamicViewStep)?.properties(`title`),t??=this.on(e,isDeploymentNode$1)?.properties(`title`),t??=this.on(e,isDeployedInstance)?.properties(`title`),t??=this.on(e,isDeploymentRelation)?.properties(`title`,`technology`),t??=this.on(e,isLinkProperty)?.properties(`title`),t&&this.extendedFormattingCommands.push({type:`normalizeQuotes`,region:t})}quotesNormalizerFactory(e){let t=this.options.quoteStyle==`auto`?this.getAutoQuoteStyle(e):this.options.quoteStyle;return(e,n)=>{let r=t===`single`?`"`:`'`,i=t===`single`?`'`:`"`,a=i.repeat(3),o=i,s=e.region.nodes.map(e=>{let t=e.text.startsWith(`"""`)||e.text.startsWith(`'''`)?a:o;return{range:e.range,newText:t+this.escapeQuotesInternalQuotes(e.text.slice(t.length,-t.length),r,i)+t}});n.push(...s)}}escapeQuotesInternalQuotes(e,t,n){let r=``,i=0;for(;i>=0;){let t=e.indexOf(n,i);if(t<0){r+=e.slice(i);break}r+=e.slice(i,t),i=t+1;let a=!1;for(;t>0&&e[t-1]==`\\`;)a=!a,t--;r+=a?n:`\\${n}`}return r}getAutoQuoteStyle(e){let t=e.flatMap(e=>e.region.nodes);return t.filter(e=>e.text[0]==`"`).length*2>=t.length?`double`:`single`}onConfigurationUpdate(e){this.options={...this.options,...e??{quoteStyle:`auto`}}}};Pe();const Uc=G.getChild(`LanguageServices`),isErrorDiagnostic=e=>e.severity===he.Error;var DefaultLikeC4LanguageServices=class{services;builder;editor;projectsManager;constructor(e){this.services=e,this.builder=e.likec4.ModelBuilder,this.projectsManager=e.shared.workspace.ProjectsManager,this.editor=e.likec4.ModelChanges}get views(){return this.services.likec4.Views}get workspaceUri(){return this.services.shared.workspace.WorkspaceManager.workspaceUri}get workspacePath(){return this.workspaceUri.fsPath}projects(){let e=this.services.shared.workspace.ProjectsManager,t=M(this.services.shared.workspace.LangiumDocuments.groupedByProject(),rn(),N(([t,n])=>{let r=t,{folderUri:i,config:a}=e.getProject(r);return{id:r,folder:i,title:a.title??a.name,documents:N(n,An(`uri`)),config:a}}));if(A(t,2)&&e.defaultProjectId){let n=t.findIndex(t=>t.id===e.defaultProjectId);if(n>0){let[e]=t.splice(n,1);return[e,...t]}return t}if(A(t,1))return t;let{id:n,folderUri:r,config:i}=e.default;return[{id:n,folder:r,title:i.title??i.name,documents:[],config:i}]}project(e){let{id:t,folderUri:n,config:r}=this.projectsManager.ensureProject(e),i=N(this.services.shared.workspace.LangiumDocuments.projectDocuments(t).toArray(),An(`uri`));return{id:t,folder:n,title:r.title??r.name,documents:i,config:r}}async diagrams(e,t){let n=this.projectsManager.ensureProjectId(e);return await this.views.diagrams(n,t)}async computedModel(e,t){let n=this.projectsManager.ensureProjectId(e);return await this.builder.computeModel(n,t)}async layoutedModel(e,t){let n=this.projectsManager.ensureProjectId(e),r=await this.builder.computeModel(n,t);if(!r)throw Error(`Failed to compute model, empty project?`);let i=await this.views.layoutAllViews(n,t);return _i.create({...r.$data,_stage:`layouted`,views:M(i,N(An(`diagram`)),Jt(An(`id`)))})}async projectsOverview(e){let t=this.services.shared.workspace.ProjectsManager.all,n=[];for(let r of t){let t=await this.builder.computeModel(r,e);if(e?.isCancellationRequested)throw Error(`Operation cancelled`);if(t===_i.EMPTY){Uc.debug(`Project ${r} is empty, skipping`);continue}n.push(t)}if(!A(n,1))throw Error(`No models found`);let r=Pi(n);return await this.views.layouter.layoutProjectsView(r)}getErrors(){return M(this.services.shared.workspace.LangiumDocuments.userDocuments.toArray(),E(e=>M(e.diagnostics??[],j(isErrorDiagnostic),N(({message:t,range:n})=>({message:t,line:n.start.line,range:n,sourceFsPath:e.uri.fsPath})))))}locate(e){switch(!0){case`element`in e:return this.services.likec4.ModelLocator.locateElement(e.element,e.projectId);case`relation`in e:return this.services.likec4.ModelLocator.locateRelation(e.relation,e.projectId);case`view`in e:return this.services.likec4.ModelLocator.locateView(e.view,e.projectId);case`deployment`in e:return this.services.likec4.ModelLocator.locateDeploymentElement(e.deployment,e.projectId);default:V(e)}}async format(e){let t=this.services.shared.workspace.LangiumDocuments,n=this.services.lsp.Formatter,r=buildFormattingOptions(e),i=this.collectDocumentsToFormat(t,e);i.sort((e,t)=>e.uri.toString().localeCompare(t.uri.toString()));let a=new Map;for(let e of i){let t=e.uri.toString(),i=await n.formatDocument(e,{options:r,textDocument:{uri:t}}),o=i.length===0?e.textDocument.getText():me.applyEdits(e.textDocument,i);a.set(t,o)}return a}collectDocumentsToFormat(e,t){let n=t?.projectIds??[],r=t?.documentUris??[],i=new Map;if(n.length>0)for(let t of n)for(let n of e.projectDocuments(t))i.set(n.uri.toString(),n);else if(r.length===0)for(let t of this.projectsManager.all)for(let n of e.projectDocuments(t))i.set(n.uri.toString(),n);for(let t of r){if(i.has(t))continue;let n;try{n=e.getDocument(v.parse(t))}catch{Uc.warn(`format: skipping unknown document ${t}`);continue}if(!isLikeC4LangiumDocument(n)){Uc.warn(`format: skipping unknown document ${t}`);continue}i.set(t,n)}return[...i.values()]}async dispose(){try{Uc.debug(`disposing LikeC4LanguageServices`),this.services.likec4.ModelBuilder.dispose(),this.services.Rpc.dispose(),await this.services.shared.workspace.FileSystemWatcher.dispose()}catch(e){Uc.error(loggable(e))}finally{Uc.debug(`LikeC4LanguageServices disposed`)}}};function buildFormattingOptions(e){return{tabSize:e?.tabSize??2,insertSpaces:e?.insertSpaces??!0,...e?.trimTrailingWhitespace!=null&&{trimTrailingWhitespace:e.trimTrailingWhitespace},...e?.insertFinalNewline!=null&&{insertFinalNewline:e.insertFinalNewline},...e?.trimFinalNewlines!=null&&{trimFinalNewlines:e.trimFinalNewlines}}}var LikeC4CodeLensProvider=class{services;constructor(e){this.services=e}async provideCodeLens(e,t,n){if(isLikeC4LangiumDocument(e))return e.state<y.Linked&&(G.debug(`Waiting for document ${e.uri.path} to be Linked`),await this.services.shared.workspace.DocumentBuilder.waitUntil(y.Linked,e.uri,n),G.debug(`Document is linked`)),e.parseResult.value.views.flatMap(e=>e.views).flatMap(e=>{let t=Cc.readId(e),n=e.$cstNode?.range;if(!n||!t)return[];let r=projectIdFrom(e);return{range:{start:n.start,end:{line:n.start.line,character:n.start.character+4}},command:{command:`likec4.open-preview`,arguments:[t,r],title:`open preview`}}})}};Pe();function isCompletionForPojectName(e,t){return Ae(t.feature)&&t.property===`project`&&isImportsFromPoject(e.node)}const Wc=`view_\${CURRENT_MINUTE}_\${CURRENT_SECOND} {
|
|
51
|
+
}`,loader:`js`}))}}]}});return Pt(Object.assign(o,s?.default??s))}const la={aws:`activate.alexa-for-business.amplify.apache-mxnet-on-aws.api-gateway.app-config.app-flow.app-mesh.app-runner.app-stream.app-sync.application-auto-scaling.application-composer.application-cost-profiler.application-discovery-service.application-migration-service.artifact.athena.audit-manager.augmented-ai-a2i.aurora.auto-scaling.backint-agent.backup.batch.billing-conductor.bottlerocket.braket.budgets.certificate-manager.chatbot.chime-sdk.chime-voice-connector.chime.clean-rooms.client-vpn.cloud-control-api.cloud-development-kit.cloud-directory.cloud-formation.cloud-front.cloud-hsm.cloud-map.cloud-search.cloud-shell.cloud-trail.cloud-wan.cloud-watch.cloud9.code-artifact.code-build.code-catalyst.code-commit.code-deploy.code-guru.code-pipeline.code-star.code-whisperer.cognito.command-line-interface.comprehend-medical.comprehend.compute-optimizer.config.connect.console-mobile-application.control-tower.corretto.cost-and-usage-report.cost-explorer.data-exchange.data-pipeline.data-sync.data-zone.database-migration-service.deep-composer.deep-learning-amis.deep-learning-containers.deep-lens.deep-racer.detective.dev-ops-guru.device-farm.direct-connect.directory-service.distro-for-open-telemetry.document-db.dynamo-db.ec2-auto-scaling.ec2-image-builder.ec2.ecs-anywhere.efs.eks-anywhere.eks-cloud.eks-distro.elasti-cache.elastic-beanstalk.elastic-block-store.elastic-container-registry.elastic-container-service.elastic-disaster-recovery.elastic-fabric-adapter.elastic-inference.elastic-kubernetes-service.elastic-load-balancing.elastic-transcoder.elemental-appliances-software.elemental-conductor.elemental-delta.elemental-link.elemental-live.elemental-media-connect.elemental-media-convert.elemental-media-live.elemental-media-package.elemental-media-store.elemental-media-tailor.elemental-server.emr.event-bridge.express-workflows.fargate.fault-injection-simulator.file-cache.fin-space.firewall-manager.forecast.fraud-detector.free-rtos.fsx-for-lustre.fsx-for-net-app-ontap.fsx-for-open-zfs.fsx-for-wfs.fsx.game-kit.game-lift.game-sparks.genomics-cli.global-accelerator.glue-data-brew.glue-elastic-views.glue.ground-station.guard-duty.health-lake.honeycode.iam-identity-center.identity-and-access-management.inspector.interactive-video-service.io-t-1-click.io-t-analytics.io-t-button.io-t-core.io-t-device-defender.io-t-device-management.io-t-edu-kit.io-t-events.io-t-express-link.io-t-fleet-wise.io-t-greengrass.io-t-robo-runner.io-t-site-wise.io-t-things-graph.io-t-twin-maker.iq.kendra.key-management-service.keyspaces.kinesis-data-analytics.kinesis-data-streams.kinesis-firehose.kinesis-video-streams.kinesis.lake-formation.lambda.launch-wizard.lex.license-manager.lightsail.local-zones.location-service.lookout-for-equipment.lookout-for-metrics.lookout-for-vision.lumberyard.macie.mainframe-modernization.managed-blockchain.managed-grafana.managed-service-for-prometheus.managed-services.managed-streaming-for-apache-kafka.managed-workflows-for-apache-airflow.management-console.marketplace-dark.marketplace-light.memory-db-for-redis.migration-evaluator.migration-hub.monitron.mq.neptune.network-firewall.neuron.nice-dcv.nice-engin-frame.nimble-studio.nitro-enclaves.omics.open-3d-engine.open-search-service.ops-works.organizations.outposts-family.outposts-rack.outposts-servers.panorama.parallel-cluster.personal-health-dashboard.personalize.pinpoint-apis.pinpoint.polly.private-5g.private-certificate-authority.private-link.professional-services.proton.quantum-ledger-database.quick-sight.rds-on-vmware.rds.re-post.red-hat-open-shift-service-on-aws.redshift.rekognition.reserved-instance-reporting.resilience-hub.resource-access-manager.resource-explorer.robo-maker.route-53.s3-on-outposts.sage-maker-ground-truth.sage-maker-studio-lab.sage-maker.savings-plans.secrets-manager.security-hub.security-lake.server-migration-service.serverless-application-repository.service-catalog.service-management-connector.shield.signer.sim-space-weaver.simple-email-service.simple-notification-service.simple-queue-service.simple-storage-service-glacier.simple-storage-service.site-to-site-vpn.snowball-edge.snowball.snowcone.snowmobile.step-functions.storage-gateway.sumerian.supply-chain.support.systems-manager.tensor-flow-on-aws.textract.thinkbox-deadline.thinkbox-frost.thinkbox-krakatoa.thinkbox-sequoia.thinkbox-stoke.thinkbox-xmesh.timestream.tools-and-sdks.torch-serve.training-certification.transcribe.transfer-family.transit-gateway.translate.trusted-advisor.verified-access.verified-permissions.virtual-private-cloud.vmware-cloud-on-aws.vpc-lattice.waf.wavelength.well-architected-tool.wickr.work-docs-sdk.work-docs.work-link.work-mail.work-spaces-family.x-ray`.split(`.`),azure:`abs-member.active-directory-connect-health.activity-log.administrative-units.advisor.ai-at-edge.ai-studio.aks-automatic.aks-istio.alerts.all-resources.analysis-services.anomaly-detector.api-center.api-connections.api-management-services.api-proxy.app-compliance-automation.app-configuration.app-registrations.app-service-certificates.app-service-domains.app-service-environments.app-service-plans.app-services.app-space-component.app-space.applens.application-gateway-containers.application-gateways.application-group.application-insights.application-security-groups.aquila.arc-data-services.arc-kubernetes.arc-machines.arc-postgre-sql.arc-sql-managed-instance.arc-sql-server.atm-multistack.auto-scale.automanaged-vm.automation-accounts.availability-sets.avs-vm.azure-a.azure-ad-b2c.azure-api-for-fhir.azure-applied-ai-services.azure-arc.azure-attestation.azure-backup-center.azure-blockchain-service.azure-center-for-sap.azure-chaos-studio.azure-cloud-shell.azure-communication-services.azure-communications-gateway.azure-compute-galleries.azure-consumption-commitment.azure-cosmos-db.azure-data-catalog.azure-data-explorer-clusters.azure-database-maria-db-server.azure-database-migration-services.azure-database-my-sql-server.azure-database-postgre-sql-server-group.azure-database-postgre-sql-server.azure-databox-gateway.azure-databricks.azure-deployment-environments.azure-dev-ops.azure-dev-tunnels.azure-edge-hardware-center.azure-experimentation-studio.azure-fileshares.azure-firewall-manager.azure-firewall-policy.azure-hcp-cache.azure-hpc-workbenches.azure-hybrid-center.azure-information-protection.azure-io-t-operations.azure-lighthouse.azure-load-testing.azure-managed-grafana.azure-managed-redis.azure-maps-accounts.azure-media-service.azure-migrate.azure-monitor-dashboard.azure-monitor-pipeline.azure-monitors-for-sap-solutions.azure-net-app-files.azure-network-function-manager-functions.azure-network-function-manager.azure-object-understanding.azure-open-ai.azure-operator-5g-core.azure-operator-insights.azure-operator-nexus.azure-operator-service-manager.azure-orbital.azure-programmable-connectivity.azure-purview-accounts.azure-quotas.azure-red-hat-open-shift.azure-sentinel.azure-service-bus.azure-sphere.azure-spring-apps.azure-sql-edge.azure-sql-server-stretch-databases.azure-sql-vm.azure-sql.azure-stack-edge.azure-stack-hci-sizer.azure-stack.azure-storage-mover.azure-support-center-blue.azure-sustainability.azure-synapse-analytics.azure-token-service.azure-video-indexer.azure-virtual-desktop.azure-vmware-solution.azure-workbooks.azurite.backlog.backup-vault.bare-metal-infrastructure.bastions.batch-accounts.batch-ai.biz-talk.blob-block.blob-page.blockchain-applications.blueprints.bonsai.bot-services.branch.breeze.browser.bug.builds.business-process-tracking.cache-redis.cache.capacity-reservation-groups.capacity.cdn-profiles.central-service-instance-for-sap.ceres.change-analysis.client-apps.cloud-services-classic.cloud-services-extended-support.cloud-test.code-optimization.code.cognitive-search.cognitive-services-decisions.cognitive-services.collaborative-service.commit.community-images.compliance-center.compliance.compute-fleet.computer-vision.conditional-access.confidential-ledgers.connected-cache.connected-vehicle-platform.connections.consortium.container-apps-environments.container-instances.container-registries.container-services-deprecated.content-moderators.content-safety.controls-horizontal.controls.cost-alerts.cost-analysis.cost-budgets.cost-export.cost-management-and-billing.cost-management.counter.cubes.custom-ip-prefix.custom-vision.customer-lockbox-for-microsoft-azure.dashboard-hub.dashboard.data-box.data-collection-rules.data-factories.data-lake-analytics.data-lake-storage-gen1.data-lake-store-gen1.data-share-invitations.data-shares.data-virtualization.database-instance-for-sap.ddo-s-protection-plans.dedicated-hsm.defender-cm-local-manager.defender-dcs-controller.defender-distributer-control-system.defender-engineering-station.defender-external-management.defender-freezer-monitor.defender-historian.defender-hmi.defender-industrial-packaging-system.defender-industrial-printer.defender-industrial-robot.defender-industrial-scale-system.defender-marquee.defender-meter.defender-plc.defender-pneumatic-device.defender-programable-board.defender-relay.defender-robot-controller.defender-rtu.defender-sensor.defender-slot.defender-web-guiding-system.detonation.dev-console.dev-ops-starter.dev-test-labs.device-compliance.device-configuration.device-enrollment.device-provisioning-services.device-security-apple.device-security-google.device-security-windows.device-update-io-t-hub.devices.diagnostics-settings.digital-twins.disk-encryption-sets.disk-pool.disks-classic.disks-snapshots.disks.dns-multistack.dns-private-resolver.dns-security-policy.dns-zones.download.e-books.edge-actions.edge-management.edge-storage-accelerator.education.elastic-job-agents.elastic-san.endpoint-analytics.engage-center-connect.enterprise-applications.entra-connect-health.entra-connect-sync.entra-connect.entra-domain-services.entra-global-secure-access.entra-id-protection.entra-identity-custom-roles.entra-identity-licenses.entra-identity-risky-signins.entra-identity-risky-users.entra-identity-roles-and-administrators.entra-internet-access.entra-managed-identities.entra-private-access.entra-privleged-identity-management.entra-verified-id.error.event-grid-domains.event-grid-subscriptions.event-grid-topics.event-hub-clusters.event-hubs.exchange-access.exchange-on-premises-access.express-route-circuits.express-route-direct.express-route-traffic-collector.extended-security-updates.extensions.external-id-modified.external-id.external-identities.face-apis.feature-previews.fhir-service.fiji.file.files.firewalls.folder-blank.folder-website.form-recognizers.frd-qa.free-services.front-door-and-cdn-profiles.ftp.function-apps.gear.genomics-accounts.genomics.globe-error.globe-success.globe-warning.groups.guide.hd-insight-clusters.hdi-aks-cluster.heart.help-and-support.host-groups.host-pools.hosts.hybrid-connectivity-hub.ic-m-troubleshooting.identity-governance.identity-multi-factor-authentication.identity-secure-score.image-definitions.image-templates.image-versions.image.images.immersive-readers.import-export-jobs.industrial-io-t.information.infrastructure-backup.input-output.instance-pools.integration-accounts.integration-environments.integration-service-environments.internet-analyzer-profiles.intune-app-protection.intune-for-education.intune-trends.intune.io-t-central-applications.io-t-edge.io-t-hub.ip-address-manager.ip-groups.journey-hub.key-vaults.keys.kubernetes-fleet-manager.kubernetes-services.lab-accounts.lab-services.landing-zone.language-understanding.language.launch-portal.learn.load-balancer-hub.load-balancers.load-test.load-testing.local-network-gateways.location.log-analytics-query-pack.log-analytics-workspaces.log-streaming.logic-apps-custom-connector.logic-apps-template.logic-apps.machine-learning-studio-classic-web-services.machine-learning-studio-web-service-plans.machine-learning-studio-workspaces.machine-learning.machines-azure-arc.maintenance-configuration.managed-applications-center.managed-database.managed-desktop.managed-dev-ops-pools.managed-file-shares.managed-identities.managed-instance-apache-cassandra.managed-service-fabric.management-groups.management-portal.marketplace-management.marketplace.med-tech-service.media-file.media.mesh-applications.metrics-advisor.metrics.microsoft-defender-easm.microsoft-defender-for-cloud.microsoft-defender-for-io-t.microsoft-dev-box.mindaro.mission-landing-zone.mobile-engagement.mobile-networks.mobile.modular-data-center.module.monitor-health-models.monitor.multi-tenancy.multifactor-authentication.my-customers.nat.network-foundation-hub.network-interfaces.network-managers.network-security-groups.network-security-hub.network-security-perimeters.network-watcher.notification-hub-namespaces.notification-hubs.offers.on-premises-data-gateways.open-supply-chain-platform.operation-log-classic.oracle-database.os-images-classic.osconfig.outbound-connection.partner-namespace.partner-registration.partner-topic.peering-service.peerings.personalizers.planetary-computer-pro.plans.policy.power-bi-embedded.power-platform.power-up.power.powershell.preview-features.private-endpoints.private-link-service.private-link-services.private-link.process-explorer.production-ready-database.promethus.proximity-placement-groups.public-ip-addresses-classic.public-ip-addresses.public-ip-prefixes.qn-a-makers.quickstart-center.recent.recovery-services-vaults.region-management.relays.remote-rendering.reservations.reserved-capacity.reserved-ip-addresses-classic.resource-explorer.resource-graph-explorer.resource-group-list.resource-groups.resource-guard.resource-linked.resource-management-private-link.resource-mover.resources-provider.restore-points-collections.restore-points.route-filters.route-tables.rtos.savings-plans.scheduler-job-collections.scheduler.scvmm-management-servers.search-grid.search.security-baselines.security.send-grid-accounts.server-farm.serverless-search.service-catalog-mad.service-endpoint-policies.service-fabric-clusters.service-group-relationships.service-groups.service-health.service-providers.shared-image-galleries.signal-r.software-as-a-service.software-updates.solutions.sonic-dash.spatial-anchor-accounts.speech-services.spot-vm.spot-vmss.sql-data-warehouses.sql-database-fleet-manager.sql-database.sql-elastic-pools.sql-managed-instance.sql-server-registries.sql-server.ssd.ssh-keys.ssis-lift-and-shift-ir.stack-hci-premium.static-apps.stor-simple-data-managers.stor-simple-device-managers.storage-accounts-classic.storage-accounts.storage-actions.storage-azure-files.storage-container.storage-explorer.storage-functions.storage-hubs.storage-queue.storage-sync-services.stream-analytics-jobs.subnet.subscriptions.system-topic.table.tag.tags.targets-management.template-specs.templates.tenant-properties.tenant-status.test-base.tfs-vc-repository.time-series-data-sets.time-series-insights-access-policies.time-series-insights-environments.time-series-insights-event-sources.toolbox.toolchain-orchestrator.traffic-manager-profiles.translator-text.troubleshoot.universal-print.update-management-center.updates.user-privacy.user-settings.user-subscriptions.users.verifiable-credentials.verification-as-a-service.versions.video-analyzers.virtual-clusters.virtual-enclaves.virtual-instance-for-sap.virtual-machine.virtual-machines-classic.virtual-network-gateways.virtual-networks-classic.virtual-networks.virtual-router.virtual-visits-builder.virtual-wan-hub.virtual-wans.vm-app-definitions.vm-app-versions.vm-image-version.vm-images-classic.vm-scale-sets.vpnclient-windows.wac-installer.wac.web-app-database.web-application-firewall-policies-waf.web-jobs.web-slots.web-test.website-power.website-staging.windows-notification-services.windows10-core-services.workbooks.worker-container-app.workflow.workload-orchestration.workspace-gateway.workspaces`.split(`.`),gcp:`access-context-manager.administration.advanced-agent-modeling.advanced-solutions-lab.agent-assist.ai-hub.ai-platform-unified.ai-platform.analytics-hub.anthos-config-management.anthos-service-mesh.anthos.api-analytics.api-monetization.api.apigee-api-platform.apigee-sense.app-engine.artifact-registry.asset-inventory.assured-workloads.auto-ml-natural-language.auto-ml-tables.auto-ml-translation.auto-ml-video-intelligence.auto-ml-vision.auto-ml.bare-metal-solutions.batch.beyondcorp.big-query.bigtable.billing.binary-authorization.catalog.certificate-authority-service.certificate-manager.cloud-api-gateway.cloud-apis.cloud-armor.cloud-asset-inventory.cloud-audit-logs.cloud-build.cloud-cdn.cloud-code.cloud-composer.cloud-data-fusion.cloud-deploy.cloud-deployment-manager.cloud-dns.cloud-domains.cloud-ekm.cloud-endpoints.cloud-external-ip-addresses.cloud-firewall-rules.cloud-for-marketing.cloud-functions.cloud-generic.cloud-gpu.cloud-healthcare-api.cloud-healthcare-marketplace.cloud-hsm.cloud-ids.cloud-inference-api.cloud-interconnect.cloud-jobs-api.cloud-load-balancing.cloud-logging.cloud-media-edge.cloud-monitoring.cloud-nat.cloud-natural-language-api.cloud-network.cloud-ops.cloud-optimization-ai-fleet-routing-api.cloud-optimization-ai.cloud-router.cloud-routes.cloud-run-for-anthos.cloud-run.cloud-scheduler.cloud-security-scanner.cloud-shell.cloud-spanner.cloud-sql.cloud-storage.cloud-tasks.cloud-test-lab.cloud-tpu.cloud-translation-api.cloud-vision-api.cloud-vpn.compute-engine.configuration-management.connectivity-test.connectors.contact-center-ai.container-optimized-os.container-registry.data-catalog.data-labeling.data-layers.data-loss-prevention-api.data-qn-a.data-studio.data-transfer.database-migration-service.dataflow.datalab.dataplex.datapol.dataprep.dataproc-metastore.dataproc.datashare.datastore.datastream.debugger.developer-portal.dialogflow-cx.dialogflow-insights.dialogflow.document-ai.early-access-center.error-reporting.eventarc.filestore.financial-services-marketplace.firestore.fleet-engine.free-trial.game-servers.gce-systems-management.genomics.gke-on-prem.google-cloud-marketplace.google-kubernetes-engine.google-maps-platform.healthcare-nlp-api.home.identity-and-access-management.identity-aware-proxy.identity-platform.iot-core.iot-edge.key-access-justifications.key-management-service.kuberun.launcher.local-ssd.looker.managed-service-for-microsoft-active-directory.media-translation-api.memorystore.migrate-for-anthos.migrate-for-compute-engine.my-cloud.network-connectivity-center.network-intelligence-center.network-security.network-tiers.network-topology.onboarding.os-configuration-management.os-inventory-management.os-patch-management.partner-interconnect.partner-portal.performance-dashboard.permissions.persistent-disk.phishing-protection.policy-analyzer.premium-network-tier.private-connectivity.private-service-connect.producer-portal.profiler.project.pub-sub.quantum-engine.quotas.real-world-insights.recommendations-ai.release-notes.retail-api.risk-manager.runtime-config.secret-manager.security-command-center.security-health-advisor.security-key-enforcement.security.service-discovery.speech-to-text.stackdriver.standard-network-tier.stream-suite.support.tensorflow-enterprise.text-to-speech.tools-for-powershell.trace.traffic-director.transfer-appliance.transfer.user-preferences.vertex-ai.video-intelligence-api.virtual-private-cloud.visual-inspection.vmware-engine.web-risk.web-security-scanner.workflows.workload-identity-pool`.split(`.`),tech:`100tb.500px.aarch64.active-campaign-icon.active-campaign.adobe-after-effects.adobe-animate.adobe-dreamweaver.adobe-icon.adobe-illustrator.adobe-incopy.adobe-indesign.adobe-lightroom.adobe-photoshop.adobe-premiere-pro.adobe-premiere.adobe-xd.adobe.adonis-js.adonisjs-icon.adroll.adyen.aerogear.aerospike-icon.aerospike.after-effects.aha.airbnb-icon.airbnb.airbrake.airflow-icon.airflow.airtable.aix.akamai.akka.alfresco.algolia.alpinejs-icon.alpinejs.altair.amazon-chime.amazon-connect.amazon-web-services.amd.amex-digital.amex.amp-icon.amp.ampersand.amplication-icon.amplication.amplitude-icon.amplitude.anaconda.analog.android-icon.android-studio.android-vertical.android.angellist.angular-icon.angular-js.angular.ansible.ant-design.anthropic-icon.anthropic.apache-camel.apache-cloudstack.apache-flink-icon.apache-flink.apache-spark.apache-superset-icon.apache-superset.apache.apiary.apidog-icon.apidog.apl.apollostack.apostrophe.appbaseio-icon.appbaseio.appcelerator.appcenter-icon.appcenter.appcircle-icon.appcircle.appcode.appdynamics-icon.appdynamics.appium.apple-app-store.apple-pay.apple-safari.apple.applitools-icon.applitools.appsignal-icon.appsignal.apptentive.appveyor.appwrite-icon.appwrite.arangodb-icon.arangodb.arc.architect-icon.architect.archlinux.arduino.argo-icon.argo.argocd.arm.armory-icon.armory.asana-icon.asana.asciidoctor.assembla-icon.assembla.astro-icon.astro.astronomer.async-api-icon.async-api.atlassian.atom-icon.atom.atomic-icon.atomic.atomicojs-icon.atomicojs.aurelia.aurora.auth0-icon.auth0.authy.autodesk-maya.autodesk-shot-grid.autoit.autoprefixer.ava.awesome.awk.aws-amplify.aws-api-gateway.aws-app-mesh.aws-appflow.aws-appsync.aws-athena.aws-aurora.aws-backup.aws-batch.aws-certificate-manager.aws-cloudformation.aws-cloudfront.aws-cloudsearch.aws-cloudtrail.aws-cloudwatch.aws-codebuild.aws-codecommit.aws-codedeploy.aws-codepipeline.aws-codestar.aws-cognito.aws-config.aws-documentdb.aws-dynamodb.aws-ec2.aws-ecs.aws-eks.aws-elastic-beanstalk.aws-elasticache.aws-elb.aws-eventbridge.aws-fargate.aws-glacier.aws-glue.aws-iam.aws-keyspaces.aws-kinesis.aws-kms.aws-lake-formation.aws-lambda.aws-lightsail.aws-mq.aws-msk.aws-neptune.aws-open-search.aws-opsworks.aws-quicksight.aws-rds.aws-redshift.aws-route53.aws-s3.aws-secrets-manager.aws-ses.aws-shield.aws-sns.aws-sqs.aws-step-functions.aws-systems-manager.aws-timestream.aws-vpc.aws-waf.aws-xray.aws.axios.azios.azure-devops.azure-sql-database.azure.babel.backbone-icon.backbone-js.backbone.backerkit.baker-street.balena.ballerina.bamboo.basecamp-icon.basecamp.basekit.baseline.bash-icon.bash.batch.beats.behance.bem-2.bem.bigpanda.bing.biomejs-icon.biomejs.bitbar.bitbucket.bitcoin.bitnami.bitrise-icon.bitrise.blender.blitzjs-icon.blitzjs.blocs.blogger.blossom.blueprint.bluesky.bluetooth.booqable-icon.booqable.bootstrap.bosun.botanalytics.bourbon.bower.box.brackets.brainjs.branch-icon.branch.brandfolder-icon.brandfolder.brave.braze-icon.braze.broadcom-icon.broadcom.broccoli.brotli.browserify-icon.browserify.browserling.browserslist.browserstack.browsersync.brunch.bubble-icon.bubble.buck.buddy.buffer.bugherd-icon.bugherd.bugsee.bugsnag.builder-io-icon.builder-io.buildkite-icon.buildkite.bulma.bun.bunny-net-icon.bunny-net.c.cachet.cairo-graphics.cake-php.cakephp-icon.calibre-icon.calibre.campaignmonitor-icon.campaignmonitor.canjs.canva.capacitor.capacitorjs-icon.capacitorjs.capistrano.carbide.cardano-icon.cardano.cassandra.cent-os.centos-icon.certbot.ceylon.chai.chalk.chargebee-icon.chargebee.chartjs.chef.chevereto.chroma.chromatic-icon.chromatic.chrome-web-store.chrome.cinder.circle-ci.cirrus-ci.cirrus.clarity.claude-icon.claude.clio-lang.clion.cljs.clojure-script.clojure.close.cloud9.cloudacademy-icon.cloudacademy.cloudcraft.cloudflare-icon.cloudflare-workers-icon.cloudflare-workers.cloudflare.cloudinary-icon.cloudinary.cloudlinux.cmake.cobalt.cockpit.cocoapods.coda-icon.coda.codacy.code-igniter.code-pen.codeac.codebase.codebeat.codecademy.codeception.codeclimate-icon.codeclimate.codecov-icon.codecov.codefactor-icon.codefactor.codeigniter-icon.codepen-icon.codersrank-icon.codersrank.coderwall.codesandbox-icon.codesandbox.codesee-icon.codesee.codio.codium-icon.codium.coffee-script.commitizen.compass.componentkit.compose-multiplatform.compose.composer.conan-io.concourse.concretecms-icon.concretecms.conda.confluence.consul.contao.contentful.convox-icon.convox.copyleft-pirate.copyleft.corda.cordova.cosmosdb.couchbase.couchdb-icon.couchdb.coursera.coveralls.cpanel.cplusplus.craftcms.crashlytics.crateio.create-react-app.createjs.crossplane-icon.crossplane.crucible.crystal.csharp.css3-official.css3.cssnext.cube-icon.cube.cucumber.curl.customerio-icon.customerio.cyclejs.cypress-icon.cypress.d3.d3js.dailydev-icon.dailydev.daisy-ui-icon.daisy-ui.danfo.dart.dashlane-icon.dashlane.data-grip.data-spell.data-station.database-labs.datadog-icon.datadog.datasette-icon.datasette.datocms-icon.datocms.dbeaver.dbt-icon.dbt.dcos-icon.dcos.debian.delighted-icon.delighted.deno.dependabot.deployhq-icon.deployhq.derby.descript-icon.descript.designernews.deviantart-icon.deviantart.devicon.dgraph-icon.dgraph.dialogflow.digital-ocean-icon.digital-ocean.dimer.dinersclub.discord-icon.discord-js.discord.discourse-icon.discourse.discover.disqus.django-icon.django-rest.django.dockbit.docker-icon.docker.doctrine.docusaurus.dojo-icon.dojo-toolkit.dojo.dolt.dotnet.dovetail-icon.dovetail.dreamhost.dribbble-icon.dribbble.drift.drip.drizzle-icon.drizzle.drone-icon.drone.drools-icon.drools.dropbox.dropmark.dropwizard.dropzone.drupal-icon.drupal.duckduckgo.dynatrace-icon.dynatrace.dyndns.ebanx.eclipse-ceylon.eclipse-icon.eclipse-ide.eclipse-vert-x.eclipse.ecma.edgedb.edgio-icon.edgio.editorconfig.effect-icon.effect.effector.egghead.elasticbeats.elasticpath-icon.elasticpath.elasticsearch.electron.element.elemental-ui.elementary.eleventy-11ty.eleventy.elixir.ello.elm-classic.elm.elo.emacs-classic.emacs.embedded-c.embedly.ember-js.ember-tomster.ember.emmet.enact.engine-yard-icon.engine-yard.envato.envoy-icon.envoy.envoyer.eraser-icon.eraser.erlang.esbuild.esdoc.eslint-old.eslint.eta-icon.eta.etcd.ethereum-color.ethereum.ethers.ethnio.eventbrite-icon.eventbrite.eventsentry.evergreen-icon.evergreen.expo-icon.expo.express.fabric.facebook.faker.falcor.fast-api.fastapi-icon.fastify-icon.fastify.fastlane.fastly.fauna-icon.fauna.feathers.feathersjs.fedora.fetch.ffmpeg-icon.ffmpeg.figma.file-zilla.firebase-icon.firebase.firefox.flannel.flarum.flask.flat-ui.flattr-icon.flattr.fleep.flickr-icon.flickr.flight.floodio.flow.flowxo.floydhub.flutter.flux.fluxxor.fly-icon.fly.fogbugz-icon.fogbugz.fomo-icon.fomo.font-awesome.forestadmin-icon.forestadmin.forever.formkeep.fortran.foundation.foundationdb-icon.foundationdb.framer.framework7-icon.framework7.freebsd.freedcamp-icon.freedcamp.freedomdefined.fresh.frontapp.fsharp.fuchsia.galliumos.game-analytics-icon.game-analytics.ganache-icon.ganache.gatling.gatsby.gazebo.gcc.geekbot.geetest-icon.geetest.gentoo.getyourguide.ghost.giantswarm.gimp.gin.git-icon.git.gitboard.gitbook.github-actions.github-codespaces.github-copilot.github-icon.github-octocat.github.gitkraken.gitlab-icon.gitlab.gitpod.gitter.gitup.glamorous-icon.glamorous.gleam.glimmerjs.glint.glitch-icon.glitch.gnome-icon.gnome.gnu-emacs.gnu-net.gnu.gnupg-icon.gnupg.go-land.go.gocd.godot-engine.godot-icon.godot.gohorse.google-360suite.google-admob.google-ads.google-adsense.google-analytics.google-bard-icon.google-bard.google-calendar.google-cloud-functions.google-cloud-run.google-cloud.google-data-studio.google-developers.google-domains-icon.google-domains.google-drive.google-fit.google-gemini.google-gmail.google-home.google-icon.google-keep.google-maps.google-marketing-platform.google-meet.google-one.google-optimize.google-palm.google-pay.google-photos.google-play-console-icon.google-play-console.google-play-icon.google-play.google-search-console.google-tag-manager.google-workspace.google.gopher.gradio-icon.gradio.gradle.grafana.grails.grammarly-icon.grammarly.graphene.graphql.grav.gravatar-icon.gravatar.graylog-icon.graylog.greensock-icon.greensock.gridsome-icon.gridsome.grommet.groovehq.groovy.grove.growth-book-icon.growth-book.grpc.grunt.gruntjs.gulp.gulpjs.gunicorn.gunjs.gusto.gwt.hack.hacker-one.hadoop.haiku-icon.haiku.haml.hanami.handlebars.hapi.hardhat-icon.hardhat.harness-icon.harness.harvester.hashicorp-icon.hashicorp-vault.hashicorp.hashnode-icon.hashnode.haskell-icon.haskell.hasura-icon.hasura.haxe.haxl.hbase.hcaptcha-icon.hcaptcha.headlessui-icon.headlessui.heap-icon.heap.helm.helpscout-icon.helpscout.hermes.heroku-icon.heroku-redis.heroku.hexo.hhvm.hibernate.highcharts.hipercard.homebrew.hono.hookstate.hootsuite-icon.hootsuite.hosted-graphite.hostgator-icon.hostgator.hotjar-icon.hotjar.houndci.html5-boilerplate.html5.htmx-icon.htmx.httpie-icon.httpie.hubspot.hugging-face-icon.hugging-face.huggy.hugo.humongous.hyper.hyperapp.ibm-spss-statistics.ibm.ie10.ieee.ietf.ifttt.imagemin.imba-icon.imba.immer-icon.immer.immutable.impala.importio-icon.importio.incident-icon.incident.infer.inferno.influxdb-icon.influxdb.ink.inkscape.insomnia.instagram-icon.instagram.intel.intellij-idea.intercom-icon.intercom.internet-computer-icon.internet-computer.internetexplorer.invision-icon.invision.ionic-icon.ionic.ios.iron-icon.iron.itsalive-icon.itsalive.jade.jaeger.jamstack-icon.jamstack.jasmine.java.javascript.jcb.jeet.jekyll.jenkins.jest.jetbrains-icon.jetbrains-space-icon.jetbrains-space.jetbrains.jfrog.jhipster-icon.jhipster.jira-align.jira.joomla.jotai.jquery-mobile.jquery.jruby.jsbin.jsdelivr.jsdom.jsfiddle.json-ld.json-schema-icon.json-schema.json.jspm.jss.juju.jule.julia.junit.jupyter.jwt-icon.jwt.k3os.k3s.kafka-icon.kafka.kaggle.kaios.kallithea.karate.karma.katalon-icon.katalon.kde.keen.kemal.keras.keycdn-icon.keycdn.keydb-icon.keydb.keystonejs.khan-academy-icon.khan-academy.kibana.kickstarter-icon.kickstarter.kinto-icon.kinto.kirby-icon.kirby.knex-js.knex.knockout.koa.kong-icon.kong.kops.koreio.kotlin-icon.kotlin.kraken.krakenjs.ktor-icon.ktor.kubernetes.kustomer.labview.languagetool.laravel.lastfm.lateral-icon.lateral.latex.launchdarkly-icon.launchdarkly.launchrock.leaflet.leankit-icon.leankit.lerna.less-js.less.lets-cloud.letsencrypt.leveldb.lexical-icon.lexical.liftweb.lighthouse.lightstep-icon.lightstep.lighttpd.linear-icon.linear.linkedin-icon.linkedin.linkerd.linode.linux-mint.linux-tux.linux.liquibase.lit-icon.lit.litmus.livewire.llvm.loader.lodash.logentries.logstash.lookback.looker-icon.looker.loom-icon.loom.loopback-icon.loopback.losant.lua.lucene-net.lucene.lumen.mac-os.madge.maestro.mageia.magento.mailchimp-freddie.mailchimp.maildeveloper.mailgun-icon.mailgun.mailjet-icon.mailjet.malinajs.manjaro.mantine-icon.mantine.mapbox-icon.mapbox.maps-me.mapzen-icon.mapzen.mariadb-icon.mariadb.marionette.markdown.marko.marvel.mastercard.mastodon-icon.mastodon.material-ui.materialize.materializecss.matlab.matomo-icon.matomo.matplotlib-icon.matplotlib.matter-icon.matter.mattermost-icon.mattermost.mautic-icon.mautic.maven.mdn.mdx.medium-icon.medium.medusa-icon.medusa.meilisearch.memcached.memgraph.mention.mercurial.mesos.messenger.meta-icon.meta.metabase.metamask-icon.metamask.meteor-icon.meteor-js.meteor.micro-icon.micro-python.micro.microcosm.micron-icon.micron.microsoft-azure.microsoft-edge.microsoft-icon.microsoft-onedrive.microsoft-power-bi.microsoft-sql-server.microsoft-teams.microsoft-windows-icon.microsoft-windows.microsoft.mida-icon.mida.middleman.midjourney.milligram.million-icon.million.milvus-icon.milvus.mindsdb-icon.mindsdb.minitab.mint-lang.mio.miro-icon.miro.mist.mistral-ai-icon.mistral-ai.mithril.mixmax.mixpanel.mlab.mob-x.mocha.mockflow-icon.mockflow.modernizr.modx-icon.modx.moleculer.momentjs.monday-icon.monday.monero.mongodb-icon.mongodb.mongoose-js.mono.moodle.moon.mootools.morpheus-icon.morpheus.mozilla.mparticle-icon.mparticle.mps-icon.mps.ms-dos.msw-icon.msw.multipass.mysql-icon.mysql.naiveui.namecheap.nano.nanonets.nasm.nativescript.nats-icon.nats.neat.neo4j.neon-icon.neon.neovim.nerog.nestjs.net-core.net.netbeans.netflix-icon.netflix.netlify-icon.netlify.network-x.neverinstall-icon.neverinstall.new-relic-icon.new-relic.new4j.nextjs-icon.nextjs.nginx.ngrok.nhibernate.nhost-icon.nhost.nightwatch.nim-lang.nim.nimble.nix.nocodb.nodal.node-sass.nodebots.nodejs-icon-alt.nodejs-icon.nodejs.nodemon.nodeos.nodewebkit.nomad-icon.nomad.notion-icon.notion.noysi.npm-icon.npm.nuclide.nuget.num-py.nuxt-icon.nuxt-js.nuxt.nvidia.nvm.nx.oauth.objective-c.observablehq.obsidian-icon.obsidian.ocaml.octodns.octopus-deploy.oh-my-zsh.okta-icon.okta.olark.onesignal.open-al.open-api.open-cl.open-cv.open-gl.open-graph.open-stack.open-suse.open-telemetry.open-zeppelin-icon.open-zeppelin.openai-icon.openai.openapi-icon.opencart.opencollective.openframeworks.openjs-foundation-icon.openjs-foundation.openlayers.opensearch-icon.opensearch.openshift.opensource.openstack-icon.opentelemetry-icon.opera.opsgenie.optimizely-icon.optimizely.oracle.oreilly.origami.origin.oshw.osquery.overloop-icon.overloop.p5js.packer.pagekit.pagekite.pagerduty-icon.pagerduty.panda.pandacss-icon.pandacss.pandas-icon.pandas.parcel-icon.parcel.parse.parsehub.partytown-icon.partytown.passbolt-icon.passbolt.passport.patreon.payload.paypal.peer5.pepperoni.percona.percy-icon.percy.perf-rocks.perl.perplexity-icon.perplexity.pf-sense.phalcon.phoenix-framework.phoenix.photon-engine.php-alt.php-storm.php.pinecone-icon.pinecone.pinia.pinterest.pipedream.pipedrive.pipefy.pivotal-tracker.pixijs.pkg.planetscale.planless-icon.planless.plasmic.plastic-scm.platformio.play.playwright.playwrite.ploty.pluralsight-icon.pluralsight.pm2-icon.pm2.pnpm.pocket-base.podman.poeditor.polygon.polymer.portainer.postcss.postgraphile.postgresql.posthog-icon.posthog.postman-icon.postman.pouchdb.powershell.preact.precursor.prerender-icon.prerender.prestashop-icon.prestashop.presto-icon.presto.prettier.prisma.prismic-icon.prismic.processing.processwire-icon.processwire.productboard-icon.productboard.producthunt.progress.prometheus.promises.proofy.protoio.protonet.protractor.prott.pug.pulumi-icon.pulumi.pumpkindb.puppet-icon.puppet.puppeteer.purescript-icon.purescript.pushbullet.pusher-icon.pusher.putty.pwa.pycharm.pypi.pyscript.pytest.python-poetry.python.pytorch-icon.pytorch.pyup.q.qdrant-icon.qdrant.qlik.qodana.qt.qualcomm.quarkus-icon.quarkus.quasar.quay.quobyte.quora.qwik-icon.qwik.r-lang.r.rabbitmq-icon.rabbitmq.rackspace-icon.rackspace.rails.ramda.raml.rancher-icon.rancher.raphael.raspberry-pi.rax.reach.react-bootstrap.react-query-icon.react-query.react-router.react-spring.react-styleguidist.react.reactivex.realm.reapp.reasonml-icon.reasonml.recaptcha.recoil-icon.recoil.red-cube-s-epic-compiler-thingy-programming-re-ct.reddit-icon.reddit.redhat-icon.redhat.redis.redsmin.redux-observable.redux-saga.redux.redwoodjs.reindex.relay.release.remix-icon.remix.ren-py.renovatebot.replay-icon.replay.replit-icon.replit.require.rescript-icon.rescript.rest-li.rethinkdb.retool-icon.retool.riak.rider.riot.risingwave-icon.risingwave.robot-operating-system-ros.rocket-chat-icon.rocket-chat.rocksdb.rocky-linux-icon.rocky-linux.rollbar-icon.rollbar.rollupjs.rome-icon.rome.ros.rsa.rsmq.rspec.rstudio.rubocop.ruby-mine.ruby-on-rails.ruby.rubygems.rum.runscope.rush-icon.rush.rust.rxdb.safari.sagui.sails.salesforce.sameroom.samsung.sanity.sap.sass-doc.sass.saucelabs.scala.scaledrone.scalingo.scribd-icon.scribd.sdl.seaborn-icon.seaborn.section-icon.section.segment-icon.segment.selenium.sema-software.semantic-release.semantic-ui.semaphoreci.sencha.sendgrid-icon.sendgrid.seneca.sensu-icon.sensu.sentry-icon.sentry.sequelize.serverless.sherlock-icon.sherlock.shields.shipit.shogun.shopify.shopware.shortcut-icon.shortcut.sidekiq-icon.sidekiq.signal.sigstore-icon.sigstore.sinatra.singlestore-icon.singlestore.sitepoint.sk-hynix.skaffolder.sketch.skylight.skype.slack-icon.slack.slides.slidev.slim.smartling.smashingmagazine.snap-svg.snaplet-icon.snaplet.snowflake-icon.snowflake.snowpack.snyk.socket-io.solarwinds.solid.solidity.solidjs-icon.solidjs.solr.sonarcloud-icon.sonarcloud.sonarlint-icon.sonarlint.sonarqube.soundcloud.sourcegraph.sourcetree.spark.sparkpost.speakerdeck.speedcurve.spidermonkey-icon.spidermonkey.spinnaker.splunk.spotify-icon.spotify.spree.spring-icon.spring.sql-developer.sqlalchemy.sqlite.square.squarespace.ssh.sst-icon.sst.stability-ai-icon.stability-ai.stackbit-icon.stackbit.stackblitz-icon.stackblitz.stackoverflow-icon.stackoverflow.stackshare.stata.stately-icon.stately.statuspage.stdlib-icon.stdlib.steam.stenciljs-icon.stenciljs.stetho.stickermule.stigg-icon.stigg.stimulus-icon.stimulus.stitch.stoplight.storyblocks-icon.storyblocks.storyblok-icon.storyblok.storybook-icon.storybook.strapi-icon.strapi.streamlit.strider.stripe.struts.styleci.stylefmt.stylelint.stylis.stylus.stytch.sublimetext-icon.sublimetext.subversion.sugarss.supabase-icon.supabase.supertokens-icon.supertokens.surge.surrealdb-icon.surrealdb.survicate-icon.survicate.suse.susy.svelte-icon.svelte-kit.svelte.svg.svgator.swagger.swc.swift.swiftype.swimm.swr.symfony.sysdig-icon.sysdig.t3.tableau-icon.tableau.taiga.tailwindcss-icon.tailwindcss.tapcart-icon.tapcart.taskade-icon.taskade.tastejs.tauri.tealium.teamcity.teamgrid.teamwork-icon.teamwork.telegram.tensorflow.terminal.terraform-icon.terraform.terser-icon.terser.testcafe.testing-library.testlodge.tex.the-algorithms.threejs.thymeleaf-icon.thymeleaf.tidal-icon.tidal.tiktok-icon.tiktok.titanium-sdk.tnw.todoist-icon.todoist.todomvc.tomcat.toml.tor-browser.tor.tortoise-git.tower.traackr.trac.traefik-mesh.traefik-proxy.travis-ci-monochrome.travis-ci.treasuredata-icon.treasuredata.treehouse-icon.treehouse.trello.trpc.truffle-icon.truffle.tsmc.tsnode.tsuru.tumblr-icon.tumblr.tunein.tuple.turbopack-icon.turbopack.turborepo-icon.turborepo.turret.twilio-icon.twilio.twitch.twitter.typeform-icon.typeform.typeorm.typescript-icon-round.typescript-icon.typescript.typesense-icon.typesense.typo3-icon.typo3.ubuntu.udacity-icon.udacity.udemy-icon.udemy.uikit.uml.umu.unbounce-icon.unbounce.undertow.unionpay.unitjs.unito-icon.unito.unity.unix.unjs.unocss.unrealengine-icon.unrealengine.upcase.upstash-icon.upstash.upwork.user-testing-icon.user-testing.uservoice-icon.uservoice.uwsgi.v8-ignition.v8-turbofan.v8.vaadin.vaddy.vagrant-icon.vagrant.vala.vault-icon.vault.vector.vercel-icon.vercel.verdaccio-icon.verdaccio.vernemq.veutify.vim.vimeo-icon.vimeo.visa.visaelectron.visual-studio-code.visual-studio.vite.vitejs.vitess.vitest.vivaldi-icon.vivaldi.vlang.vmware.void.volar.vorejs.vscode.vsphere.vue-storefront.vue.vuetifyjs.vueuse.vulkan.vultr-icon.vultr.vwo.vyper.w3c.waffle-icon.waffle.wagtail.wakatime.walkme.watchman.waypoint-icon.waypoint.wayscript-icon.wayscript.wearos.weave.web-dev-icon.web-dev.web3js.webassembly.webcomponents.webdriverio.webflow.webgpu.webhint-icon.webhint.webhooks.webix-icon.webix.webkit.weblate.webmin.webpack.webplatform.webrtc.websocket.webstorm.webtorrent.weebly.whalar-icon.whalar.whatsapp-icon.whatsapp-monochrome-icon.whatsapp.whatwg.wicket-icon.wicket.wifi.wildfly.windi-css.windows11.windows8.winglang-icon.winglang.wire.wix.wmr.woo-commerce.woocommerce-icon.woopra.wordpress-icon-alt.wordpress-icon.wordpress.workboard.workos-icon.workos.workplace-icon.workplace.wpengine.wufoo.x.xamarin.xampp.xata-icon.xata.xcart.xcode.xero.xml.xray-for-jira.xstate.xtend.xwiki-icon.xwiki.yahoo.yaml.yammer.yandex-ru.yarn.ycombinator.yeoman.yii-framework.yii.youtrack.youtube-icon.youtube.yugabyte-icon.yugabyte.yuno-host.zabbix.zapier.zend-framework.zendesk-icon.zendesk.zenhub-icon.zenhub.zeplin.zeroheight-icon.zeroheight.zig.zod.zoho.zoom-icon.zoom.zorin-os.zsh.zube.zulip-icon.zulip.zwave`.split(`.`),bootstrap:`0-circle-fill.0-circle.0-square-fill.0-square.1-circle-fill.1-circle.1-square-fill.1-square.123.2-circle-fill.2-circle.2-square-fill.2-square.3-circle-fill.3-circle.3-square-fill.3-square.4-circle-fill.4-circle.4-square-fill.4-square.5-circle-fill.5-circle.5-square-fill.5-square.6-circle-fill.6-circle.6-square-fill.6-square.7-circle-fill.7-circle.7-square-fill.7-square.8-circle-fill.8-circle.8-square-fill.8-square.9-circle-fill.9-circle.9-square-fill.9-square.activity.airplane-engines-fill.airplane-engines.airplane-fill.airplane.alarm-fill.alarm.alexa.align-bottom.align-center.align-end.align-middle.align-start.align-top.alipay.alphabet-uppercase.alphabet.alt.amazon.amd.android.android2.app-indicator.app.apple.archive-fill.archive.arrow-90deg-down.arrow-90deg-left.arrow-90deg-right.arrow-90deg-up.arrow-bar-down.arrow-bar-left.arrow-bar-right.arrow-bar-up.arrow-clockwise.arrow-counterclockwise.arrow-down-circle-fill.arrow-down-circle.arrow-down-left-circle-fill.arrow-down-left-circle.arrow-down-left-square-fill.arrow-down-left-square.arrow-down-left.arrow-down-right-circle-fill.arrow-down-right-circle.arrow-down-right-square-fill.arrow-down-right-square.arrow-down-right.arrow-down-short.arrow-down-square-fill.arrow-down-square.arrow-down-up.arrow-down.arrow-left-circle-fill.arrow-left-circle.arrow-left-right.arrow-left-short.arrow-left-square-fill.arrow-left-square.arrow-left.arrow-repeat.arrow-return-left.arrow-return-right.arrow-right-circle-fill.arrow-right-circle.arrow-right-short.arrow-right-square-fill.arrow-right-square.arrow-right.arrow-through-heart-fill.arrow-through-heart.arrow-up-circle-fill.arrow-up-circle.arrow-up-left-circle-fill.arrow-up-left-circle.arrow-up-left-square-fill.arrow-up-left-square.arrow-up-left.arrow-up-right-circle-fill.arrow-up-right-circle.arrow-up-right-square-fill.arrow-up-right-square.arrow-up-right.arrow-up-short.arrow-up-square-fill.arrow-up-square.arrow-up.arrows-angle-contract.arrows-angle-expand.arrows-collapse-vertical.arrows-collapse.arrows-expand-vertical.arrows-expand.arrows-fullscreen.arrows-move.arrows-vertical.arrows.aspect-ratio-fill.aspect-ratio.asterisk.at.award-fill.award.back.backpack-fill.backpack.backpack2-fill.backpack2.backpack3-fill.backpack3.backpack4-fill.backpack4.backspace-fill.backspace-reverse-fill.backspace-reverse.backspace.badge-3d-fill.badge-3d.badge-4k-fill.badge-4k.badge-8k-fill.badge-8k.badge-ad-fill.badge-ad.badge-ar-fill.badge-ar.badge-cc-fill.badge-cc.badge-hd-fill.badge-hd.badge-sd-fill.badge-sd.badge-tm-fill.badge-tm.badge-vo-fill.badge-vo.badge-vr-fill.badge-vr.badge-wc-fill.badge-wc.bag-check-fill.bag-check.bag-dash-fill.bag-dash.bag-fill.bag-heart-fill.bag-heart.bag-plus-fill.bag-plus.bag-x-fill.bag-x.bag.balloon-fill.balloon-heart-fill.balloon-heart.balloon.ban-fill.ban.bandaid-fill.bandaid.bank.bank2.bar-chart-fill.bar-chart-line-fill.bar-chart-line.bar-chart-steps.bar-chart.basket-fill.basket.basket2-fill.basket2.basket3-fill.basket3.battery-charging.battery-full.battery-half.battery.behance.bell-fill.bell-slash-fill.bell-slash.bell.bezier.bezier2.bicycle.bing.binoculars-fill.binoculars.blockquote-left.blockquote-right.bluetooth.body-text.book-fill.book-half.book.bookmark-check-fill.bookmark-check.bookmark-dash-fill.bookmark-dash.bookmark-fill.bookmark-heart-fill.bookmark-heart.bookmark-plus-fill.bookmark-plus.bookmark-star-fill.bookmark-star.bookmark-x-fill.bookmark-x.bookmark.bookmarks-fill.bookmarks.bookshelf.boombox-fill.boombox.bootstrap-fill.bootstrap-icons.bootstrap-reboot.bootstrap.border-all.border-bottom.border-center.border-inner.border-left.border-middle.border-outer.border-right.border-style.border-top.border-width.border.bounding-box-circles.bounding-box.box-arrow-down-left.box-arrow-down-right.box-arrow-down.box-arrow-in-down-left.box-arrow-in-down-right.box-arrow-in-down.box-arrow-in-left.box-arrow-in-right.box-arrow-in-up-left.box-arrow-in-up-right.box-arrow-in-up.box-arrow-left.box-arrow-right.box-arrow-up-left.box-arrow-up-right.box-arrow-up.box-fill.box-seam-fill.box-seam.box.box2-fill.box2-heart-fill.box2-heart.box2.boxes.braces-asterisk.braces.bricks.briefcase-fill.briefcase.brightness-alt-high-fill.brightness-alt-high.brightness-alt-low-fill.brightness-alt-low.brightness-high-fill.brightness-high.brightness-low-fill.brightness-low.brilliance.broadcast-pin.broadcast.browser-chrome.browser-edge.browser-firefox.browser-safari.brush-fill.brush.bucket-fill.bucket.bug-fill.bug.building-add.building-check.building-dash.building-down.building-exclamation.building-fill-add.building-fill-check.building-fill-dash.building-fill-down.building-fill-exclamation.building-fill-gear.building-fill-lock.building-fill-slash.building-fill-up.building-fill-x.building-fill.building-gear.building-lock.building-slash.building-up.building-x.building.buildings-fill.buildings.bullseye.bus-front-fill.bus-front.c-circle-fill.c-circle.c-square-fill.c-square.cake-fill.cake.cake2-fill.cake2.calculator-fill.calculator.calendar-check-fill.calendar-check.calendar-date-fill.calendar-date.calendar-day-fill.calendar-day.calendar-event-fill.calendar-event.calendar-fill.calendar-heart-fill.calendar-heart.calendar-minus-fill.calendar-minus.calendar-month-fill.calendar-month.calendar-plus-fill.calendar-plus.calendar-range-fill.calendar-range.calendar-week-fill.calendar-week.calendar-x-fill.calendar-x.calendar.calendar2-check-fill.calendar2-check.calendar2-date-fill.calendar2-date.calendar2-day-fill.calendar2-day.calendar2-event-fill.calendar2-event.calendar2-fill.calendar2-heart-fill.calendar2-heart.calendar2-minus-fill.calendar2-minus.calendar2-month-fill.calendar2-month.calendar2-plus-fill.calendar2-plus.calendar2-range-fill.calendar2-range.calendar2-week-fill.calendar2-week.calendar2-x-fill.calendar2-x.calendar2.calendar3-event-fill.calendar3-event.calendar3-fill.calendar3-range-fill.calendar3-range.calendar3-week-fill.calendar3-week.calendar3.calendar4-event.calendar4-range.calendar4-week.calendar4.camera-fill.camera-reels-fill.camera-reels.camera-video-fill.camera-video-off-fill.camera-video-off.camera-video.camera.camera2.capslock-fill.capslock.capsule-pill.capsule.car-front-fill.car-front.card-checklist.card-heading.card-image.card-list.card-text.caret-down-fill.caret-down-square-fill.caret-down-square.caret-down.caret-left-fill.caret-left-square-fill.caret-left-square.caret-left.caret-right-fill.caret-right-square-fill.caret-right-square.caret-right.caret-up-fill.caret-up-square-fill.caret-up-square.caret-up.cart-check-fill.cart-check.cart-dash-fill.cart-dash.cart-fill.cart-plus-fill.cart-plus.cart-x-fill.cart-x.cart.cart2.cart3.cart4.cash-coin.cash-stack.cash.cassette-fill.cassette.cast.cc-circle-fill.cc-circle.cc-square-fill.cc-square.chat-dots-fill.chat-dots.chat-fill.chat-heart-fill.chat-heart.chat-left-dots-fill.chat-left-dots.chat-left-fill.chat-left-heart-fill.chat-left-heart.chat-left-quote-fill.chat-left-quote.chat-left-text-fill.chat-left-text.chat-left.chat-quote-fill.chat-quote.chat-right-dots-fill.chat-right-dots.chat-right-fill.chat-right-heart-fill.chat-right-heart.chat-right-quote-fill.chat-right-quote.chat-right-text-fill.chat-right-text.chat-right.chat-square-dots-fill.chat-square-dots.chat-square-fill.chat-square-heart-fill.chat-square-heart.chat-square-quote-fill.chat-square-quote.chat-square-text-fill.chat-square-text.chat-square.chat-text-fill.chat-text.chat.check-all.check-circle-fill.check-circle.check-lg.check-square-fill.check-square.check.check2-all.check2-circle.check2-square.check2.chevron-bar-contract.chevron-bar-down.chevron-bar-expand.chevron-bar-left.chevron-bar-right.chevron-bar-up.chevron-compact-down.chevron-compact-left.chevron-compact-right.chevron-compact-up.chevron-contract.chevron-double-down.chevron-double-left.chevron-double-right.chevron-double-up.chevron-down.chevron-expand.chevron-left.chevron-right.chevron-up.circle-fill.circle-half.circle-square.circle.clipboard-check-fill.clipboard-check.clipboard-data-fill.clipboard-data.clipboard-fill.clipboard-heart-fill.clipboard-heart.clipboard-minus-fill.clipboard-minus.clipboard-plus-fill.clipboard-plus.clipboard-pulse.clipboard-x-fill.clipboard-x.clipboard.clipboard2-check-fill.clipboard2-check.clipboard2-data-fill.clipboard2-data.clipboard2-fill.clipboard2-heart-fill.clipboard2-heart.clipboard2-minus-fill.clipboard2-minus.clipboard2-plus-fill.clipboard2-plus.clipboard2-pulse-fill.clipboard2-pulse.clipboard2-x-fill.clipboard2-x.clipboard2.clock-fill.clock-history.clock.cloud-arrow-down-fill.cloud-arrow-down.cloud-arrow-up-fill.cloud-arrow-up.cloud-check-fill.cloud-check.cloud-download-fill.cloud-download.cloud-drizzle-fill.cloud-drizzle.cloud-fill.cloud-fog-fill.cloud-fog.cloud-fog2-fill.cloud-fog2.cloud-hail-fill.cloud-hail.cloud-haze-fill.cloud-haze.cloud-haze2-fill.cloud-haze2.cloud-lightning-fill.cloud-lightning-rain-fill.cloud-lightning-rain.cloud-lightning.cloud-minus-fill.cloud-minus.cloud-moon-fill.cloud-moon.cloud-plus-fill.cloud-plus.cloud-rain-fill.cloud-rain-heavy-fill.cloud-rain-heavy.cloud-rain.cloud-slash-fill.cloud-slash.cloud-sleet-fill.cloud-sleet.cloud-snow-fill.cloud-snow.cloud-sun-fill.cloud-sun.cloud-upload-fill.cloud-upload.cloud.clouds-fill.clouds.cloudy-fill.cloudy.code-slash.code-square.code.coin.collection-fill.collection-play-fill.collection-play.collection.columns-gap.columns.command.compass-fill.compass.cone-striped.cone.controller.cookie.copy.cpu-fill.cpu.credit-card-2-back-fill.credit-card-2-back.credit-card-2-front-fill.credit-card-2-front.credit-card-fill.credit-card.crop.crosshair.crosshair2.cup-fill.cup-hot-fill.cup-hot.cup-straw.cup.currency-bitcoin.currency-dollar.currency-euro.currency-exchange.currency-pound.currency-rupee.currency-yen.cursor-fill.cursor-text.cursor.dash-circle-dotted.dash-circle-fill.dash-circle.dash-lg.dash-square-dotted.dash-square-fill.dash-square.dash.database-add.database-check.database-dash.database-down.database-exclamation.database-fill-add.database-fill-check.database-fill-dash.database-fill-down.database-fill-exclamation.database-fill-gear.database-fill-lock.database-fill-slash.database-fill-up.database-fill-x.database-fill.database-gear.database-lock.database-slash.database-up.database-x.database.device-hdd-fill.device-hdd.device-ssd-fill.device-ssd.diagram-2-fill.diagram-2.diagram-3-fill.diagram-3.diamond-fill.diamond-half.diamond.dice-1-fill.dice-1.dice-2-fill.dice-2.dice-3-fill.dice-3.dice-4-fill.dice-4.dice-5-fill.dice-5.dice-6-fill.dice-6.disc-fill.disc.discord.display-fill.display.displayport-fill.displayport.distribute-horizontal.distribute-vertical.door-closed-fill.door-closed.door-open-fill.door-open.dot.download.dpad-fill.dpad.dribbble.dropbox.droplet-fill.droplet-half.droplet.duffle-fill.duffle.ear-fill.ear.earbuds.easel-fill.easel.easel2-fill.easel2.easel3-fill.easel3.egg-fill.egg-fried.egg.eject-fill.eject.emoji-angry-fill.emoji-angry.emoji-astonished-fill.emoji-astonished.emoji-dizzy-fill.emoji-dizzy.emoji-expressionless-fill.emoji-expressionless.emoji-frown-fill.emoji-frown.emoji-grimace-fill.emoji-grimace.emoji-grin-fill.emoji-grin.emoji-heart-eyes-fill.emoji-heart-eyes.emoji-kiss-fill.emoji-kiss.emoji-laughing-fill.emoji-laughing.emoji-neutral-fill.emoji-neutral.emoji-smile-fill.emoji-smile-upside-down-fill.emoji-smile-upside-down.emoji-smile.emoji-sunglasses-fill.emoji-sunglasses.emoji-surprise-fill.emoji-surprise.emoji-tear-fill.emoji-tear.emoji-wink-fill.emoji-wink.envelope-arrow-down-fill.envelope-arrow-down.envelope-arrow-up-fill.envelope-arrow-up.envelope-at-fill.envelope-at.envelope-check-fill.envelope-check.envelope-dash-fill.envelope-dash.envelope-exclamation-fill.envelope-exclamation.envelope-fill.envelope-heart-fill.envelope-heart.envelope-open-fill.envelope-open-heart-fill.envelope-open-heart.envelope-open.envelope-paper-fill.envelope-paper-heart-fill.envelope-paper-heart.envelope-paper.envelope-plus-fill.envelope-plus.envelope-slash-fill.envelope-slash.envelope-x-fill.envelope-x.envelope.eraser-fill.eraser.escape.ethernet.ev-front-fill.ev-front.ev-station-fill.ev-station.exclamation-circle-fill.exclamation-circle.exclamation-diamond-fill.exclamation-diamond.exclamation-lg.exclamation-octagon-fill.exclamation-octagon.exclamation-square-fill.exclamation-square.exclamation-triangle-fill.exclamation-triangle.exclamation.exclude.explicit-fill.explicit.exposure.eye-fill.eye-slash-fill.eye-slash.eye.eyedropper.eyeglasses.facebook.fan.fast-forward-btn-fill.fast-forward-btn.fast-forward-circle-fill.fast-forward-circle.fast-forward-fill.fast-forward.feather.feather2.file-arrow-down-fill.file-arrow-down.file-arrow-up-fill.file-arrow-up.file-bar-graph-fill.file-bar-graph.file-binary-fill.file-binary.file-break-fill.file-break.file-check-fill.file-check.file-code-fill.file-code.file-diff-fill.file-diff.file-earmark-arrow-down-fill.file-earmark-arrow-down.file-earmark-arrow-up-fill.file-earmark-arrow-up.file-earmark-bar-graph-fill.file-earmark-bar-graph.file-earmark-binary-fill.file-earmark-binary.file-earmark-break-fill.file-earmark-break.file-earmark-check-fill.file-earmark-check.file-earmark-code-fill.file-earmark-code.file-earmark-diff-fill.file-earmark-diff.file-earmark-easel-fill.file-earmark-easel.file-earmark-excel-fill.file-earmark-excel.file-earmark-fill.file-earmark-font-fill.file-earmark-font.file-earmark-image-fill.file-earmark-image.file-earmark-lock-fill.file-earmark-lock.file-earmark-lock2-fill.file-earmark-lock2.file-earmark-medical-fill.file-earmark-medical.file-earmark-minus-fill.file-earmark-minus.file-earmark-music-fill.file-earmark-music.file-earmark-pdf-fill.file-earmark-pdf.file-earmark-person-fill.file-earmark-person.file-earmark-play-fill.file-earmark-play.file-earmark-plus-fill.file-earmark-plus.file-earmark-post-fill.file-earmark-post.file-earmark-ppt-fill.file-earmark-ppt.file-earmark-richtext-fill.file-earmark-richtext.file-earmark-ruled-fill.file-earmark-ruled.file-earmark-slides-fill.file-earmark-slides.file-earmark-spreadsheet-fill.file-earmark-spreadsheet.file-earmark-text-fill.file-earmark-text.file-earmark-word-fill.file-earmark-word.file-earmark-x-fill.file-earmark-x.file-earmark-zip-fill.file-earmark-zip.file-earmark.file-easel-fill.file-easel.file-excel-fill.file-excel.file-fill.file-font-fill.file-font.file-image-fill.file-image.file-lock-fill.file-lock.file-lock2-fill.file-lock2.file-medical-fill.file-medical.file-minus-fill.file-minus.file-music-fill.file-music.file-pdf-fill.file-pdf.file-person-fill.file-person.file-play-fill.file-play.file-plus-fill.file-plus.file-post-fill.file-post.file-ppt-fill.file-ppt.file-richtext-fill.file-richtext.file-ruled-fill.file-ruled.file-slides-fill.file-slides.file-spreadsheet-fill.file-spreadsheet.file-text-fill.file-text.file-word-fill.file-word.file-x-fill.file-x.file-zip-fill.file-zip.file.files-alt.files.filetype-aac.filetype-ai.filetype-bmp.filetype-cs.filetype-css.filetype-csv.filetype-doc.filetype-docx.filetype-exe.filetype-gif.filetype-heic.filetype-html.filetype-java.filetype-jpg.filetype-js.filetype-json.filetype-jsx.filetype-key.filetype-m4p.filetype-md.filetype-mdx.filetype-mov.filetype-mp3.filetype-mp4.filetype-otf.filetype-pdf.filetype-php.filetype-png.filetype-ppt.filetype-pptx.filetype-psd.filetype-py.filetype-raw.filetype-rb.filetype-sass.filetype-scss.filetype-sh.filetype-sql.filetype-svg.filetype-tiff.filetype-tsx.filetype-ttf.filetype-txt.filetype-wav.filetype-woff.filetype-xls.filetype-xlsx.filetype-xml.filetype-yml.film.filter-circle-fill.filter-circle.filter-left.filter-right.filter-square-fill.filter-square.filter.fingerprint.fire.flag-fill.flag.floppy-fill.floppy.floppy2-fill.floppy2.flower1.flower2.flower3.folder-check.folder-fill.folder-minus.folder-plus.folder-symlink-fill.folder-symlink.folder-x.folder.folder2-open.folder2.fonts.forward-fill.forward.front.fuel-pump-diesel-fill.fuel-pump-diesel.fuel-pump-fill.fuel-pump.fullscreen-exit.fullscreen.funnel-fill.funnel.gear-fill.gear-wide-connected.gear-wide.gear.gem.gender-ambiguous.gender-female.gender-male.gender-neuter.gender-trans.geo-alt-fill.geo-alt.geo-fill.geo.gift-fill.gift.git.github.gitlab.globe-americas.globe-asia-australia.globe-central-south-asia.globe-europe-africa.globe.globe2.google-play.google.gpu-card.graph-down-arrow.graph-down.graph-up-arrow.graph-up.grid-1x2-fill.grid-1x2.grid-3x2-gap-fill.grid-3x2-gap.grid-3x2.grid-3x3-gap-fill.grid-3x3-gap.grid-3x3.grid-fill.grid.grip-horizontal.grip-vertical.h-circle-fill.h-circle.h-square-fill.h-square.hammer.hand-index-fill.hand-index-thumb-fill.hand-index-thumb.hand-index.hand-thumbs-down-fill.hand-thumbs-down.hand-thumbs-up-fill.hand-thumbs-up.handbag-fill.handbag.hash.hdd-fill.hdd-network-fill.hdd-network.hdd-rack-fill.hdd-rack.hdd-stack-fill.hdd-stack.hdd.hdmi-fill.hdmi.headphones.headset-vr.headset.heart-arrow.heart-fill.heart-half.heart-pulse-fill.heart-pulse.heart.heartbreak-fill.heartbreak.hearts.heptagon-fill.heptagon-half.heptagon.hexagon-fill.hexagon-half.hexagon.highlighter.highlights.hospital-fill.hospital.hourglass-bottom.hourglass-split.hourglass-top.hourglass.house-add-fill.house-add.house-check-fill.house-check.house-dash-fill.house-dash.house-door-fill.house-door.house-down-fill.house-down.house-exclamation-fill.house-exclamation.house-fill.house-gear-fill.house-gear.house-heart-fill.house-heart.house-lock-fill.house-lock.house-slash-fill.house-slash.house-up-fill.house-up.house-x-fill.house-x.house.houses-fill.houses.hr.hurricane.hypnotize.image-alt.image-fill.image.images.inbox-fill.inbox.inboxes-fill.inboxes.incognito.indent.infinity.info-circle-fill.info-circle.info-lg.info-square-fill.info-square.info.input-cursor-text.input-cursor.instagram.intersect.journal-album.journal-arrow-down.journal-arrow-up.journal-bookmark-fill.journal-bookmark.journal-check.journal-code.journal-medical.journal-minus.journal-plus.journal-richtext.journal-text.journal-x.journal.journals.joystick.justify-left.justify-right.justify.kanban-fill.kanban.key-fill.key.keyboard-fill.keyboard.ladder.lamp-fill.lamp.laptop-fill.laptop.layer-backward.layer-forward.layers-fill.layers-half.layers.layout-sidebar-inset-reverse.layout-sidebar-inset.layout-sidebar-reverse.layout-sidebar.layout-split.layout-text-sidebar-reverse.layout-text-sidebar.layout-text-window-reverse.layout-text-window.layout-three-columns.layout-wtf.life-preserver.lightbulb-fill.lightbulb-off-fill.lightbulb-off.lightbulb.lightning-charge-fill.lightning-charge.lightning-fill.lightning.line.link-45deg.link.linkedin.list-check.list-columns-reverse.list-columns.list-nested.list-ol.list-stars.list-task.list-ul.list.lock-fill.lock.luggage-fill.luggage.lungs-fill.lungs.magic.magnet-fill.magnet.mailbox-flag.mailbox.mailbox2-flag.mailbox2.map-fill.map.markdown-fill.markdown.marker-tip.mask.mastodon.medium.megaphone-fill.megaphone.memory.menu-app-fill.menu-app.menu-button-fill.menu-button-wide-fill.menu-button-wide.menu-button.menu-down.menu-up.messenger.meta.mic-fill.mic-mute-fill.mic-mute.mic.microsoft-teams.microsoft.minecart-loaded.minecart.modem-fill.modem.moisture.moon-fill.moon-stars-fill.moon-stars.moon.mortarboard-fill.mortarboard.motherboard-fill.motherboard.mouse-fill.mouse.mouse2-fill.mouse2.mouse3-fill.mouse3.music-note-beamed.music-note-list.music-note.music-player-fill.music-player.newspaper.nintendo-switch.node-minus-fill.node-minus.node-plus-fill.node-plus.noise-reduction.nut-fill.nut.nvidia.nvme-fill.nvme.octagon-fill.octagon-half.octagon.opencollective.optical-audio-fill.optical-audio.option.outlet.p-circle-fill.p-circle.p-square-fill.p-square.paint-bucket.palette-fill.palette.palette2.paperclip.paragraph.pass-fill.pass.passport-fill.passport.patch-check-fill.patch-check.patch-exclamation-fill.patch-exclamation.patch-minus-fill.patch-minus.patch-plus-fill.patch-plus.patch-question-fill.patch-question.pause-btn-fill.pause-btn.pause-circle-fill.pause-circle.pause-fill.pause.paypal.pc-display-horizontal.pc-display.pc-horizontal.pc.pci-card-network.pci-card-sound.pci-card.peace-fill.peace.pen-fill.pen.pencil-fill.pencil-square.pencil.pentagon-fill.pentagon-half.pentagon.people-fill.people.percent.person-add.person-arms-up.person-badge-fill.person-badge.person-bounding-box.person-check-fill.person-check.person-circle.person-dash-fill.person-dash.person-down.person-exclamation.person-fill-add.person-fill-check.person-fill-dash.person-fill-down.person-fill-exclamation.person-fill-gear.person-fill-lock.person-fill-slash.person-fill-up.person-fill-x.person-fill.person-gear.person-heart.person-hearts.person-lines-fill.person-lock.person-plus-fill.person-plus.person-raised-hand.person-rolodex.person-slash.person-square.person-standing-dress.person-standing.person-up.person-vcard-fill.person-vcard.person-video.person-video2.person-video3.person-walking.person-wheelchair.person-workspace.person-x-fill.person-x.person.phone-fill.phone-flip.phone-landscape-fill.phone-landscape.phone-vibrate-fill.phone-vibrate.phone.pie-chart-fill.pie-chart.piggy-bank-fill.piggy-bank.pin-angle-fill.pin-angle.pin-fill.pin-map-fill.pin-map.pin.pinterest.pip-fill.pip.play-btn-fill.play-btn.play-circle-fill.play-circle.play-fill.play.playstation.plug-fill.plug.plugin.plus-circle-dotted.plus-circle-fill.plus-circle.plus-lg.plus-slash-minus.plus-square-dotted.plus-square-fill.plus-square.plus.postage-fill.postage-heart-fill.postage-heart.postage.postcard-fill.postcard-heart-fill.postcard-heart.postcard.power.prescription.prescription2.printer-fill.printer.projector-fill.projector.puzzle-fill.puzzle.qr-code-scan.qr-code.question-circle-fill.question-circle.question-diamond-fill.question-diamond.question-lg.question-octagon-fill.question-octagon.question-square-fill.question-square.question.quora.quote.r-circle-fill.r-circle.r-square-fill.r-square.radar.radioactive.rainbow.receipt-cutoff.receipt.reception-0.reception-1.reception-2.reception-3.reception-4.record-btn-fill.record-btn.record-circle-fill.record-circle.record-fill.record.record2-fill.record2.recycle.reddit.regex.repeat-1.repeat.reply-all-fill.reply-all.reply-fill.reply.rewind-btn-fill.rewind-btn.rewind-circle-fill.rewind-circle.rewind-fill.rewind.robot.rocket-fill.rocket-takeoff-fill.rocket-takeoff.rocket.router-fill.router.rss-fill.rss.rulers.safe-fill.safe.safe2-fill.safe2.save-fill.save.save2-fill.save2.scissors.scooter.screwdriver.sd-card-fill.sd-card.search-heart-fill.search-heart.search.segmented-nav.send-arrow-down-fill.send-arrow-down.send-arrow-up-fill.send-arrow-up.send-check-fill.send-check.send-dash-fill.send-dash.send-exclamation-fill.send-exclamation.send-fill.send-plus-fill.send-plus.send-slash-fill.send-slash.send-x-fill.send-x.send.server.shadows.share-fill.share.shield-check.shield-exclamation.shield-fill-check.shield-fill-exclamation.shield-fill-minus.shield-fill-plus.shield-fill-x.shield-fill.shield-lock-fill.shield-lock.shield-minus.shield-plus.shield-shaded.shield-slash-fill.shield-slash.shield-x.shield.shift-fill.shift.shop-window.shop.shuffle.sign-dead-end-fill.sign-dead-end.sign-do-not-enter-fill.sign-do-not-enter.sign-intersection-fill.sign-intersection-side-fill.sign-intersection-side.sign-intersection-t-fill.sign-intersection-t.sign-intersection-y-fill.sign-intersection-y.sign-intersection.sign-merge-left-fill.sign-merge-left.sign-merge-right-fill.sign-merge-right.sign-no-left-turn-fill.sign-no-left-turn.sign-no-parking-fill.sign-no-parking.sign-no-right-turn-fill.sign-no-right-turn.sign-railroad-fill.sign-railroad.sign-stop-fill.sign-stop-lights-fill.sign-stop-lights.sign-stop.sign-turn-left-fill.sign-turn-left.sign-turn-right-fill.sign-turn-right.sign-turn-slight-left-fill.sign-turn-slight-left.sign-turn-slight-right-fill.sign-turn-slight-right.sign-yield-fill.sign-yield.signal.signpost-2-fill.signpost-2.signpost-fill.signpost-split-fill.signpost-split.signpost.sim-fill.sim-slash-fill.sim-slash.sim.sina-weibo.skip-backward-btn-fill.skip-backward-btn.skip-backward-circle-fill.skip-backward-circle.skip-backward-fill.skip-backward.skip-end-btn-fill.skip-end-btn.skip-end-circle-fill.skip-end-circle.skip-end-fill.skip-end.skip-forward-btn-fill.skip-forward-btn.skip-forward-circle-fill.skip-forward-circle.skip-forward-fill.skip-forward.skip-start-btn-fill.skip-start-btn.skip-start-circle-fill.skip-start-circle.skip-start-fill.skip-start.skype.slack.slash-circle-fill.slash-circle.slash-lg.slash-square-fill.slash-square.slash.sliders.sliders2-vertical.sliders2.smartwatch.snapchat.snow.snow2.snow3.sort-alpha-down-alt.sort-alpha-down.sort-alpha-up-alt.sort-alpha-up.sort-down-alt.sort-down.sort-numeric-down-alt.sort-numeric-down.sort-numeric-up-alt.sort-numeric-up.sort-up-alt.sort-up.soundwave.sourceforge.speaker-fill.speaker.speedometer.speedometer2.spellcheck.spotify.square-fill.square-half.square.stack-overflow.stack.star-fill.star-half.star.stars.steam.stickies-fill.stickies.sticky-fill.sticky.stop-btn-fill.stop-btn.stop-circle-fill.stop-circle.stop-fill.stop.stoplights-fill.stoplights.stopwatch-fill.stopwatch.strava.stripe.subscript.substack.subtract.suit-club-fill.suit-club.suit-diamond-fill.suit-diamond.suit-heart-fill.suit-heart.suit-spade-fill.suit-spade.suitcase-fill.suitcase-lg-fill.suitcase-lg.suitcase.suitcase2-fill.suitcase2.sun-fill.sun.sunglasses.sunrise-fill.sunrise.sunset-fill.sunset.superscript.symmetry-horizontal.symmetry-vertical.table.tablet-fill.tablet-landscape-fill.tablet-landscape.tablet.tag-fill.tag.tags-fill.tags.taxi-front-fill.taxi-front.telegram.telephone-fill.telephone-forward-fill.telephone-forward.telephone-inbound-fill.telephone-inbound.telephone-minus-fill.telephone-minus.telephone-outbound-fill.telephone-outbound.telephone-plus-fill.telephone-plus.telephone-x-fill.telephone-x.telephone.tencent-qq.terminal-dash.terminal-fill.terminal-plus.terminal-split.terminal-x.terminal.text-center.text-indent-left.text-indent-right.text-left.text-paragraph.text-right.text-wrap.textarea-resize.textarea-t.textarea.thermometer-half.thermometer-high.thermometer-low.thermometer-snow.thermometer-sun.thermometer.threads-fill.threads.three-dots-vertical.three-dots.thunderbolt-fill.thunderbolt.ticket-detailed-fill.ticket-detailed.ticket-fill.ticket-perforated-fill.ticket-perforated.ticket.tiktok.toggle-off.toggle-on.toggle2-off.toggle2-on.toggles.toggles2.tools.tornado.train-freight-front-fill.train-freight-front.train-front-fill.train-front.train-lightrail-front-fill.train-lightrail-front.translate.transparency.trash-fill.trash.trash2-fill.trash2.trash3-fill.trash3.tree-fill.tree.trello.triangle-fill.triangle-half.triangle.trophy-fill.trophy.tropical-storm.truck-flatbed.truck-front-fill.truck-front.truck.tsunami.tv-fill.tv.twitch.twitter-x.twitter.type-bold.type-h1.type-h2.type-h3.type-h4.type-h5.type-h6.type-italic.type-strikethrough.type-underline.type.ubuntu.ui-checks-grid.ui-checks.ui-radios-grid.ui-radios.umbrella-fill.umbrella.unindent.union.unity.universal-access-circle.universal-access.unlock-fill.unlock.upc-scan.upc.upload.usb-c-fill.usb-c.usb-drive-fill.usb-drive.usb-fill.usb-micro-fill.usb-micro.usb-mini-fill.usb-mini.usb-plug-fill.usb-plug.usb-symbol.usb.valentine.valentine2.vector-pen.view-list.view-stacked.vignette.vimeo.vinyl-fill.vinyl.virus.virus2.voicemail.volume-down-fill.volume-down.volume-mute-fill.volume-mute.volume-off-fill.volume-off.volume-up-fill.volume-up.vr.wallet-fill.wallet.wallet2.watch.water.webcam-fill.webcam.wechat.whatsapp.wifi-1.wifi-2.wifi-off.wifi.wikipedia.wind.window-dash.window-desktop.window-dock.window-fullscreen.window-plus.window-sidebar.window-split.window-stack.window-x.window.windows.wordpress.wrench-adjustable-circle-fill.wrench-adjustable-circle.wrench-adjustable.wrench.x-circle-fill.x-circle.x-diamond-fill.x-diamond.x-lg.x-octagon-fill.x-octagon.x-square-fill.x-square.x.xbox.yelp.yin-yang.youtube.zoom-in.zoom-out`.split(`.`)},ua=Object.keys(la),da=la,fa=[`likec4lib {`,` icons {`,...[...Object.entries(la)].flatMap(([e,t])=>t.map(t=>e+`:`+t)).map(e=>` `+e),` }`,`}`].join(`
|
|
52
|
+
`),pa=`likec4builtin`,ma=`${pa}:///likec4/lib/icons.c4`;function isLikeC4Builtin(e){return(`uri`in e?e.uri:e).scheme===pa}function isNotLikeC4Builtin(e){return!isLikeC4Builtin(e)}var ADisposable=class{toDispose=[];isDisposed=!1;onDispose(...e){this.toDispose.push(...e)}dispose(){this.throwIfDisposed(),this.isDisposed=!0;let e;for(;e=this.toDispose.pop();)try{e.dispose()}catch(e){logWarnError(e)}}throwIfDisposed(){this.isDisposed&&q.warn(`this has already been disposed`)}};const ha=`AnyProperty`;function isAnyProperty(e){return J.isInstance(e,ha)}const ga=`ColorLiteral`;function isColorLiteral(e){return J.isInstance(e,ga)}const _a=`DeploymentElement`;function isDeploymentElement(e){return J.isInstance(e,_a)}const va=`DeploymentNodeOrElementKind`,ya=`DeploymentViewRule`;function isDeploymentViewRule(e){return J.isInstance(e,ya)}const ba=`DynamicViewProperty`,xa=`DynamicViewRule`;function isDynamicViewRule(e){return J.isInstance(e,xa)}const Sa=`DynamicViewStep`;function isDynamicViewStep(e){return J.isInstance(e,Sa)}const Ca=`ElementProperty`;function isElementProperty(e){return J.isInstance(e,Ca)}const wa=`ExpressionV2`;function isExpressionV2(e){return J.isInstance(e,wa)}const Ta=`FqnExpr`;function isFqnExpr(e){return J.isInstance(e,Ta)}const Ea=`FqnExprOrWhere`;function isFqnExprOrWhere(e){return J.isInstance(e,Ea)}const Da=`FqnExprOrWith`;function isFqnExprOrWith(e){return J.isInstance(e,Da)}const Oa=`FqnReferenceable`,ka=`LikeC4View`;function isLikeC4View(e){return J.isInstance(e,ka)}const Aa=`MetadataProperty`;function isMetadataProperty(e){return J.isInstance(e,Aa)}const ja=`MetadataValue`,Ma=`Referenceable`,Na=`RelationExpr`;function isRelationExpr(e){return J.isInstance(e,Na)}const Pa=`RelationExprOrWhere`;function isRelationExprOrWhere(e){return J.isInstance(e,Pa)}const Fa=`RelationExprOrWith`;function isRelationExprOrWith(e){return J.isInstance(e,Fa)}const Ia=`RelationProperty`,La=`RelationshipStyleProperty`;function isRelationshipStyleProperty(e){return J.isInstance(e,La)}const Ra=`SizeProperty`;function isSizeProperty(e){return J.isInstance(e,Ra)}const za=`StringProperty`;function isStringProperty(e){return J.isInstance(e,za)}const Ba=`StyleProperty`;function isStyleProperty(e){return J.isInstance(e,Ba)}const Va=`ViewProperty`;function isViewProperty(e){return J.isInstance(e,Va)}const Ha=`ViewRule`;function isViewRule(e){return J.isInstance(e,Ha)}const Ua=`ViewRuleStyleOrGlobalRef`;function isViewRuleStyleOrGlobalRef(e){return J.isInstance(e,Ua)}const Wa=`WhereElement`;function isWhereElement(e){return J.isInstance(e,Wa)}const Ga=`WhereElementExpression`;function isWhereElementExpression(e){return J.isInstance(e,Ga)}const Ka=`WhereExpression`,qa=`WhereKindEqual`;function isWhereKindEqual(e){return J.isInstance(e,qa)}const Ja=`WhereMetadataEqual`;function isWhereMetadataEqual(e){return J.isInstance(e,Ja)}const Ya=`WhereRelation`;function isWhereRelation(e){return J.isInstance(e,Ya)}const Xa=`WhereRelationExpression`;function isWhereRelationExpression(e){return J.isInstance(e,Xa)}const Za=`WhereTagEqual`;function isWhereTagEqual(e){return J.isInstance(e,Za)}const Qa=`AbstractDynamicStep`,$a=`ArrowProperty`;function isArrowProperty(e){return J.isInstance(e,$a)}const eo=`BorderProperty`;function isBorderProperty(e){return J.isInstance(e,eo)}const to=`ColorProperty`;function isColorProperty(e){return J.isInstance(e,to)}const no=`CustomColor`,ro=`CustomElementProperties`;function isCustomElementProperties(e){return J.isInstance(e,ro)}const io=`CustomRelationProperties`;function isCustomRelationProperties(e){return J.isInstance(e,io)}const ao=`DeployedInstance`;function isDeployedInstance(e){return J.isInstance(e,ao)}const oo=`DeployedInstanceBody`;function isDeployedInstanceBody(e){return J.isInstance(e,oo)}const so=`DeploymentNode`;function isDeploymentNode$1(e){return J.isInstance(e,so)}t(isDeploymentNode$1,`isDeploymentNode`);const co=`DeploymentNodeBody`;function isDeploymentNodeBody(e){return J.isInstance(e,co)}const lo=`DeploymentNodeKind`;function isDeploymentNodeKind(e){return J.isInstance(e,lo)}const uo=`DeploymentRelation`;function isDeploymentRelation(e){return J.isInstance(e,uo)}const fo=`DeploymentRelationBody`;function isDeploymentRelationBody(e){return J.isInstance(e,fo)}const po=`DeploymentView`;function isDeploymentView$1(e){return J.isInstance(e,po)}t(isDeploymentView$1,`isDeploymentView`);const mo=`DeploymentViewBody`;function isDeploymentViewBody(e){return J.isInstance(e,mo)}const ho=`DeploymentViewRulePredicate`;function isDeploymentViewRulePredicate(e){return J.isInstance(e,ho)}const go=`DeploymentViewRuleStyle`;function isDeploymentViewRuleStyle(e){return J.isInstance(e,go)}const _o=`DirectedRelationExpr`;function isDirectedRelationExpr(e){return J.isInstance(e,_o)}const vo=`DynamicView`;function isDynamicView$1(e){return J.isInstance(e,vo)}t(isDynamicView$1,`isDynamicView`);const yo=`DynamicViewBody`;function isDynamicViewBody(e){return J.isInstance(e,yo)}const bo=`DynamicViewDisplayVariantProperty`;function isDynamicViewDisplayVariantProperty(e){return J.isInstance(e,bo)}const xo=`DynamicViewGlobalPredicateRef`;function isDynamicViewGlobalPredicateRef(e){return J.isInstance(e,xo)}const So=`DynamicViewIncludePredicate`;function isDynamicViewIncludePredicate(e){return J.isInstance(e,So)}const Co=`DynamicViewParallelSteps`;function isDynamicViewParallelSteps(e){return J.isInstance(e,Co)}const wo=`DynamicViewRef`,To=`Element`;function isElement(e){return J.isInstance(e,To)}const Eo=`ElementBody`;function isElementBody(e){return J.isInstance(e,Eo)}const Do=`ElementKind`;function isElementKind(e){return J.isInstance(e,Do)}const Oo=`ElementKindExpression`;function isElementKindExpression(e){return J.isInstance(e,Oo)}const ko=`ElementRef`;function isElementRef(e){return J.isInstance(e,ko)}const Ao=`ElementStringProperty`;function isElementStringProperty(e){return J.isInstance(e,Ao)}const jo=`ElementStyleProperty`;function isElementStyleProperty(e){return J.isInstance(e,jo)}const Mo=`ElementTagExpression`;function isElementTagExpression(e){return J.isInstance(e,Mo)}const No=`ElementView`;function isElementView$1(e){return J.isInstance(e,No)}t(isElementView$1,`isElementView`);const Po=`ElementViewBody`;function isElementViewBody(e){return J.isInstance(e,Po)}const Fo=`ElementViewRef`,Io=`Expressions`;function isExpressions(e){return J.isInstance(e,Io)}const Lo=`ExtendDeployment`;function isExtendDeployment(e){return J.isInstance(e,Lo)}const Ro=`ExtendDeploymentBody`;function isExtendDeploymentBody(e){return J.isInstance(e,Ro)}const zo=`ExtendElement`;function isExtendElement(e){return J.isInstance(e,zo)}const Bo=`ExtendElementBody`;function isExtendElementBody(e){return J.isInstance(e,Bo)}const Vo=`ExtendRelation`;function isExtendRelation(e){return J.isInstance(e,Vo)}const Ho=`ExtendRelationBody`;function isExtendRelationBody(e){return J.isInstance(e,Ho)}const Uo=`FqnExpressions`;function isFqnExpressions(e){return J.isInstance(e,Uo)}const Wo=`FqnExprWhere`;function isFqnExprWhere(e){return J.isInstance(e,Wo)}const Go=`FqnExprWith`;function isFqnExprWith(e){return J.isInstance(e,Go)}const Ko=`FqnRef`;function isFqnRef(e){return J.isInstance(e,Ko)}const qo=`FqnRefExpr`;function isFqnRefExpr(e){return J.isInstance(e,qo)}const Jo=`GlobalDynamicPredicateGroup`;function isGlobalDynamicPredicateGroup(e){return J.isInstance(e,Jo)}const Yo=`GlobalPredicateGroup`;function isGlobalPredicateGroup(e){return J.isInstance(e,Yo)}const Xo=`Globals`;function isGlobals(e){return J.isInstance(e,Xo)}const Zo=`GlobalStyle`;function isGlobalStyle(e){return J.isInstance(e,Zo)}const Qo=`GlobalStyleGroup`;function isGlobalStyleGroup(e){return J.isInstance(e,Qo)}const $o=`GlobalStyleId`,es=`HexColor`;function isHexColor(e){return J.isInstance(e,es)}const ts=`IconColorProperty`;function isIconColorProperty(e){return J.isInstance(e,ts)}const ns=`IconPositionProperty`;function isIconPositionProperty(e){return J.isInstance(e,ns)}const rs=`IconProperty`;function isIconProperty(e){return J.isInstance(e,rs)}const is=`IconSizeProperty`;function isIconSizeProperty(e){return J.isInstance(e,is)}const as=`Imported`;function isImported(e){return J.isInstance(e,as)}const os=`ImportsFromPoject`;function isImportsFromPoject(e){return J.isInstance(e,os)}const ss=`IncomingRelationExpr`;function isIncomingRelationExpr(e){return J.isInstance(e,ss)}const cs=`InOutRelationExpr`;function isInOutRelationExpr(e){return J.isInstance(e,cs)}const ls=`LibIcon`;function isLibIcon(e){return J.isInstance(e,ls)}const us=`LikeC4Grammar`;function isLikeC4Grammar(e){return J.isInstance(e,us)}const ds=`LikeC4Lib`;function isLikeC4Lib(e){return J.isInstance(e,ds)}const fs=`LineProperty`;function isLineProperty(e){return J.isInstance(e,fs)}const ps=`LinkProperty`;function isLinkProperty(e){return J.isInstance(e,ps)}const ms=`MarkdownOrString`;function isMarkdownOrString(e){return J.isInstance(e,ms)}const hs=`MetadataArray`;function isMetadataArray(e){return J.isInstance(e,hs)}const gs=`MetadataAttribute`;function isMetadataAttribute(e){return J.isInstance(e,gs)}const _s=`MetadataBody`;function isMetadataBody(e){return J.isInstance(e,_s)}const vs=`Model`;function isModel(e){return J.isInstance(e,vs)}const ys=`ModelDeployments`;function isModelDeployments(e){return J.isInstance(e,ys)}const bs=`ModelViews`;function isModelViews(e){return J.isInstance(e,bs)}const xs=`MultipleProperty`;function isMultipleProperty(e){return J.isInstance(e,xs)}const Ss=`NavigateToProperty`;function isNavigateToProperty(e){return J.isInstance(e,Ss)}const Cs=`NotationProperty`;function isNotationProperty(e){return J.isInstance(e,Cs)}const ws=`NotesProperty`;function isNotesProperty(e){return J.isInstance(e,ws)}const Ts=`OpacityProperty`;function isOpacityProperty(e){return J.isInstance(e,Ts)}const Es=`OutgoingRelationExpr`;function isOutgoingRelationExpr(e){return J.isInstance(e,Es)}const Ds=`PaddingSizeProperty`;function isPaddingSizeProperty(e){return J.isInstance(e,Ds)}const Os=`Relation`;function isRelation(e){return J.isInstance(e,Os)}const ks=`RelationBody`;function isRelationBody(e){return J.isInstance(e,ks)}const As=`RelationExprWhere`;function isRelationExprWhere(e){return J.isInstance(e,As)}const js=`RelationExprWith`;function isRelationExprWith(e){return J.isInstance(e,js)}const Ms=`RelationKindDotRef`;function isRelationKindDotRef(e){return J.isInstance(e,Ms)}const Ns=`RelationNavigateToProperty`;function isRelationNavigateToProperty(e){return J.isInstance(e,Ns)}const Ps=`RelationshipKind`;function isRelationshipKind(e){return J.isInstance(e,Ps)}const Fs=`RelationStringProperty`;function isRelationStringProperty(e){return J.isInstance(e,Fs)}const Is=`RelationStyleProperty`;function isRelationStyleProperty(e){return J.isInstance(e,Is)}const Ls=`RGBAColor`;function isRGBAColor(e){return J.isInstance(e,Ls)}const Rs=`ShapeProperty`;function isShapeProperty(e){return J.isInstance(e,Rs)}const zs=`ShapeSizeProperty`;function isShapeSizeProperty(e){return J.isInstance(e,zs)}const Bs=`SpecificationColor`;function isSpecificationColor(e){return J.isInstance(e,Bs)}const Vs=`SpecificationDeploymentNodeKind`;function isSpecificationDeploymentNodeKind(e){return J.isInstance(e,Vs)}const Hs=`SpecificationElementKind`;function isSpecificationElementKind(e){return J.isInstance(e,Hs)}const Us=`SpecificationElementStringProperty`;function isSpecificationElementStringProperty(e){return J.isInstance(e,Us)}const Ws=`SpecificationRelationshipKind`;function isSpecificationRelationshipKind(e){return J.isInstance(e,Ws)}const Gs=`SpecificationRelationshipStringProperty`;function isSpecificationRelationshipStringProperty(e){return J.isInstance(e,Gs)}const Ks=`SpecificationRule`;function isSpecificationRule(e){return J.isInstance(e,Ks)}const qs=`SpecificationTag`;function isSpecificationTag(e){return J.isInstance(e,qs)}const Js=`StrictFqnElementRef`;function isStrictFqnElementRef(e){return J.isInstance(e,Js)}const Ys=`StrictFqnRef`;function isStrictFqnRef(e){return J.isInstance(e,Ys)}function isTag(e){return J.isInstance(e,`Tag`)}const Xs=`TagRef`;function isTagRef(e){return J.isInstance(e,Xs)}const Zs=`Tags`;function isTags(e){return J.isInstance(e,Zs)}const Qs=`TextSizeProperty`;function isTextSizeProperty(e){return J.isInstance(e,Qs)}const $s=`ViewRef`,ec=`ViewRuleAncestors`;function isViewRuleAncestors(e){return J.isInstance(e,ec)}const tc=`ViewRuleAutoLayout`;function isViewRuleAutoLayout(e){return J.isInstance(e,tc)}const nc=`ViewRuleGlobalPredicateRef`;function isViewRuleGlobalPredicateRef(e){return J.isInstance(e,nc)}const rc=`ViewRuleGlobalStyle`;function isViewRuleGlobalStyle(e){return J.isInstance(e,rc)}const ic=`ViewRuleGroup`;function isViewRuleGroup(e){return J.isInstance(e,ic)}const ac=`ViewRulePredicate`;function isViewRulePredicate(e){return J.isInstance(e,ac)}const oc=`ViewRuleRank`;function isViewRuleRank(e){return J.isInstance(e,oc)}const sc=`ViewRuleStyle`;function isViewRuleStyle(e){return J.isInstance(e,sc)}const cc=`ViewStringProperty`;function isViewStringProperty(e){return J.isInstance(e,cc)}const lc=`WhereBinaryExpression`;function isWhereBinaryExpression(e){return J.isInstance(e,lc)}const uc=`WhereElementKind`;function isWhereElementKind(e){return J.isInstance(e,uc)}const dc=`WhereElementMetadata`;function isWhereElementMetadata(e){return J.isInstance(e,dc)}const fc=`WhereElementNegation`;function isWhereElementNegation(e){return J.isInstance(e,fc)}const pc=`WhereElementTag`;function isWhereElementTag(e){return J.isInstance(e,pc)}const mc=`WhereRelationKind`;function isWhereRelationKind(e){return J.isInstance(e,mc)}const hc=`WhereRelationMetadata`;function isWhereRelationMetadata(e){return J.isInstance(e,hc)}const gc=`WhereRelationNegation`;function isWhereRelationNegation(e){return J.isInstance(e,gc)}const _c=`WhereRelationParticipantKind`;function isWhereRelationParticipantKind(e){return J.isInstance(e,_c)}const vc=`WhereRelationParticipantMetadata`;function isWhereRelationParticipantMetadata(e){return J.isInstance(e,vc)}const yc=`WhereRelationParticipantTag`;function isWhereRelationParticipantTag(e){return J.isInstance(e,yc)}const bc=`WhereRelationTag`;function isWhereRelationTag(e){return J.isInstance(e,bc)}const xc=`WildcardExpression`;function isWildcardExpression(e){return J.isInstance(e,xc)}const Sc=`DynamicStepChain`;function isDynamicStepChain(e){return J.isInstance(e,Sc)}const Cc=`DynamicStepSingle`;function isDynamicStepSingle(e){return J.isInstance(e,Cc)}var LikeC4AstReflection=class extends xe{getAllTypes(){return[Qa,ha,$a,eo,ga,to,no,ro,io,ao,oo,_a,so,co,lo,va,uo,fo,po,mo,ya,ho,go,_o,Sc,Cc,vo,yo,bo,xo,So,Co,ba,wo,xa,Sa,To,Eo,Do,Oo,Ca,ko,Ao,jo,Mo,No,Po,Fo,wa,Io,Lo,Ro,zo,Bo,`ExtendElementProperty`,Vo,Ho,`ExtendRelationProperty`,Ta,Ea,Da,Wo,Go,Uo,Ko,qo,Oa,Jo,Yo,Zo,Qo,$o,Xo,es,ts,ns,rs,is,as,os,cs,ss,ls,us,ds,ka,fs,ps,ms,hs,gs,_s,Aa,ja,vs,ys,`ModelReferenceable`,bs,xs,Ss,Cs,ws,Ts,Es,Ds,Ls,Ma,Os,ks,Na,Pa,Fa,As,js,Ms,Ns,Ia,Fs,Is,Ps,La,Rs,zs,Ra,Bs,Vs,Hs,Us,Ws,Gs,Ks,qs,Js,Ys,za,Ba,`Tag`,Xs,Zs,Qs,Va,$s,Ha,ec,tc,nc,rc,ic,ac,oc,sc,Ua,cc,lc,Wa,Ga,uc,dc,fc,pc,Ka,qa,Ja,Ya,Xa,mc,hc,gc,_c,vc,yc,bc,Za,xc]}computeIsSubtype(e,t){switch(e){case $a:case fs:return this.isSubtype(La,t);case eo:case ts:case ns:case xs:case Ts:case Rs:return this.isSubtype(Ba,t);case to:return this.isSubtype(`RelationshipStyleProperty`,t)||this.isSubtype(`StyleProperty`,t);case ao:case so:return this.isSubtype(`DeploymentElement`,t)||this.isSubtype(`Referenceable`,t);case lo:case Do:return this.isSubtype(va,t);case po:case vo:case No:return this.isSubtype(ka,t);case ho:case go:case ec:return this.isSubtype(ya,t);case _o:case ss:case cs:case Es:return this.isSubtype(Na,t);case Sc:case Cc:return this.isSubtype(`AbstractDynamicStep`,t)||this.isSubtype(`DynamicViewStep`,t);case bo:return this.isSubtype(ba,t);case xo:case So:return this.isSubtype(xa,t);case ba:case Ca:case Ss:case Ia:case La:case za:case Ba:return this.isSubtype(ha,t);case To:return this.isSubtype(`FqnReferenceable`,t)||this.isSubtype(`ModelReferenceable`,t)||this.isSubtype(`Referenceable`,t);case Oo:case Mo:case qo:case xc:return this.isSubtype(Ta,t);case Ao:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`StringProperty`,t);case jo:return this.isSubtype(Ca,t);case Lo:case zo:case Ma:return this.isSubtype(Oa,t);case Ta:case Wo:return this.isSubtype(Ea,t);case Ea:case Go:return this.isSubtype(Da,t);case Da:case Fa:return this.isSubtype(wa,t);case es:case Ls:return this.isSubtype(ga,t);case rs:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`StyleProperty`,t);case is:case Ds:case zs:case Qs:return this.isSubtype(`SizeProperty`,t)||this.isSubtype(`StyleProperty`,t);case as:return this.isSubtype(`ModelReferenceable`,t)||this.isSubtype(`Referenceable`,t);case ps:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`ExtendElementProperty`,t)||this.isSubtype(`ExtendRelationProperty`,t)||this.isSubtype(`RelationProperty`,t)||this.isSubtype(`ViewProperty`,t);case ms:case hs:return this.isSubtype(ja,t);case gs:case Us:case Gs:return this.isSubtype(za,t);case _s:return this.isSubtype(Aa,t);case Aa:return this.isSubtype(`ElementProperty`,t)||this.isSubtype(`ExtendElementProperty`,t)||this.isSubtype(`ExtendRelationProperty`,t)||this.isSubtype(`RelationProperty`,t);case Cs:case ws:return this.isSubtype(`AnyProperty`,t)||this.isSubtype(`StringProperty`,t);case Na:case As:return this.isSubtype(Pa,t);case Pa:case js:return this.isSubtype(Fa,t);case Ns:case Is:return this.isSubtype(Ia,t);case Fs:return this.isSubtype(`RelationProperty`,t)||this.isSubtype(`StringProperty`,t);case Va:return this.isSubtype(`AnyProperty`,t)||this.isSubtype(`DynamicViewProperty`,t);case tc:return this.isSubtype(`DeploymentViewRule`,t)||this.isSubtype(`DynamicViewRule`,t)||this.isSubtype(`ViewRule`,t);case nc:case ic:case ac:case oc:return this.isSubtype(Ha,t);case rc:case sc:return this.isSubtype(Ua,t);case Ua:return this.isSubtype(`DynamicViewRule`,t)||this.isSubtype(`ViewRule`,t);case cc:return this.isSubtype(`StringProperty`,t)||this.isSubtype(`ViewProperty`,t);case lc:return this.isSubtype(`WhereElementExpression`,t)||this.isSubtype(`WhereRelationExpression`,t);case Wa:case fc:return this.isSubtype(Ga,t);case Ga:case Xa:return this.isSubtype(Ka,t);case uc:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereKindEqual`,t);case dc:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereMetadataEqual`,t);case pc:return this.isSubtype(`WhereElement`,t)||this.isSubtype(`WhereTagEqual`,t);case Ya:case gc:return this.isSubtype(Xa,t);case mc:case _c:return this.isSubtype(`WhereKindEqual`,t)||this.isSubtype(`WhereRelation`,t);case hc:case vc:return this.isSubtype(`WhereMetadataEqual`,t)||this.isSubtype(`WhereRelation`,t);case yc:case bc:return this.isSubtype(`WhereRelation`,t)||this.isSubtype(`WhereTagEqual`,t);default:return!1}}getReferenceType(e){let t=`${e.container.$type}:${e.property}`;switch(t){case`AbstractDynamicStep:kind`:case`DeploymentRelation:kind`:case`DynamicStepChain:kind`:case`DynamicStepSingle:kind`:case`ExtendRelation:kind`:case`OutgoingRelationExpr:kind`:case`Relation:kind`:case`RelationKindDotRef:kind`:case`WhereRelationKind:value`:return Ps;case`ColorProperty:customColor`:case`IconColorProperty:customColor`:return no;case`DeploymentNode:kind`:return lo;case`DynamicViewGlobalPredicateRef:predicate`:return Jo;case`DynamicViewRef:view`:return vo;case`Element:kind`:case`ElementKindExpression:kind`:return Do;case`ElementViewRef:view`:return No;case`FqnRef:value`:case`StrictFqnRef:value`:return Ma;case`IconProperty:libicon`:return ls;case`Imported:imported`:case`StrictFqnElementRef:el`:return To;case`TagRef:tag`:return`Tag`;case`ViewRef:view`:return ka;case`ViewRuleGlobalPredicateRef:predicate`:return Yo;case`ViewRuleGlobalStyle:style`:return $o;case`WhereElementKind:value`:case`WhereRelationParticipantKind:value`:return va;default:throw Error(`${t} is not a valid reference id.`)}}getTypeMetaData(e){switch(e){case Qa:return{name:Qa,properties:[{name:`custom`},{name:`dotKind`},{name:`kind`},{name:`target`},{name:`title`}]};case $a:return{name:$a,properties:[{name:`key`},{name:`value`}]};case eo:return{name:eo,properties:[{name:`key`},{name:`value`}]};case to:return{name:to,properties:[{name:`customColor`},{name:`key`},{name:`themeColor`}]};case no:return{name:no,properties:[{name:`name`}]};case ro:return{name:ro,properties:[{name:`props`,defaultValue:[]}]};case io:return{name:io,properties:[{name:`props`,defaultValue:[]}]};case ao:return{name:ao,properties:[{name:`body`},{name:`name`},{name:`summary`},{name:`target`},{name:`title`}]};case oo:return{name:oo,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case so:return{name:so,properties:[{name:`body`},{name:`kind`},{name:`name`},{name:`summary`},{name:`title`}]};case co:return{name:co,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case lo:return{name:lo,properties:[{name:`name`}]};case uo:return{name:uo,properties:[{name:`body`},{name:`description`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`tags`},{name:`target`},{name:`technology`},{name:`title`}]};case fo:return{name:fo,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case po:return{name:po,properties:[{name:`body`},{name:`name`}]};case mo:return{name:mo,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`tags`}]};case ho:return{name:ho,properties:[{name:`expr`},{name:`isInclude`,defaultValue:!1}]};case go:return{name:go,properties:[{name:`props`,defaultValue:[]},{name:`targets`}]};case _o:return{name:_o,properties:[{name:`source`},{name:`target`}]};case vo:return{name:vo,properties:[{name:`body`},{name:`name`}]};case yo:return{name:yo,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`steps`,defaultValue:[]},{name:`tags`}]};case bo:return{name:bo,properties:[{name:`key`},{name:`value`}]};case xo:return{name:xo,properties:[{name:`predicate`}]};case So:return{name:So,properties:[{name:`exprs`}]};case Co:return{name:Co,properties:[{name:`steps`,defaultValue:[]}]};case wo:return{name:wo,properties:[{name:`view`}]};case To:return{name:To,properties:[{name:`body`},{name:`kind`},{name:`name`},{name:`props`,defaultValue:[]}]};case Eo:return{name:Eo,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case Do:return{name:Do,properties:[{name:`name`}]};case Oo:return{name:Oo,properties:[{name:`isEqual`,defaultValue:!1},{name:`kind`}]};case ko:return{name:ko,properties:[{name:`modelElement`}]};case Ao:return{name:Ao,properties:[{name:`key`},{name:`value`}]};case jo:return{name:jo,properties:[{name:`key`},{name:`props`,defaultValue:[]}]};case Mo:return{name:Mo,properties:[{name:`isEqual`,defaultValue:!1},{name:`tag`}]};case No:return{name:No,properties:[{name:`body`},{name:`extends`},{name:`name`},{name:`viewOf`}]};case Po:return{name:Po,properties:[{name:`props`,defaultValue:[]},{name:`rules`,defaultValue:[]},{name:`tags`}]};case Fo:return{name:Fo,properties:[{name:`view`}]};case Io:return{name:Io,properties:[{name:`prev`},{name:`value`}]};case Lo:return{name:Lo,properties:[{name:`body`},{name:`deploymentNode`}]};case Ro:return{name:Ro,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case zo:return{name:zo,properties:[{name:`body`},{name:`element`}]};case Bo:return{name:Bo,properties:[{name:`elements`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`tags`}]};case Vo:return{name:Vo,properties:[{name:`body`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};case Ho:return{name:Ho,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case Uo:return{name:Uo,properties:[{name:`prev`},{name:`value`}]};case Wo:return{name:Wo,properties:[{name:`subject`},{name:`where`}]};case Go:return{name:Go,properties:[{name:`custom`},{name:`subject`}]};case Ko:return{name:Ko,properties:[{name:`parent`},{name:`value`}]};case qo:return{name:qo,properties:[{name:`ref`},{name:`selector`}]};case Jo:return{name:Jo,properties:[{name:`name`},{name:`predicates`,defaultValue:[]}]};case Yo:return{name:Yo,properties:[{name:`name`},{name:`predicates`,defaultValue:[]}]};case Xo:return{name:Xo,properties:[{name:`name`},{name:`predicates`,defaultValue:[]},{name:`styles`,defaultValue:[]}]};case Zo:return{name:Zo,properties:[{name:`id`},{name:`props`,defaultValue:[]},{name:`targets`}]};case Qo:return{name:Qo,properties:[{name:`id`},{name:`styles`,defaultValue:[]}]};case $o:return{name:$o,properties:[{name:`name`}]};case es:return{name:es,properties:[{name:`hex`}]};case ts:return{name:ts,properties:[{name:`customColor`},{name:`key`},{name:`themeColor`}]};case ns:return{name:ns,properties:[{name:`key`},{name:`value`}]};case rs:return{name:rs,properties:[{name:`key`},{name:`libicon`},{name:`value`}]};case is:return{name:is,properties:[{name:`key`},{name:`value`}]};case as:return{name:as,properties:[{name:`imported`},{name:`prev`}]};case os:return{name:os,properties:[{name:`imports`},{name:`project`}]};case ss:return{name:ss,properties:[{name:`to`}]};case cs:return{name:cs,properties:[{name:`inout`}]};case ls:return{name:ls,properties:[{name:`name`}]};case us:return{name:us,properties:[{name:`deployments`,defaultValue:[]},{name:`globals`,defaultValue:[]},{name:`imports`,defaultValue:[]},{name:`likec4lib`,defaultValue:[]},{name:`models`,defaultValue:[]},{name:`specifications`,defaultValue:[]},{name:`views`,defaultValue:[]}]};case ds:return{name:ds,properties:[{name:`icons`,defaultValue:[]}]};case fs:return{name:fs,properties:[{name:`key`},{name:`value`}]};case ps:return{name:ps,properties:[{name:`key`},{name:`title`},{name:`value`}]};case ms:return{name:ms,properties:[{name:`markdown`},{name:`text`}]};case hs:return{name:hs,properties:[{name:`values`,defaultValue:[]}]};case gs:return{name:gs,properties:[{name:`boolValue`,defaultValue:!1},{name:`key`},{name:`value`}]};case _s:return{name:_s,properties:[{name:`props`,defaultValue:[]}]};case vs:return{name:vs,properties:[{name:`elements`,defaultValue:[]},{name:`name`}]};case ys:return{name:ys,properties:[{name:`elements`,defaultValue:[]},{name:`name`}]};case bs:return{name:bs,properties:[{name:`folder`},{name:`name`},{name:`styles`,defaultValue:[]},{name:`views`,defaultValue:[]}]};case xs:return{name:xs,properties:[{name:`key`},{name:`value`,defaultValue:!1}]};case Ss:return{name:Ss,properties:[{name:`key`},{name:`value`}]};case Cs:return{name:Cs,properties:[{name:`key`},{name:`value`}]};case ws:return{name:ws,properties:[{name:`key`},{name:`value`}]};case Ts:return{name:Ts,properties:[{name:`key`},{name:`value`}]};case Es:return{name:Es,properties:[{name:`dotKind`},{name:`from`},{name:`isBidirectional`,defaultValue:!1},{name:`kind`}]};case Ds:return{name:Ds,properties:[{name:`key`},{name:`value`}]};case Os:return{name:Os,properties:[{name:`body`},{name:`description`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`tags`},{name:`target`},{name:`technology`},{name:`title`}]};case ks:return{name:ks,properties:[{name:`props`,defaultValue:[]},{name:`tags`}]};case As:return{name:As,properties:[{name:`subject`},{name:`where`}]};case js:return{name:js,properties:[{name:`custom`},{name:`subject`}]};case Ms:return{name:Ms,properties:[{name:`kind`}]};case Ns:return{name:Ns,properties:[{name:`key`},{name:`value`}]};case Ps:return{name:Ps,properties:[{name:`name`}]};case Fs:return{name:Fs,properties:[{name:`key`},{name:`value`}]};case Is:return{name:Is,properties:[{name:`key`},{name:`props`,defaultValue:[]}]};case Ls:return{name:Ls,properties:[{name:`alpha`},{name:`blue`},{name:`green`},{name:`red`}]};case Rs:return{name:Rs,properties:[{name:`key`},{name:`value`}]};case zs:return{name:zs,properties:[{name:`key`},{name:`value`}]};case Bs:return{name:Bs,properties:[{name:`color`},{name:`name`}]};case Vs:return{name:Vs,properties:[{name:`kind`},{name:`props`,defaultValue:[]},{name:`tags`}]};case Hs:return{name:Hs,properties:[{name:`kind`},{name:`props`,defaultValue:[]},{name:`tags`}]};case Us:return{name:Us,properties:[{name:`key`},{name:`value`}]};case Ws:return{name:Ws,properties:[{name:`kind`},{name:`props`,defaultValue:[]}]};case Gs:return{name:Gs,properties:[{name:`key`},{name:`value`}]};case Ks:return{name:Ks,properties:[{name:`colors`,defaultValue:[]},{name:`deploymentNodes`,defaultValue:[]},{name:`elements`,defaultValue:[]},{name:`name`},{name:`relationships`,defaultValue:[]},{name:`tags`,defaultValue:[]}]};case qs:return{name:qs,properties:[{name:`color`},{name:`tag`}]};case Js:return{name:Js,properties:[{name:`el`},{name:`parent`}]};case Ys:return{name:Ys,properties:[{name:`parent`},{name:`value`}]};case`Tag`:return{name:`Tag`,properties:[{name:`name`}]};case Xs:return{name:Xs,properties:[{name:`tag`}]};case Zs:return{name:Zs,properties:[{name:`prev`},{name:`values`,defaultValue:[]}]};case Qs:return{name:Qs,properties:[{name:`key`},{name:`value`}]};case $s:return{name:$s,properties:[{name:`view`}]};case ec:return{name:ec,properties:[{name:`key`},{name:`value`,defaultValue:!1}]};case tc:return{name:tc,properties:[{name:`direction`},{name:`nodeSep`},{name:`rankSep`}]};case nc:return{name:nc,properties:[{name:`predicate`}]};case rc:return{name:rc,properties:[{name:`style`}]};case ic:return{name:ic,properties:[{name:`groupRules`,defaultValue:[]},{name:`props`,defaultValue:[]},{name:`title`}]};case ac:return{name:ac,properties:[{name:`exprs`},{name:`isInclude`,defaultValue:!1}]};case oc:return{name:oc,properties:[{name:`targets`},{name:`value`}]};case sc:return{name:sc,properties:[{name:`props`,defaultValue:[]},{name:`targets`}]};case cc:return{name:cc,properties:[{name:`key`},{name:`value`}]};case lc:return{name:lc,properties:[{name:`left`},{name:`operator`},{name:`right`}]};case uc:return{name:uc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case dc:return{name:dc,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case fc:return{name:fc,properties:[{name:`value`}]};case pc:return{name:pc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case mc:return{name:mc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case hc:return{name:hc,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case gc:return{name:gc,properties:[{name:`value`}]};case _c:return{name:_c,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case vc:return{name:vc,properties:[{name:`key`},{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case yc:return{name:yc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`participant`},{name:`value`}]};case bc:return{name:bc,properties:[{name:`not`,defaultValue:!1},{name:`operator`},{name:`value`}]};case xc:return{name:xc,properties:[{name:`isWildcard`,defaultValue:!1}]};case Sc:return{name:Sc,properties:[{name:`custom`},{name:`dotKind`},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};case Cc:return{name:Cc,properties:[{name:`custom`},{name:`dotKind`},{name:`isBackward`,defaultValue:!1},{name:`kind`},{name:`source`},{name:`target`},{name:`title`}]};default:return{name:e,properties:[]}}}};const J=new LikeC4AstReflection;let wc;const LikeC4Grammar=()=>wc??=it(`{"$type":"Grammar","isDeclared":true,"name":"LikeC4","rules":[{"$type":"ParserRule","entry":true,"name":"LikeC4Grammar","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"imports","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@16"},"arguments":[]}},{"$type":"Assignment","feature":"specifications","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@8"},"arguments":[]}},{"$type":"Assignment","feature":"models","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@19"},"arguments":[]}},{"$type":"Assignment","feature":"views","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@44"},"arguments":[]}},{"$type":"Assignment","feature":"globals","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@124"},"arguments":[]}},{"$type":"Assignment","feature":"deployments","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@109"},"arguments":[]}},{"$type":"Assignment","feature":"likec4lib","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@1"},"arguments":[]}}],"cardinality":"*"},"definesHiddenTokens":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LikeC4Lib","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"likec4lib"},{"$type":"Keyword","value":"{"},{"$type":"Keyword","value":"icons"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"icons","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@2"},"arguments":[]},"cardinality":"+"},{"$type":"Keyword","value":"}"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LibIcon","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@162"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Tag","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationshipKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomColor","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNodeKind","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRule","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"specification"}},{"$type":"Keyword","value":"{"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@9"},"arguments":[]}},{"$type":"Assignment","feature":"tags","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@12"},"arguments":[]}},{"$type":"Assignment","feature":"relationships","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@14"},"arguments":[]}},{"$type":"Assignment","feature":"colors","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@13"},"arguments":[]}},{"$type":"Assignment","feature":"deploymentNodes","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@11"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationElementKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"element"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@3"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@10"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationElementStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"notation"},{"$type":"Keyword","value":"summary"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationDeploymentNodeKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"deploymentNode"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@7"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@10"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationTag","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"tag"},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@4"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Group","elements":[{"$type":"Keyword","value":"color"},{"$type":"Assignment","feature":"color","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@159"},"arguments":[]}}],"cardinality":"?"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationColor","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"color"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@6"},"arguments":[]}},{"$type":"Assignment","feature":"color","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@159"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRelationshipKind","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"relationship"},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@5"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@15"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SpecificationRelationshipStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"notation"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ImportsFromPoject","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"import"},{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"imports","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@17"},"arguments":[]}},{"$type":"Keyword","value":"}"}]},{"$type":"Assignment","feature":"imports","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@17"},"arguments":[]}}]},{"$type":"Keyword","value":"from"},{"$type":"Assignment","feature":"project","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Imported","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"imported","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Imported"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"imported","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Tags","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]},"cardinality":"+"},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Tags"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]},"cardinality":"*"}],"cardinality":"*"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Model","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"model"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@24"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@27"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Element","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}}]}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@21"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@23"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@147"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@134"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"summary"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElement","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"element","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@31"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@25"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElementBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@26"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@34"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@20"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendElementProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@28"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@29"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendRelationProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementRef","definition":{"$type":"Assignment","feature":"modelElement","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StrictFqnElementRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"el","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"StrictFqnElementRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"el","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@20"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StrictFqnRef","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"StrictFqnRef"},"feature":"parent","operator":"="},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@1"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Relation","parameters":[{"$type":"Parameter","name":"isExplicit"}],"definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","guardCondition":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@34/parameters@0"}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}}]},{"$type":"Group","guardCondition":{"$type":"Negation","value":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@34/parameters@0"}}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]},"cardinality":"?"}]}]},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"description","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"technology","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@35"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"wildcard":false},{"$type":"ParserRule","name":"RelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@36"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@37"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@81"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@38"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@39"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"technology"},{"$type":"Keyword","value":"description"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationStyleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"style"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataProperty","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@40"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@41"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataAttribute","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@42"},"arguments":[]}},{"$type":"Assignment","feature":"boolValue","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataValue","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@43"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataArray","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"["},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"values","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"]"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ModelViews","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"views"}},{"$type":"Assignment","feature":"folder","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"views","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@45"},"arguments":[]}},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LikeC4ViewRule","returnType":{"$ref":"#/types@2"},"definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@46"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@47"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@118"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"extends"},{"$type":"Assignment","feature":"extends","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@49"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Keyword","value":"of"},{"$type":"Assignment","feature":"viewOf","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}}]}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@51"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"dynamic"},{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@52"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@2"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@46"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewRef","definition":{"$type":"Assignment","feature":"view","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@47"},"deprecatedSyntax":false}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@58"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@53"},"arguments":[]},"cardinality":"*"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"steps","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@63"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@65"},"arguments":[]}]}},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@62"},"arguments":[]}}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@54"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewDisplayVariantProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"variant"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@155"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@56"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@130"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewStringProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"title"},{"$type":"Keyword","value":"description"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewLayoutDirection","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"TopBottom"},{"$type":"Keyword","value":"LeftRight"},{"$type":"Keyword","value":"BottomTop"},{"$type":"Keyword","value":"RightLeft"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@69"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@61"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@59"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleRank","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"rank"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@60"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RankValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"same"},{"$type":"Keyword","value":"min"},{"$type":"Keyword","value":"max"},{"$type":"Keyword","value":"source"},{"$type":"Keyword","value":"sink"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"group"},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@141"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@132"},"arguments":[]}]},"cardinality":"*"},{"$type":"Assignment","feature":"groupRules","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@61"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@70"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@71"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@74"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewParallelSteps","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"parallel"},{"$type":"Keyword","value":"par"}]},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"steps","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@63"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@65"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"DynamicViewStepTarget","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@79"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewStep","returnType":{"$ref":"#/types@5"},"definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@66"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicStepChain","returnType":{"$ref":"#/interfaces@1"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@67"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","type":{"$ref":"#/interfaces@2"},"feature":"source","operator":"="},{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@64"},"arguments":[]}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicStepSingle","returnType":{"$ref":"#/interfaces@1"},"definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isBackward","operator":"?=","terminal":{"$type":"Keyword","value":"<-"}},{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@64"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRulePredicate","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isInclude","operator":"?=","terminal":{"$type":"Keyword","value":"include"}},{"$type":"Keyword","value":"exclude"}]},{"$type":"Assignment","feature":"exprs","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGlobalPredicateRef","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"predicate"},{"$type":"Assignment","feature":"predicate","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@125"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewIncludePredicate","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"include"},{"$type":"Assignment","feature":"exprs","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewGlobalPredicateRef","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"predicate"},{"$type":"Assignment","feature":"predicate","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@126"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleGlobalStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"global"},{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"style","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@127"},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleStyleOrGlobalRef","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@72"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@73"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleAutoLayout","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"autoLayout"},{"$type":"Assignment","feature":"direction","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@57"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"rankSep","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Assignment","feature":"nodeSep","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NotationProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"notation"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NotesProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"notes"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@164"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomElementProperties","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@80"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@23"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@77"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomRelationProperties","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@81"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@37"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@77"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@150"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"NavigateToProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"navigateTo"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@48"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationNavigateToProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"navigateTo"}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@50"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Expressions","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@83"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"Expressions"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@83"},"arguments":[]},"cardinality":"?"}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExpressionV2","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@86"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@84"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExprOrWith","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@85"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExprWith"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"with"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@78"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExprOrWhere","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExprWhere"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"where"},{"$type":"Assignment","feature":"where","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExprOrWith","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@87"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"RelationExprWith"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"with"},{"$type":"Assignment","feature":"custom","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@79"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExprOrWhere","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@90"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"RelationExprWhere"},"feature":"subject","operator":"="},{"$type":"Keyword","value":"where"},{"$type":"Assignment","feature":"where","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExpr","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WildcardExpression"}},{"$type":"Assignment","feature":"isWildcard","operator":"?=","terminal":{"$type":"Keyword","value":"*"}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"ElementTagExpression"}},{"$type":"Keyword","value":"element.tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@168"},"arguments":[]},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"ElementKindExpression"}},{"$type":"Keyword","value":"element.kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@168"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@3"},"deprecatedSyntax":false}}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@89"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnRefExpr","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"ref","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Assignment","feature":"selector","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@178"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@179"},"arguments":[]}]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationExpr","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@91"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@93"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"InOutRelationExpr","inferredType":{"$type":"InferredType","name":"RelationExpr"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@92"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"InOutRelationExpr"},"feature":"inout","operator":"="},{"$type":"Keyword","value":"->"}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IncomingRelationExpr","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"->"},{"$type":"Assignment","feature":"to","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DirectedRelationExpr","inferredType":{"$type":"InferredType","name":"RelationExpr"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@94"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"DirectedRelationExpr"},"feature":"source","operator":"="},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}}],"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"OutgoingRelationExpr","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"from","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isBidirectional","operator":"?=","terminal":{"$type":"Keyword","value":"<->"}},{"$type":"Keyword","value":"->"},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"FqnExpressions","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"FqnExpressions"},"feature":"prev","operator":"="},{"$type":"Keyword","value":","},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@88"},"arguments":[]},"cardinality":"?"}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementExpression","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@97"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementOr","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@98"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"or"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@98"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementAnd","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@99"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"and"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@99"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementPrimary","inferredType":{"$type":"InferredType","name":"WhereElementExpression"},"definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"("},{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]},{"$type":"Keyword","value":")"}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@100"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@101"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElementNegation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"not"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@96"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereElement","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementTag"}},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementKind"}},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@6"},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereElementMetadata"}},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MetadataFilterValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationExpression","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@104"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationOr","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@105"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"or"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@105"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationAnd","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@106"},"arguments":[]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereBinaryExpression"},"feature":"left","operator":"="},{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"and"}},{"$type":"Assignment","feature":"right","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@106"},"arguments":[]}}],"cardinality":"*"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationPrimary","inferredType":{"$type":"InferredType","name":"WhereRelationExpression"},"definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Keyword","value":"("},{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]},{"$type":"Keyword","value":")"}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@107"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@108"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelationNegation","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"not"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@103"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"WhereRelation","definition":{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationTag"}},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationKind"}},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationMetadata"}},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantTag"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"tag"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@151"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantKind"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"kind"},{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/types@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Group","elements":[{"$type":"Action","inferredType":{"$type":"InferredType","name":"WhereRelationParticipantMetadata"}},{"$type":"Assignment","feature":"participant","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Keyword","value":"metadata"},{"$type":"RuleCall","rule":{"$ref":"#/rules@181"},"arguments":[]},{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@167"},"arguments":[]},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@102"},"arguments":[]}}],"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ModelDeployments","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"deployment"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@114"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNode","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@7"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@7"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]}]},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"summary","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@111"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentNodeBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@112"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeployedInstance","definition":{"$type":"Group","elements":[{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]}],"cardinality":"?"},{"$type":"Keyword","value":"instanceOf"},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@30"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"summary","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@113"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeployedInstanceBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@22"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":false},"calledByName":false}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendDeployment","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"extend"},{"$type":"Assignment","feature":"deploymentNode","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@33"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@115"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ExtendDeploymentBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@26"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"elements","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@112"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@116"},"arguments":[{"$type":"NamedArgument","value":{"$type":"BooleanLiteral","true":true},"calledByName":false}]},{"$type":"RuleCall","rule":{"$ref":"#/rules@110"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentRelation","parameters":[{"$type":"Parameter","name":"isExplicit"}],"definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Group","guardCondition":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@116/parameters@0"}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}}]},{"$type":"Group","guardCondition":{"$type":"Negation","value":{"$type":"ParameterReference","parameter":{"$ref":"#/rules@116/parameters@0"}}},"elements":[{"$type":"Assignment","feature":"source","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]},"cardinality":"?"}]}]},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"dotKind","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@152"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Keyword","value":"-["},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"deprecatedSyntax":false}},{"$type":"Keyword","value":"]->"}]},{"$type":"Keyword","value":"->"}]},{"$type":"Assignment","feature":"target","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@32"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"description","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}},{"$type":"Assignment","feature":"technology","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"}],"cardinality":"?"}],"cardinality":"?"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@117"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentRelationBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@36"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentView","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"deployment"},{"$type":"Keyword","value":"view"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]}},{"$type":"Assignment","feature":"body","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@119"},"arguments":[]},"cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewBody","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"tags","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@18"},"arguments":[]},"cardinality":"?"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@55"},"arguments":[]},"cardinality":"*"},{"$type":"Assignment","feature":"rules","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@120"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRule","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@123"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@122"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@75"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@121"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ViewRuleAncestors","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"includeAncestors"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRuleStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DeploymentViewRulePredicate","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isInclude","operator":"?=","terminal":{"$type":"Keyword","value":"include"}},{"$type":"Keyword","value":"exclude"}]},{"$type":"Assignment","feature":"expr","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@82"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Globals","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"Keyword","value":"global"}},{"$type":"Keyword","value":"{"},{"$type":"Group","elements":[{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@125"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@126"},"arguments":[]}]},"cardinality":"*"},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@128"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@129"},"arguments":[]}]},"cardinality":"*"}],"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalPredicateGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"predicateGroup"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@68"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalDynamicPredicateGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"dynamicPredicateGroup"},{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"predicates","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@70"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyleId","definition":{"$type":"Assignment","feature":"name","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyle","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"style"},{"$type":"Assignment","feature":"id","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@127"},"arguments":[]}},{"$type":"Assignment","feature":"targets","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@95"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@76"},"arguments":[]}]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"GlobalStyleGroup","definition":{"$type":"Group","elements":[{"$type":"Keyword","value":"styleGroup"},{"$type":"Assignment","feature":"id","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@127"},"arguments":[]}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"styles","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@72"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LinkProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"link"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@163"},"arguments":[]}},{"$type":"Assignment","feature":"title","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]},"cardinality":"?"},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ColorProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"color"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"themeColor","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]}},{"$type":"Assignment","feature":"customColor","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"OpacityProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"opacity"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@185"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MultipleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"multiple"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@173"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"icon"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"libicon","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@2"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@162"},"arguments":[]},"deprecatedSyntax":false}},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"none"},{"$type":"RuleCall","rule":{"$ref":"#/rules@163"},"arguments":[]}]}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconColorProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconColor"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"themeColor","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]}},{"$type":"Assignment","feature":"customColor","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@6"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@165"},"arguments":[]},"deprecatedSyntax":false}}]},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconSize"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconPositionValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"left"},{"$type":"Keyword","value":"right"},{"$type":"Keyword","value":"top"},{"$type":"Keyword","value":"bottom"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconPositionProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"iconPosition"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@137"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ShapeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"shape"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"BorderStyleValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"Keyword","value":"none"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"BorderProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"border"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@140"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"SizeValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"xs"},{"$type":"Keyword","value":"sm"},{"$type":"Keyword","value":"md"},{"$type":"Keyword","value":"lg"},{"$type":"Keyword","value":"xl"},{"$type":"Keyword","value":"xsmall"},{"$type":"Keyword","value":"small"},{"$type":"Keyword","value":"medium"},{"$type":"Keyword","value":"large"},{"$type":"Keyword","value":"xlarge"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ShapeSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"size"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"PaddingSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"padding"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"TextSizeProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"textSize"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"StyleProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@139"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@141"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@132"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@134"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@135"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@133"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@143"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@144"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@145"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@136"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@138"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementStyleProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"style"}},{"$type":"Keyword","value":"{"},{"$type":"Assignment","feature":"props","operator":"+=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@146"},"arguments":[]},"cardinality":"*"},{"$type":"Keyword","value":"}"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LineProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Keyword","value":"line"}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ArrowProperty","definition":{"$type":"Group","elements":[{"$type":"Assignment","feature":"key","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"head"},{"$type":"Keyword","value":"tail"}]}},{"$type":"Keyword","value":":","cardinality":"?"},{"$type":"Assignment","feature":"value","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]}},{"$type":"Keyword","value":";","cardinality":"?"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationshipStyleProperty","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@131"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@148"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@149"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"TagRef","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@180"},"arguments":[]},{"$type":"Assignment","feature":"tag","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@4"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RelationKindDotRef","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@182"},"arguments":[]},{"$type":"Assignment","feature":"kind","operator":"=","terminal":{"$type":"CrossReference","type":{"$ref":"#/rules@5"},"terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@166"},"arguments":[]},"deprecatedSyntax":false}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"LineOptions","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"solid"},{"$type":"Keyword","value":"dashed"},{"$type":"Keyword","value":"dotted"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ArrowType","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"none"},{"$type":"Keyword","value":"normal"},{"$type":"Keyword","value":"onormal"},{"$type":"Keyword","value":"dot"},{"$type":"Keyword","value":"odot"},{"$type":"Keyword","value":"diamond"},{"$type":"Keyword","value":"odiamond"},{"$type":"Keyword","value":"crow"},{"$type":"Keyword","value":"open"},{"$type":"Keyword","value":"vee"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"DynamicViewDisplayVariantValue","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"diagram"},{"$type":"Keyword","value":"sequence"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ThemeColor","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"primary"},{"$type":"Keyword","value":"secondary"},{"$type":"Keyword","value":"muted"},{"$type":"Keyword","value":"slate"},{"$type":"Keyword","value":"blue"},{"$type":"Keyword","value":"indigo"},{"$type":"Keyword","value":"sky"},{"$type":"Keyword","value":"red"},{"$type":"Keyword","value":"gray"},{"$type":"Keyword","value":"green"},{"$type":"Keyword","value":"amber"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ElementShape","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"rectangle"},{"$type":"Keyword","value":"component"},{"$type":"Keyword","value":"person"},{"$type":"Keyword","value":"browser"},{"$type":"Keyword","value":"mobile"},{"$type":"Keyword","value":"cylinder"},{"$type":"Keyword","value":"storage"},{"$type":"Keyword","value":"queue"},{"$type":"Keyword","value":"bucket"},{"$type":"Keyword","value":"document"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Participant","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"source"},{"$type":"Keyword","value":"target"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"ColorLiteral","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@160"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@161"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"RGBAColor","definition":{"$type":"Group","elements":[{"$type":"Alternatives","elements":[{"$type":"Keyword","value":"rgba"},{"$type":"Keyword","value":"rgb"}]},{"$type":"Keyword","value":"("},{"$type":"Assignment","feature":"red","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"green","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"blue","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]}},{"$type":"Keyword","value":",","cardinality":"?"},{"$type":"Assignment","feature":"alpha","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@188"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@185"},"arguments":[]}]},"cardinality":"?"},{"$type":"Keyword","value":")"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"HexColor","definition":{"$type":"Group","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@180"},"arguments":[]},{"$type":"Assignment","feature":"hex","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@191"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@189"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]}]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"IconId","dataType":"string","definition":{"$type":"RuleCall","rule":{"$ref":"#/rules@174"},"arguments":[]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Uri","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@175"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@176"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@177"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"MarkdownOrString","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"markdown","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@186"},"arguments":[]}},{"$type":"Assignment","feature":"text","operator":"=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@187"},"arguments":[]}}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"CustomColorId","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]},{"$type":"Keyword","value":"element"},{"$type":"Keyword","value":"model"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","name":"Id","dataType":"string","definition":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@190"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@157"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@156"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@154"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@153"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@158"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@142"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@155"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@137"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@60"},"arguments":[]},{"$type":"Keyword","value":"element"},{"$type":"Keyword","value":"model"},{"$type":"Keyword","value":"group"},{"$type":"Keyword","value":"node"},{"$type":"Keyword","value":"deployment"},{"$type":"Keyword","value":"instance"},{"$type":"Keyword","value":"relationship"}]},"definesHiddenTokens":false,"entry":false,"fragment":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"EqOperator","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Alternatives","elements":[{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]},{"$type":"RuleCall","rule":{"$ref":"#/rules@183"},"arguments":[]}]}},{"$type":"Group","elements":[{"$type":"Assignment","feature":"operator","operator":"=","terminal":{"$type":"Keyword","value":"is"}},{"$type":"Assignment","feature":"not","operator":"?=","terminal":{"$type":"Keyword","value":"not"},"cardinality":"?"}]}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"ParserRule","fragment":true,"name":"IsEqual","definition":{"$type":"Alternatives","elements":[{"$type":"Assignment","feature":"isEqual","operator":"?=","terminal":{"$type":"RuleCall","rule":{"$ref":"#/rules@184"},"arguments":[]}},{"$type":"RuleCall","rule":{"$ref":"#/rules@183"},"arguments":[]}]},"definesHiddenTokens":false,"entry":false,"hiddenTokens":[],"parameters":[],"wildcard":false},{"$type":"TerminalRule","hidden":true,"name":"BLOCK_COMMENT","definition":{"$type":"RegexToken","regex":"/\\\\/\\\\*[\\\\s\\\\S]*?\\\\*\\\\//"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"LINE_COMMENT","definition":{"$type":"RegexToken","regex":"/\\\\/\\\\/[^\\\\n\\\\r]*/"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"WS","definition":{"$type":"RegexToken","regex":"/[\\\\t ]+/"},"fragment":false},{"$type":"TerminalRule","hidden":true,"name":"NL","definition":{"$type":"RegexToken","regex":"/[\\\\r\\\\n]+/"},"fragment":false},{"$type":"TerminalRule","name":"BOOLEAN","type":{"$type":"ReturnType","name":"boolean"},"definition":{"$type":"RegexToken","regex":"/\\\\b(true|false)\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"LIB_ICON","definition":{"$type":"RegexToken","regex":"/(aws|azure|bootstrap|gcp|tech):[-\\\\w]*/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_WITH_SCHEMA","definition":{"$type":"RegexToken","regex":"/\\\\w+:\\\\/{2}\\\\S+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_RELATIVE","definition":{"$type":"RegexToken","regex":"/\\\\.{0,2}\\\\/[^\\\\/]\\\\S+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"URI_ALIAS","definition":{"$type":"RegexToken","regex":"/@[a-zA-Z0-9_-]*\\\\/[^\\\\s]+/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"DotUnderscore","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\._(?![_a-zA-Z])/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"DotWildcard","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\.\\\\*{1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Hash","definition":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"#"}},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"StickyDot","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\./"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Dot","definition":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"."}},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"NotEqual","definition":{"$type":"RegexToken","regex":"/\\\\!\\\\={1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Eq","definition":{"$type":"RegexToken","regex":"/\\\\={1,2}/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Percent","definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+%/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"MarkdownString","definition":{"$type":"TerminalAlternatives","elements":[{"$type":"TerminalGroup","elements":[{"$type":"CharacterRange","left":{"$type":"Keyword","value":"'''"}},{"$type":"UntilToken","terminal":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"'''"}}}]},{"$type":"TerminalGroup","elements":[{"$type":"CharacterRange","left":{"$type":"Keyword","value":"\\"\\"\\""}},{"$type":"UntilToken","terminal":{"$type":"CharacterRange","left":{"$type":"Keyword","value":"\\"\\"\\""}}}]}]},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"String","definition":{"$type":"RegexToken","regex":"/\\"(?:[^\\"\\\\\\\\]|\\\\\\\\.)*\\"|'(?:[^'\\\\\\\\]|\\\\\\\\.)*'/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Float","type":{"$type":"ReturnType","name":"number"},"definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+\\\\.\\\\d+\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Number","type":{"$type":"ReturnType","name":"number"},"definition":{"$type":"RegexToken","regex":"/\\\\b\\\\d+\\\\b/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"IdTerminal","definition":{"$type":"RegexToken","regex":"/([a-zA-Z]|_+[a-zA-Z0-9])[-\\\\w]*/"},"fragment":false,"hidden":false},{"$type":"TerminalRule","name":"Hex","definition":{"$type":"RegexToken","regex":"/[a-fA-F0-9]{3,}(?![-_g-zG-Z])/"},"fragment":false,"hidden":false}],"types":[{"$type":"Type","name":"ModelReferenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@17"}}]}},{"$type":"Type","name":"Referenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@110"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@112"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@17"}}]}},{"$type":"Type","name":"LikeC4View","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@46"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@47"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@118"}}]}},{"$type":"Type","name":"StringProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@23"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@56"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@37"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@41"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@10"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@15"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@76"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@77"}}]}},{"$type":"Type","name":"AnyProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/types@3"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@55"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@53"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@22"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@36"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@150"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@76"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@77"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@80"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@146"}}]}},{"$type":"Type","name":"DynamicViewStep","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@2"}}]}},{"$type":"Type","name":"DeploymentNodeOrElementKind","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@3"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@7"}}]}},{"$type":"Type","name":"WhereTagEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@0/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@0/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@3/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereKindEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@1/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@1/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@4/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereMetadataEqual","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@101/definition/elements@2/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@2/elements@0/inferredType"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@108/definition/elements@5/elements@0/inferredType"}}]}},{"$type":"Type","name":"WhereExpression","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@96"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@103"}}]}},{"$type":"Type","name":"DeploymentElement","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@110"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@112"}}]}},{"$type":"Type","name":"FqnReferenceable","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/types@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@20"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@24"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@114"}}]}},{"$type":"Type","name":"SizeProperty","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/rules@143"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@144"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@145"}},{"$type":"SimpleType","typeRef":{"$ref":"#/rules@136"}}]}}],"interfaces":[{"$type":"Interface","name":"AbstractDynamicStep","attributes":[{"$type":"TypeAttribute","name":"kind","isOptional":true,"type":{"$type":"ReferenceType","referenceType":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@5"}}}},{"$type":"TypeAttribute","name":"dotKind","isOptional":true,"type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@152"}}},{"$type":"TypeAttribute","name":"target","type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@30"}},"isOptional":false},{"$type":"TypeAttribute","name":"title","isOptional":true,"type":{"$type":"SimpleType","primitiveType":"string"}},{"$type":"TypeAttribute","name":"custom","isOptional":true,"type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@79"}}}],"superTypes":[]},{"$type":"Interface","name":"DynamicStepSingle","superTypes":[{"$ref":"#/interfaces@0"}],"attributes":[{"$type":"TypeAttribute","name":"source","type":{"$type":"SimpleType","typeRef":{"$ref":"#/rules@30"}},"isOptional":false},{"$type":"TypeAttribute","name":"isBackward","isOptional":true,"type":{"$type":"SimpleType","primitiveType":"boolean"}}]},{"$type":"Interface","name":"DynamicStepChain","superTypes":[{"$ref":"#/interfaces@0"}],"attributes":[{"$type":"TypeAttribute","name":"source","type":{"$type":"UnionType","types":[{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@1"}},{"$type":"SimpleType","typeRef":{"$ref":"#/interfaces@2"}}]},"isOptional":false}]}],"definesHiddenTokens":false,"hiddenTokens":[],"imports":[],"usedGrammars":[]}`),Tc={languageId:`likec4`,fileExtensions:[`.c4`,`.likec4`,`.like-c4`],caseInsensitive:!1,mode:`production`},Ec={skipValidations:!0,recoveryEnabled:!0,nodeLocationTracking:`full`},Dc={AstReflection:()=>new LikeC4AstReflection},Oc={Grammar:()=>LikeC4Grammar(),LanguageMetaData:()=>Tc,parser:{ParserConfig:()=>Ec}},kc=Symbol.for(`idattr`),Ac={writeId(e,t){return e[kc]=t,e},readId(e){return e[kc]}},jc={writeId(e,t){return M(t)?e[kc]=void 0:e[kc]=t,e},readId(e){return e[kc]}};function isLikeC4LangiumDocument(e){return e?.textDocument.languageId===Tc.languageId}function isLikeC4UserDocument(e){return isLikeC4LangiumDocument(e)&&isNotLikeC4Builtin(e)}function parseMarkdownAsString(e){return e?.markdown||e?.text}function parseAstPercent(e){let t=parseFloat(e);return isNaN(t)?100:Sn(t,{min:0,max:100})}function parseAstOpacityProperty({value:e}){return parseAstPercent(e)}function parseAstSizeValue({value:e}){switch(e){case`xs`:case`sm`:case`md`:case`lg`:case`xl`:return e;case`xsmall`:return`xs`;case`small`:return`sm`;case`medium`:return`md`;case`large`:return`lg`;case`xlarge`:return`xl`;default:ci(e)}}function parseAstIconPositionValue({value:e}){switch(e){case`left`:case`right`:case`top`:case`bottom`:return e;default:ci(e)}}function toRelationshipStyle(e,t){let r={};if(!e||e.length===0)return r;for(let o of e)if(t(o))switch(!0){case isColorProperty(o):{let e=toColor(o);k(e)&&(r.color=e);break}case isLineProperty(o):r.line=o.value;break;case isArrowProperty(o):switch(o.key){case`head`:r.head=o.value;break;case`tail`:r.tail=o.value;break;default:ci(o)}break;default:ci(o)}return r}function toColor(e){return e?.themeColor??e?.customColor?.$refText}function toAutoLayout(e){let t=e.rankSep,r=e.nodeSep,o;switch(e.direction){case`TopBottom`:o=`TB`;break;case`BottomTop`:o=`BT`;break;case`LeftRight`:o=`LR`;break;case`RightLeft`:o=`RL`;break;default:ci(e.direction)}return{direction:o,...r&&{nodeSep:r},...t&&{rankSep:t}}}function toAstViewLayoutDirection(e){switch(e){case`TB`:return`TopBottom`;case`BT`:return`BottomTop`;case`LR`:return`LeftRight`;case`RL`:return`RightLeft`;default:ci(e)}}function getViewRulePredicateContainer(e){return et(e,e=>isViewRulePredicate(e)||isDeploymentViewRulePredicate(e)||isDynamicViewIncludePredicate(e))}const _isModel=e=>isModel(e)||isElementBody(e)||isExtendElementBody(e)||isElementViewBody(e)||isDynamicViewBody(e)||isElementRef(e),Mc=t(e=>isModelDeployments(e)||isDeploymentViewBody(e)||isDeploymentNodeBody(e)||isExtendDeploymentBody(e)||isDeployedInstanceBody(e),`_isDeployment`);function isFqnRefInsideGlobals(e){for(;;){if(Mc(e)||_isModel(e))return!1;if(isGlobals(e)||isModelViews(e))return!0;if(e.$container)e=e.$container;else return!1}}function isFqnRefInsideModel(e){for(;;){if(Mc(e))return!1;if(_isModel(e))return!0;if(e.$container)e=e.$container;else return!1}}function isFqnRefInsideDeployment(e){for(;;){if(_isModel(e))return!1;if(Mc(e))return!0;if(e.$container)e=e.$container;else return!1}}function elementRef(e){try{let t=isStrictFqnElementRef(e)?e.el.ref:e.modelElement.value.ref;return t?.$type===`Imported`&&(t=t.imported.ref),t?.$type===`Element`?t:void 0}catch{return}}function readStrictFqn(e){let t=[e.$type===`StrictFqnRef`?e.value.$refText:e.el.$refText],r=e.parent;for(;r;)t.push(r.$type===`StrictFqnRef`?r.value.$refText:r.el.$refText),r=r.parent;return t.length===1?t[0]:t.reverse().join(`.`)}function referenceableParent(e){for(;e.parent;)e=e.parent;return e.value.ref??null}function instanceRef(e){let t;for(;t=e.value?.ref;){if(isDeploymentNode$1(t))return null;if(isDeployedInstance(t))return t;if(M(e.parent))return null;e=e.parent}return null}function importsRef(e){let t=referenceableParent(e);return t?.$type===`Imported`?t:null}function isReferenceToDeploymentModel(e){let t;for(;t=e.value?.ref;){if(isDeploymentElement(t))return!0;if(M(e.parent))return!1;e=e.parent}return!1}var AstNodeDescriptionProvider=class extends y{services;constructor(e){super(e),this.services=e}createDescription(e,t,r){r??=Te(e);let o=super.createDescription(e,t,r);return isLikeC4Builtin(r.uri)||(r.likec4ProjectId??=this.services.shared.workspace.ProjectsManager.ownerProjectId(r),o.likec4ProjectId=r.likec4ProjectId),o}},IndexManager=class extends fe{services;constructor(e){super(e),this.services=e}async updateContent(e,t){e.likec4ProjectId=this.services.workspace.ProjectsManager.ownerProjectId(e),await super.updateContent(e,t)}projectElements(e,t,r){let o=this.services.workspace.ProjectsManager;return st(this.symbolIndex.keys()).filter(t=>r&&!r.has(t)?!1:o.isIncluded(e,t)).flatMap(e=>this.getFileDescriptions(e,t))}};const Nc=$r(`/`),Pc=t((e,t)=>Nc(e.uri.path,t.uri.path),`ensureOrder`);var LangiumDocuments=class extends _{services;constructor(e){super(e),this.services=e}get projectsManager(){return this.services.workspace.ProjectsManager}addDocument(e){let t=e.uri.toString();if(this.documentMap.has(t))throw Error(`A document with the URI '${t}' is already present.`);let r=[...this.documentMap.values(),e].sort(Pc);this.documentMap.clear();for(let e of r)this.documentMap.set(e.uri.toString(),e);isLikeC4UserDocument(e)&&(e.likec4ProjectId=this.projectsManager.ownerProjectId(e))}getDocument(e){let t=super.getDocument(e);return isLikeC4UserDocument(t)&&(t.likec4ProjectId=this.projectsManager.ownerProjectId(t)),t}get userDocuments(){return st(this.documentMap.values()).filter(e=>isLikeC4UserDocument(e)&&!this.projectsManager.isExcluded(e))}get all(){return st(this.documentMap.values()).map(e=>(isLikeC4UserDocument(e)&&(e.likec4ProjectId=this.projectsManager.ownerProjectId(e)),e))}projectDocuments(e){let t=this.services.workspace.ProjectsManager;return st(this.documentMap.values()).filter(r=>isLikeC4UserDocument(r)&&t.isIncluded(e,r)?(r.likec4ProjectId=e,!0):!1)}groupedByProject(){let e=this.services.workspace.ProjectsManager;return F(this.userDocuments.toArray(),I(t=>(t.likec4ProjectId=e.ownerProjectId(t),t)),tn(jn(`likec4ProjectId`)))}resetProjectIds(){let e=[];for(let t of this.documentMap.values())delete t.likec4ProjectId,isLikeC4UserDocument(t)&&!this.projectsManager.isExcluded(t)&&e.push(t.uri);return e}},Fc=e(Kn(),1);const Y=q.getChild(`projects`);function isLangiumDocument(e){return typeof e==`object`&&`uri`in e&&`textDocument`in e}function normalizeUri(e){return isLangiumDocument(e)?e.uri.toString():typeof e==`string`?_t(e,{acceptRelative:!1,strict:!0})?e:C.file(e).toString():e.toString()}const Ic=$r(`/`,!0),compareUri=(e,t)=>Ic(gt(e.path),gt(t.path));function isParentFolderFor(e){return t=>e.startsWith(ii(t)?t:t.folder)}function _overlaps(e,t){let r=ii(e)?e:e.folder,o=ii(t)?t:t.folder;return r===o||r.startsWith(o)||o.startsWith(r)}function overlaps(...e){return cn(_overlaps,e)}function _includes(e,t){return t.startsWith(e.folder)||e.includePaths?.some(isParentFolderFor(t))?!_excludes(e,t):!1}function _excludes(e,t){return e.exclude?.(dt(t))??!1}function includes(...e){return cn(_includes,e)}function excludes(...e){return cn(_excludes,e)}function ProjectFolder(e){return e=normalizeUri(e),pt(e)}const compareProjectByFolder=(e,t)=>compareUri(e.folderUri,t.folderUri);function ensureProjectsOrder(e){return e.length<=1?e:Cn(e,compareProjectByFolder)}const Lc={id:`default`,config:{name:`default`,exclude:[`**/node_modules/**`]},exclude:(0,Fc.default)(`**/node_modules/**`,{dot:!0}),includeConfig:{paths:[],maxDepth:3,fileThreshold:30}};function isExcludedByDefault(e){return Lc.exclude(dt(e))}function parseRegisterOptions(e){if(`configUri`in e){W(!Yt(e.configUri),`configUri is emptyish`);let t=C.isUri(e.configUri)?e.configUri:C.parse(normalizeUri(e.configUri)),r=ProjectFolder(S.dirname(t));return{configUri:t,folder:r,folderUri:C.parse(r)}}W(!Yt(e.folderUri),`folderUri is emptyish`);let t=ProjectFolder(e.folderUri),r=C.parse(t);return{configUri:S.joinPath(r,`likec4.config.json`),folder:t,folderUri:r}}var Rc=class ProjectsManager extends ADisposable{services;static DefaultProjectId=Lc.id;#e=[];#t=void 0;#n=void 0;#r=[];#i=new Jr(e=>{if(e===ProjectsManager.DefaultProjectId){let t=this.getWorkspaceFolder(),r=S.joinPath(t,`likec4.config.json`),o=ProjectFolder(t);return{id:e,config:Lc.config,folder:o,folderUri:C.parse(o),configUri:r,exclude:Lc.exclude,includeConfig:{...Lc.includeConfig}}}return si(this.#r.find(t=>t.id===e),`Project ${e} not found`)});#a=new Jr(e=>{if(this.isExcludedByWorkspace(e))return!0;let t=this.#o.get(e);return t?excludes(t,e)?!this.#r.some(includes(e)):!1:isExcludedByDefault(e)});#o=new Jr(e=>{if(this.#r.length===0)return null;let t=isParentFolderFor(e);return this.#r.find(t)??this.#r.find(includes(e))??null});constructor(e){super(),this.services=e,this.onDispose(b.create(()=>{this.resetCaches(),this.#e.length=0})),Y.trace`created`}isExcludedByWorkspace(e){return this.#n?(C.isUri(e)&&(e=normalizeUri(e)),this.#n(dt(e))):!1}setWorkspaceExcludePatterns(e){try{if(!Array.isArray(e)){this.#n=void 0;return}let t=F(e,P(k),I(e=>(!zt(e)&&!e.startsWith(`**`)&&(e=ht(`**`,e)),e)));if(!N(t,1)){this.#n=void 0;return}Y.debug`set workspace exclude patterns: ${t}`,this.#n=(0,Fc.default)(t,{dot:!0})}catch(e){Y.warn(`Failed to set workspace exclude patterns`,{error:e}),this.#n=void 0}}get defaultProjectId(){if(this.#t)return this.#t;if(!(this.#r.length>1))return N(this.#r,1)?this.#r[0].id:ProjectsManager.DefaultProjectId}set defaultProjectId(e){if(e!==this.#t){if(this.#t=void 0,!e||e===ProjectsManager.DefaultProjectId){Y.debug`reset default project ID`;return}W(this.#r.find(t=>t.id===e),`Project "${e}" not found`),Y.debug`set default project ID to ${e}`,this.#t=e}}get default(){return this.#i.get(this.defaultProjectId??ProjectsManager.DefaultProjectId)}get all(){if(N(this.#r,1)){let e=[...I(this.#r,jn(`id`)),Lc.id];if(this.#t){let t=e.findIndex(e=>e===this.#t);t>0&&(e.splice(t,1),e.unshift(this.#t))}return e}return[Lc.id]}getProject(e){let t=typeof e==`string`?e:e.likec4ProjectId??this.ownerProjectId(e);return this.#i.get(t)}findOverlaped(e){if(this.#r.length===0)return[];let t=overlaps(ProjectFolder(e)),isInsideOrIncludes=e=>t(e)||!!e.includePaths&&!!rn(e.includePaths,t);return this.#r.filter(isInsideOrIncludes)}ensureProjectId(e){return e===ProjectsManager.DefaultProjectId?this.defaultProjectId??ProjectsManager.DefaultProjectId:e?(W(this.#r.some(t=>e===t.id),`Project ID ${e} is not registered`),e):si(this.defaultProjectId,()=>`Specify exact project, known: [${I(this.#r,jn(`id`)).join(`, `)}]`)}ensureProject(e){return e=this.ensureProjectId(e),this.getProject(e)}hasMultipleProjects(){return this.#r.length>1}isExcluded(...e){let t=e.length===1?e[0]:e[1];return isLangiumDocument(t)&&isLikeC4Builtin(t)?!0:e.length===1?this.#a.get(normalizeUri(t)):excludes(this.#i.get(e[0]),normalizeUri(t))}isIncluded(e,t){let r=normalizeUri(t);return this.isExcludedByWorkspace(r)?!1:N(this.#r,1)?e===ProjectsManager.DefaultProjectId?!this.#o.get(r)&&!isExcludedByDefault(r):includes(this.#i.get(e),r):!isExcludedByDefault(r)}async registerConfigFile(e,t){if(this.isExcludedByWorkspace(e))throw Error(`Skipping project config, path ${e.fsPath} is excluded by editor settings`);if(isExcludedByDefault(normalizeUri(e)))throw Error(`Failed to register project config, path ${e.fsPath} is excluded by default: ${Lc.config.exclude.map(e=>`"${e}"`).join(`, `)}`);try{let r=await this.services.workspace.FileSystemProvider.loadProjectConfig(e);return await this.registerProject({config:r,configUri:e},t)}catch(t){if(!re(t))throw wrapError(t,`Failed to register project config ${e.fsPath}:\n`);return Promise.reject(t)}}async registerProject(e,t){let r=Nt.validate(e.config),{configUri:o,folder:s,folderUri:c}=parseRegisterOptions(e),u=Nt.normalizeInclude(r.include),d=this.#r.find(e=>e.folder===s);return d?(d.config.name!==r.name&&(Y.info`project name changed from ${d.config.name} to ${r.name}`,Y.info`remove ${d.id}`,d.id=this.uniqueProjectId(r.name),Y.info`add ${d.id}`),this.warnIfConfigOverride(d,o),d.config=r,d.folder=s,d.folderUri=c,d.configUri=o,d.includeConfig=u):(d={id:this.uniqueProjectId(r.name),config:r,folder:s,configUri:o,folderUri:c,includeConfig:u},this.#r=ensureProjectsOrder([...this.#r,d]),Y.info`add ${d.id}`),safeCall(()=>this.updateIncludesExcludes(d)),this.isInitiatingOrReloading?d:(this.resetCaches(),this.notifyListeners(),await this.rebuildProject(d.id,t).catch(e=>re(e)?Promise.reject(e):(Y.warn(`Failed to rebuild project {projectId} after config change`,{projectId:d.id,error:e}),Promise.resolve())),d)}ownerProjectId(e){return this.#o.get(normalizeUri(e))?.id??this.#t??ProjectsManager.DefaultProjectId}relativePath(e){let t=normalizeUri(e),r=this.#o.get(t);return r?S.relative(r.folderUri,C.parse(t)):t}get isInitiatingOrReloading(){return!!this.#s||!this.services.workspace.WorkspaceManager.isReady}#s=null;async reloadProjects(e){return this.#s?(Y.debug`reload projects is already in progress, waiting`,await this.#s.catch(()=>{})):(Y.debug`schedule reload projects`,this.#s=Promise.resolve().then(()=>this._reloadProjects(e)).catch(e=>(re(e)||Y.warn(`Failed to reload projects`,{error:e}),Promise.reject(e))).finally(()=>{this.#s=null}),await this.#s)}async _reloadProjects(e){let t=this.services.workspace.WorkspaceManager.workspaceFolders;if(!t||t.length===0){Y.warn(`Failed to reloadProjects, no workspace folders found`);return}Y.debug`start reload projects`;let r=[];for(let e of t){let t=C.parse(e.uri);Y.debug`scan projects in ${t.fsPath}`;try{let e=await this.services.workspace.FileSystemProvider.scanProjectFiles(t);for(let o of e)Y.debug`found config ${S.relative(t,o.uri)}`,r.push(o.uri)}catch(e){Y.warn(`Failed on scanProjectFiles in {folder}`,{folder:t.fsPath,error:e})}}if(r.length===0){if(this.#r.length===0){Y.warning(`No config files found`);return}Y.warning(`no config files found, but {count} projects were registered before`,{count:this.#r.length}),Y.warning(`reset`)}r.sort(compareUri);let o=new Map(this.#r.map(e=>[e.configUri.toString(),e]));this.#r=[],this.#i.clear();for(let e of r)try{await this.registerConfigFile(e)}catch(t){Y.warn(loggable(t));let r=o.get(e.toString());r&&(Y.debug`Update failed, restore project ${r.id}`,await this.registerProject(r).catch(e=>{Y.warn(`fail to restore project ${r.id}, ignoring`,{error:e})}))}this.resetCaches(),this.notifyListeners(),await this.services.workspace.WorkspaceManager.rebuildAll(e)}uniqueProjectId(e){let t=new Set(I(this.#r,jn(`id`))),r=e;if(!t.has(r))return r;Y.warn`Project "${e}" already exists, generating unique ID`;let o=1;for(;t.has(r);)r=`${e}-${o++}`;return r}resetCaches(){Y.trace(`resetCaches`),this.#t&&!this.#r.some(e=>e.id===this.#t)&&(this.#t=void 0),this.#i.clear(),this.#o.clear(),this.#a.clear()}async rebuildProject(e,t){let r=this.#r.find(t=>t.id===e);if(!r)return e===ProjectsManager.DefaultProjectId?Y.info`Rebuilding all documents `:Y.warn`Project ${e} not found, rebuilding all`,await this.services.workspace.WorkspaceManager.rebuildAll(t);let o=Y.getChild(r.id),_includes=e=>includes(r,normalizeUri(e)),s=this.services.workspace.LangiumDocuments.userDocuments.filter(_includes).map(e=>e.uri).toArray();if(s.length===0){o.trace`no documents found for project ${r.id}, skipping rebuild`;return}o.info`rebuild project documents: ${s.length}`,this.resetCaches(),await this.services.workspace.DocumentBuilder.update(s,[],t).catch(e=>{o.warn(`Failed to rebuild project`,{error:e})})}getAllIncludePaths(){let e=[];for(let t of this.#r)if(t.includePaths)for(let r of t.includePaths)e.push({projectId:t.id,includePath:r.uri,includeConfig:t.includeConfig});return e}onProjectsUpdate(e){return this.#e.push(e),b.create(()=>{let t=this.#e.indexOf(e);t>=0&&this.#e.splice(t,1)})}getWorkspaceFolder(){try{return this.services.workspace.WorkspaceManager.workspaceUri}catch(e){return Y.warn(`Failed to get workspace URI, using default folder`,{error:e}),C.file(`/`)}}notifyListeners(){for(let e of[...this.#e])try{e()}catch(e){Y.warn(loggable(e))}}updateIncludesExcludes(e){let t=e.config;switch(delete e.includePaths,delete e.exclude,!0){case M(t.exclude):e.exclude=Lc.exclude;break;case t.exclude&&N(t.exclude,1):e.exclude=(0,Fc.default)(I(t.exclude,t=>(!ft(t)&&!t.startsWith(`**`)&&(t=ht(`**`,t)),vt(lt(e.folderUri.path,t)))),{contains:!0,dot:!0});break}let r=e.includeConfig.paths;if(!N(r,1))return e;e.includePaths=I(r,t=>{let r=S.resolvePath(e.folderUri,t);return{uri:r,folder:ProjectFolder(r)}}),Y.debug`project ${e.id} include paths: ${e.includePaths.map(e=>e.uri.fsPath).join(`, `)}`;for(let t of e.includePaths)for(let r of this.#r)r.id!==e.id&&(overlaps(t,r)&&Y.warn(`Project "{projectId}" include path "{includePath}" overlaps with project "{otherProjectId}" folder. Files in overlapping areas will only belong to one project.`,{projectId:e.id,includePath:t.folder,otherProjectId:r.id}),r.includePaths?.forEach(o=>{overlaps(t,o)&&Y.warn(`Project "{projectId}" include path "{includePath}" overlaps with project "{otherProjectId}" include path "{otherIncludePath}". Files in overlapping areas will only belong to one project.`,{projectId:e.id,includePath:t.folder,otherProjectId:r.id,otherIncludePath:o.folder})}));return e}warnIfConfigOverride(e,t){try{let[r,o]=I([e.configUri,t],S.basename);r!==o&&Y.warn`config ${o} overrides ${r} in folder ${e.folder}`}catch{}}},zc=class TimeoutError extends Error{name=`TimeoutError`;constructor(e,t){super(e,t),Error.captureStackTrace?.(this,TimeoutError)}};const getAbortedReason=e=>e.reason??new DOMException(`This operation was aborted.`,`AbortError`);function pTimeout(e,t){let{milliseconds:r,fallback:o,message:s,customTimers:c={setTimeout,clearTimeout},signal:u}=t,d,abortHandler,p=new Promise((t,p)=>{if(typeof r!=`number`||Math.sign(r)!==1)throw TypeError(`Expected \`milliseconds\` to be a positive number, got \`${r}\``);if(u?.aborted){p(getAbortedReason(u));return}if(u&&(abortHandler=()=>{p(getAbortedReason(u))},u.addEventListener(`abort`,abortHandler,{once:!0})),e.then(t,p),r===1/0)return;let m=new zc;d=c.setTimeout.call(void 0,()=>{if(o){try{t(o())}catch(e){p(e)}return}typeof e.cancel==`function`&&e.cancel(),s===!1?t():s instanceof Error?p(s):(m.message=s??`Promise timed out after ${r} milliseconds`,p(m))},r)}).finally(()=>{p.clear(),abortHandler&&u&&u.removeEventListener(`abort`,abortHandler)});return p.clear=()=>{c.clearTimeout.call(void 0,d),d=void 0},p}function hasLikeC4Ext(e){return Tc.fileExtensions.some(t=>e!==t&&e.endsWith(t))}const Bc=[`node_modules`,`.git`,`.svn`,`.yarn`,`.pnpm`];function isNodeModulesOrRepo(e){return Bc.includes(e)}function insideNodeModulesOrRepo(e){for(let t of Bc)if(e.includes(t))return!0;return!1}const Vc=$r(`/`);function ensureOrder(e,t){return Vc(e.uri.path,t.uri.path)}var LikeC4WorkspaceManager=class extends rt{services;documentFactory;fileSystemProvider;#e=!1;#t=[];initialBuildOptions={eagerLinking:!0,validation:!0};constructor(e){super(e),this.services=e,this.documentFactory=e.workspace.LangiumDocumentFactory,this.fileSystemProvider=e.workspace.FileSystemProvider}get isReady(){return this.#e}async performStartup(e){try{this.#e=!1,await this.readExcludeConfig(),this.folders??=e;let t=[];for(let r of e)try{let e=C.parse(r.uri),o=await this.fileSystemProvider.scanProjectFiles(e);t.push(...o),this.services.workspace.FileSystemWatcher.watch(e.fsPath)}catch(e){logWarnError(e)}let r=this.services.workspace.ProjectsManager,o=0;for(let e of t)try{await r.registerConfigFile(e.uri),o++}catch(e){logWarnError(e)}return t.length!==o&&q.warn`loaded ${o} projects out of ${t.length}`,await super.performStartup(e)}finally{this.#e=!0}}async loadAdditionalDocuments(e,t){t(this.documentFactory.fromString(fa,C.parse(ma)));let r=this.services.workspace.ProjectsManager.getAllIncludePaths(),o=vn(e=>this.services.workspace.ProjectsManager.isExcludedByWorkspace(e.uri)),s=0,c=[];for(let{projectId:e,includePath:t,includeConfig:s}of r)try{q.debug`scanning include path ${t.fsPath} for project ${e}`;let r=F(await this.fileSystemProvider.readDirectory(t,{recursive:!0,maxDepth:s.maxDepth}),P(o));c.push(...r),r.length===0?q.trace`no files found in include path ${t.fsPath}`:q.debug`loaded ${r.length} files from include path ${t.fsPath}`}catch(e){q.warn(`Failed to scan include path ${t.fsPath}`,{error:e})}for(let e of xn(c,e=>e.uri.path))try{t(await this.langiumDocuments.getOrCreateDocument(e.uri)),s++}catch(t){q.warn(`Failed to load document ${e.uri.fsPath}`,{error:t})}if(r.length>0&&s>0){let e=Math.min(...r.map(e=>e.includeConfig.fileThreshold));s>e?q.warn(`Loaded ${s} files from include paths (threshold: ${e}). Large include directories may slow workspace initialization. Consider adjusting "include.fileThreshold" or "include.maxDepth" in your project configuration.`):q.info`loaded ${s} total files from ${r.length} include paths`}}async traverseFolder(e,t,r,o){let s=await this.fileSystemProvider.readDirectory(t,{recursive:!0});for(let t of s)if(this.includeEntry(e,t,r)){if(t.isDirectory){await this.traverseFolder(e,t.uri,r,o);continue}try{o(await this.langiumDocuments.getOrCreateDocument(t.uri))}catch(e){q.warn(`Failed to load document {path}`,{error:e,path:t.uri.fsPath})}}}includeEntry(e,t,r){let o=S.basename(t.uri);return t.isDirectory?!(isNodeModulesOrRepo(o)||this.services.workspace.ProjectsManager.isExcludedByWorkspace(t.uri)):t.isFile?(r.fileExtensions.includes(S.extname(t.uri))||r.fileNames.includes(o))&&!this.services.workspace.ProjectsManager.isExcludedByWorkspace(t.uri):!1}workspace(){return this.folders&&N(this.folders,1)?this.folders[0]:null}async rebuildAll(e){let t=this.services.workspace.LangiumDocuments.resetProjectIds();q.info(`invalidate and rebuild all {docs} documents`,{docs:t.length}),this.forceCleanCaches(),await this.documentBuilder.update(t,[],e)}get workspaceUri(){let e=this.workspace();return V(e,`Workspace not initialized`),C.parse(e.uri)}get workspaceURL(){let e=this.workspace();return V(e,`Workspace not initialized`),new URL(e.uri)}forceCleanCaches(){for(let e of[...this.#t])e();this.services.workspace.ManualLayouts.clearCaches(),this.services.workspace.Cache.clear()}onForceCleanCache(e){return this.#t.push(e),b.create(()=>{let t=this.#t.indexOf(e);t!==-1&&this.#t.splice(t,1)})}async readExcludeConfig(){if(!this.services.lsp.Connection){q.debug`no LSP connection, skipping initial configuration read`;return}let e=this.services.workspace.ConfigurationProvider,wait=e=>pTimeout(e,{milliseconds:1e3,message:!1});try{q.trace`waiting for ConfigurationProvider ready...`,await wait(e.ready),q.trace`ConfigurationProvider ready, reading exclude patterns...`;let t=await wait(e.getConfiguration(`likec4`,`exclude`));t?(q.trace`exclude configuration found ${t}`,this.services.workspace.ProjectsManager.setWorkspaceExcludePatterns(t)):q.trace(`no initial exclude configuration found`)}catch(e){q.warn(`Failed to read initial exclude configuration`,{error:e})}}};function projectIdFrom(e){if(isImported(e)){for(;e.$type===`Imported`&&e.$container;)e=e.$container;V(isImportsFromPoject(e))}if(isImportsFromPoject(e))return e.project;let t=at(e)?Te(e):e;return t.likec4ProjectId?t.likec4ProjectId:(q.warn`Document ${t.uri.fsPath} does not have a project ID assigned, this may lead to unexpected behavior.`,Rc.DefaultProjectId)}function stringHash$1(...e){return mi(e.length>1?e.join(`:::`):e[0])}t(stringHash$1,`stringHash`);function safeCall(e){try{return e()}catch(e){q.trace(`Safe call failed`,{error:e});return}}function performanceNow(){try{return globalThis.performance.now()}catch{return Date.now()}}function performanceMark(){let e=performanceNow();return{get ms(){return performanceNow()-e},get pretty(){return Gn(performanceNow()-e)}}}const Hc=q.getChild(`manual-layouts`),Uc=`.likec4.snap`,isManualLayoutFile=e=>e!==Uc&&e.endsWith(Uc);function fileName(e){return`${e}${Uc}`}function viewIdFromURI(e){let t=S.basename(e);return isManualLayoutFile(t)?t.slice(0,-12):null}function getManualLayoutsOutDir(e){return S.resolvePath(e.folderUri,e.config.manualLayouts?.outDir??`.likec4`)}const Wc={manualLayouts:e=>new DefaultLikeC4ManualLayouts(e)},Gc=`file://./`;var DefaultLikeC4ManualLayouts=class extends ADisposable{services;cache;listeners=[];#e=pLimit(1);constructor(e){super(),this.services=e,this.cache=new Fe,this.onDispose(b.create(()=>{this.listeners.length=0,this.cache.clear()})),li(()=>{this.onDispose(e.workspace.ProjectsManager.onProjectsUpdate(()=>{this.clearCaches()}))})}async handleFileSystemUpdate(e){let t=e.update??e.delete,r=viewIdFromURI(t)??void 0,o=this.services.workspace.ProjectsManager.ownerProjectId(t);if(this.cache.delete(o),`delete`in e){this.triggerUpdate(Ar({removed:t,projectId:o,viewId:r}));return}let s=this.services.workspace.ProjectsManager.getProject(o);if(!r){let e=await this.readSnapshot(t,s);e?r=e.id:(Hc.error(`Snapshot ${t.fsPath} does not exist or is invalid`),r=`index`)}this.triggerUpdate({updated:t,projectId:o,viewId:r})}onManualLayoutUpdate(e){return this.listeners.push(e),{dispose:()=>{let t=this.listeners.indexOf(e);t!==-1&&this.listeners.splice(t,1)}}}async readManualLayouts(e){let t=Hc.getChild(e.id),r=this.services.workspace.FileSystemProvider,o=getManualLayoutsOutDir(e),s=[],c=`${o.toString()}`;try{let u=await r.scanDirectory(o,isManualLayoutFile);if(u.length===0)return null;u.sort((e,t)=>e.uri.path.localeCompare(t.uri.path));for(let o of u)try{let t=await r.readFile(o.uri),u=bt.parse(t);c=mi(c+o.uri.toString()+t);let d=this.resolveIconPathsAfterRead(u,e.folderUri);s.push({...d,_layout:`manual`})}catch(e){t.warn(`Failed to read view snapshot ${o.uri.fsPath}`,{err:e})}s.length&&t.trace`read manual layouts for ${e.id}, found ${s.length}`}catch(r){t.warn(`Failed to read manual layouts for ${e.folderUri.fsPath}`,{err:r})}if(s.length===0)return null;let u=Jt(s,jn(`id`));return{hash:c,views:u}}async readSnapshot(e,t){let r=this.services.workspace.FileSystemProvider;try{let o=await r.readFile(e),s=bt.parse(o);if(!t){let r=this.services.workspace.ProjectsManager.ownerProjectId(e);t=this.services.workspace.ProjectsManager.getProject(r)}return{...this.resolveIconPathsAfterRead(s,t.folderUri),_layout:`manual`}}catch(t){return Hc.warn(`Failed to read view snapshot ${e.fsPath}`,{err:t}),null}}async read(e){return await this.#e(async()=>{let t=this.cache.get(e.id);if(t!==void 0)return Hc.trace`cache hit project ${e.id}`,t;let r=await this.readManualLayouts(e);return this.cache.set(e.id,r),r})}async write(e,t){this.cache.delete(e.id);let r=Hc.getChild(e.id),o=getManualLayoutsOutDir(e),s=S.joinPath(o,fileName(t.id));if(`manualLayout`in t){let{manualLayout:e,...r}=t;t=r}let c=bt.stringify(this.normalizeIconPathsForWrite(t,e.folderUri),{space:2,quote:`'`}),u={uri:s.toString(),range:h.create(le.create(0,0),le.create(c.split(`
|
|
53
|
+
`).length-1,1))};r.debug`write snapshot of ${t.id} in project ${e.id} to ${s.fsPath}`;let d=this.services.workspace.FileSystemProvider;try{await d.writeFile(s,c+`
|
|
54
|
+
`),this.triggerUpdate({updated:s,projectId:e.id,viewId:t.id})}catch(e){r.warn(`Failed to write snapshot ${t.id} to ${s.fsPath}`,{err:e})}return u}async remove(e,t){this.cache.delete(e.id);let r=Hc.getChild(e.id),o=getManualLayoutsOutDir(e),s=S.joinPath(o,fileName(t));r.debug`delete snapshot of ${t} in project ${e.id}. File: ${s.fsPath}`;let c={uri:s.toString(),range:h.create(0,0,0,0)};try{if(!await this.services.workspace.FileSystemProvider.deleteFile(s))return r.warn`Snapshot ${t} did not exist at ${s.fsPath}`,null;this.triggerUpdate({removed:s,projectId:e.id,viewId:t})}catch(e){r.warn(`Failed to delete snapshot ${t} from ${s.fsPath}`,{err:e})}return c}clearCaches(){Hc.trace`clear caches`,this.cache.clear()}triggerUpdate(e){let t=[...this.listeners];for(let r of t)safeCall(()=>r(e))}normalizeIconPathsForWrite(e,t){let r=e.nodes.map(e=>{if(!e.icon||typeof e.icon!=`string`)return e;if(e.icon.startsWith(`file://`)){let r=C.parse(e.icon),o=S.relative(t,r);return o.startsWith(`..`)?e:{...e,icon:`${Gc}${o}`}}return e});return{...e,nodes:r}}resolveIconPathsAfterRead(e,t){let r=e.nodes.map(e=>{if(!e.icon||typeof e.icon!=`string`)return e;if(e.icon.startsWith(Gc)){let r=e.icon.substring(9),o=S.joinPath(t,r);return{...e,icon:o.toString()}}return e});return{...e,nodes:r}}};const Kc=q.getChild(`chokidar`),qc={fileSystemWatcher:e=>new ChokidarFileSystemWatcher(e)},isAnyLikeC4File=e=>{let t=Yn(e);return hasLikeC4Ext(t)||Rt(t)||isManualLayoutFile(t)};var ChokidarFileSystemWatcher=class{services;watcher;queue=new Un({concurrency:1,timeout:5e3});constructor(e){this.services=e,Kc.debug`ChokidarFileSystemWatcher created`}watch(e){if(this.watcher){Kc.debug`add watching folder: ${e}`,this.watcher.add(e);return}this.watcher=this.createWatcher(e)}async dispose(){if(this.watcher){let e=this.watcher;this.watcher=void 0;try{await e.close()}catch{}}}createWatcher(e){Kc.debug`create watcher for folder: ${e}`;let t=Ni.watch(e,{ignored:[e=>insideNodeModulesOrRepo(e),(e,t)=>!!t&&t.isFile()&&!isAnyLikeC4File(e)],followSymlinks:!0,ignoreInitial:!0}),onAddOrChange=(e,t)=>{t?.isDirectory()||this.enqueueFileOp(`addOrChange: `+e,async()=>{await this.onAddOrChange(e)})},onRemove=(e,t)=>{t?.isDirectory()||this.enqueueFileOp(`remove: `+e,async()=>{await this.onRemove(e)})};return t.on(`add`,onAddOrChange).on(`change`,onAddOrChange).on(`unlink`,onRemove).on(`unlinkDir`,e=>{this.enqueueFileOp(`removeDir: `+e,async()=>{await this.onRemoveDir(e)})}),t}enqueueFileOp(e,t){this.queue.add(async()=>{try{await t()}catch(t){Kc.warn(`Failed on {fileop}`,{fileop:e,error:t})}}).catch(t=>{Kc.error(`Error on {fileop}`,{fileop:e,error:t})})}async onAddOrChange(e){let t=this.services.workspace,r=Yn(e),o=C.file(e);switch(!0){case Rt(r):Kc.debug`project config changed: ${e}`,t.ManualLayouts.clearCaches(),await t.ProjectsManager.registerConfigFile(o);break;case isManualLayoutFile(r):Kc.debug`manual layout file changed: ${e}`,await t.ManualLayouts.handleFileSystemUpdate({update:o});break;case hasLikeC4Ext(r):Kc.debug`file changed: ${e}`,await t.DocumentBuilder.update([o],[]);break;default:Kc.warn`Unknown file change: ${e}`}}async onRemove(e){let t=this.services.workspace,r=Yn(e),o=C.file(e);switch(!0){case Rt(r):Kc.debug`project file removed: ${e}`,t.ManualLayouts.clearCaches(),await t.ProjectsManager.reloadProjects();break;case hasLikeC4Ext(r):Kc.debug`file removed: ${e}`,await t.DocumentBuilder.update([],[o]);break;case isManualLayoutFile(r):Kc.debug`manual layout file removed: ${e}`,await t.ManualLayouts.handleFileSystemUpdate({delete:o});break;default:Kc.warn`Unknown file removal: ${e}`}}async onRemoveDir(e){Kc.debug`directory removed: ${e}`;let t=this.services.workspace;t.ProjectsManager.findOverlaped(e).length>0&&(t.ManualLayouts.clearCaches(),await t.ProjectsManager.reloadProjects())}},NoopFileSystemProvider=class{scanProjectFiles(){return Promise.resolve([])}scanDirectory(){return Promise.resolve([])}readFile(e){if(isLikeC4Builtin(e))return Promise.resolve(fa);throw Error(`No file system is available.`)}readDirectory(){return Promise.resolve([])}loadProjectConfig(){throw Error(`No file system is available.`)}writeFile(){throw Error(`No file system is available.`)}deleteFile(){throw Error(`No file system is available.`)}},NoopFileSystemWatcher=class{constructor(){q.debug`NoopFileSystemWatcher created`}watch(){}dispose(){return Promise.resolve()}},NoopLikeC4ManualLayouts=class{constructor(){q.debug`NoopLikeC4ManualLayouts created`}handleFileSystemUpdate(){return Promise.resolve()}readSnapshot(){return Promise.resolve(null)}read(){return Promise.resolve(null)}write(){return Promise.reject(Error(`NoopLikeC4ManualLayouts: write operation is not supported`))}remove(){return Promise.resolve(null)}clearCaches(){}onManualLayoutUpdate(){return{dispose:()=>{}}}dispose(){}};const Jc={fileSystemWatcher:()=>new NoopFileSystemWatcher},Yc={fileSystemProvider:()=>new NoopFileSystemProvider,...Jc},Xc={manualLayouts:()=>new NoopLikeC4ManualLayouts},Zc=q.getChild(`filesystem`);function isLikeC4ConfigFile(e,t=!1){return!t&&Rt(Yn(e))}function isLikeC4File(e,t=!1){return!t&&hasLikeC4Ext(Yn(e))}const WithFileSystem=(e=!1)=>({fileSystemProvider:()=>new SymLinkTraversingFileSystemProvider,...e?qc:Jc});var SymLinkTraversingFileSystemProvider=class extends Ye{async readFile(e){if(isLikeC4Builtin(e))return Promise.resolve(fa);try{return await super.readFile(e)}catch(t){return Zc.warn(`Failed to read file ${e.fsPath}`,{error:t}),``}}async readDirectory(e,t){let r=t?.recursive??!0,o=t?.maxDepth??1/0,s=[];try{let t=new Mi().withSymlinks({resolvePaths:!1}).exclude(isNodeModulesOrRepo).withFullPaths().filter(isLikeC4File);r?o!==1/0&&(t=t.withMaxDepth(o)):t=t.withMaxDepth(1);let c=await t.crawl(e.fsPath).withPromise();for(let e of c)s.push({isFile:!0,isDirectory:!1,uri:C.file(e)})}catch(t){Zc.warn(`Failed to read directory ${e.fsPath}`,{error:t})}return s.sort(ensureOrder)}async scanProjectFiles(e){let t=await this.scanDirectory(e,isLikeC4ConfigFile);if(t.length<=1)return t;let r=$r(`/`,!0),compareByPath=(e,t)=>r(e.uri.path,t.uri.path);return t.sort(compareByPath)}async scanDirectory(e,t){let r=[];try{let o=await new Mi().withSymlinks({resolvePaths:!1}).exclude(isNodeModulesOrRepo).withFullPaths().filter(t).crawl(e.fsPath).withPromise();for(let e of o)r.push({isFile:!0,isDirectory:!1,uri:C.file(e)})}catch(t){Zc.warn(`Failed to scan directory {path}`,{path:e.fsPath,error:t})}return r}async loadProjectConfig(e){return await loadConfig(e)}async writeFile(e,t){let r=Xn(e.fsPath),o=Ci(r,{throwIfNoEntry:!1});if(o?.isFile())throw Error(`Cannot create directory ${r} because a file with the same name exists.`);return o||(Zc.debug(`creating directory {path}`,{path:r}),Si(r,{recursive:!0})),Zc.debug(`writing file {path}`,{path:e.fsPath}),await Ei(e.fsPath,t,{encoding:`utf-8`})}async deleteFile(e){try{let t=e.fsPath,r=Ci(t,{throwIfNoEntry:!1});return r?.isFile()||r?.isSymbolicLink()?(await Ti(t),Zc.debug(`deleted file {path}`,{path:t}),!0):(Zc.warn(`deleteFile failed: {path} does not exist, or is not a file`,{path:t}),!1)}catch(t){Zc.warn(`Failed to delete file ${e.fsPath}`,{error:t})}return!1}},LikeC4DocumentationProvider=class extends v{parser;locator;constructor(e){super(e),this.parser=e.likec4.ModelParser,this.locator=e.likec4.ModelLocator}getDocumentation(e){if(!isDeploymentNode$1(e)&&!isDeployedInstance(e)&&!isElement(e))return super.getDocumentation(e);try{let t=Te(e);if(t.state<w.Linked)return super.getDocumentation(e);let r=this.parser.forDocument(t);switch(!0){case isDeploymentNode$1(e):{let t=r.parseDeploymentNode(e);return t?`**${t.title}**`:void 0}case isDeployedInstance(e):{let o=r.parseDeployedInstance(e);if(!o)return;let[s,c]=z.isImportRef(o.element)?[o.element.project,o.element.model]:[t.likec4ProjectId,o.element.model],u=s?this.locator.getParsedElement(c,s):this.locator.getParsedElement(c),d=[`_instance of_ \`${c}\``];return u&&d.push(`**${u.element.title}**`),d.join(`
|
|
55
|
+
`)}case isElement(e):{let t=r.parseElement(e);return t?[`**${t.title}**`,`<small>kind: \`${t.kind}\`</small>`].join(`
|
|
56
|
+
`):void 0}default:return e}}catch(e){logWarnError(e)}}};function areOverlap(e,t){return[e,t]=compareRanges(e,t)>0?[t,e]:[e,t],isInRagne(e.range,t.range.start)}function compareRanges(e,t){let r=e.range.start.line-t.range.start.line;return r===0?e.range.start.character-t.range.start.character:r}function isInRagne(e,t){return!(t.line<e.start.line||t.line>e.end.line||t.line==e.start.line&&t.character<e.start.character||t.line==e.end.line&&t.character>e.end.character)}function isMultiline(e){return!!e&&e.range.start.line!=e.range.end.line}const X={newLine:Le.newLine({allowMore:!0}),oneSpace:Le.oneSpace(),noSpace:Le.noSpace(),indent:Le.indent({allowMore:!0}),noIndent:Le.noIndent()};var LikeC4Formatter=class extends Se{options={quoteStyle:`auto`};extendedFormattingCommands=[];constructor(e){super(),e.shared.workspace.ConfigurationProvider.onConfigurationSectionUpdate(e=>this.onConfigurationUpdate(e.configuration.formatting))}doDocumentFormat(e,t,r){this.extendedFormattingCommands=[];let o=super.doDocumentFormat(e,t,r);return this.doExtendedFormatting(o),o}format(e){this.removeIndentFromTopLevelStatements(e),this.indentContentInBraces(e),this.normalizeQuotes(e),this.formatImports(e),this.formatSpecificationRule(e),this.formatGlobals(e),this.formatElementDeclaration(e),this.formatExtendElement(e),this.formatRelation(e),this.formatMetadataProperty(e),this.formatDeploymentNodeDeclaration(e),this.formatDeployedInstance(e),this.formatDeploymentRelation(e),this.formatExtendDeployment(e),this.formatView(e),this.formatViewRuleGroup(e),this.formatViewRuleGlobalStyle(e),this.formatViewRuleGlobalPredicate(e),this.formatIncludeExcludeExpressions(e),this.formatWhereExpression(e),this.formatWhereRelationExpression(e),this.formatWhereElementExpression(e),this.formatRelationExpression(e),this.formatAutolayoutProperty(e),this.formatWithPredicate(e),this.formatViewRuleStyle(e),this.formatLeafProperty(e),this.formatLinkProperty(e),this.formatNavigateToProperty(e),this.formatTags(e)}formatTags(e){this.on(e,isTags,(e,t)=>{let r=Xe(e.$cstNode,`values`).filter(k).slice(1);t.cst(r).prepend(X.oneSpace),t.keywords(`,`).prepend(X.noSpace).append(X.oneSpace)})}formatDeploymentRelation(e){this.on(e,isDeploymentRelation,(e,t)=>{let r=e?.source?.$cstNode?[e?.source?.$cstNode]:[];t.cst(r).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace),t.keywords(`-[`).append(X.noSpace),t.nodes(...P([e.target,e.tags],k)).prepend(X.oneSpace),t.properties(`title`,`description`,`technology`).prepend(X.oneSpace)})}formatExtendDeployment(e){this.on(e,isExtendDeployment,(e,t)=>{t.keywords(`extend`).append(X.oneSpace)})}formatRelation(e){this.on(e,e=>isRelation(e)||isDeploymentRelation(e),(e,t)=>{let r=e?.source?.$cstNode?[e?.source?.$cstNode]:[];t.cst(r).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace),t.keywords(`-[`).append(X.noSpace),t.nodes(...P([e.target,e.tags],k)).prepend(X.oneSpace),t.properties(`title`,`description`,`technology`).prepend(X.oneSpace)}),this.on(e,isDynamicViewStep,(e,t)=>{t.keywords(`->`,`<-`).surround(X.oneSpace),t.property(`dotKind`).prepend(X.oneSpace).append(X.oneSpace),t.keywords(`]->`).prepend(X.noSpace).append(X.oneSpace),t.keywords(`-[`).prepend(X.oneSpace).append(X.noSpace),t.properties(`title`).prepend(X.oneSpace),(isDynamicStepChain(e)&&isMultiline(e.$cstNode)||isDynamicStepSingle(e)&&isDynamicStepChain(e.$container)&&isMultiline(e.$container.$cstNode))&&(t.property(`dotKind`).prepend(Le.indent({allowLess:!1,allowMore:!0,priority:2})),t.keywords(`->`,`-[`).prepend(Le.indent({allowLess:!1,allowMore:!0,priority:2})),e.custom?.$cstNode&&isMultiline(e.custom.$cstNode)&&t.property(`custom`).prepend({options:{allowLess:!1,allowMore:!0,priority:2},moves:[{tabs:1}]}))})}removeIndentFromTopLevelStatements(e){isLikeC4Grammar(e.$container)&&this.getNodeFormatter(e).keywords(`specification`,`model`,`views`,`likec4lib`,`global`,`deployments`,`import`).prepend(X.noIndent)}indentContentInBraces(e){if(isLikeC4Lib(e)||isSpecificationRule(e)||isSpecificationElementKind(e)||isSpecificationRelationshipKind(e)||isSpecificationDeploymentNodeKind(e)||isGlobals(e)||isGlobalStyle(e)||isGlobalStyleGroup(e)||isGlobalPredicateGroup(e)||isGlobalDynamicPredicateGroup(e)||isGlobalStyleGroup(e)||isModel(e)||isElementBody(e)||isExtendElementBody(e)||isRelationBody(e)||isRelationStyleProperty(e)||isMetadataBody(e)||isModelViews(e)||isElementViewBody(e)||isDynamicViewBody(e)||isDeploymentViewBody(e)||isViewRuleStyle(e)||isViewRuleGroup(e)||isCustomElementProperties(e)||isCustomRelationProperties(e)||isElementStyleProperty(e)||isDynamicViewParallelSteps(e)||isModelDeployments(e)||isDeploymentNodeBody(e)||isDeploymentRelationBody(e)||isDeployedInstanceBody(e)||isExtendDeploymentBody(e)){let t=this.getNodeFormatter(e),r=t.keywords(`{`);r.prepend(X.noIndent).prepend(X.oneSpace);let o=isMultiline(e.$cstNode),s=t.keywords(`}`),c=t.interior(r,s),u=null;for(let e of c.nodes){if(!o){t.cst([e]).surround(X.oneSpace);continue}(!u||!areOverlap(u,e))&&t.cst([e]).prepend(Le.newLine({allowMore:!0})).prepend(X.indent),u=e}o?s.prepend(X.noIndent).prepend(Le.newLine({allowMore:!0})):s.prepend(Le.oneSpace({allowLess:!0}))}}appendKeywordsWithSpace(e){this.on(e,isElementKind)?.keywords(`element`).append(X.oneSpace)}formatView(e){this.on(e,isElementView$1,(e,t)=>{(e.extends||e.viewOf||e.name)&&t.keywords(`view`).append(X.oneSpace),t.keywords(`of`,`extends`).surround(X.oneSpace)}),this.on(e,isDynamicView$1)?.keywords(`dynamic`,`view`).append(X.oneSpace),this.on(e,isDeploymentView$1)?.keywords(`deployment`,`view`).append(X.oneSpace)}formatLeafProperty(e){if(isElementStringProperty(e)||isRelationStringProperty(e)||isViewStringProperty(e)||isNotationProperty(e)||isNotesProperty(e)||isSpecificationElementStringProperty(e)||isSpecificationRelationshipStringProperty(e)||isColorProperty(e)||isLineProperty(e)||isArrowProperty(e)||isIconProperty(e)||isShapeProperty(e)||isBorderProperty(e)||isOpacityProperty(e)||isMultipleProperty(e)||isIconColorProperty(e)||isIconSizeProperty(e)||isIconPositionProperty(e)||isShapeSizeProperty(e)||isPaddingSizeProperty(e)||isTextSizeProperty(e)){let t=this.getNodeFormatter(e),r=t.keyword(`:`),o=t.keywords(`title`,`description`,`technology`,`summary`,`notation`,`notes`,`color`,`line`,`head`,`tail`,`icon`,`iconColor`,`iconSize`,`iconPosition`,`shape`,`border`,`opacity`,`multiple`,`size`,`padding`,`textSize`);r.nodes.length===0?o.append(X.oneSpace):r.prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)}}formatLinkProperty(e){this.on(e,isLinkProperty,(e,t)=>{t.keyword(`link`).append(X.oneSpace),t.property(`value`).append(X.oneSpace),t.keyword(`:`).prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)})}formatNavigateToProperty(e){this.on(e,isNavigateToProperty)?.property(`key`).append(X.oneSpace)}formatAutolayoutProperty(e){this.on(e,isViewRuleAutoLayout,(e,t)=>{t.keyword(`autoLayout`).append(X.oneSpace),t.property(`rankSep`).prepend(X.oneSpace),t.property(`nodeSep`).prepend(X.oneSpace)})}formatMetadataProperty(e){this.on(e,isMetadataAttribute,(e,t)=>{t.property(`key`).append(X.oneSpace),t.keyword(`:`).prepend(X.noSpace).append(X.oneSpace),t.keyword(`;`).prepend(X.noSpace).append(X.newLine)})}formatElementDeclaration(e){this.on(e,isElement,(e,t)=>{let r=Ue(e.$cstNode,`kind`),o=Ue(e.$cstNode,`name`);o&&r&&(compareRanges(o,r)>0?t.cst([r]).append(X.oneSpace):(t.cst([o]).append(X.oneSpace),t.cst([r]).prepend(X.oneSpace))),t.properties(`props`).prepend(X.oneSpace)})}formatExtendElement(e){this.on(e,isExtendElement,(e,t)=>{t.keywords(`extend`).append(X.oneSpace)})}formatGlobals(e){this.on(e,isGlobalStyle,(e,t)=>{t.keyword(`style`).append(X.oneSpace),t.property(`id`).append(X.oneSpace)}),this.on(e,isGlobalStyleGroup,(e,t)=>{t.keyword(`styleGroup`).append(X.oneSpace)}),this.on(e,isGlobalPredicateGroup,(e,t)=>{t.keyword(`predicateGroup`).append(X.oneSpace)}),this.on(e,isGlobalDynamicPredicateGroup,(e,t)=>{t.keyword(`dynamicPredicateGroup`).append(X.oneSpace)})}formatImports(e){this.on(e,isImportsFromPoject,(e,t)=>{t.keyword(`import`).append(X.oneSpace),t.keywords(`{`,`}`,`from`).surround(X.oneSpace)}),this.on(e,isImported,(e,t)=>{t.keywords(`,`).prepend(X.noSpace).append(X.oneSpace)})}formatSpecificationRule(e){if((isSpecificationElementKind(e)||isSpecificationRelationshipKind(e)||isSpecificationTag(e)||isSpecificationDeploymentNodeKind(e))&&this.getNodeFormatter(e).keywords(`element`,`relationship`,`tag`,`deploymentNode`).append(X.oneSpace),isSpecificationColor(e)){let t=this.getNodeFormatter(e);t.keyword(`color`).append(X.oneSpace),t.property(`name`).append(X.oneSpace)}}formatWithPredicate(e){(isFqnExprWith(e)||isRelationExprWith(e))&&this.getNodeFormatter(e).keyword(`with`).prepend(X.oneSpace)}formatDeploymentNodeDeclaration(e){this.on(e,isDeploymentNode$1,(e,t)=>{let r=Ue(e.$cstNode,`kind`),o=Ue(e.$cstNode,`name`);o&&r&&(compareRanges(o,r)>0?t.cst([r]).append(X.oneSpace):(t.cst([o]).append(X.oneSpace),t.cst([r]).prepend(X.oneSpace))),t.properties(`title`).prepend(X.oneSpace)})}formatDeployedInstance(e){this.on(e,isDeployedInstance,(e,t)=>{let r=e.$cstNode?.content.find(e=>e.text===`=`);r&&t.cst([r]).surround(X.oneSpace),t.keyword(`instanceOf`).append(X.oneSpace),t.property(`title`).prepend(X.oneSpace)})}formatViewRuleGlobalStyle(e){this.on(e,isViewRuleGlobalStyle,(e,t)=>{t.keywords(`global`,`style`).append(X.oneSpace)})}formatViewRuleGlobalPredicate(e){let t=this.getNodeFormatter(e);(isViewRuleGlobalPredicateRef(e)||isDynamicViewGlobalPredicateRef(e))&&t.keywords(`global`,`predicate`).append(X.oneSpace)}formatViewRuleGroup(e){this.on(e,isViewRuleGroup,(e,t)=>{t.keyword(`group`).append(X.oneSpace)})}formatViewRuleStyle(e){this.on(e,isViewRuleStyle)?.keyword(`style`).append(X.oneSpace),this.on(e,isDeploymentViewRuleStyle)?.keyword(`style`).append(X.oneSpace),this.on(e,isExpressions)?.keyword(`,`).prepend(X.noSpace).append(X.oneSpace),this.on(e,isFqnExpressions)?.keyword(`,`).prepend(X.noSpace).append(X.oneSpace)}formatWhereExpression(e){(isRelationExprWhere(e)||isFqnExprWhere(e))&&this.getNodeFormatter(e).keyword(`where`).append(X.oneSpace)}formatWhereRelationExpression(e){if(this.on(e,isWhereRelationExpression,(e,t)=>{t.property(`operator`).surround(X.oneSpace)}),this.on(e,isWhereRelationNegation,(e,t)=>{t.keyword(`not`).append(X.oneSpace)}),isWhereRelation(e)){let t=this.getNodeFormatter(e);t.property(`operator`).surround(X.oneSpace),t.property(`not`).surround(X.oneSpace)}}formatWhereElementExpression(e){if(this.on(e,isWhereElementExpression,(e,t)=>{t.property(`operator`).surround(X.oneSpace)}),this.on(e,isWhereElementNegation,(e,t)=>{t.keyword(`not`).append(X.oneSpace)}),isWhereElement(e)){let t=this.getNodeFormatter(e);t.property(`operator`).surround(X.oneSpace),t.property(`not`).surround(X.oneSpace)}}formatIncludeExcludeExpressions(e){if(isDynamicViewRule(e)||isViewRulePredicate(e)||isDeploymentViewRulePredicate(e)){let t=this.getNodeFormatter(e);(!e.$cstNode||!isMultiline(e.$cstNode))&&t.keywords(`include`,`exclude`).append(X.oneSpace)}if(isExpressions(e)){let t=this.getNodeFormatter(e),r=this.findPredicateExpressionRoot(e),o=r?.$cstNode&&isMultiline(r?.$cstNode);o&&t.property(`value`).prepend(X.indent),t.keyword(`,`).prepend(X.noSpace).append(o?X.newLine:X.oneSpace)}}formatRelationExpression(e){this.on(e,isIncomingRelationExpr,(e,t)=>{t.keyword(`->`).append(X.oneSpace)}),this.on(e,isInOutRelationExpr,(e,t)=>{t.keyword(`->`).prepend(X.oneSpace)}),this.on(e,isOutgoingRelationExpr,(e,t)=>{t.keywords(`->`,`<->`).prepend(X.oneSpace),t.keywords(`-[`).prepend(X.oneSpace).append(X.noSpace),t.keywords(`]->`).prepend(X.noSpace).append(X.oneSpace),t.property(`dotKind`).prepend(X.oneSpace).append(X.oneSpace)}),this.on(e,isDirectedRelationExpr,(e,t)=>{t.property(`target`).prepend(X.oneSpace)})}findPredicateExpressionRoot(e){let t=e.$container;for(;;){if(!t||isDynamicViewRule(t)||isViewRulePredicate(t)||isDeploymentViewRulePredicate(t))return t;t=t.$container}}on(e,t,r){let o=t(e)?this.getNodeFormatter(e):void 0;return r&&o&&r(e,o),o}doExtendedFormatting(e){let t=this.quotesNormalizerFactory(this.extendedFormattingCommands);for(let r of this.extendedFormattingCommands)switch(r.type){case`normalizeQuotes`:t(r,e);break;default:H(r.type)}}normalizeQuotes(e){if(this.options.quoteStyle===`ignore`)return;let t=null;if(isMetadataAttribute(e)){let r=e.value;isMetadataArray(r)?t=this.getNodeFormatter(r).nodes(...r.values):r&&(t=this.getNodeFormatter(e).property(`value`))}else t=this.on(e,isStringProperty)?.property(`value`);t??=this.on(e,isElement)?.properties(`props`),t??=this.on(e,isImportsFromPoject)?.properties(`project`),t??=this.on(e,isRelation)?.properties(`title`,`technology`),t??=this.on(e,isViewRuleGroup)?.properties(`title`),t??=this.on(e,isDynamicViewStep)?.properties(`title`),t??=this.on(e,isDeploymentNode$1)?.properties(`title`),t??=this.on(e,isDeployedInstance)?.properties(`title`),t??=this.on(e,isDeploymentRelation)?.properties(`title`,`technology`),t??=this.on(e,isLinkProperty)?.properties(`title`),t&&this.extendedFormattingCommands.push({type:`normalizeQuotes`,region:t})}quotesNormalizerFactory(e){let t=this.options.quoteStyle==`auto`?this.getAutoQuoteStyle(e):this.options.quoteStyle;return(e,r)=>{let o=t===`single`?`"`:`'`,s=t===`single`?`'`:`"`,c=s.repeat(3),u=s,d=e.region.nodes.map(e=>{let t=e.text.startsWith(`"""`)||e.text.startsWith(`'''`)?c:u;return{range:e.range,newText:t+this.escapeQuotesInternalQuotes(e.text.slice(t.length,-t.length),o,s)+t}});r.push(...d)}}escapeQuotesInternalQuotes(e,t,r){let o=``,s=0;for(;s>=0;){let t=e.indexOf(r,s);if(t<0){o+=e.slice(s);break}o+=e.slice(s,t),s=t+1;let c=!1;for(;t>0&&e[t-1]==`\\`;)c=!c,t--;o+=c?r:`\\${r}`}return o}getAutoQuoteStyle(e){let t=e.flatMap(e=>e.region.nodes);return t.filter(e=>e.text[0]==`"`).length*2>=t.length?`double`:`single`}onConfigurationUpdate(e){this.options={...this.options,...e??{quoteStyle:`auto`}}}};Pe();const Qc=q.getChild(`LanguageServices`),isErrorDiagnostic=e=>e.severity===me.Error;var DefaultLikeC4LanguageServices=class{services;builder;editor;projectsManager;constructor(e){this.services=e,this.builder=e.likec4.ModelBuilder,this.projectsManager=e.shared.workspace.ProjectsManager,this.editor=e.likec4.ModelChanges}get views(){return this.services.likec4.Views}get workspaceUri(){return this.services.shared.workspace.WorkspaceManager.workspaceUri}get workspacePath(){return this.workspaceUri.fsPath}projects(){let e=this.services.shared.workspace.ProjectsManager,t=F(this.services.shared.workspace.LangiumDocuments.groupedByProject(),an(),I(([t,r])=>{let o=t,{folderUri:s,config:c}=e.getProject(o);return{id:o,folder:s,title:c.title??c.name,documents:I(r,jn(`uri`)),config:c}}));if(N(t,2)&&e.defaultProjectId){let r=t.findIndex(t=>t.id===e.defaultProjectId);if(r>0){let[e]=t.splice(r,1);return[e,...t]}return t}if(N(t,1))return t;let{id:r,folderUri:o,config:s}=e.default;return[{id:r,folder:o,title:s.title??s.name,documents:[],config:s}]}project(e){let{id:t,folderUri:r,config:o}=this.projectsManager.ensureProject(e),s=I(this.services.shared.workspace.LangiumDocuments.projectDocuments(t).toArray(),jn(`uri`));return{id:t,folder:r,title:o.title??o.name,documents:s,config:o}}async diagrams(e,t){let r=this.projectsManager.ensureProjectId(e);return await this.views.diagrams(r,t)}async computedModel(e,t){let r=this.projectsManager.ensureProjectId(e);return await this.builder.computeModel(r,t)}async layoutedModel(e,t){let r=this.projectsManager.ensureProjectId(e),o=await this.builder.computeModel(r,t);if(!o)throw Error(`Failed to compute model, empty project?`);let s=await this.views.layoutAllViews(r,t);return vi.create({...o.$data,_stage:`layouted`,views:F(s,I(jn(`diagram`)),Jt(jn(`id`)))})}async projectsOverview(e){let t=this.services.shared.workspace.ProjectsManager.all,r=[];for(let o of t){let t=await this.builder.computeModel(o,e);if(e?.isCancellationRequested)throw Error(`Operation cancelled`);if(t===vi.EMPTY){Qc.debug(`Project ${o} is empty, skipping`);continue}r.push(t)}if(!N(r,1))throw Error(`No models found`);let o=Fi(r);return await this.views.layouter.layoutProjectsView(o)}getErrors(){return F(this.services.shared.workspace.LangiumDocuments.userDocuments.toArray(),A(e=>F(e.diagnostics??[],P(isErrorDiagnostic),I(({message:t,range:r})=>({message:t,line:r.start.line,range:r,sourceFsPath:e.uri.fsPath})))))}locate(e){switch(!0){case`element`in e:return this.services.likec4.ModelLocator.locateElement(e.element,e.projectId);case`relation`in e:return this.services.likec4.ModelLocator.locateRelation(e.relation,e.projectId);case`view`in e:return this.services.likec4.ModelLocator.locateView(e.view,e.projectId);case`deployment`in e:return this.services.likec4.ModelLocator.locateDeploymentElement(e.deployment,e.projectId);default:H(e)}}async format(e){let t=this.services.shared.workspace.LangiumDocuments,r=this.services.lsp.Formatter,o=buildFormattingOptions(e),s=this.collectDocumentsToFormat(t,e);s.sort((e,t)=>e.uri.toString().localeCompare(t.uri.toString()));let c=new Map;for(let e of s){let t=e.uri.toString(),s=await r.formatDocument(e,{options:o,textDocument:{uri:t}}),u=s.length===0?e.textDocument.getText():pe.applyEdits(e.textDocument,s);c.set(t,u)}return c}collectDocumentsToFormat(e,t){let r=t?.projectIds??[],o=t?.documentUris??[],s=new Map;if(r.length>0)for(let t of r)for(let r of e.projectDocuments(t))s.set(r.uri.toString(),r);else if(o.length===0)for(let t of this.projectsManager.all)for(let r of e.projectDocuments(t))s.set(r.uri.toString(),r);for(let t of o){if(s.has(t))continue;let r;try{r=e.getDocument(C.parse(t))}catch{Qc.warn(`format: skipping unknown document ${t}`);continue}if(!isLikeC4LangiumDocument(r)){Qc.warn(`format: skipping unknown document ${t}`);continue}s.set(t,r)}return[...s.values()]}async dispose(){try{Qc.debug(`disposing LikeC4LanguageServices`),this.services.likec4.FqnIndex.dispose(),this.services.likec4.DeploymentsIndex.dispose(),this.services.likec4.ModelParser.dispose(),this.services.likec4.ModelBuilder.dispose(),this.services.likec4.Views.dispose(),this.services.likec4.LastSeen.dispose(),this.services.Rpc.dispose(),this.services.shared.workspace.ManualLayouts.dispose(),this.services.shared.workspace.ProjectsManager.dispose(),await this.services.shared.workspace.FileSystemWatcher.dispose()}catch(e){Qc.error(loggable(e))}finally{Qc.debug(`LikeC4LanguageServices disposed`)}}};function buildFormattingOptions(e){return{tabSize:e?.tabSize??2,insertSpaces:e?.insertSpaces??!0,...e?.trimTrailingWhitespace!=null&&{trimTrailingWhitespace:e.trimTrailingWhitespace},...e?.insertFinalNewline!=null&&{insertFinalNewline:e.insertFinalNewline},...e?.trimFinalNewlines!=null&&{trimFinalNewlines:e.trimFinalNewlines}}}var LikeC4CodeLensProvider=class{services;constructor(e){this.services=e}async provideCodeLens(e,t,r){if(isLikeC4LangiumDocument(e))return e.state<w.Linked&&(q.debug(`Waiting for document ${e.uri.path} to be Linked`),await this.services.shared.workspace.DocumentBuilder.waitUntil(w.Linked,e.uri,r),q.debug(`Document is linked`)),e.parseResult.value.views.flatMap(e=>e.views).flatMap(e=>{let t=Ac.readId(e),r=e.$cstNode?.range;if(!r||!t)return[];let o=projectIdFrom(e);return{range:{start:r.start,end:{line:r.start.line,character:r.start.character+4}},command:{command:`likec4.open-preview`,arguments:[t,o],title:`open preview`}}})}};Pe();function isCompletionForPojectName(e,t){return Ae(t.feature)&&t.property===`project`&&isImportsFromPoject(e.node)}const $c=`view_\${CURRENT_MINUTE}_\${CURRENT_SECOND} {
|
|
46
57
|
title 'Untitled'
|
|
47
58
|
|
|
48
59
|
include \${0:*}
|
|
49
|
-
}`;var LikeC4CompletionProvider=class extends
|
|
50
|
-
`)});break;case t.value===`view`&&Oe(e.node,isModelViews):acceptSnippet({detail:`Insert element view`,kind:
|
|
60
|
+
}`;var LikeC4CompletionProvider=class extends ge{services;constructor(e){super(e),this.services=e}completionOptions={triggerCharacters:[`.`,`#`]};completionFor(e,t,r){switch(!0){case Me(t.feature):return this.completionForKeyword(e,t.feature,r);case Be(t.feature)&&!!e.node:return this.completionForCrossReference(e,t,r);case isCompletionForPojectName(e,t):return this.completionForImportedProject(e,r)}}completionForKeyword(e,t,r){if(!this.filterKeyword(e,t))return;let acceptProperty=o=>{r(e,{label:t.value,detail:`Insert ${t.value} property`,kind:T.Property,insertTextFormat:he.Snippet,insertText:`${t.value} ${o}`})},acceptSnippet=({insertText:o,...s})=>{r(e,{label:t.value,detail:`Insert ${t.value}`,kind:T.Snippet,insertTextFormat:he.Snippet,...s,insertText:`${t.value} ${o}`})},acceptPropertyAndSuggest=e=>{acceptProperty(`\${1|${e.join(`,`)}|}$0`)};switch(!0){case t.value===`import`:acceptSnippet({insertText:`{ $0 } from '\${1|${this.services.shared.workspace.ProjectsManager.all.join(`,`)}|}'`});break;case t.value===`deployment`&&Oe(e.node,isModelViews):acceptSnippet({detail:`Insert deployment view`,kind:T.Class,insertText:`view ${$c}`});break;case t.value===`dynamic`&&Oe(e.node,isModelViews):acceptSnippet({detail:`Insert dynamic view`,kind:T.Class,insertText:["view view_${CURRENT_MINUTE}_${CURRENT_SECOND} {",` title 'Untitled'`,` `,` $0`,`}`].join(`
|
|
61
|
+
`)});break;case t.value===`view`&&Oe(e.node,isModelViews):acceptSnippet({detail:`Insert element view`,kind:T.Class,insertText:$c});break;case t.value===`opacity`:acceptPropertyAndSuggest([`0%`,`20%`,`60%`,`100%`]);break;case t.value===`shape`:acceptPropertyAndSuggest(er);break;case[`color`,`iconColor`].includes(t.value):acceptPropertyAndSuggest(ar);break;case[`size`,`textSize`,`padding`].includes(t.value):acceptPropertyAndSuggest(ir);break;case t.value===`border`:acceptPropertyAndSuggest($n);break;case t.value===`autoLayout`:acceptPropertyAndSuggest([`TopBottom`,`BottomTop`,`LeftRight`,`RightLeft`]);break;case[`title`,`description`,`technology`,`summary`,`notes`,`notation`].includes(t.value):acceptProperty(`'$0'`);break;case t.value===`metadata`:acceptProperty(`{
|
|
51
62
|
$0
|
|
52
|
-
}`);break;case[`views`,`specification`,`model`,`deployment`,`with`].includes(t.value):acceptSnippet({kind:
|
|
63
|
+
}`);break;case[`views`,`specification`,`model`,`deployment`,`with`].includes(t.value):acceptSnippet({kind:T.Module,insertText:`{
|
|
53
64
|
$0
|
|
54
|
-
}`});break;case t.value===`group`:acceptSnippet({kind:
|
|
65
|
+
}`});break;case t.value===`group`:acceptSnippet({kind:T.Module,insertText:`'\${1:Title}' {
|
|
55
66
|
$0
|
|
56
|
-
}`});break;case[`par`,`parallel`].includes(t.value):acceptSnippet({detail:`Insert parallel steps`,kind:
|
|
67
|
+
}`});break;case[`par`,`parallel`].includes(t.value):acceptSnippet({detail:`Insert parallel steps`,kind:T.Module,insertText:`{
|
|
57
68
|
$0
|
|
58
|
-
}`});break;case t.value===`style`&&e.node&&Oe(e.node,isGlobalStyle):acceptSnippet({kind:
|
|
69
|
+
}`});break;case t.value===`style`&&e.node&&Oe(e.node,isGlobalStyle):acceptSnippet({kind:T.Module,insertText:`\${1:name} \${2:*} {
|
|
59
70
|
$0
|
|
60
|
-
}`});break;case t.value===`style`&&e.node&&Oe(e.node,
|
|
71
|
+
}`});break;case t.value===`style`&&e.node&&Oe(e.node,gn([isModelViews,isGlobalStyleGroup])):acceptSnippet({kind:T.Module,insertText:`\${1:*} {
|
|
61
72
|
$0
|
|
62
|
-
}`});break;case t.value===`style`:acceptSnippet({kind:
|
|
73
|
+
}`});break;case t.value===`style`:acceptSnippet({kind:T.Module,insertText:`{
|
|
63
74
|
$0
|
|
64
|
-
}`});break;case t.value===`extend`:acceptSnippet({detail:`Extend another view`,kind:
|
|
75
|
+
}`});break;case t.value===`extend`:acceptSnippet({detail:`Extend another view`,kind:T.Class,insertText:`$1 {
|
|
65
76
|
$0
|
|
66
|
-
}`});break;case t.value===`mode`:acceptPropertyAndSuggest([`sequence`,`diagram`]);break;case[`include`,`exclude`].includes(t.value):
|
|
77
|
+
}`});break;case t.value===`mode`:acceptPropertyAndSuggest([`sequence`,`diagram`]);break;case[`include`,`exclude`].includes(t.value):r(e,{label:t.value,kind:T.Operator,detail:`Insert ${t.value} predicate`,insertTextFormat:he.PlainText,insertText:`${t.value} `});break;default:r(e,{label:t.value,kind:this.getKeywordCompletionItemKind(t),detail:`Keyword`,sortText:`1`})}}completionForImportedProject(e,t){let r=this.services.shared.workspace.ProjectsManager,o=e.document.textDocument,s={start:o.positionAt(e.tokenOffset),end:o.positionAt(e.tokenEndOffset)},c=o.getText(s),u=j(c)?`'`:c.substring(0,1);for(let o of r.all){let r=u+o+u;t(e,{label:o,kind:T.Folder,insertText:r,filterText:r,textEdit:Je.replace(s,r),detail:`Project`,sortText:`0_`+o})}}},LikeC4DocumentHighlightProvider=class extends ke{createDocumentHighlight(e){return sa.DocumentHighlight.create(e.segment.range,sa.DocumentHighlightKind.Read)}},LikeC4DocumentLinkProvider=class{services;constructor(e){this.services=e}async getDocumentLinks(e,t,r){return!isLikeC4LangiumDocument(e)||this.services.shared.workspace.ProjectsManager.isExcluded(e)?[]:Ge(e.parseResult.value).filter(isLinkProperty).map(t=>{try{let r=Ue(t.$cstNode,`value`)?.range,o=r&&this.resolveLink(e,t.value);if(o&&_t(o))return{range:r,target:o}}catch(e){logWarnError(e)}return null}).nonNullable().toArray()}resolveLink(e,t){if(_t(t)||mt(t))return t;if(ft(t))return lt(e.uri.toString(),`../`,t);let r=this.services.shared.workspace.ProjectsManager.getProject(e).folderUri;return lt(r.toString(),t)}relativeLink(e,t){if(mt(t))return ut(t);if(ft(t)){let r=this.services.shared.workspace.ProjectsManager.getProject(e).folderUri.toString(),o=new URL(e.uri.toString());return ut(yt(new URL(t,o).toString(),r))}return null}};Pe();const el=q.getChild(`DocumentSymbolProvider`);var LikeC4DocumentSymbolProvider=class{services;nodeKindProvider;nameProvider;parser;locator;constructor(e){this.services=e,this.nodeKindProvider=e.shared.lsp.NodeKindProvider,this.parser=e.likec4.ModelParser,this.locator=e.likec4.ModelLocator,this.nameProvider=e.references.NameProvider}async getSymbols(e,t,r){if(!isLikeC4LangiumDocument(e)||this.services.shared.workspace.ProjectsManager.isExcluded(e))return[];e.state<w.Linked&&(el.debug(`Waiting for document ${e.uri.path} to be Linked`),await this.services.shared.workspace.DocumentBuilder.waitUntil(w.Linked,e.uri,r),el.debug(`document is Linked`));let{parseResult:{value:{specifications:o,models:s,deployments:c,views:u,likec4lib:d}}}=e;return[...d.map(e=>()=>this.getLikec4LibSymbol(e)),...o.map(e=>()=>this.getSpecSymbol(e)),...s.map(e=>()=>this.getModelSymbol(e)),...c.map(e=>()=>this.getDeploymentModelSymbol(e)),...u.map(e=>()=>this.getModelViewsSymbol(e))].flatMap(e=>{try{return e()??[]}catch(e){return logWarnError(e),[]}})}getLikec4LibSymbol(e){let t=e?.$cstNode;if(!t)return[];let r=e.icons.map(e=>this.getLibIconSymbol(e)).filter(k);return r.length===0?[]:[{kind:He.Namespace,name:`icons`,range:t.range,selectionRange:ye(t,`icons`)?.range??t.range,children:r}]}getSpecSymbol(e){let t=e?.$cstNode;if(!t)return[];let r=Ue(t,`name`);if(!r)return[];let o=F([...e.elements,...e.tags,...e.relationships],I(e=>{try{if(isSpecificationElementKind(e)||isSpecificationRelationshipKind(e)||isSpecificationDeploymentNodeKind(e))return this.getKindSymbol(e);if(isSpecificationTag(e))return this.getTagSymbol(e)}catch(e){return logWarnError(e),null}H(e)}),P(k));return o.length===0?[]:[{kind:He.Namespace,name:e.name,range:t.range,selectionRange:r.range,children:o}]}getModelSymbol(e){let t=e.$cstNode;if(!t)return[];let r=Ue(t,`name`);return r?[{kind:this.symbolKind(e),name:e.name,range:t.range,selectionRange:r.range,children:e.elements.flatMap(e=>isExtendRelation(e)?[]:this.getElementsSymbol(e))}]:[]}getDeploymentModelSymbol(e){let t=e.$cstNode;if(!t)return[];let r=Ue(t,`name`);return r?[{kind:this.symbolKind(e),name:e.name,range:t.range,selectionRange:r.range,children:e.elements.flatMap(e=>this.getDeploymentElementSymbol(e))}]:[]}getElementsSymbol(e,t){try{if(isExtendElement(e))return this.getExtendElementSymbol(e);if(isElement(e))return this.getElementSymbol(e)}catch(e){logWarnError(e)}return[]}getExtendElementSymbol(e){let t=e.$cstNode,r=e.element.$cstNode,o=e.body;return!t||!r?[]:[{kind:this.symbolKind(e),name:readStrictFqn(e.element),range:t.range,selectionRange:r.range,children:o.elements.flatMap(t=>this.getElementsSymbol(t,readStrictFqn(e.element)))}]}getElementSymbol(e){let t=e.$cstNode,r=Ue(t,`name`);if(!r||!t)return[];let o=e.name,s=e.kind.$refText;return[{kind:this.symbolKind(e),name:o,range:t.range,selectionRange:r.range,detail:s,children:e.body?.elements.flatMap(e=>this.getElementsSymbol(e))??[]}]}getModelViewsSymbol(e){let t=e.$cstNode,r=Ue(t,`name`);return!r||!t?[]:[{kind:this.symbolKind(e),name:e.name,range:t.range,selectionRange:r.range,children:e.views.flatMap(e=>this.getViewSymbol(e))}]}getKindSymbol(e){return!e.$cstNode||!e.kind.$cstNode||j(e.kind.name)?null:{kind:this.symbolKind(e),name:e.kind.name,range:e.$cstNode.range,selectionRange:e.kind.$cstNode.range}}getTagSymbol(e){return!e.$cstNode||!e.tag.$cstNode||j(e.tag.name)?null:{kind:this.symbolKind(e),name:`#`+e.tag.name,range:e.$cstNode.range,selectionRange:e.tag.$cstNode.range}}getLibIconSymbol(e){return!e.$cstNode||j(e.name)?null:{kind:this.symbolKind(e),name:e.name,range:e.$cstNode.range,selectionRange:e.$cstNode.range}}getViewSymbol(e){let t=e?.$cstNode;if(!t)return[];let r=e.name?Ue(t,`name`):null;return r?[{kind:this.symbolKind(e),name:r.text,range:t.range,selectionRange:r.range,children:[]}]:[]}getDeploymentElementSymbol(e){try{if(isDeploymentNode$1(e))return this.getDeploymentNodeSymbol(e);if(isDeployedInstance(e))return this.getDeployedInstanceSymbol(e);if(isExtendDeployment(e))return[]}catch(e){logWarnError(e)}return[]}getDeploymentNodeSymbol(e){let t=e.$cstNode,r=this.nameProvider.getNameNode(e);if(!r||!t)return[];let o=this.nameProvider.getNameStrict(e),s=e.kind.$refText;return[{kind:this.symbolKind(e),name:o,range:t.range,selectionRange:r.range,detail:s,children:e.body?.elements.flatMap(e=>this.getDeploymentElementSymbol(e))??[]}]}getDeployedInstanceSymbol(e){let t=e.$cstNode,r=this.nameProvider.getNameNode(e);if(!r||!t)return[];let o=Te(e),s=this.parser.forDocument(o).parseDeployedInstance(e),c=this.nameProvider.getNameStrict(e),u=`instance of `+s.element.model;return[{kind:this.symbolKind(e),name:c,range:t.range,selectionRange:r.range,detail:u,children:[]}]}symbolKind(e){return this.nodeKindProvider.getSymbolKind(e)}};const tl=`
|
|
67
78
|
---
|
|
68
|
-
`;var LikeC4HoverProvider=class extends je{services;parser;locator;constructor(e){super(e),this.services=e,this.parser=e.likec4.ModelParser,this.locator=e.likec4.ModelLocator}getAstNodeHoverContent(e){if(isTag(e))return{contents:{kind:`markdown`,value:"tag `"+e.name+"`"}};if(isElementKind(e))return{contents:{kind:`markdown`,value:"element kind `"+e.name+"`"}};if(isDeploymentNodeKind(e))return{contents:{kind:`markdown`,value:"deployment node `"+e.name+"`"}};if(isRelationshipKind(e))return{contents:{kind:`markdown`,value:"relationship kind `"+e.name+"`"}};try{if(isElement(e))return this.getElementHover(e);if(isDeploymentNode$1(e))return this.getDeploymentNodeHover(e);if(isDeployedInstance(e))return this.getDeployedInstanceHover(e)}catch(e){
|
|
79
|
+
`;var LikeC4HoverProvider=class extends je{services;parser;locator;constructor(e){super(e),this.services=e,this.parser=e.likec4.ModelParser,this.locator=e.likec4.ModelLocator}getAstNodeHoverContent(e){if(isTag(e))return{contents:{kind:`markdown`,value:"tag `"+e.name+"`"}};if(isElementKind(e))return{contents:{kind:`markdown`,value:"element kind `"+e.name+"`"}};if(isDeploymentNodeKind(e))return{contents:{kind:`markdown`,value:"deployment node `"+e.name+"`"}};if(isRelationshipKind(e))return{contents:{kind:`markdown`,value:"relationship kind `"+e.name+"`"}};try{if(isElement(e))return this.getElementHover(e);if(isDeploymentNode$1(e))return this.getDeploymentNodeHover(e);if(isDeployedInstance(e))return this.getDeployedInstanceHover(e)}catch(e){q.debug(loggable(e))}}getElementHover(e){let t=this.locator.getParsedElement(e);if(!t)return;let r=t.element,o=[`<sup>\`${r.id}\`</sup> `,`### ${r.title} `],s=Kr(r);s&&o.push(``,(s.md??s.txt).split(`
|
|
69
80
|
`).join(`
|
|
70
|
-
`));let
|
|
71
|
-
<small>_Model not processed yet, open any view to trigger_</small> `),{contents:{kind:`markdown`,value:
|
|
72
|
-
`)}}}getElementModelHover(e,t){let
|
|
73
|
-
`):void 0}getDeploymentNodeHover(e){let t=
|
|
74
|
-
`)}}}getDeployedInstanceHover(e){let t=
|
|
75
|
-
`)}}}},LikeC4CodeActionProvider=class{getCodeActions(e,t){}};Pe();const qc=G.getChild(`SemanticTokenProvider`),Jc={...Qe},Yc={...Ee};function createSemanticTypeMethods(e){let t=[],n=new Proxy({},{get(r,i){if(i===`modifier`)return e=>(t.push(e),n);if(i in Yc)return t.push(Yc[i]),n;if(i in Jc)return()=>e(Jc[i],t);throw Error(`Unknown semantic token type or modifier: ${i}`)}});return n}const Xc=`Stop Highlighting`,stopHighlight=()=>{throw Xc};var LikeC4SemanticTokenProvider=class extends ze{services;rules=[];constructor(e){super(e),this.services=e,this.initRules()}initRules(){this.rules=[];let when=(e,t)=>{let n={predicate:e,highlightFn:t};this.rules.push(n)};when(isRelationshipKind,e=>{e.property(`name`).function()}),when(L(isRelation,isOutgoingRelationExpr,isDeploymentRelation),e=>{e.property(`kind`).function()}),when(isLibIcon,e=>{e.property(`name`).definition.function(),stopHighlight()}),when(L(isNavigateToProperty,isRelationNavigateToProperty),e=>{e.property(`value`).readonly.definition.interface()}),when(isWildcardExpression,e=>{e.cst().readonly.definition.variable(),stopHighlight()}),when(isFqnRefExpr,e=>{e.node.selector&&(e.node.ref.parent?e.property(`selector`).property():e.property(`selector`).readonly.definition.variable())}),when(isTagRef,e=>{e.cst().type()}),when(isRelationKindDotRef,e=>{e.cst().function()}),when(isWhereRelationKind,e=>{T(e.node.value?.$refText)&&e.property(`value`).function()}),when(L(isWhereElementMetadata,isWhereRelationMetadata,isWhereRelationParticipantMetadata),e=>{e.keyword(`metadata`).keyword(),e.property(`key`).property()}),when(L(isWhereElementTag,isWhereElementKind,isWhereRelationTag,isWhereRelationKind),e=>{T(e.node.value)&&e.property(`value`).readonly.definition.type()}),when(L(isWhereRelationParticipantKind,isWhereRelationParticipantTag,isWhereRelationParticipantMetadata),e=>{e.property(`participant`).keyword()}),when(isElementKindExpression,e=>{T(e.node.kind)&&e.property(`kind`).definition.type()}),when(L(isGlobalStyleGroup,isGlobalStyle),e=>{e.property(`id`).readonly.definition.variable()}),when(isViewRuleGlobalStyle,e=>{e.property(`style`).readonly.definition.variable()}),when(L(isGlobalPredicateGroup,isGlobalDynamicPredicateGroup),e=>{e.property(`name`).readonly.definition.variable()}),when(isViewRuleGlobalPredicateRef,e=>{e.property(`predicate`).readonly.definition.variable()}),when(isElementTagExpression,e=>{T(e.node.tag)&&e.property(`tag`).definition.type()}),when(L(isFqnRef,isStrictFqnRef),e=>{if(e.node.parent){e.property(`value`).property();return}let t=e.node.value.$refText;t!==`this`&&t!==`it`&&e.property(`value`).readonly.definition.variable()}),when(isStrictFqnElementRef,e=>{e.node.parent?e.property(`el`).property():e.property(`el`).readonly.definition.variable()}),when(isSpecificationColor,e=>{e.keyword(`color`).keyword(),e.property(`name`).readonly.declaration.type()}),when(isSpecificationTag,e=>{T(e.node.color)&&e.keyword(`color`).property()}),when(L(isSpecificationElementKind,isSpecificationRelationshipKind,isSpecificationDeploymentNodeKind),e=>{e.property(`kind`).readonly.declaration.type()}),when(isTag,e=>{e.property(`name`).definition.type()}),when(isOpacityProperty,e=>{e.property(`value`).number()}),when(isIconProperty,e=>{if(e.node.libicon||e.node.value===`none`){e.property(e.node.libicon?`libicon`:`value`).defaultLibrary.enum();return}e.property(`value`).string()}),when(isLinkProperty,e=>{T(e.node.value)&&e.property(`value`).string()}),when(L(isColorProperty,isIconColorProperty),e=>{T(e.node.customColor)&&e.property(`customColor`).enum(),T(e.node.themeColor)&&e.property(`themeColor`).enum()}),when(e=>isAnyProperty(e)&&!L(isMetadataProperty,isElementStyleProperty,isRelationStyleProperty)(e)&&T(e.key),e=>e.property(`key`).property()),when(L(isShapeProperty,isArrowProperty,isLineProperty,isBorderProperty,isSizeProperty,isIconPositionProperty,isIconSizeProperty,isDynamicViewDisplayVariantProperty),e=>{T(e.node.value)&&e.property(`value`).enum()})}highlightElement(e,t){if(L(isElement,isDeploymentNode$1,isDeployedInstance)(e))return this.highlightNameAndKind(e);if(isLikeC4View(e))return this.highlightView(e);let n;for(let{predicate:t,highlightFn:r}of this.rules)if(t(e))try{n??=this.mark(e),r(n)}catch(t){if(t===Xc)return`prune`;qc.warn(`Error highlighting node of type ${e._type}`,{error:t})}}highlightNameAndKind(e){if(this.mark(e).property(`name`).declaration.readonly.variable(),isDeployedInstance(e)||this.mark(e).property(`kind`).keyword(),isElement(e)){e.props.length>0&&this.mark(e).property(`props`).string();return}e.title&&this.mark(e).property(`title`).string()}highlightView(e){e.name&&this.mark(e).property(`name`).modifier(`local`).declaration.readonly.interface()}mark(e){let cst=t=>createSemanticTypeMethods((n,r)=>this.highlightToken({range:oi(t??e.$cstNode,`AST node has no CST node`).range,type:n,modifier:r})),keyword=t=>createSemanticTypeMethods((n,r)=>this.highlightKeyword({node:e,keyword:t,type:n,modifier:r})),property=(t,n)=>createSemanticTypeMethods((r,i)=>this.highlightProperty({node:e,property:t,type:r,modifier:i,...n===void 0?{}:{index:n}}));return{node:e,cst,keyword,property}}};const Zc=L(isElement,isExtendElement);var FqnIndex=class extends ADisposable{services;projects;langiumDocuments;documentCache;workspaceCache;logger=G.getChild(`fqn-index`);constructor(e){super(),this.services=e,this.langiumDocuments=e.shared.workspace.LangiumDocuments,this.projects=e.shared.workspace.ProjectsManager,this.documentCache=new Jr(e=>this.createDocumentIndex(e)),this.workspaceCache=new oe(e.shared,y.IndexedContent),this.onDispose(e.shared.workspace.DocumentBuilder.onDocumentPhase(y.IndexedContent,e=>{isLikeC4UserDocument(e)&&this.documentCache.delete(e)}))}documents(e){return this.langiumDocuments.projectDocuments(e).filter(e=>e.state>=y.IndexedContent)}get(e){return e.state<y.IndexedContent&&this.logger.warn(`document {doc} is in state {state}, expected at least IndexedContent ({expect}). This may lead to incorrect FQN resolution.`,{doc:_.basename(e.uri),state:e.state,expect:y.IndexedContent}),this.documentCache.get(e)}resolve(e){return e.$type===`Imported`?this.getFqn(e.imported.ref):e.$type===`Element`?this.getFqn(e):this.services.likec4.DeploymentsIndex.getFqn(e)}getFqn(e){z(isElement(e)||isDeploymentElement(e));let t=wc.readId(e);if(T(t))return t;let n=x(e);return n.state<y.IndexedContent&&this.logger.warn(`document {doc} is not yet indexed, creating on the fly to resolve FQN for element {el}`,{el:e.name??e.$type,doc:_.basename(n.uri)}),z(isLikeC4LangiumDocument(n)),this.get(n),B(wc.readId(e),`Element fqn must be set, invalid state`)}byFqn(e,t){return S(this.workspaceCache.get(`${e}:fqn:${t}`,()=>this.documents(e).flatMap(e=>this.get(e).byFqn(t)).toArray()))}rootElements(e){return S(this.workspaceCache.get(`${e}:rootElements`,()=>{let t=new H;for(let n of this.documents(e))for(let e of this.get(n).rootElements())t.set(e.name,e);return uniqueByName(t)}))}directChildrenOf(e,t){return S(this.workspaceCache.get(`${e}:directChildrenOf:${t}`,()=>{let n=new H;for(let r of this.documents(e))for(let e of this.get(r).children(t))n.set(e.name,e);return uniqueByName(n)}))}uniqueDescedants(e,t){return S(this.workspaceCache.get(`${e}:uniqueDescedants:${t}`,()=>{let n=new H,r=new H;for(let i of this.documents(e)){let e=this.get(i);for(let r of e.children(t))n.set(r.name,r);for(let n of e.descendants(t))r.set(n.name,n)}let i=uniqueByName(n),a=[...r.associations()].flatMap(([e,t])=>t.length===1&&!n.has(e)?t:[]);return[...i,...di(a)]}))}createDocumentIndex(e){let t=e.parseResult.value.models.flatMap(e=>e.elements.filter(Zc));if(t.length===0)return Qc.EMPTY;let n=e.likec4ProjectId??this.projects.ownerProjectId(e),r=[],i=new H,a=new H,o=new H,s=this.services.workspace.AstNodeDescriptionProvider,createAndSaveDescription=(t,r,i)=>{let a=Object.assign(s.createDescription(t,r,e),{id:i,likec4ProjectId:n});return wc.writeId(t,i),o.set(i,a),a};function traverseElement(e,t){let n=lr(e.name,t),o=createAndSaveDescription(e,e.name,n);t?i.set(t,o):r.push(o);let s=j(e.body?.elements??[],Zc);if(!A(s,1))return[o];let c=E(s,e=>traverseElement(e,n));for(let e of c)a.set(n,e);return[o,...c]}function traverseExtendElement(e){let t=readStrictFqn(e.element),n=M(e.body?.elements??[],j(isElement),E(e=>traverseElement(e,t)));if(n.length!==0)for(let e of[t,...Yr(t)])for(let t of n)a.set(e,t)}for(let n of t)try{if(isExtendElement(n)){traverseExtendElement(n);continue}traverseElement(n,null)}catch(t){this.logger.warn(`Error while traversing element {el} in document {doc}`,{el:n.$type,doc:_.basename(e.uri),error:t})}return new Qc(r,i,a,o,n)}};function uniqueByName(e){return[...e.associations()].flatMap(([e,t])=>t.length===1?t:[]).sort((e,t)=>Zr(e.name,t.name))}var Qc=class DocumentFqnIndex{_rootElements;_children;_descendants;_byfqn;projectId;static EMPTY=new DocumentFqnIndex([],new H,new H,new H,jc.DefaultProjectId);constructor(e,t,n,r,i){this._rootElements=e,this._children=t,this._descendants=n,this._byfqn=r,this.projectId=i}rootElements(){return this._rootElements}byFqn(e){return this._byfqn.get(e)??[]}children(e){return this._children.get(e)??[]}descendants(e){return this._descendants.get(e)??[]}};const $c=Fr(isDeploymentElement,isExtendDeployment);var DeploymentsIndex=class extends FqnIndex{services;Names;logger=G.getChild(`deployments-index`);constructor(e){super(e),this.services=e,this.Names=e.references.NameProvider}createDocumentIndex(e){let t=e.parseResult.value.deployments.flatMap(e=>e.elements.filter($c));if(t.length===0)return Qc.EMPTY;let n=e.likec4ProjectId??this.projects.ownerProjectId(e),r=[],i=new H,a=new H,o=new H,s=this.Names,c=this.services.workspace.AstNodeDescriptionProvider,createAndSaveDescription=(t,r,i)=>{let a={...c.createDescription(t,r,e),id:i,likec4ProjectId:n};return wc.writeId(t,i),o.set(i,a),a};function traverseElement(e,t){let n=s.getName(e);if(!T(n))return[];let o=gr(n,t),c=createAndSaveDescription(e,n,o);if(t?i.set(t,c):r.push(c),isDeployedInstance(e))return[c];let l=j(e.body?.elements??[],$c);if(!A(l,1))return[c];let u=E(l,e=>traverseElement(e,o));for(let e of u)a.set(o,e);return[c,...u]}function traverseExtend(e){let t=readStrictFqn(e.deploymentNode),n=M(e.body?.elements??[],j($c),E(e=>traverseElement(e,t)));if(n.length!==0)for(let e of[t,...Er(t)])for(let t of n)a.set(e,t)}for(let n of t)try{if(isExtendDeployment(n)){traverseExtend(n);continue}traverseElement(n,null)}catch(t){this.logger.warn(`Error while traversing element {el} in document {doc}`,{el:n.$type,doc:_.basename(e.uri),error:t})}return new Qc(r,i,a,o,n)}};const el=/^(aws|azure|gcp|tech):(.+)$/;function deriveTechnologyFromIcon(e){if(!e)return;let t=el.exec(e);if(t)return t[2].replace(/-icon$/,``).split(`-`).map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(` `)}var MergedSpecification=class{specs={elements:{},deployments:{},relationships:{},colors:{}};tags;globals={predicates:{},dynamicPredicates:{},styles:{}};imports=new H(Set);projectId;inferTechFromIcon;constructor(e,t){let n={},r=[];for(let t of e){let{c4Specification:e,c4Globals:i,c4Imports:a}=t,o=t.likec4ProjectId;w(o)&&(r.length===0||r[0]!==o)&&r.push(t.likec4ProjectId),Object.assign(n,e.tags),Object.assign(this.specs.elements,e.elements),Object.assign(this.specs.relationships,e.relationships),Object.assign(this.specs.colors,e.colors),Object.assign(this.specs.deployments,e.deployments),Object.assign(this.globals.predicates,i.predicates),Object.assign(this.globals.dynamicPredicates,i.dynamicPredicates),Object.assign(this.globals.styles,i.styles);for(let[e,t]of a)this.imports.set(e,t)}this.tags=sr(n),this.projectId=Cn(r),this.inferTechFromIcon=t?.inferTechFromIcon??!0}toModelElement=({tags:e,links:t,style:n,id:r,kind:i,title:a,description:o,technology:s,summary:c,metadata:l})=>{try{let u=this.specs.elements[i];if(!u)return G.warn`No kind '${i}' found for ${r}`,null;s??=u.technology,o??=u.description,c??=u.summary,t??=u.links,Yt(a)&&(a=u.title||ai(r)),u.tags&&ni(u.tags)&&(e=e?Tn([...u.tags,...e]):u.tags);let d=fr({...u.style,...n});return!s&&this.inferTechFromIcon&&(s=deriveTechnologyFromIcon(d.icon)),fr({metadata:l&&!D(l)?l:void 0,notation:u.notation,style:d,links:t,tags:e,summary:c,technology:s,description:o,title:a,kind:i,id:r})}catch(e){logWarnError(e)}return null};toModelRelation=({astPath:e,source:t,target:n,kind:r,links:i,id:a,...o})=>{if(w(r)&&this.specs.relationships[r]){let{multiple:e,...s}=this.specs.relationships[r];return{...s,...o,...i&&{links:i},source:t,target:n,kind:r,id:a}}return{...i&&{links:i},...o,source:t,target:n,id:a}};toDeploymentElement=e=>{if(`element`in e&&!(`kind`in e))return{...e,element:I.flatten(e.element)};if(`element`in e)return G.warn`Invalid ParsedAstDeployment ${e.id}, has both element and kind properties`,null;try{let t=this.specs.deployments[e.kind];if(!t)return G.warn`No kind ${e.kind} found for ${e.id}`,null;let{id:n,style:r,title:i,...a}=e;return i=i===ai(e.id)&&t.title?t.title:i,fr({...t,...a,title:i,style:fr({...t.style,...r}),id:n})}catch(e){logWarnError(e)}return null};toDeploymentRelation=({astPath:e,source:t,target:n,kind:r,links:i,id:a,...o})=>{if(w(r)&&this.specs.relationships[r]){let{multiple:e,...s}=this.specs.relationships[r];return{...s,...o,...i&&{links:i},source:t,target:n,kind:r,id:a}}return{...i&&{links:i},...o,source:t,target:n,id:a}}},LastSeenArtifacts=class{#e=new Map;#t=new Map;#n=new Map;constructor(e){e.shared.workspace.WorkspaceManager.onForceCleanCache(()=>{this.#e.clear(),this.#t.clear(),this.#n.clear()})}rememberSpecification(e){return e.projectId&&this.#e.set(e.projectId,e),e}rememberModel(e){let t=e.projectId,n=e.$styles,r=this.#t.get(t);return(!r||!r.equals(n))&&this.#t.set(t,n),this.#n.set(t,e),e}specification(e){return this.#e.get(e)}styles(e){return this.#t.get(e)}model(e){return this.#n.get(e)}};function assignNavigateTo(e){let t=new Map;for(let n of e)if(zr(n)&&n.viewOf&&O(n.extends)){let e=t.get(n.viewOf)??[];e.push(n.id),t.set(n.viewOf,e)}for(let{id:n,nodes:r}of e)for(let e of r){let r=e.modelRef;if(e.navigateTo||!r)continue;let i=nn(t.get(r)??[],e=>e!==n);i&&(e.navigateTo=i)}return e}var MergedExtends=class{mergedData=new Map;mergeMetadata(e,t){let n={...e};for(let[e,r]of Object.entries(t)){let t=n[e];if(t===void 0){n[e]=r;continue}let i=Array.isArray(t)?t:[t],a=Array.isArray(r)?r:[r],o=Tn([...i,...a]);n[e]=o.length===1?o[0]:o}return n}merge(e){for(let t of e){let{id:e,links:n,tags:r,metadata:i}=t,a=this.mergedData.get(e)??{links:[],tags:[],metadata:{}};n&&a.links.push(...n),r&&(a.tags=Tn([...a.tags,...r])),i&&(a.metadata=this.mergeMetadata(a.metadata,i)),this.mergedData.set(e,a)}}applyExtended(e){let t=this.mergedData.get(e.id);if(!t)return e;let n=t.links;e.links&&e.links.length>0&&(n=[...e.links,...n]);let r=t.tags;e.tags&&e.tags.length>0&&(r=Tn([...e.tags,...r]));let i=t.metadata;return e.metadata&&(i=this.mergeMetadata(e.metadata,t.metadata)),{...e,tags:A(r,1)?r:null,links:A(n,1)?n:null,...!D(i)&&{metadata:i}}}};function buildModelData(e,t,n){let r=new MergedSpecification(n,{inferTechFromIcon:t.config.inferTechnologyFromIcon??!0});r.projectId===t.id&&e.likec4.LastSeen.rememberSpecification(r);let i=an(r.specs.colors,e=>cr(e.color)),a=new Set,o=new MergedExtends,s=new MergedExtends,c=n.flatMap(e=>e.c4ExtendRelations),l=new Set,scanMetadataKeys=e=>{e?.metadata&&Nn(e.metadata).forEach(e=>a.add(e))},u=M(n,E(e=>(o.merge(e.c4ExtendElements),N(e.c4Elements,r.toModelElement))),j(T),fi,ln((e,t)=>{let n=li(t.id);return n&&O(e[n])?(G.debug`No parent found for ${t.id}`,e):(e[t.id]=o.applyExtended(t),scanMetadataKeys(e[t.id]),e)},{})),d=M(n,E(e=>N(e.c4Relations,r.toModelRelation)),j(e=>{if(!e)return!1;let t=I.flatten(e.source),n=I.flatten(e.target);return O(u[t])&&!Br(t)||O(u[n])&&!Br(n)?(G.debug`Invalid relation ${e.id}
|
|
76
|
-
source: ${t} resolved: ${!!
|
|
77
|
-
target: ${
|
|
78
|
-
source: ${e.source.deployment} resolved: ${!!
|
|
79
|
-
target: ${e.target.deployment} resolved: ${!!
|
|
80
|
-
`,` `)}`,description:null,rules:[{include:[{wildcard:!0}]}]}))}}let h=M(m,Jt(An(`id`)));m.some(pr)&&(h=Ii(h));for(let e of c)l.has(e.astPath)||G.warn(`Relation extend at ${e.astPath} does not match any relation in the model`);return{data:{[ur]:`parsed`,projectId:t.id,project:fr({id:t.id,title:t.config.title??t.config.name,styles:t.config.styles,manualLayouts:t.config.manualLayouts,inferTechnologyFromIcon:t.config.inferTechnologyFromIcon}),specification:{tags:r.tags,elements:r.specs.elements,relationships:an(r.specs.relationships,({notation:e,technology:t,...n})=>({...e&&{notation:e},...t&&{technology:t},style:n})),deployments:r.specs.deployments,...a.size>0&&{metadataKeys:[...a].sort(Zr)},customColors:i},elements:u,relations:d,globals:r.globals,views:h,deployments:{elements:f,relations:p},imports:{}},imports:r.imports}}const Z=G.getChild(`builder`);var DefaultLikeC4ModelBuilder=class extends ADisposable{services;projects;parser;listeners=[];cache;DocumentBuilder;manualLayouts;mutex;lastSeen;constructor(e){super(),this.services=e,this.projects=e.shared.workspace.ProjectsManager,this.parser=e.likec4.ModelParser,this.DocumentBuilder=e.shared.workspace.DocumentBuilder,this.mutex=e.shared.workspace.WorkspaceLock,this.manualLayouts=e.shared.workspace.ManualLayouts,this.lastSeen=e.likec4.LastSeen,this.cache=new ProjectModelCache(e),this.onDispose(this.cache,this.DocumentBuilder.onUpdate((e,t)=>{t.length>0&&this.notifyListeners(t)}),e.shared.workspace.WorkspaceManager.onForceCleanCache(()=>{this.clearCache()}),this.manualLayouts.onManualLayoutUpdate(({projectId:e})=>{this.notifyListeners(e)}));let t=un(Xt(),j(e=>isNotLikeC4Builtin(e)&&!this.projects.isExcluded(e)),N(e=>e.uri));this.onDispose(this.DocumentBuilder.onBuildPhase(y.Validated,(e,n)=>{let r=t(e);r.length>0&&this.notifyListeners(r)})),Z.debug`created`}unsafeSyncParseModelData(e){return this.cache.parsedData(e,()=>{let t=Z.getChild(e);try{let n=this.projects.getProject(e),r=this.documents(e);return r.length===0?(t.trace`unsafeSyncParseModelData: ${`skipped due to no documents`}`,null):(t.trace`unsafeSyncParseModelData: ${`completed`}`,buildModelData(this.services,n,r))}catch(t){return Z.warn(`unsafeSyncParseModelData failed for project ${e}`,{err:t}),null}})}unsafeSyncJoinedModelData(e){return this.cache.parsedJoinedData(e,()=>{let t=Z.getChild(e),n=this.unsafeSyncParseModelData(e);if(!n)return null;if(n.imports.size===0)return t.trace(`unsafeSyncJoinedModelData: no imports`),n.data;t.debug(`unsafeSyncJoinedModelData: processing imports`);let r=[...n.imports.associations()].reduce((e,[t,n])=>{if(n.size===0)return e;let r=this.unsafeSyncParseModelData(t);if(r){let i=[...n].flatMap(e=>r.data.elements[e]??[]);A(i,1)&&(e[t]=structuredClone(i))}return e},{});return{...n.data,imports:r}})}async parseModel(e,t){return e=this.projects.ensureProjectId(e),await this.mutex.read(async()=>(t?.isCancellationRequested&&await te(t),this.cache.parsedModel(e,()=>{let t=Z.getChild(e),n=this.unsafeSyncJoinedModelData(e);return n?_i.create(n):(t.debug`parseModel: returning EMPTY`,_i.EMPTY.asParsed)})))}unsafeSyncComputeModel(e,t){return this.cache.computedModel(e,t??null,()=>{let n=Z.getChild(e),r=this.unsafeSyncJoinedModelData(e);if(!r)return e!==jc.DefaultProjectId&&n.warn`unsafeSyncComputeModel: returning EMPTY`,_i.EMPTY.asComputed;let i=performanceMark(),a=_i.create(r),o=[];for(let e of On(r.views)){let r=Fi(e,a);if(!r.isSuccess){n.warn(loggable(r.error));continue}t?.views[e.id]&&Object.assign(r.view,{hasManualLayout:!0}),o.push(r.view)}assignNavigateTo(o);let s={...r,manualLayouts:{...t?.views},[wr]:`computed`,views:Jt(o,An(`id`))};return n.debug(`computeModel${t?` with manual layouts`:``}: {status} in ${i.pretty}`,{status:`completed`}),this.lastSeen.rememberModel(_i.create(s))})}async computeModel(e,t){e=this.projects.ensureProjectId(e);let n=Z.getChild(e);return await this.mutex.read(async()=>{t?.isCancellationRequested&&await te(t);let r=this.projects.getProject(e),i=await this.manualLayouts.read(r),a=this.unsafeSyncComputeModel(e,i);return a===_i.EMPTY&&e!==jc.DefaultProjectId&&n.warn(`computeModel returned EMPTY`),a})}onModelParsed(e){return this.listeners.push(e),g.create(()=>{let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)})}clearCache(){Z.debug(`clear all caches`),this.cache.clear()}documents(e){return this.parser.documents(e).toArray()}notifyListeners(e){let t;t=Kt(e)?M(e,en(e=>this.projects.ownerProjectId(e)),rn()):[[e,[]]];for(let e of this.listeners)try{for(let[n,r]of t)e(n,r)}catch(e){Z.warn(loggable(e))}}},ProjectModelCache=class extends f{constructor(e){super(e=>typeof e==`string`?e:e.id),this.toDispose.push(e.shared.workspace.DocumentBuilder.onDocumentPhase(y.Validated,t=>{let n=e.shared.workspace.ProjectsManager.ownerProjectId(t);this.clear(n)}),e.shared.workspace.DocumentBuilder.onUpdate((t,n)=>{if(n.length>0){let t=e.shared.workspace.ProjectsManager,r=Tn(N(n,t.ownerProjectId.bind(t)));if(!A(r,1))return;Z.trace`clear project caches for: ${r} (on delete ${n.map(e=>e.fsPath)})`;for(let e of r)this.clear(e)}}))}parsedData(e,t){let n=`parsed-data`,r=this.get(e,n);if(r!==void 0)return Z.trace`cache hit project ${e} key: ${n}`,r;let i=t();return this.set(e,n,i),Z.trace`cache miss project ${e} key: ${n}`,i}parsedJoinedData(e,t){let n=`parsed-joined-data`,r=this.get(e,n);if(r!==void 0)return Z.trace`cache hit project ${e} key: ${n}`,r;let i=t();return this.set(e,n,i),Z.trace`cache miss project ${e} key: ${n}`,i}parsedModel(e,t){let n=`parsed-model`,r=this.get(e,n);if(r!==void 0)return Z.trace`cache hit project ${e} key: ${n}`,r;let i=t();return this.set(e,n,i),Z.trace`cache miss project ${e} key: ${n}`,i}computedModel(e,t,n){let r=t?`computed-model-${t.hash}`:`computed-model`,i=this.get(e,r);if(i!==void 0)return Z.trace`cache hit project ${e} key: ${r}`,i;let a=n();return this.set(e,r,a),Z.trace`cache miss project ${e} key: ${r}`,a}};const{findNodeForKeyword:tl,findNodeForProperty:nl}=we,{getDocument:rl,streamAllContents:il}=Re,al=G.getChild(`locator`);var LikeC4ModelLocator=class{services;fqnIndex;deploymentsIndex;langiumDocuments;parser;projects;constructor(e){this.services=e,this.fqnIndex=e.likec4.FqnIndex,this.deploymentsIndex=e.likec4.DeploymentsIndex,this.langiumDocuments=e.shared.workspace.LangiumDocuments,this.parser=e.likec4.ModelParser,this.projects=e.shared.workspace.ProjectsManager}documents(e){return this.parser.documents(e)}getParsedElement(...e){try{let t,n;if(e.length===2?(t=e[0],n=e[1]):(t=e[0],n=Mn(t)?this.projects.ensureProjectId():projectIdFrom(t)),Mn(t)){let e=t,r=this.fqnIndex.byFqn(n,e).head();if(!r)return null;let i=this.langiumDocuments.getDocument(r.documentUri),a=this.findParsedElementByFqnIn(e,i);return a&&i?{projectId:n,element:a,document:i}:null}let r=this.fqnIndex.getFqn(t),i=rl(t),a=this.findParsedElementByFqnIn(r,i);return a&&i?{projectId:n,element:a,document:i}:null}catch(e){return al.debug(loggable(e)),null}}findParsedElementByFqnIn(e,t){if(t)return this.parser.parse(t).c4Elements.find(t=>t.id===e)}locateElement(e,t){let[n,r]=Kr(e);n??=this.projects.ensureProjectId(t);let i=this.fqnIndex.byFqn(n,r).head(),a=i?.nameSegment??i?.selectionSegment;return!i||!a?null:{uri:i.documentUri.toString(),range:a.range}}locateDeploymentElement(e,t){let n=this.projects.ensureProjectId(t),r=e,i=this.deploymentsIndex.byFqn(n,r).head(),a=i?.nameSegment??i?.selectionSegment;return!i||!a?null:{uri:i.documentUri.toString(),range:a.range}}locateRelation(e,t){let n=this.projects.ensureProjectId(t);for(let t of this.documents(n)){let n=t.c4Relations.find(t=>t.id===e)??t.c4DeploymentRelations.find(t=>t.id===e);if(!n)continue;let r=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,n.astPath);if(!isRelation(r)&&!isDeploymentRelation(r))continue;let i=r.kind?nl(r.$cstNode,`kind`):void 0;if(i??=r.dotKind?nl(r.$cstNode,`dotKind`):void 0,i??=tl(r.$cstNode,`->`),i??=nl(r.$cstNode,`title`),i??=nl(r.$cstNode,`target`),i??=r.$cstNode,i)return{uri:t.uri.toString(),range:{start:i.range.start,end:i.range.start}}}return null}locateViewAst(e,t){let n=this.projects.ensureProjectId(t);for(let t of this.documents(n)){let n=t.c4Views.find(t=>t.id===e);if(!n)continue;let r=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,n.astPath);if(isLikeC4View(r))return{doc:t,view:n,viewAst:r}}return null}locateView(e,t){let n=this.locateViewAst(e,t);if(!n)return null;let r=n.viewAst,i=r.name?nl(r.$cstNode,`name`):void 0;return i??=tl(r.$cstNode,`view`),i??=r.$cstNode,i?{uri:n.doc.uri.toString(),range:{start:i.range.start,end:i.range.start}}:null}async locateDocumentTags(e,t){let n=this.langiumDocuments.getDocument(e);if(!n||!n.likec4ProjectId)return null;n.state<y.Linked&&(al.debug(`Waiting for document ${n.uri.path} to be Linked`),await this.services.shared.workspace.DocumentBuilder.waitUntil(y.Linked,n.uri,t));let r=projectIdFrom(n);al.trace`locate document tags for ${n.uri.fsPath} in project ${r}`;try{let e=this.services.likec4.LastSeen.specification(r)?.tags,t=this.services.likec4.LastSeen.styles(r)??rr.DEFAULT;if(!e)return al.trace(`No specification or styles found for project ${r}, cannot locate tags for document ${n.uri.fsPath}`),null;let i=M(il(n.parseResult.value),ti(e=>isTag(e)||isTagRef(e)),mi(),E(n=>{let r,i;try{isTag(n)?(r=n.name,i=n.$cstNode):(r=n.tag.$refText,i=n.tag.$refNode);let a=e[r];return U(a,`Tag ${r} not found in merged specification`),U(i,`Tag ${r} does not have a $cstNode`),{name:r,color:t.tagColor(a.color).fill,range:i.range,isSpecification:isTag(n)}}catch(e){return al.warn(`Fail on tag ${r}`,{err:e}),[]}}));return al.debug(`Found ${i.length} tags in document ${n.uri.path}`),i}catch(e){return al.warn(loggable(e)),null}}locateDynamicViewStep(e){let{doc:t,viewAst:n}=this.locateViewAst(e.view,e.projectId)??{};if(!t||!n)return null;if(!isDynamicView$1(n)||!n.body)return al.warn(`View ${e.view} is not a dynamic view`),null;let r=this.services.workspace.AstNodeLocator.getAstNodePath(n.body)+e.astPath,i=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,r);if(!i||!isDynamicViewStep(i))return al.warn(`Failed to locate dynamic view step ${r} in view ${e.view}`),null;let a=i.kind?nl(i.$cstNode,`kind`):void 0;return a??=i.dotKind?nl(i.$cstNode,`dotKind`):void 0,a??=tl(i.$cstNode,`->`),a??=tl(i.$cstNode,`<-`),a??=nl(i.$cstNode,`title`),a??=nl(i.$cstNode,`target`),a??=i.$cstNode,a?{uri:t.uri.toString(),range:{start:a.range.start,end:a.range.start}}:null}};const ol=[`this`,`it`,`self`,`super`,`likec4lib`,`global`];function tryOrLog(e){return async function tryOrLogFn(t,n,r){try{let i=e(t,n,r);Qt(i)&&await i;return}catch(e){let r=e instanceof Error?e.message:String(e);n(`error`,`Validation failed: ${r}`,{node:t}),G.debug(`Validation failed: ${r}`,{error:e})}}}const{getDocument:sl}=Re,deploymentNodeChecks=e=>{let t=e.likec4.DeploymentsIndex,n=e.references.NameProvider;return tryOrLog((e,r)=>{let i=n.getName(e);if(!i){r(`error`,`DeploymentNode must be named`,{node:e});return}let a=B(n.getNameNode(e),`name CstNode not found`).range;ol.includes(i)&&r(`error`,`Reserved word: ${i}`,{node:e,range:a});let o=projectIdFrom(e),s=t.getFqn(e);t.byFqn(o,s).limit(2).toArray().length>1&&r(`error`,`Duplicate node name "${s}"`,{node:e,range:a})})},deployedInstanceChecks=e=>{let t=e.likec4.DeploymentsIndex,n=e.references.NameProvider;return tryOrLog((e,r)=>{let i=n.getName(e);if(!i){r(`error`,`Deployed instance must be named, unique inside node`,{node:e});return}let a=B(n.getNameNode(e),`name CstNode not found`).range;ol.includes(i)&&r(`error`,`Reserved word: ${i}`,{node:e,range:a});let o=projectIdFrom(e),s=t.getFqn(e);t.byFqn(o,s).limit(2).toArray().length>1&&r(`error`,`Duplicate instance name "${s}"`,{node:e,range:a})})},deploymentRelationChecks=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,n)=>{if(!e.target?.value?.ref){n(`error`,`DeploymentRelation target '${e.target?.$cstNode?.text??``}' not resolved`,{node:e,property:`target`});return}let r=sl(e),i=t.forDocument(r),a;try{a=i._resolveDeploymentRelationSource(e)}catch(t){G.warn(loggable(t)),n(`error`,`DeploymentRelation source not resolved`,{node:e,property:`source`});return}if(R.isImportRef(a)){n(`error`,`DeploymentRelation cannot refer imported model (not implemented yet)`,{node:e,property:`source`});return}if(R.isModelRef(a)){n(`error`,`DeploymentRelation must refer deployment element`,{node:e,property:`source`});return}let o=i.parseFqnRef(e.target);if(R.isImportRef(o)){n(`error`,`DeploymentRelation cannot refer imported model (not implemented yet)`,{node:e,property:`target`});return}if(R.isModelRef(o)){n(`error`,`DeploymentRelation must refer deployment element`,{node:e,property:`target`});return}Ur(a.deployment,o.deployment)&&n(`error`,`Invalid parent-child relationship`,{node:e})})},extendDeploymentChecks=e=>tryOrLog((e,t)=>{let n=e.deploymentNode.value.ref;(!n||!isDeploymentNode$1(n))&&t(`error`,`ExtendDeployment allows only DeploymentNode`,{node:e,property:`deploymentNode`})}),dynamicViewStepSingle=e=>{let t=e.likec4.FqnIndex;return tryOrLog((e,n)=>{let r=elementRef(e.source),i=r&&t.getFqn(r);i||n(`error`,`Source not found (not parsed/indexed yet)`,{node:e,property:`source`});let a=elementRef(e.target),o=a&&t.getFqn(a);o||n(`error`,`Target not found (not parsed/indexed yet)`,{node:e,property:`target`}),i&&o&&(Nr(i,o)||Nr(o,i))&&n(`error`,`Invalid parent-child relationship`,{node:e})})},dynamicViewStepChain=e=>{let t=e.likec4.FqnIndex;return tryOrLog((e,n)=>{let r=e.source;isDynamicStepSingle(r)&&r.isBackward&&n(`error`,`Invalid chain after backward step`,{node:e});let i=elementRef(e.target);i&&t.getFqn(i)||n(`error`,`Target not found (not parsed/indexed yet)`,{node:e,property:`target`})})},dynamicViewDisplayVariant=e=>tryOrLog((e,t)=>{if(D(e.value)||e.value!==`diagram`&&e.value!==`sequence`){t(`error`,`Invalid display variant: "diagram" or "sequence" are allowed`,{node:e,property:`value`});return}Oe(e,isDynamicViewBody)||t(`error`,`Display mode can be defined only inside dynamic view`,{node:e})}),{getDocument:cl}=Re,checkElement=e=>{let t=e.likec4.FqnIndex,n=e.workspace.AstNodeLocator;return tryOrLog((e,r)=>{let i=t.getFqn(e);if(!i){r(`error`,`Not indexed element`,{node:e,property:`name`});return}ol.includes(e.name)&&r(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let a=cl(e),o=a.uri,s=n.getAstNodePath(e),c=t.byFqn(projectIdFrom(a),i).filter(e=>e.documentUri!==o||e.path!==s).head();if(c){let t=c.documentUri!==o;r(`error`,`Duplicate element name ${e.name===i?e.name:e.name+` (`+i+`)`}`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:c.nameSegment?.range??c.selectionSegment?.range,uri:c.documentUri.toString()},message:`conflicting element`}]}})}})},checkElementRef=e=>tryOrLog((e,t)=>{isReferenceToDeploymentModel(e.modelElement)&&t(`error`,`Only model elements allowed here`,{node:e,property:`modelElement`})}),{getDocument:ll}=Re,checkImportsFromPoject=e=>{let t=e.shared.workspace.ProjectsManager;return tryOrLog((e,n)=>{if(!t.all.includes(e.project)){n(`error`,`Imported project not found`,{node:e,property:`project`});return}let r=projectIdFrom(ll(e));if(e.project===r){n(`error`,`Imported project cannot be the same as the current project`,{node:e,property:`project`});return}})},opacityPropertyRuleChecks=e=>tryOrLog((e,t)=>{let n=parseFloat(e.value);(isNaN(n)||n<0||n>100)&&t(`warning`,`Value ignored, must be between 0% and 100%`,{node:e,property:`value`})}),iconPropertyRuleChecks=e=>(e,t)=>{let n=e.$container;n.props.some(t=>isIconProperty(t)&&t!==e)&&t(`error`,`Icon must be defined once`,{node:e}),isElementStyleProperty(n)&&isElementBody(n.$container)&&n.$container.props.some(e=>isIconProperty(e))&&t(`warning`,`Redundant as icon defined on element`,{node:e}),e.value?.startsWith(`file://`)&&t(`error`,`Icon URI must not start with file://`,{node:e,property:`value`})},colorLiteralRuleChecks=e=>(e,t)=>{if(e.$type===`HexColor`){if(e.hex===void 0||Mn(e.hex)&&!e.hex.match(/^[a-fA-F0-9]+$/)){t(`error`,`Invalid HEX`,{node:e,property:`hex`});return}let n=Ht(e.hex)?e.hex.toString().length:e.hex.length;n!==6&&n!==3&&n!==8&&t(`error`,`Invalid value "${e.$cstNode?.text}", must be 3, 6 or 8 characters long`,{node:e,property:`hex`});return}if(e.$type===`RGBAColor`){if((!Ht(e.red)||e.red<0||e.red>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`red`}),(!Ht(e.green)||e.green<0||e.green>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`green`}),(!Ht(e.blue)||e.blue<0||e.blue>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`blue`}),Ht(e.alpha)&&(e.alpha<0||e.alpha>1)&&t(`error`,`Invalid value, must be between 0 and 1`,{node:e,property:`alpha`}),Mn(e.alpha)){let n=parseFloat(e.alpha);(n<0||n>100)&&t(`error`,`Invalid value, must be between 0% and 100%`,{node:e,property:`alpha`})}return}V(e)},relationChecks=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,n)=>{let r=t.forDocument(x(e)),i=safeCall(()=>r._resolveRelationSource(e));if(!i){n(`error`,`Source not resolved`,{node:e,property:`source`});return}let a=safeCall(()=>r.parseFqnRef(e.target));if(!a){n(`error`,`Target not resolved`,{node:e,property:`target`});return}R.isImportRef(i)&&(R.isImportRef(a)?n(`warning`,`Relationship between imported elements may not be visible in origin projects`,{node:e}):n(`warning`,`Relationship from imported element to local element may not be visible in origin project`,{node:e,property:`source`})),Ur(R.flatten(i),R.flatten(a))&&n(`error`,`Invalid parent-child relationship`,{node:e})})},checkRelationBody=e=>tryOrLog((e,t)=>{e.$container.tags?.values&&e.tags?.values&&t(`error`,`Relation cannot have tags in both header and body`,{node:e.tags})}),extendRelationChecks=e=>{let t=e.likec4.ModelParser,n=new oe(e.shared,y.Linked),calcFingerprint=({source:e,target:t,kind:n,title:r})=>stringHash$1(`extend-relation`,R.flatten(e),R.flatten(t),n??`default`,r??``);function getProjectFingerprints(t){return n.get(t,()=>new Set(M(e.shared.workspace.LangiumDocuments.projectDocuments(t).toArray(),E(e=>e.c4Relations??[]),N(e=>calcFingerprint(e)))))}return tryOrLog((e,n)=>{let r=x(e),i=t.forDocument(r),a=safeCall(()=>i.parseFqnRef(e.source));if(!a){n(`error`,`Source not resolved`,{node:e,property:`source`});return}let o=safeCall(()=>i.parseFqnRef(e.target));if(!o){n(`error`,`Target not resolved`,{node:e,property:`target`});return}if(!R.isModelRef(a)&&!R.isImportRef(a)){n(`error`,`Source must reference a model element`,{node:e,property:`source`});return}if(!R.isModelRef(o)&&!R.isImportRef(o)){n(`error`,`Target must reference a model element`,{node:e,property:`target`});return}let s=projectIdFrom(r),c=(e.kind??e.dotKind?.kind)?.ref?.name??`default`,{title:l=``}=i.parseBaseProps({},{title:e.title}),u=calcFingerprint({source:a,target:o,kind:c,title:l});getProjectFingerprints(s).has(u)||n(`warning`,`This extend does not match any relation (by source, kind, target, title)`,{node:e})})},checkSpecificationRule=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one specification per document`,{node:e,property:`name`})}),checkModel=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one model per document`,{node:e,property:`name`})}),checkGlobals=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one global block per document`,{node:e,property:`name`})}),checkElementKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{ol.includes(e.name)&&n(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let r=projectIdFrom(e),i=t.projectElements(r,bo).filter(t=>t.name===e.name&&t.node!==e).head();if(i){let t=i.documentUri!==x(e).uri;n(`error`,`Duplicate element kind '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:i.nameSegment.range,uri:i.documentUri.toString()},message:`conflicting definition`}]}})}})},checkDeploymentNodeKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{ol.includes(e.name)&&n(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let r=projectIdFrom(e),i=t.projectElements(r,no).filter(t=>t.name===e.name&&t.node!==e).head();if(i){let t=i.documentUri!==x(e).uri;n(`error`,`Duplicate deploymentNode kind '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:i.nameSegment.range,uri:i.documentUri.toString()},message:`conflicting definition`}]}})}})},checkTag=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{let r=e.name,i=projectIdFrom(e),a=t.projectElements(i,`Tag`).filter(t=>t.name===r&&t.node!==e).head();if(a){let t=a.documentUri!==x(e).uri;n(`error`,`Duplicate tag '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:a.nameSegment.range,uri:a.documentUri.toString()},message:`conflicting definition`}]}})}})},checkRelationshipKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{ol.includes(e.name)&&n(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let r=projectIdFrom(e);t.projectElements(r,`RelationshipKind`).filter(t=>t.name===e.name).limit(2).count()>1&&n(`error`,`Duplicate RelationshipKind '${e.name}'`,{node:e,property:`name`})})},checkGlobalPredicate=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{let r=projectIdFrom(e),i=t.projectElements(r,Ho),a=t.projectElements(r,Vo);i.concat(a).filter(t=>t.name===e.name).limit(2).count()>1&&n(`error`,`Duplicate GlobalPredicateGroup or GlobalDynamicPredicateGroup name '${e.name}'`,{node:e,property:`name`})})},checkGlobalStyleId=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{let r=projectIdFrom(e);t.projectElements(r,`GlobalStyleId`).filter(t=>t.name===e.name).limit(2).count()>1&&n(`error`,`Duplicate GlobalStyleId name '${e.name}'`,{node:e,property:`name`})})},ul=/@likec4-generated/,viewChecks=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,n)=>{let r=ve(e.$cstNode,[`BLOCK_COMMENT`]);if(r&&ul.test(r.text)&&n(`warning`,`ManualLayoutV1 is no longer supported; remove this block`,{node:e,range:r.range}),!e.name)return;ol.includes(e.name)&&n(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let i=projectIdFrom(e);t.projectElements(i,`LikeC4View`).filter(t=>t.name===e.name).limit(2).count()>1&&n(`error`,`Duplicate view '${e.name}'`,{node:e,property:`name`})})};function collectFqnExprs(e){let t=[],n=e;for(;n;)n.value&&t.push(n.value),n=n.prev;return t.reverse()}const viewRuleRankChecks=e=>tryOrLog((e,t)=>{let n=collectFqnExprs(e.targets);n.length<2&&e.value===`same`&&t(`warning`,`Rank rule should have at least 2 targets`,{node:e,property:`targets`});let r=n.filter(isFqnRefExpr),i=r[0]?.ref?.parent;for(let n=1;n<r.length;n++){let a=r[n];e.value===`same`&&!areSame(i,a?.ref?.parent)&&t(`error`,`All targets must have the same parent rank same`,{node:e,property:`targets`})}});function areSame(e,t){return!e&&!t?!0:!e||!t||e.value.ref!==t.value.ref?!1:areSame(e.parent,t.parent)}const checkFqnExprWith=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,n)=>{let r=getViewRulePredicateContainer(e);if(r?.$type!==`DynamicViewIncludePredicate`&&r?.isInclude!==!0){n(`error`,`Invalid usage inside "exclude"`,{node:e});return}let i=r.$type===`DynamicViewIncludePredicate`,a=t.forDocument(x(r)),o=F.unwrap(a.parseFqnExprWith(e).custom.expr);switch(!0){case F.isWildcard(o)&&i:case F.isElementKindExpr(o)&&i:case F.isElementTagExpr(o)&&i:n(`warning`,`Predicate is ignored, as not supported in dynamic views`,{node:e});return;case F.isWildcard(o):case F.isModelRef(o):case F.isDeploymentRef(o):return;case F.isElementKindExpr(o):case F.isElementTagExpr(o):n(`error`,`Invalid target (expect reference to specific element)`,{node:e,property:`subject`});return;default:si(o)}})},checkFqnRefExpr=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,n)=>{let r=t.forDocument(x(e)).parseFqnRefExpr(e),i=getViewRulePredicateContainer(e),a=isFqnRefInsideDeployment(e)&&!Oe(e,e=>isDeploymentViewRuleStyle(e)||isViewRuleStyle(e));if(i?.$type===`DeploymentViewRulePredicate`||a){if(!Oe(e,isRelationExpr)){if(F.isModelRef(r)){n(`error`,`Deployment view predicate must reference deployment model`,{node:e});return}if(F.isDeploymentRef(r)&&I.isInsideInstanceRef(r.ref)){n(`error`,`Must reference deployment nodes or instances, but not internals`,{node:e});return}}T(e.selector)&&!isDeploymentNode$1(e.ref.value?.ref)&&n(`warning`,`Selector '${e.selector}' applies to deployment nodes only, ignored here`,{node:e,property:`selector`});return}if(i?.$type===`DynamicViewIncludePredicate`)switch(!0){case F.isElementKindExpr(r):case F.isElementTagExpr(r):case F.isWildcard(r):n(`warning`,`Predicate is ignored, as not supported in dynamic views`,{node:e});return}})},checkIncomingRelationExpr=e=>tryOrLog((e,t)=>{e.to.$type===`WildcardExpression`&&!isInOutRelationExpr(e.$container)&&O(et(e,isElementView$1)?.viewOf)&&t(`warning`,`Predicate is ignored as it concerns all relationships`,{node:e})}),checkOutgoingRelationExpr=e=>tryOrLog((e,t)=>{if(getViewRulePredicateContainer(e)?.$type===`ViewRulePredicate`&&e.$container.$type!==`DirectedRelationExpr`&&e.from.$type===`WildcardExpression`){let n=et(e,isElementView$1);n&&O(n.viewOf)&&t(`warning`,`Predicate is ignored as it concerns all relationships`,{node:e})}}),checkRelationExpr=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,n)=>{let r=et(e,isDeploymentViewRulePredicate);if(!r||r.isInclude!==!0)return;let i=x(e),a=t.forDocument(i),o=xr.unwrap(a.parseRelationExpr(e)),s=`Model reference is allowed in exclude predicate only`;if(xr.isDirect(o)){(_r.isModelRef(o.source)||_r.isModelRef(o.target))&&n(`error`,s,{node:e});return}let c;if(c=xr.isIncoming(o)?o.incoming:xr.isOutgoing(o)?o.outgoing:o.inout,_r.isModelRef(c)){n(`error`,s,{node:e});return}})},checkRelationExprWith=e=>tryOrLog((e,t)=>{let n=getViewRulePredicateContainer(e);if(!(!n||n.$type==`DynamicViewIncludePredicate`)&&!n.isInclude){t(`error`,`Invalid usage inside "exclude"`,{node:e});return}});var LikeC4DocumentValidator=class extends ce{services;constructor(e){super(e),this.services=e}async validateDocument(e,t,n){return this.services.shared.workspace.ProjectsManager.isExcluded(e)?[]:await super.validateDocument(e,t,n)}};Pe();const dl=L(isImportsFromPoject,isImported,isGlobals,isGlobalPredicateGroup,isGlobalDynamicPredicateGroup,isGlobalStyle,isGlobalStyleGroup,isFqnExprWith,isRelationExprWith,isFqnExpr,isRelationExpr,isDynamicViewParallelSteps,isDynamicStepChain,isDynamicStepSingle,isDeploymentViewRule,isDeploymentViewRulePredicate,isExpressionV2,isRelationExpr,isFqnRefExpr,isViewProperty,isStyleProperty,isTags,isViewRule,isDynamicViewRule,isLikeC4View,isViewRuleStyleOrGlobalRef,isDeployedInstance,isDeploymentNode$1,isDeploymentRelation,isRelationshipStyleProperty,isDynamicViewDisplayVariantProperty,isMetadataBody,isMetadataProperty,isRelation,isRelationBody,isElementProperty,isStringProperty,isNavigateToProperty,isElement,isElementBody,isElementStyleProperty,isElementRef,isExtendElement,isExtendElementBody,isExtendDeployment,isExtendDeploymentBody,isExtendRelation,isExtendRelationBody,isSpecificationElementKind,isSpecificationRelationshipKind,isSpecificationDeploymentNodeKind,isSpecificationTag,isSpecificationColor,isSpecificationRule,isExpressions,isColorLiteral),findInvalidContainer=e=>{let t=e;for(;t&&!isLikeC4Grammar(t);){if(dl(t))return t;t=t.$container}};function checksFromDiagnostics(e){let t=e.state>=y.Validated?e.diagnostics?.filter(e=>e.severity===he.Error)??[]:[],n=new WeakSet;for(let{node:e}of t){if(O(e)||n.has(e))continue;n.add(e);let t=findInvalidContainer(e);t&&n.add(t)}let isValid=e=>!n.has(e);return{isValid,invalidNodes:n}}function registerValidationChecks(e){G.debug(`registerValidationChecks`),e.validation.ValidationRegistry.register({DeployedInstance:deployedInstanceChecks(e),DeploymentNodeKind:checkDeploymentNodeKind(e),DeploymentNode:deploymentNodeChecks(e),DeploymentRelation:deploymentRelationChecks(e),ExtendDeployment:extendDeploymentChecks(e),ExtendRelation:extendRelationChecks(e),FqnRefExpr:checkFqnRefExpr(e),RelationExpr:checkRelationExpr(e),OpacityProperty:opacityPropertyRuleChecks(e),IconProperty:iconPropertyRuleChecks(e),SpecificationRule:checkSpecificationRule(e),Model:checkModel(e),Globals:checkGlobals(e),GlobalPredicateGroup:checkGlobalPredicate(e),GlobalDynamicPredicateGroup:checkGlobalPredicate(e),GlobalStyleId:checkGlobalStyleId(e),DynamicStepSingle:dynamicViewStepSingle(e),DynamicStepChain:dynamicViewStepChain(e),LikeC4View:viewChecks(e),Element:checkElement(e),ElementRef:checkElementRef(e),ElementKind:checkElementKind(e),Relation:relationChecks(e),RelationBody:checkRelationBody(e),Tag:checkTag(e),FqnExprWith:checkFqnExprWith(e),RelationExprWith:checkRelationExprWith(e),RelationshipKind:checkRelationshipKind(e),IncomingRelationExpr:checkIncomingRelationExpr(e),OutgoingRelationExpr:checkOutgoingRelationExpr(e),ImportsFromPoject:checkImportsFromPoject(e),ColorLiteral:colorLiteralRuleChecks(e),DynamicViewDisplayVariantProperty:dynamicViewDisplayVariant(e),ViewRuleRank:viewRuleRankChecks(e)});let t=e.shared.lsp.Connection;t&&ci(()=>{e.shared.workspace.DocumentBuilder.onUpdate((e,n)=>{for(let e of n)G.debug(`clear diagnostics for deleted ${e.path}`),t.sendDiagnostics({uri:e.toString(),diagnostics:[]}).catch(e=>G.error(loggable(e)))})})}const fl=G.getChild(`parser`);function toSingleLine(e){if(e==null)return;let t=removeIndent(e);return Mn(t)?t.split(`
|
|
81
|
+
`));let c=this.services.likec4.LastSeen.model(t.projectId)?.findElement(r.id),u=c&&this.getElementModelHover(c,t.projectId);return o.push(u||`
|
|
82
|
+
<small>_Model not processed yet, open any view to trigger_</small> `),{contents:{kind:`markdown`,value:o.join(`
|
|
83
|
+
`)}}}getElementModelHover(e,t){let r=[],o=[...e.incoming(`direct`)].length,s=[...e.outgoing(`direct`)].length;(o>0||s>0)&&r.push(tl,`<small>**${o}** incoming, **${s}** outgoing relationships</small> `);let printViewLink=e=>{let r=[e.id,t],o=C.parse(`command:likec4.open-preview?${encodeURIComponent(JSON.stringify(r))}`);return` - [${e.titleOrId}](${o})`},c=[...e.scopedViews()].map(printViewLink);c.length>0&&r.push(tl,`<small>Element views:</small>`,...c);let u=[...e.views()].map(t=>t.isScopedElementView()&&t.viewOf===e?null:printViewLink(t)).filter(D);if(u.length>0){let e=c.length>0?`Also appears in views:`:`Appears in views:`;r.push(c.length>0?``:tl,`<small>${e}</small>`,...u,` `)}return r.length>0?r.join(`
|
|
84
|
+
`):void 0}getDeploymentNodeHover(e){let t=Te(e),r=this.parser.forDocument(t).parseDeploymentNode(e),o=[r.id+` `];r.title!==e.name&&o.push(`### ${r.title}`),o.push("deployment node `"+r.kind+"` ");let s=Kr(r);return s&&o.push(``,s.md??s.txt),{contents:{kind:`markdown`,value:o.join(`
|
|
85
|
+
`)}}}getDeployedInstanceHover(e){let t=Te(e),r=this.parser.forDocument(t).parseDeployedInstance(e),[o,s]=z.isImportRef(r.element)?[r.element.project,r.element.model]:[t.likec4ProjectId,r.element.model],c=o?this.locator.getParsedElement(s,o):this.locator.getParsedElement(s),u=[r.id+` `,`instance of \`${z.flatten(r.element)}\``];return c&&u.push(`### ${c.element.title}`,"element kind `"+c.element.kind+"` "),{contents:{kind:`markdown`,value:u.join(`
|
|
86
|
+
`)}}}},LikeC4CodeActionProvider=class{getCodeActions(e,t){}};Pe();const nl=q.getChild(`SemanticTokenProvider`),rl={...Qe},il={...Ee};function createSemanticTypeMethods(e){let t=[],r=new Proxy({},{get(o,s){if(s===`modifier`)return e=>(t.push(e),r);if(s in il)return t.push(il[s]),r;if(s in rl)return()=>e(rl[s],t);throw Error(`Unknown semantic token type or modifier: ${s}`)}});return r}const al=`Stop Highlighting`,stopHighlight=()=>{throw al};var LikeC4SemanticTokenProvider=class extends ze{services;rules=[];constructor(e){super(e),this.services=e,this.initRules()}initRules(){this.rules=[];let when=(e,t)=>{let r={predicate:e,highlightFn:t};this.rules.push(r)};when(isRelationshipKind,e=>{e.property(`name`).function()}),when(R(isRelation,isOutgoingRelationExpr,isDeploymentRelation),e=>{e.property(`kind`).function()}),when(isLibIcon,e=>{e.property(`name`).definition.function(),stopHighlight()}),when(R(isNavigateToProperty,isRelationNavigateToProperty),e=>{e.property(`value`).readonly.definition.interface()}),when(isWildcardExpression,e=>{e.cst().readonly.definition.variable(),stopHighlight()}),when(isFqnRefExpr,e=>{e.node.selector&&(e.node.ref.parent?e.property(`selector`).property():e.property(`selector`).readonly.definition.variable())}),when(isTagRef,e=>{e.cst().type()}),when(isRelationKindDotRef,e=>{e.cst().function()}),when(isWhereRelationKind,e=>{k(e.node.value?.$refText)&&e.property(`value`).function()}),when(R(isWhereElementMetadata,isWhereRelationMetadata,isWhereRelationParticipantMetadata),e=>{e.keyword(`metadata`).keyword(),e.property(`key`).property()}),when(R(isWhereElementTag,isWhereElementKind,isWhereRelationTag,isWhereRelationKind),e=>{k(e.node.value)&&e.property(`value`).readonly.definition.type()}),when(R(isWhereRelationParticipantKind,isWhereRelationParticipantTag,isWhereRelationParticipantMetadata),e=>{e.property(`participant`).keyword()}),when(isElementKindExpression,e=>{k(e.node.kind)&&e.property(`kind`).definition.type()}),when(R(isGlobalStyleGroup,isGlobalStyle),e=>{e.property(`id`).readonly.definition.variable()}),when(isViewRuleGlobalStyle,e=>{e.property(`style`).readonly.definition.variable()}),when(R(isGlobalPredicateGroup,isGlobalDynamicPredicateGroup),e=>{e.property(`name`).readonly.definition.variable()}),when(isViewRuleGlobalPredicateRef,e=>{e.property(`predicate`).readonly.definition.variable()}),when(isElementTagExpression,e=>{k(e.node.tag)&&e.property(`tag`).definition.type()}),when(R(isFqnRef,isStrictFqnRef),e=>{if(e.node.parent){e.property(`value`).property();return}let t=e.node.value.$refText;t!==`this`&&t!==`it`&&e.property(`value`).readonly.definition.variable()}),when(isStrictFqnElementRef,e=>{e.node.parent?e.property(`el`).property():e.property(`el`).readonly.definition.variable()}),when(isSpecificationColor,e=>{e.keyword(`color`).keyword(),e.property(`name`).readonly.declaration.type()}),when(isSpecificationTag,e=>{k(e.node.color)&&e.keyword(`color`).property()}),when(R(isSpecificationElementKind,isSpecificationRelationshipKind,isSpecificationDeploymentNodeKind),e=>{e.property(`kind`).readonly.declaration.type()}),when(isTag,e=>{e.property(`name`).definition.type()}),when(isOpacityProperty,e=>{e.property(`value`).number()}),when(isIconProperty,e=>{if(e.node.libicon||e.node.value===`none`){e.property(e.node.libicon?`libicon`:`value`).defaultLibrary.enum();return}e.property(`value`).string()}),when(isLinkProperty,e=>{k(e.node.value)&&e.property(`value`).string()}),when(R(isColorProperty,isIconColorProperty),e=>{k(e.node.customColor)&&e.property(`customColor`).enum(),k(e.node.themeColor)&&e.property(`themeColor`).enum()}),when(e=>isAnyProperty(e)&&!R(isMetadataProperty,isElementStyleProperty,isRelationStyleProperty)(e)&&k(e.key),e=>e.property(`key`).property()),when(R(isShapeProperty,isArrowProperty,isLineProperty,isBorderProperty,isSizeProperty,isIconPositionProperty,isIconSizeProperty,isDynamicViewDisplayVariantProperty),e=>{k(e.node.value)&&e.property(`value`).enum()})}highlightElement(e,t){if(R(isElement,isDeploymentNode$1,isDeployedInstance)(e))return this.highlightNameAndKind(e);if(isLikeC4View(e))return this.highlightView(e);let r;for(let{predicate:t,highlightFn:o}of this.rules)if(t(e))try{r??=this.mark(e),o(r)}catch(t){if(t===al)return`prune`;nl.warn(`Error highlighting node of type ${e._type}`,{error:t})}}highlightNameAndKind(e){if(this.mark(e).property(`name`).declaration.readonly.variable(),isDeployedInstance(e)||this.mark(e).property(`kind`).keyword(),isElement(e)){e.props.length>0&&this.mark(e).property(`props`).string();return}e.title&&this.mark(e).property(`title`).string()}highlightView(e){e.name&&this.mark(e).property(`name`).modifier(`local`).declaration.readonly.interface()}mark(e){let cst=t=>createSemanticTypeMethods((r,o)=>this.highlightToken({range:si(t??e.$cstNode,`AST node has no CST node`).range,type:r,modifier:o})),keyword=t=>createSemanticTypeMethods((r,o)=>this.highlightKeyword({node:e,keyword:t,type:r,modifier:o})),property=(t,r)=>createSemanticTypeMethods((o,s)=>this.highlightProperty({node:e,property:t,type:o,modifier:s,...r===void 0?{}:{index:r}}));return{node:e,cst,keyword,property}}};const ol=R(isElement,isExtendElement);var FqnIndex=class extends ADisposable{services;projects;langiumDocuments;documentCache;workspaceCache;logger=q.getChild(`fqn-index`);constructor(e){super(),this.services=e,this.langiumDocuments=e.shared.workspace.LangiumDocuments,this.projects=e.shared.workspace.ProjectsManager,this.documentCache=new Yr(e=>this.createDocumentIndex(e)),this.workspaceCache=new ae(e.shared,w.IndexedContent),this.onDispose(e.shared.workspace.DocumentBuilder.onDocumentPhase(w.IndexedContent,e=>{isLikeC4UserDocument(e)&&this.documentCache.delete(e)}))}documents(e){return this.langiumDocuments.projectDocuments(e).filter(e=>e.state>=w.IndexedContent)}get(e){return e.state<w.IndexedContent&&this.logger.warn(`document {doc} is in state {state}, expected at least IndexedContent ({expect}). This may lead to incorrect FQN resolution.`,{doc:S.basename(e.uri),state:e.state,expect:w.IndexedContent}),this.documentCache.get(e)}resolve(e){return e.$type===`Imported`?this.getFqn(e.imported.ref):e.$type===`Element`?this.getFqn(e):this.services.likec4.DeploymentsIndex.getFqn(e)}getFqn(e){V(isElement(e)||isDeploymentElement(e));let t=jc.readId(e);if(k(t))return t;let r=Te(e);return r.state<w.IndexedContent&&this.logger.warn(`document {doc} is not yet indexed, creating on the fly to resolve FQN for element {el}`,{el:e.name??e.$type,doc:S.basename(r.uri)}),V(isLikeC4LangiumDocument(r)),this.get(r),Gr(jc.readId(e),`Element fqn must be set, invalid state`)}byFqn(e,t){return st(this.workspaceCache.get(`${e}:fqn:${t}`,()=>this.documents(e).flatMap(e=>this.get(e).byFqn(t)).toArray()))}rootElements(e){return st(this.workspaceCache.get(`${e}:rootElements`,()=>{let t=new U;for(let r of this.documents(e))for(let e of this.get(r).rootElements())t.set(e.name,e);return uniqueByName(t)}))}directChildrenOf(e,t){return st(this.workspaceCache.get(`${e}:directChildrenOf:${t}`,()=>{let r=new U;for(let o of this.documents(e))for(let e of this.get(o).children(t))r.set(e.name,e);return uniqueByName(r)}))}uniqueDescedants(e,t){return st(this.workspaceCache.get(`${e}:uniqueDescedants:${t}`,()=>{let r=new U,o=new U;for(let s of this.documents(e)){let e=this.get(s);for(let o of e.children(t))r.set(o.name,o);for(let r of e.descendants(t))o.set(r.name,r)}let s=uniqueByName(r),c=[...o.associations()].flatMap(([e,t])=>t.length===1&&!r.has(e)?t:[]);return[...s,...fi(c)]}))}createDocumentIndex(e){let t=e.parseResult.value.models.flatMap(e=>e.elements.filter(ol));if(t.length===0)return sl.EMPTY;let r=e.likec4ProjectId??this.projects.ownerProjectId(e),o=[],s=new U,c=new U,u=new U,d=this.services.workspace.AstNodeDescriptionProvider,createAndSaveDescription=(t,o,s)=>{let c=Object.assign(d.createDescription(t,o,e),{id:s,likec4ProjectId:r});return jc.writeId(t,s),u.set(s,c),c};function traverseElement(e,t){let r=cr(e.name,t),u=createAndSaveDescription(e,e.name,r);t?s.set(t,u):o.push(u);let d=P(e.body?.elements??[],ol);if(!N(d,1))return[u];let p=A(d,e=>traverseElement(e,r));for(let e of p)c.set(r,e);return[u,...p]}function traverseExtendElement(e){let t=readStrictFqn(e.element),r=F(e.body?.elements??[],P(isElement),A(e=>traverseElement(e,t)));if(r.length!==0)for(let e of[t,...Xr(t)])for(let t of r)c.set(e,t)}for(let r of t)try{if(isExtendElement(r)){traverseExtendElement(r);continue}traverseElement(r,null)}catch(t){this.logger.warn(`Error while traversing element {el} in document {doc}`,{el:r.$type,doc:S.basename(e.uri),error:t})}return new sl(o,s,c,u,r)}};function uniqueByName(e){return[...e.associations()].flatMap(([e,t])=>t.length===1?t:[]).sort((e,t)=>Qr(e.name,t.name))}var sl=class DocumentFqnIndex{_rootElements;_children;_descendants;_byfqn;projectId;static EMPTY=new DocumentFqnIndex([],new U,new U,new U,Rc.DefaultProjectId);constructor(e,t,r,o,s){this._rootElements=e,this._children=t,this._descendants=r,this._byfqn=o,this.projectId=s}rootElements(){return this._rootElements}byFqn(e){return this._byfqn.get(e)??[]}children(e){return this._children.get(e)??[]}descendants(e){return this._descendants.get(e)??[]}};const cl=Fr(isDeploymentElement,isExtendDeployment);var DeploymentsIndex=class extends FqnIndex{services;Names;logger=q.getChild(`deployments-index`);constructor(e){super(e),this.services=e,this.Names=e.references.NameProvider}createDocumentIndex(e){let t=e.parseResult.value.deployments.flatMap(e=>e.elements.filter(cl));if(t.length===0)return sl.EMPTY;let r=e.likec4ProjectId??this.projects.ownerProjectId(e),o=[],s=new U,c=new U,u=new U,d=this.Names,p=this.services.workspace.AstNodeDescriptionProvider,createAndSaveDescription=(t,o,s)=>{let c={...p.createDescription(t,o,e),id:s,likec4ProjectId:r};return jc.writeId(t,s),u.set(s,c),c};function traverseElement(e,t){let r=d.getName(e);if(!k(r))return[];let u=gr(r,t),p=createAndSaveDescription(e,r,u);if(t?s.set(t,p):o.push(p),isDeployedInstance(e))return[p];let m=P(e.body?.elements??[],cl);if(!N(m,1))return[p];let h=A(m,e=>traverseElement(e,u));for(let e of h)c.set(u,e);return[p,...h]}function traverseExtend(e){let t=readStrictFqn(e.deploymentNode),r=F(e.body?.elements??[],P(cl),A(e=>traverseElement(e,t)));if(r.length!==0)for(let e of[t,...Er(t)])for(let t of r)c.set(e,t)}for(let r of t)try{if(isExtendDeployment(r)){traverseExtend(r);continue}traverseElement(r,null)}catch(t){this.logger.warn(`Error while traversing element {el} in document {doc}`,{el:r.$type,doc:S.basename(e.uri),error:t})}return new sl(o,s,c,u,r)}};const ll=/^(aws|azure|gcp|tech):(.+)$/;function deriveTechnologyFromIcon(e){if(!e)return;let t=ll.exec(e);if(t)return t[2].replace(/-icon$/,``).split(`-`).map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(` `)}var MergedSpecification=class{specs={elements:{},deployments:{},relationships:{},colors:{}};tags;globals={predicates:{},dynamicPredicates:{},styles:{}};imports=new U(Set);projectId;inferTechFromIcon;constructor(e,t){let r={},o=[];for(let t of e){let{c4Specification:e,c4Globals:s,c4Imports:c}=t,u=t.likec4ProjectId;D(u)&&(o.length===0||o[0]!==u)&&o.push(t.likec4ProjectId),Object.assign(r,e.tags),Object.assign(this.specs.elements,e.elements),Object.assign(this.specs.relationships,e.relationships),Object.assign(this.specs.colors,e.colors),Object.assign(this.specs.deployments,e.deployments),Object.assign(this.globals.predicates,s.predicates),Object.assign(this.globals.dynamicPredicates,s.dynamicPredicates),Object.assign(this.globals.styles,s.styles);for(let[e,t]of c)this.imports.set(e,t)}this.tags=or(r),this.projectId=wn(o),this.inferTechFromIcon=t?.inferTechFromIcon??!0}toModelElement=({tags:e,links:t,style:r,id:o,kind:s,title:c,description:u,technology:d,summary:p,metadata:m})=>{try{let h=this.specs.elements[s];if(!h)return q.warn`No kind '${s}' found for ${o}`,null;d??=h.technology,u??=h.description,p??=h.summary,t??=h.links,Yt(c)&&(c=h.title||oi(o)),h.tags&&ri(h.tags)&&(e=e?En([...h.tags,...e]):h.tags);let g=fr({...h.style,...r});return!d&&this.inferTechFromIcon&&(d=deriveTechnologyFromIcon(g.icon)),fr({metadata:m&&!j(m)?m:void 0,notation:h.notation,style:g,links:t,tags:e,summary:p,technology:d,description:u,title:c,kind:s,id:o})}catch(e){logWarnError(e)}return null};toModelRelation=({astPath:e,source:t,target:r,kind:o,links:s,id:c,...u})=>{if(D(o)&&this.specs.relationships[o]){let{multiple:e,...d}=this.specs.relationships[o];return{...d,...u,...s&&{links:s},source:t,target:r,kind:o,id:c}}return{...s&&{links:s},...u,source:t,target:r,id:c}};toDeploymentElement=e=>{if(`element`in e&&!(`kind`in e))return{...e,element:L.flatten(e.element)};if(`element`in e)return q.warn`Invalid ParsedAstDeployment ${e.id}, has both element and kind properties`,null;try{let t=this.specs.deployments[e.kind];if(!t)return q.warn`No kind ${e.kind} found for ${e.id}`,null;let{id:r,style:o,title:s,...c}=e;return s=s===oi(e.id)&&t.title?t.title:s,fr({...t,...c,title:s,style:fr({...t.style,...o}),id:r})}catch(e){logWarnError(e)}return null};toDeploymentRelation=({astPath:e,source:t,target:r,kind:o,links:s,id:c,...u})=>{if(D(o)&&this.specs.relationships[o]){let{multiple:e,...d}=this.specs.relationships[o];return{...d,...u,...s&&{links:s},source:t,target:r,kind:o,id:c}}return{...s&&{links:s},...u,source:t,target:r,id:c}}},LastSeenArtifacts=class extends ADisposable{#e=new Map;#t=new Map;#n=new Map;constructor(e){super();let clearCache=()=>{this.#e.clear(),this.#t.clear(),this.#n.clear()};this.onDispose(e.shared.workspace.WorkspaceManager.onForceCleanCache(clearCache),b.create(clearCache))}rememberSpecification(e){return e.projectId&&this.#e.set(e.projectId,e),e}rememberModel(e){let t=e.projectId,r=e.$styles,o=this.#t.get(t);return(!o||!o.equals(r))&&this.#t.set(t,r),this.#n.set(t,e),e}specification(e){return this.#e.get(e)}styles(e){return this.#t.get(e)}model(e){return this.#n.get(e)}};function assignNavigateTo(e){let t=new Map;for(let r of e)if(zr(r)&&r.viewOf&&M(r.extends)){let e=t.get(r.viewOf)??[];e.push(r.id),t.set(r.viewOf,e)}for(let{id:r,nodes:o}of e)for(let e of o){let o=e.modelRef;if(e.navigateTo||!o)continue;let s=rn(t.get(o)??[],e=>e!==r);s&&(e.navigateTo=s)}return e}var MergedExtends=class{mergedData=new Map;mergeMetadata(e,t){let r={...e};for(let[e,o]of Object.entries(t)){let t=r[e];if(t===void 0){r[e]=o;continue}let s=Array.isArray(t)?t:[t],c=Array.isArray(o)?o:[o],u=En([...s,...c]);r[e]=u.length===1?u[0]:u}return r}merge(e){for(let t of e){let{id:e,links:r,tags:o,metadata:s}=t,c=this.mergedData.get(e)??{links:[],tags:[],metadata:{}};r&&c.links.push(...r),o&&(c.tags=En([...c.tags,...o])),s&&(c.metadata=this.mergeMetadata(c.metadata,s)),this.mergedData.set(e,c)}}applyExtended(e){let t=this.mergedData.get(e.id);if(!t)return e;let r=t.links;e.links&&e.links.length>0&&(r=[...e.links,...r]);let o=t.tags;e.tags&&e.tags.length>0&&(o=En([...e.tags,...o]));let s=t.metadata;return e.metadata&&(s=this.mergeMetadata(e.metadata,t.metadata)),{...e,tags:N(o,1)?o:null,links:N(r,1)?r:null,...!j(s)&&{metadata:s}}}};function buildModelData(e,t,r){let o=new MergedSpecification(r,{inferTechFromIcon:t.config.inferTechnologyFromIcon??!0});o.projectId===t.id&&e.likec4.LastSeen.rememberSpecification(o);let s=on(o.specs.colors,e=>sr(e.color)),c=new Set,u=new MergedExtends,d=new MergedExtends,p=r.flatMap(e=>e.c4ExtendRelations),m=new Set,scanMetadataKeys=e=>{e?.metadata&&Pn(e.metadata).forEach(e=>c.add(e))},h=F(r,A(e=>(u.merge(e.c4ExtendElements),I(e.c4Elements,o.toModelElement))),P(k),pi,un((e,t)=>{let r=ui(t.id);return r&&M(e[r])?(q.debug`No parent found for ${t.id}`,e):(e[t.id]=u.applyExtended(t),scanMetadataKeys(e[t.id]),e)},{})),g=F(r,A(e=>I(e.c4Relations,o.toModelRelation)),P(e=>{if(!e)return!1;let t=L.flatten(e.source),r=L.flatten(e.target);return M(h[t])&&!Br(t)||M(h[r])&&!Br(r)?(q.debug`Invalid relation ${e.id}
|
|
87
|
+
source: ${t} resolved: ${!!h[t]}
|
|
88
|
+
target: ${r} resolved: ${!!h[r]}\n`,!1):!0}),I(e=>{let t=stringHash$1(`extend-relation`,L.flatten(e.source),L.flatten(e.target),e.kind??`default`,e.title??``),r=p.filter(e=>e.id===t);if(r.length===0)return e;r.forEach(e=>m.add(e.astPath));let o=e.tags?[...e.tags]:[],s=e.links?[...e.links]:[],c=e.metadata?{...e.metadata}:{};for(let e of r){if(e.tags&&o.push(...e.tags),e.links)for(let t of e.links)s.some(e=>e.url===t.url&&(e.title||``)===(t.title||``))||s.push(t);if(e.metadata)for(let[t,r]of Object.entries(e.metadata)){let e=c[t];if(e===void 0)c[t]=r;else{let o=Array.isArray(e)?e:[e],s=Array.isArray(r)?r:[r],u=En([...o,...s]);c[t]=u.length===1?u[0]:u}}}let u=En(o),d=s;return{...e,...N(u,1)&&{tags:u},...N(d,1)&&{links:d},...!j(c)&&{metadata:c}}}),nn(scanMetadataKeys),Jt(jn(`id`))),_=F(r,A(e=>(d.merge(e.c4ExtendDeployments),I(e.c4Deployments,o.toDeploymentElement))),P(k),pi,un((e,t)=>{let r=ui(t.id);return r&&M(e[r])?(q.debug`No parent found for deployment element ${t.id}`,e):(e[t.id]=Ir(t)?d.applyExtended(t):t,scanMetadataKeys(e[t.id]),e)},{})),v=F(r,A(e=>I(e.c4DeploymentRelations,o.toDeploymentRelation)),P(e=>e?M(_[e.source.deployment])||M(_[e.target.deployment])?(q.debug`Invalid deployment relation ${e.id}
|
|
89
|
+
source: ${e.source.deployment} resolved: ${!!_[e.source.deployment]}
|
|
90
|
+
target: ${e.target.deployment} resolved: ${!!_[e.target.deployment]}\n`,!1):!0:!1),un((e,t)=>Xt(e[t.id])?(q.debug`Duplicate deployment relation ${t.id}`,e):(scanMetadataKeys(t),e[t.id]=t,e),{}));function toC4View(e){let r=e.uri.toString();return e=>{let{id:o,title:s,description:c,astPath:u,...d}=e;return e[dr]===`element`&&M(s)&&`viewOf`in e&&(s=h[e.viewOf]?.title??null),M(s)&&o===`index`&&(s=`Landscape view`),{...mn(d,e=>e===void 0),[ur]:`parsed`,sourcePath:S.relative(t.folderUri,r),docUri:r,description:c,title:s,id:o}}}let y=r.flatMap(e=>I(e.c4Views,toC4View(e)));if(y.some(e=>e.id===`index`)||y.unshift({[ur]:`parsed`,[dr]:`element`,id:`index`,title:`Landscape view`,description:null,rules:[{include:[{wildcard:!0}]}]}),t.config.implicitViews===!0){let e=new Set;for(let t of y)t[dr]===`element`&&`viewOf`in t&&t.viewOf&&e.add(t.viewOf);let t=new Set(y.map(e=>e.id));for(let r of Pn(h)){if(e.has(r)||Br(r))continue;let o=`__`+r.replaceAll(`.`,`_`);t.has(o)||(t.add(o),y.push({[ur]:`parsed`,[dr]:`element`,id:o,viewOf:r,title:`Auto / ${(h[r]?.title??r).replaceAll(`
|
|
91
|
+
`,` `)}`,description:null,rules:[{include:[{wildcard:!0}]}]}))}}let b=F(y,Jt(jn(`id`)));y.some(pr)&&(b=Li(b));for(let e of p)m.has(e.astPath)||q.warn(`Relation extend at ${e.astPath} does not match any relation in the model`);return{data:{[ur]:`parsed`,projectId:t.id,project:fr({id:t.id,title:t.config.title??t.config.name,styles:t.config.styles,manualLayouts:t.config.manualLayouts,inferTechnologyFromIcon:t.config.inferTechnologyFromIcon}),specification:{tags:o.tags,elements:o.specs.elements,relationships:on(o.specs.relationships,({notation:e,technology:t,...r})=>({...e&&{notation:e},...t&&{technology:t},style:r})),deployments:o.specs.deployments,...c.size>0&&{metadataKeys:[...c].sort(Qr)},customColors:s},elements:h,relations:g,globals:o.globals,views:b,deployments:{elements:_,relations:v},imports:{}},imports:o.imports}}const Z=q.getChild(`builder`);var DefaultLikeC4ModelBuilder=class extends ADisposable{services;projects;parser;listeners=[];cache;DocumentBuilder;manualLayouts;mutex;lastSeen;constructor(e){super(),this.services=e,this.projects=e.shared.workspace.ProjectsManager,this.parser=e.likec4.ModelParser,this.DocumentBuilder=e.shared.workspace.DocumentBuilder,this.mutex=e.shared.workspace.WorkspaceLock,this.manualLayouts=e.shared.workspace.ManualLayouts,this.lastSeen=e.likec4.LastSeen,this.cache=new ProjectModelCache(e),this.onDispose(this.cache,b.create(()=>{this.listeners.length=0}),this.DocumentBuilder.onUpdate((e,t)=>{t.length>0&&this.notifyListeners(t)}),e.shared.workspace.WorkspaceManager.onForceCleanCache(()=>{this.clearCache()}),this.manualLayouts.onManualLayoutUpdate(({projectId:e})=>{this.notifyListeners(e)}));let t=dn(Zt(),P(e=>isNotLikeC4Builtin(e)&&!this.projects.isExcluded(e)),I(e=>e.uri));this.onDispose(this.DocumentBuilder.onBuildPhase(w.Validated,(e,r)=>{let o=t(e);o.length>0&&this.notifyListeners(o)})),Z.debug`created`}unsafeSyncParseModelData(e){return this.cache.parsedData(e,()=>{let t=Z.getChild(e);try{let r=this.projects.getProject(e),o=this.documents(e);return o.length===0?(t.trace`unsafeSyncParseModelData: ${`skipped due to no documents`}`,null):(t.trace`unsafeSyncParseModelData: ${`completed`}`,buildModelData(this.services,r,o))}catch(t){return Z.warn(`unsafeSyncParseModelData failed for project ${e}`,{err:t}),null}})}unsafeSyncJoinedModelData(e){return this.cache.parsedJoinedData(e,()=>{let t=Z.getChild(e),r=this.unsafeSyncParseModelData(e);if(!r)return null;if(r.imports.size===0)return t.trace(`unsafeSyncJoinedModelData: no imports`),r.data;t.debug(`unsafeSyncJoinedModelData: processing imports`);let o=[...r.imports.associations()].reduce((e,[t,r])=>{if(r.size===0)return e;let o=this.unsafeSyncParseModelData(t);if(o){let s=[...r].flatMap(e=>o.data.elements[e]??[]);N(s,1)&&(e[t]=structuredClone(s))}return e},{});return{...r.data,imports:o}})}async parseModel(e,t){return e=this.projects.ensureProjectId(e),await this.mutex.read(async()=>(t?.isCancellationRequested&&await ee(t),this.cache.parsedModel(e,()=>{let t=Z.getChild(e),r=this.unsafeSyncJoinedModelData(e);return r?vi.create(r):(t.debug`parseModel: returning EMPTY`,vi.EMPTY.asParsed)})))}unsafeSyncComputeModel(e,t){return this.cache.computedModel(e,t??null,()=>{let r=Z.getChild(e),o=this.unsafeSyncJoinedModelData(e);if(!o)return e!==Rc.DefaultProjectId&&r.warn`unsafeSyncComputeModel: returning EMPTY`,vi.EMPTY.asComputed;let s=performanceMark(),c=vi.create(o),u=[];for(let e of kn(o.views)){let o=Ii(e,c);if(!o.isSuccess){r.warn(loggable(o.error));continue}t?.views[e.id]&&Object.assign(o.view,{hasManualLayout:!0}),u.push(o.view)}assignNavigateTo(u);let d={...o,manualLayouts:{...t?.views},[wr]:`computed`,views:Jt(u,jn(`id`))};return r.debug(`computeModel${t?` with manual layouts`:``}: {status} in ${s.pretty}`,{status:`completed`}),this.lastSeen.rememberModel(vi.create(d))})}async computeModel(e,t){e=this.projects.ensureProjectId(e);let r=Z.getChild(e);return await this.mutex.read(async()=>{t?.isCancellationRequested&&await ee(t);let o=this.projects.getProject(e),s=await this.manualLayouts.read(o),c=this.unsafeSyncComputeModel(e,s);return c===vi.EMPTY&&e!==Rc.DefaultProjectId&&r.warn(`computeModel returned EMPTY`),c})}onModelParsed(e){return this.listeners.push(e),b.create(()=>{let t=this.listeners.indexOf(e);t>=0&&this.listeners.splice(t,1)})}clearCache(){Z.debug(`clear all caches`),this.cache.clear()}documents(e){return this.parser.documents(e).toArray()}notifyListeners(e){let t;if(Kt(e)){if(t=F(e,tn(e=>this.projects.ownerProjectId(e)),an()),Yt(t))return}else t=[[e,[]]];for(let e of[...this.listeners])for(let[r,o]of t)try{e(r,o)}catch(e){Z.warn(loggable(e))}}},ProjectModelCache=class extends g{constructor(e){super(e=>typeof e==`string`?e:e.id),this.toDispose.push(e.shared.workspace.DocumentBuilder.onDocumentPhase(w.Validated,t=>{let r=e.shared.workspace.ProjectsManager.ownerProjectId(t);this.clear(r)}),e.shared.workspace.DocumentBuilder.onUpdate((t,r)=>{if(r.length>0){let t=e.shared.workspace.ProjectsManager,o=En(I(r,t.ownerProjectId.bind(t)));if(!N(o,1))return;Z.trace`clear project caches for: ${o} (on delete ${r.map(e=>e.fsPath)})`;for(let e of o)this.clear(e)}}))}parsedData(e,t){let r=`parsed-data`,o=this.get(e,r);if(o!==void 0)return Z.trace`cache hit project ${e} key: ${r}`,o;let s=t();return this.set(e,r,s),Z.trace`cache miss project ${e} key: ${r}`,s}parsedJoinedData(e,t){let r=`parsed-joined-data`,o=this.get(e,r);if(o!==void 0)return Z.trace`cache hit project ${e} key: ${r}`,o;let s=t();return this.set(e,r,s),Z.trace`cache miss project ${e} key: ${r}`,s}parsedModel(e,t){let r=`parsed-model`,o=this.get(e,r);if(o!==void 0)return Z.trace`cache hit project ${e} key: ${r}`,o;let s=t();return this.set(e,r,s),Z.trace`cache miss project ${e} key: ${r}`,s}computedModel(e,t,r){let o=t?`computed-model-${t.hash}`:`computed-model`,s=this.get(e,o);if(s!==void 0)return Z.trace`cache hit project ${e} key: ${o}`,s;let c=r();return this.set(e,o,c),Z.trace`cache miss project ${e} key: ${o}`,c}};const{findNodeForKeyword:ul,findNodeForProperty:dl}=Ce,{getDocument:fl,streamAllContents:pl}=Re,ml=q.getChild(`locator`);var LikeC4ModelLocator=class{services;fqnIndex;deploymentsIndex;langiumDocuments;parser;projects;constructor(e){this.services=e,this.fqnIndex=e.likec4.FqnIndex,this.deploymentsIndex=e.likec4.DeploymentsIndex,this.langiumDocuments=e.shared.workspace.LangiumDocuments,this.parser=e.likec4.ModelParser,this.projects=e.shared.workspace.ProjectsManager}documents(e){return this.parser.documents(e)}getParsedElement(...e){try{let t,r;if(e.length===2?(t=e[0],r=e[1]):(t=e[0],r=Nn(t)?this.projects.ensureProjectId():projectIdFrom(t)),Nn(t)){let e=t,o=this.fqnIndex.byFqn(r,e).head();if(!o)return null;let s=this.langiumDocuments.getDocument(o.documentUri),c=this.findParsedElementByFqnIn(e,s);return c&&s?{projectId:r,element:c,document:s}:null}let o=this.fqnIndex.getFqn(t),s=fl(t),c=this.findParsedElementByFqnIn(o,s);return c&&s?{projectId:r,element:c,document:s}:null}catch(e){return ml.debug(loggable(e)),null}}findParsedElementByFqnIn(e,t){if(t)return this.parser.parse(t).c4Elements.find(t=>t.id===e)}locateElement(e,t){let[r,o]=qr(e);r??=this.projects.ensureProjectId(t);let s=this.fqnIndex.byFqn(r,o).head(),c=s?.nameSegment??s?.selectionSegment;return!s||!c?null:{uri:s.documentUri.toString(),range:c.range}}locateDeploymentElement(e,t){let r=this.projects.ensureProjectId(t),o=e,s=this.deploymentsIndex.byFqn(r,o).head(),c=s?.nameSegment??s?.selectionSegment;return!s||!c?null:{uri:s.documentUri.toString(),range:c.range}}locateRelation(e,t){let r=this.projects.ensureProjectId(t);for(let t of this.documents(r)){let r=t.c4Relations.find(t=>t.id===e)??t.c4DeploymentRelations.find(t=>t.id===e);if(!r)continue;let o=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,r.astPath);if(!isRelation(o)&&!isDeploymentRelation(o))continue;let s=o.kind?dl(o.$cstNode,`kind`):void 0;if(s??=o.dotKind?dl(o.$cstNode,`dotKind`):void 0,s??=ul(o.$cstNode,`->`),s??=dl(o.$cstNode,`title`),s??=dl(o.$cstNode,`target`),s??=o.$cstNode,s)return{uri:t.uri.toString(),range:{start:s.range.start,end:s.range.start}}}return null}locateViewAst(e,t){let r=this.projects.ensureProjectId(t);for(let t of this.documents(r)){let r=t.c4Views.find(t=>t.id===e);if(!r)continue;let o=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,r.astPath);if(isLikeC4View(o))return{doc:t,view:r,viewAst:o}}return null}locateView(e,t){let r=this.locateViewAst(e,t);if(!r)return null;let o=r.viewAst,s=o.name?dl(o.$cstNode,`name`):void 0;return s??=ul(o.$cstNode,`view`),s??=o.$cstNode,s?{uri:r.doc.uri.toString(),range:{start:s.range.start,end:s.range.start}}:null}async locateDocumentTags(e,t){let r=this.langiumDocuments.getDocument(e);if(!r||!r.likec4ProjectId)return null;r.state<w.Linked&&(ml.debug(`Waiting for document ${r.uri.path} to be Linked`),await this.services.shared.workspace.DocumentBuilder.waitUntil(w.Linked,r.uri,t));let o=projectIdFrom(r);ml.trace`locate document tags for ${r.uri.fsPath} in project ${o}`;try{let e=this.services.likec4.LastSeen.specification(o)?.tags,t=this.services.likec4.LastSeen.styles(o)??nr.DEFAULT;if(!e)return ml.trace(`No specification or styles found for project ${o}, cannot locate tags for document ${r.uri.fsPath}`),null;let s=F(pl(r.parseResult.value),ni(e=>isTag(e)||isTagRef(e)),hi(),A(r=>{let o,s;try{isTag(r)?(o=r.name,s=r.$cstNode):(o=r.tag.$refText,s=r.tag.$refNode);let c=e[o];return W(c,`Tag ${o} not found in merged specification`),W(s,`Tag ${o} does not have a $cstNode`),{name:o,color:t.tagColor(c.color).fill,range:s.range,isSpecification:isTag(r)}}catch(e){return ml.warn(`Fail on tag ${o}`,{err:e}),[]}}));return ml.debug(`Found ${s.length} tags in document ${r.uri.path}`),s}catch(e){return ml.warn(loggable(e)),null}}locateDynamicViewStep(e){let{doc:t,viewAst:r}=this.locateViewAst(e.view,e.projectId)??{};if(!t||!r)return null;if(!isDynamicView$1(r)||!r.body)return ml.warn(`View ${e.view} is not a dynamic view`),null;let o=this.services.workspace.AstNodeLocator.getAstNodePath(r.body)+e.astPath,s=this.services.workspace.AstNodeLocator.getAstNode(t.parseResult.value,o);if(!s||!isDynamicViewStep(s))return ml.warn(`Failed to locate dynamic view step ${o} in view ${e.view}`),null;let c=s.kind?dl(s.$cstNode,`kind`):void 0;return c??=s.dotKind?dl(s.$cstNode,`dotKind`):void 0,c??=ul(s.$cstNode,`->`),c??=ul(s.$cstNode,`<-`),c??=dl(s.$cstNode,`title`),c??=dl(s.$cstNode,`target`),c??=s.$cstNode,c?{uri:t.uri.toString(),range:{start:c.range.start,end:c.range.start}}:null}};function stripIndent(e){let t=e.match(/^[ \t]*(?=\S)/gm);if(!t)return e;let r=1/0;for(let e of t)r=Math.min(r,e.length);return r===0||r===1/0?e:e.replace(RegExp(`^[ \\t]{${r}}`,`gm`),``)}function dedent(e){return stripIndent(e.replace(/^(?:[ \t]*\r?\n)+|(?:\r?\n[ \t]*)+$/g,``))}const hl=[`this`,`it`,`self`,`super`,`likec4lib`,`global`];function tryOrLog(e){return async function tryOrLogFn(t,r,o){try{let s=e(t,r,o);$t(s)&&await s;return}catch(e){let o=e instanceof Error?e.message:String(e);r(`error`,`Validation failed: ${o}`,{node:t}),q.debug(`Validation failed: ${o}`,{error:e})}}}const{getDocument:gl}=Re,deploymentNodeChecks=e=>{let t=e.likec4.DeploymentsIndex,r=e.references.NameProvider;return tryOrLog((e,o)=>{let s=r.getName(e);if(!s){o(`error`,`DeploymentNode must be named`,{node:e});return}let c=Gr(r.getNameNode(e),`name CstNode not found`).range;hl.includes(s)&&o(`error`,`Reserved word: ${s}`,{node:e,range:c});let u=projectIdFrom(e),d=t.getFqn(e);t.byFqn(u,d).limit(2).toArray().length>1&&o(`error`,`Duplicate node name "${d}"`,{node:e,range:c})})},deployedInstanceChecks=e=>{let t=e.likec4.DeploymentsIndex,r=e.references.NameProvider;return tryOrLog((e,o)=>{let s=r.getName(e);if(!s){o(`error`,`Deployed instance must be named, unique inside node`,{node:e});return}let c=Gr(r.getNameNode(e),`name CstNode not found`).range;hl.includes(s)&&o(`error`,`Reserved word: ${s}`,{node:e,range:c});let u=projectIdFrom(e),d=t.getFqn(e);t.byFqn(u,d).limit(2).toArray().length>1&&o(`error`,`Duplicate instance name "${d}"`,{node:e,range:c})})},deploymentRelationChecks=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,r)=>{if(!e.target?.value?.ref){r(`error`,`DeploymentRelation target '${e.target?.$cstNode?.text??``}' not resolved`,{node:e,property:`target`});return}let o=gl(e),s=t.forDocument(o),c;try{c=s._resolveDeploymentRelationSource(e)}catch(t){q.warn(loggable(t)),r(`error`,`DeploymentRelation source not resolved`,{node:e,property:`source`});return}if(z.isImportRef(c)){r(`error`,`DeploymentRelation cannot refer imported model (not implemented yet)`,{node:e,property:`source`});return}if(z.isModelRef(c)){r(`error`,`DeploymentRelation must refer deployment element`,{node:e,property:`source`});return}let u=s.parseFqnRef(e.target);if(z.isImportRef(u)){r(`error`,`DeploymentRelation cannot refer imported model (not implemented yet)`,{node:e,property:`target`});return}if(z.isModelRef(u)){r(`error`,`DeploymentRelation must refer deployment element`,{node:e,property:`target`});return}Ur(c.deployment,u.deployment)&&r(`error`,`Invalid parent-child relationship`,{node:e})})},extendDeploymentChecks=e=>tryOrLog((e,t)=>{let r=e.deploymentNode.value.ref;(!r||!isDeploymentNode$1(r))&&t(`error`,`ExtendDeployment allows only DeploymentNode`,{node:e,property:`deploymentNode`})}),dynamicViewStepSingle=e=>{let t=e.likec4.FqnIndex;return tryOrLog((e,r)=>{let o=elementRef(e.source),s=o&&t.getFqn(o);s||r(`error`,`Source not found (not parsed/indexed yet)`,{node:e,property:`source`});let c=elementRef(e.target),u=c&&t.getFqn(c);u||r(`error`,`Target not found (not parsed/indexed yet)`,{node:e,property:`target`}),s&&u&&(Nr(s,u)||Nr(u,s))&&r(`error`,`Invalid parent-child relationship`,{node:e})})},dynamicViewStepChain=e=>{let t=e.likec4.FqnIndex;return tryOrLog((e,r)=>{let o=e.source;isDynamicStepSingle(o)&&o.isBackward&&r(`error`,`Invalid chain after backward step`,{node:e});let s=elementRef(e.target);s&&t.getFqn(s)||r(`error`,`Target not found (not parsed/indexed yet)`,{node:e,property:`target`})})},dynamicViewParallelSteps=e=>tryOrLog((e,t)=>{for(let r of e.steps)isDynamicViewParallelSteps(r)&&t(`error`,`Nested parallel blocks are not allowed`,{node:r})}),dynamicViewDisplayVariant=e=>tryOrLog((e,t)=>{if(j(e.value)||e.value!==`diagram`&&e.value!==`sequence`){t(`error`,`Invalid display variant: "diagram" or "sequence" are allowed`,{node:e,property:`value`});return}Oe(e,isDynamicViewBody)||t(`error`,`Display mode can be defined only inside dynamic view`,{node:e})}),{getDocument:_l}=Re,checkElement=e=>{let t=e.likec4.FqnIndex,r=e.workspace.AstNodeLocator;return tryOrLog((e,o)=>{let s=t.getFqn(e);if(!s){o(`error`,`Not indexed element`,{node:e,property:`name`});return}hl.includes(e.name)&&o(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let c=_l(e),u=c.uri,d=r.getAstNodePath(e),p=t.byFqn(projectIdFrom(c),s).filter(e=>e.documentUri!==u||e.path!==d).head();if(p){let t=p.documentUri!==u;o(`error`,`Duplicate element name ${e.name===s?e.name:e.name+` (`+s+`)`}`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:p.nameSegment?.range??p.selectionSegment?.range,uri:p.documentUri.toString()},message:`conflicting element`}]}})}})},checkElementRef=e=>tryOrLog((e,t)=>{isReferenceToDeploymentModel(e.modelElement)&&t(`error`,`Only model elements allowed here`,{node:e,property:`modelElement`})}),{getDocument:vl}=Re,checkImportsFromPoject=e=>{let t=e.shared.workspace.ProjectsManager;return tryOrLog((e,r)=>{if(!t.all.includes(e.project)){r(`error`,`Imported project not found`,{node:e,property:`project`});return}let o=projectIdFrom(vl(e));if(e.project===o){r(`error`,`Imported project cannot be the same as the current project`,{node:e,property:`project`});return}})},opacityPropertyRuleChecks=e=>tryOrLog((e,t)=>{let r=parseFloat(e.value);(isNaN(r)||r<0||r>100)&&t(`warning`,`Value ignored, must be between 0% and 100%`,{node:e,property:`value`})}),iconPropertyRuleChecks=e=>(e,t)=>{let r=e.$container;r.props.some(t=>isIconProperty(t)&&t!==e)&&t(`error`,`Icon must be defined once`,{node:e}),isElementStyleProperty(r)&&isElementBody(r.$container)&&r.$container.props.some(e=>isIconProperty(e))&&t(`warning`,`Redundant as icon defined on element`,{node:e}),e.value?.startsWith(`file://`)&&t(`error`,`Icon URI must not start with file://`,{node:e,property:`value`})},colorLiteralRuleChecks=e=>(e,t)=>{if(e.$type===`HexColor`){if(e.hex===void 0||Nn(e.hex)&&!e.hex.match(/^[a-fA-F0-9]+$/)){t(`error`,`Invalid HEX`,{node:e,property:`hex`});return}let r=Ht(e.hex)?e.hex.toString().length:e.hex.length;r!==6&&r!==3&&r!==8&&t(`error`,`Invalid value "${e.$cstNode?.text}", must be 3, 6 or 8 characters long`,{node:e,property:`hex`});return}if(e.$type===`RGBAColor`){if((!Ht(e.red)||e.red<0||e.red>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`red`}),(!Ht(e.green)||e.green<0||e.green>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`green`}),(!Ht(e.blue)||e.blue<0||e.blue>255)&&t(`error`,`Invalid value, must be between 0 and 255`,{node:e,property:`blue`}),Ht(e.alpha)&&(e.alpha<0||e.alpha>1)&&t(`error`,`Invalid value, must be between 0 and 1`,{node:e,property:`alpha`}),Nn(e.alpha)){let r=parseFloat(e.alpha);(r<0||r>100)&&t(`error`,`Invalid value, must be between 0% and 100%`,{node:e,property:`alpha`})}return}H(e)},relationChecks=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,r)=>{let o=t.forDocument(Te(e)),s=safeCall(()=>o._resolveRelationSource(e));if(!s){r(`error`,`Source not resolved`,{node:e,property:`source`});return}let c=safeCall(()=>o.parseFqnRef(e.target));if(!c){r(`error`,`Target not resolved`,{node:e,property:`target`});return}z.isImportRef(s)&&(z.isImportRef(c)?r(`warning`,`Relationship between imported elements may not be visible in origin projects`,{node:e}):r(`warning`,`Relationship from imported element to local element may not be visible in origin project`,{node:e,property:`source`})),Ur(z.flatten(s),z.flatten(c))&&r(`error`,`Invalid parent-child relationship`,{node:e})})},checkRelationBody=e=>tryOrLog((e,t)=>{e.$container.tags?.values&&e.tags?.values&&t(`error`,`Relation cannot have tags in both header and body`,{node:e.tags})}),extendRelationChecks=e=>{let t=e.likec4.ModelParser,r=new ae(e.shared,w.Linked),calcFingerprint=({source:e,target:t,kind:r,title:o})=>stringHash$1(`extend-relation`,z.flatten(e),z.flatten(t),r??`default`,o??``);function getProjectFingerprints(t){return r.get(t,()=>new Set(F(e.shared.workspace.LangiumDocuments.projectDocuments(t).toArray(),A(e=>e.c4Relations??[]),I(e=>calcFingerprint(e)))))}return tryOrLog((e,r)=>{let o=Te(e),s=t.forDocument(o),c=safeCall(()=>s.parseFqnRef(e.source));if(!c){r(`error`,`Source not resolved`,{node:e,property:`source`});return}let u=safeCall(()=>s.parseFqnRef(e.target));if(!u){r(`error`,`Target not resolved`,{node:e,property:`target`});return}if(!z.isModelRef(c)&&!z.isImportRef(c)){r(`error`,`Source must reference a model element`,{node:e,property:`source`});return}if(!z.isModelRef(u)&&!z.isImportRef(u)){r(`error`,`Target must reference a model element`,{node:e,property:`target`});return}let d=projectIdFrom(o),p=(e.kind??e.dotKind?.kind)?.ref?.name??`default`,{title:m=``}=s.parseBaseProps({},{title:e.title}),h=calcFingerprint({source:c,target:u,kind:p,title:m});getProjectFingerprints(d).has(h)||r(`warning`,`This extend does not match any relation (by source, kind, target, title)`,{node:e})})},checkSpecificationRule=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one specification per document`,{node:e,property:`name`})}),checkModel=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one model per document`,{node:e,property:`name`})}),checkGlobals=e=>tryOrLog((e,t)=>{e.$containerIndex&&e.$containerIndex>0&&t(`warning`,`Prefer one global block per document`,{node:e,property:`name`})}),checkElementKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{hl.includes(e.name)&&r(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let o=projectIdFrom(e),s=t.projectElements(o,Do).filter(t=>t.name===e.name&&t.node!==e).head();if(s){let t=s.documentUri!==Te(e).uri;r(`error`,`Duplicate element kind '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:s.nameSegment.range,uri:s.documentUri.toString()},message:`conflicting definition`}]}})}})},checkDeploymentNodeKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{hl.includes(e.name)&&r(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let o=projectIdFrom(e),s=t.projectElements(o,lo).filter(t=>t.name===e.name&&t.node!==e).head();if(s){let t=s.documentUri!==Te(e).uri;r(`error`,`Duplicate deploymentNode kind '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:s.nameSegment.range,uri:s.documentUri.toString()},message:`conflicting definition`}]}})}})},checkTag=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{let o=e.name,s=projectIdFrom(e),c=t.projectElements(s,`Tag`).filter(t=>t.name===o&&t.node!==e).head();if(c){let t=c.documentUri!==Te(e).uri;r(`error`,`Duplicate tag '${e.name}'`,{node:e,property:`name`,...t&&{relatedInformation:[{location:{range:c.nameSegment.range,uri:c.documentUri.toString()},message:`conflicting definition`}]}})}})},checkRelationshipKind=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{hl.includes(e.name)&&r(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let o=projectIdFrom(e);t.projectElements(o,`RelationshipKind`).filter(t=>t.name===e.name).limit(2).count()>1&&r(`error`,`Duplicate RelationshipKind '${e.name}'`,{node:e,property:`name`})})},checkGlobalPredicate=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{let o=projectIdFrom(e),s=t.projectElements(o,Yo),c=t.projectElements(o,Jo);s.concat(c).filter(t=>t.name===e.name).limit(2).count()>1&&r(`error`,`Duplicate GlobalPredicateGroup or GlobalDynamicPredicateGroup name '${e.name}'`,{node:e,property:`name`})})},checkGlobalStyleId=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{let o=projectIdFrom(e);t.projectElements(o,`GlobalStyleId`).filter(t=>t.name===e.name).limit(2).count()>1&&r(`error`,`Duplicate GlobalStyleId name '${e.name}'`,{node:e,property:`name`})})},yl=/@likec4-generated/,viewChecks=e=>{let t=e.shared.workspace.IndexManager;return tryOrLog((e,r)=>{let o=_e(e.$cstNode,[`BLOCK_COMMENT`]);if(o&&yl.test(o.text)&&r(`warning`,`ManualLayoutV1 is no longer supported; remove this block`,{node:e,range:o.range}),!e.name)return;hl.includes(e.name)&&r(`error`,`Reserved word: ${e.name}`,{node:e,property:`name`});let s=projectIdFrom(e);t.projectElements(s,`LikeC4View`).filter(t=>t.name===e.name).limit(2).count()>1&&r(`error`,`Duplicate view '${e.name}'`,{node:e,property:`name`})})};function collectFqnExprs(e){let t=[],r=e;for(;r;)r.value&&t.push(r.value),r=r.prev;return t.reverse()}const viewRuleRankChecks=e=>tryOrLog((e,t)=>{let r=collectFqnExprs(e.targets);r.length<2&&e.value===`same`&&t(`warning`,`Rank rule should have at least 2 targets`,{node:e,property:`targets`});let o=r.filter(isFqnRefExpr),s=o[0]?.ref?.parent;for(let r=1;r<o.length;r++){let c=o[r];e.value===`same`&&!areSame(s,c?.ref?.parent)&&t(`error`,`All targets must have the same parent rank same`,{node:e,property:`targets`})}});function areSame(e,t){return!e&&!t?!0:!e||!t||e.value.ref!==t.value.ref?!1:areSame(e.parent,t.parent)}const checkFqnExprWith=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,r)=>{let o=getViewRulePredicateContainer(e);if(o?.$type!==`DynamicViewIncludePredicate`&&o?.isInclude!==!0){r(`error`,`Invalid usage inside "exclude"`,{node:e});return}let s=o.$type===`DynamicViewIncludePredicate`,c=t.forDocument(Te(o)),u=lr.unwrap(c.parseFqnExprWith(e).custom.expr);switch(!0){case lr.isWildcard(u)&&s:case lr.isElementKindExpr(u)&&s:case lr.isElementTagExpr(u)&&s:r(`warning`,`Predicate is ignored, as not supported in dynamic views`,{node:e});return;case lr.isWildcard(u):case lr.isModelRef(u):case lr.isDeploymentRef(u):return;case lr.isElementKindExpr(u):case lr.isElementTagExpr(u):r(`error`,`Invalid target (expect reference to specific element)`,{node:e,property:`subject`});return;default:ci(u)}})},checkFqnRefExpr=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,r)=>{let o=t.forDocument(Te(e)).parseFqnRefExpr(e),s=getViewRulePredicateContainer(e),c=isFqnRefInsideDeployment(e)&&!Oe(e,e=>isDeploymentViewRuleStyle(e)||isViewRuleStyle(e));if(s?.$type===`DeploymentViewRulePredicate`||c){if(!Oe(e,isRelationExpr)){if(lr.isModelRef(o)){r(`error`,`Deployment view predicate must reference deployment model`,{node:e});return}if(lr.isDeploymentRef(o)&&L.isInsideInstanceRef(o.ref)){r(`error`,`Must reference deployment nodes or instances, but not internals`,{node:e});return}}k(e.selector)&&!isDeploymentNode$1(e.ref.value?.ref)&&r(`warning`,`Selector '${e.selector}' applies to deployment nodes only, ignored here`,{node:e,property:`selector`});return}if(s?.$type===`DynamicViewIncludePredicate`)switch(!0){case lr.isElementKindExpr(o):case lr.isElementTagExpr(o):case lr.isWildcard(o):r(`warning`,`Predicate is ignored, as not supported in dynamic views`,{node:e});return}})},checkIncomingRelationExpr=e=>tryOrLog((e,t)=>{e.to.$type===`WildcardExpression`&&!isInOutRelationExpr(e.$container)&&M(et(e,isElementView$1)?.viewOf)&&t(`warning`,`Predicate is ignored as it concerns all relationships`,{node:e})}),checkOutgoingRelationExpr=e=>tryOrLog((e,t)=>{if(getViewRulePredicateContainer(e)?.$type===`ViewRulePredicate`&&e.$container.$type!==`DirectedRelationExpr`&&e.from.$type===`WildcardExpression`){let r=et(e,isElementView$1);r&&M(r.viewOf)&&t(`warning`,`Predicate is ignored as it concerns all relationships`,{node:e})}}),checkRelationExpr=e=>{let t=e.likec4.ModelParser;return tryOrLog((e,r)=>{let o=et(e,isDeploymentViewRulePredicate);if(!o||o.isInclude!==!0)return;let s=Te(e),c=t.forDocument(s),u=xr.unwrap(c.parseRelationExpr(e)),d=`Model reference is allowed in exclude predicate only`;if(xr.isDirect(u)){(_r.isModelRef(u.source)||_r.isModelRef(u.target))&&r(`error`,d,{node:e});return}let p;if(p=xr.isIncoming(u)?u.incoming:xr.isOutgoing(u)?u.outgoing:u.inout,_r.isModelRef(p)){r(`error`,d,{node:e});return}})},checkRelationExprWith=e=>tryOrLog((e,t)=>{let r=getViewRulePredicateContainer(e);if(!(!r||r.$type==`DynamicViewIncludePredicate`)&&!r.isInclude){t(`error`,`Invalid usage inside "exclude"`,{node:e});return}});var LikeC4DocumentValidator=class extends se{services;constructor(e){super(e),this.services=e}async validateDocument(e,t,r){return this.services.shared.workspace.ProjectsManager.isExcluded(e)?[]:await super.validateDocument(e,t,r)}};Pe();const bl=R(isImportsFromPoject,isImported,isGlobals,isGlobalPredicateGroup,isGlobalDynamicPredicateGroup,isGlobalStyle,isGlobalStyleGroup,isFqnExprWith,isRelationExprWith,isFqnExpr,isRelationExpr,isDynamicViewParallelSteps,isDynamicStepChain,isDynamicStepSingle,isDeploymentViewRule,isDeploymentViewRulePredicate,isExpressionV2,isRelationExpr,isFqnRefExpr,isViewProperty,isStyleProperty,isTags,isViewRule,isDynamicViewRule,isLikeC4View,isViewRuleStyleOrGlobalRef,isDeployedInstance,isDeploymentNode$1,isDeploymentRelation,isRelationshipStyleProperty,isDynamicViewDisplayVariantProperty,isMetadataBody,isMetadataProperty,isRelation,isRelationBody,isElementProperty,isStringProperty,isNavigateToProperty,isElement,isElementBody,isElementStyleProperty,isElementRef,isExtendElement,isExtendElementBody,isExtendDeployment,isExtendDeploymentBody,isExtendRelation,isExtendRelationBody,isSpecificationElementKind,isSpecificationRelationshipKind,isSpecificationDeploymentNodeKind,isSpecificationTag,isSpecificationColor,isSpecificationRule,isExpressions,isColorLiteral),findInvalidContainer=e=>{let t=e;for(;t&&!isLikeC4Grammar(t);){if(bl(t))return t;t=t.$container}};function checksFromDiagnostics(e){let t=e.state>=w.Validated?e.diagnostics?.filter(e=>e.severity===me.Error)??[]:[],r=new WeakSet;for(let{node:e}of t){if(M(e)||r.has(e))continue;r.add(e);let t=findInvalidContainer(e);t&&r.add(t)}let isValid=e=>!r.has(e);return{isValid,invalidNodes:r}}function registerValidationChecks(e){q.debug(`registerValidationChecks`),e.validation.ValidationRegistry.register({DeployedInstance:deployedInstanceChecks(e),DeploymentNodeKind:checkDeploymentNodeKind(e),DeploymentNode:deploymentNodeChecks(e),DeploymentRelation:deploymentRelationChecks(e),ExtendDeployment:extendDeploymentChecks(e),ExtendRelation:extendRelationChecks(e),FqnRefExpr:checkFqnRefExpr(e),RelationExpr:checkRelationExpr(e),OpacityProperty:opacityPropertyRuleChecks(e),IconProperty:iconPropertyRuleChecks(e),SpecificationRule:checkSpecificationRule(e),Model:checkModel(e),Globals:checkGlobals(e),GlobalPredicateGroup:checkGlobalPredicate(e),GlobalDynamicPredicateGroup:checkGlobalPredicate(e),GlobalStyleId:checkGlobalStyleId(e),DynamicStepSingle:dynamicViewStepSingle(e),DynamicStepChain:dynamicViewStepChain(e),DynamicViewParallelSteps:dynamicViewParallelSteps(e),LikeC4View:viewChecks(e),Element:checkElement(e),ElementRef:checkElementRef(e),ElementKind:checkElementKind(e),Relation:relationChecks(e),RelationBody:checkRelationBody(e),Tag:checkTag(e),FqnExprWith:checkFqnExprWith(e),RelationExprWith:checkRelationExprWith(e),RelationshipKind:checkRelationshipKind(e),IncomingRelationExpr:checkIncomingRelationExpr(e),OutgoingRelationExpr:checkOutgoingRelationExpr(e),ImportsFromPoject:checkImportsFromPoject(e),ColorLiteral:colorLiteralRuleChecks(e),DynamicViewDisplayVariantProperty:dynamicViewDisplayVariant(e),ViewRuleRank:viewRuleRankChecks(e)});let t=e.shared.lsp.Connection;t&&li(()=>{e.shared.workspace.DocumentBuilder.onUpdate((e,r)=>{for(let e of r)q.debug(`clear diagnostics for deleted ${e.path}`),t.sendDiagnostics({uri:e.toString(),diagnostics:[]}).catch(e=>q.error(loggable(e)))})})}const xl=q.getChild(`parser`);function toSingleLine(e){if(e==null)return;let t=removeIndent(e);return Nn(t)?t.split(`
|
|
81
92
|
`).join(` `):`md`in t?{md:t.md.split(`
|
|
82
93
|
`).join(` `)}:{txt:t.txt.split(`
|
|
83
|
-
`).join(` `)}}function removeIndent(e){if(e!=null)switch(!0){case Mn(e):return qn(e).trim();case isMarkdownOrString(e)&&Mn(e.markdown):return{md:qn(e.markdown).trim()};case isMarkdownOrString(e)&&Mn(e.text):return{txt:qn(e.text).trim()};case isMarkdownOrString(e):return{txt:``};default:return}}var BaseParser=class{services;doc;project;isValid;docUri;docPathInProject;constructor(e,t,n){this.services=e,this.doc=t,this.project=n,this.isValid=checksFromDiagnostics(t).isValid,this.docUri=t.uri.toString(),this.docPathInProject=_.relative(n.folderUri,t.uri)}logError(e,t,n){let r=e instanceof Error?e.message:typeof e==`string`?e:String(e);if(at(t)){let e=this.services.references.NameProvider.getName(t);e=e?`"${e}" (${t.$type})`:`${t.$type}`;let n=t.$cstNode,i=n?`:${n.range.start.line+1}:${n.range.start.character+1}`:``;r+=`\n\tat ${e} (${this.doc.uri.fsPath}${i})`}else t&&`$refText`in t&&(r+=`\n\tat reference "${t.$refText}" (${this.doc.uri.fsPath})`);n&&n!==`base`?fl.getChild(n).debug(r):fl.debug(r)}tryParse(e,t,n){try{return!t||!this.isValid(t)?void 0:n(t)}catch(n){this.logError(n,t,e);return}}tryMap(e,t,n){return E(t,t=>this.tryParse(e,t,n)??[])}resolveFqn(e){if(isImported(e)){let t=projectIdFrom(e),n=this.resolveFqn(B(e.imported.ref,`FqnRef is empty of imported: ${e.$cstNode?.text}`));return this.doc.c4Imports.set(t,n),vr(t,n)}return isExtendElement(e)?readStrictFqn(e.element):isExtendDeployment(e)?readStrictFqn(e.deploymentNode):isDeploymentElement(e)?this.services.likec4.DeploymentsIndex.getFqn(e):this.services.likec4.FqnIndex.getFqn(e)}getAstNodePath(e){return this.services.workspace.AstNodeLocator.getAstNodePath(e)}getMetadata(e){if(!e||!this.isValid(e)||D(e.props))return;let extractValues=e=>{if(isMarkdownOrString(e)){let t=removeIndent(e);if(!t)return[];if(typeof t==`string`)return T(t)?[t]:[];{let e=t.md||t.txt;return T(e)?[e]:[]}}else if(isMetadataArray(e))return e.values.map(e=>removeIndent(e)).map(e=>typeof e==`string`?e:e.md||e.txt).filter(T);return[]},t=M(e.props,E(e=>e.value?extractValues(e.value).map(t=>[e.key,t]):[[e.key,String(e.boolValue)]]),j(([e,t])=>T(t)));if(D(t))return;let n=M(t,en(([e])=>e),an(e=>e.map(([e,t])=>t))),r={};for(let[e,t]of Object.entries(n))t&&t.length>0&&(r[e]=t.length===1?t[0]:t);return D(r)?void 0:r}parseMarkdownOrString(e){if(isMarkdownOrString(e))return removeIndent(e)}convertTags(e){return this.parseTags(e)}parseTags(e){let t=e?.tags;if(!t)return null;let n=[];for(;t;)n.push(...this.tryMap(`base`,t.values,e=>B(e.tag.ref,`Tag reference is not resolved`).name).filter(T)),t=t.prev;return Vr(n)?Tn(n):null}convertLinks(e){return this.parseLinks(e)}parseLinks(e){if(!e?.props||e.props.length===0)return;let t=this.tryMap(`base`,j(e.props,isLinkProperty),e=>{let t=e.value;if(Yt(t))return;let n=T(e.title)?toSingleLine(e.title):void 0,r=this.services.lsp.DocumentLinkProvider.relativeLink(this.doc,t);return Ar({url:t,title:n,relative:r&&r!==t?r:void 0})});return Vr(t)?t:void 0}parseIconProperty(e){if(!e||!this.isValid(e))return;let{libicon:t,value:n}=e;switch(!0){case!!t:{let n=t.ref?.name;if(!n){this.logError(`Library icon ${t.$refText} is not a valid library icon`,e);return}return n}case n&&n===`none`:return n;case n&&_t(n):if(n.startsWith(`file:`)){this.logError(`Icon property '${n}' used the 'file' protocol which is not supported`,e);return}return n;case n&&n.startsWith(`@`):return this.parseImageAlias(n);case n&&ft(n):return lt(this.doc.uri.toString(),`../`,n);case n&&mt(n):return ht(this.project.folderUri.toString(),n);default:this.logError(`Icon property '${n}' is not a valid URL, library icon, image alias or 'none'`,e);return}}parseImageAlias(e){let t=e.indexOf(`/`),n=t>0?e.substring(0,t):e,r=t>0?e.substring(t+1):``,i={"@":`./images`,...this.project.config.imageAliases}[n];if(!i){fl.warn(`Image alias "${n}" not found in project configuration`);return}let a=r?ht(i,r):i;return ht(this.project.folderUri.toString(),a)}parseColorLiteral(e){if(this.isValid(e)){if(isHexColor(e))return`#${e.hex}`;if(isRGBAColor(e)){let t=Ht(e.alpha)?e.alpha:void 0;return Mn(e.alpha)&&(t=parseAstPercent(e.alpha)/100),t===void 0?`rgb(${e.red},${e.green},${e.blue})`:`rgba(${e.red},${e.green},${e.blue},${t})`}V(e)}}parseElementStyle(e){if(!e)return{};if(Kt(e)){let t=this.parseStyleProps(e.find(isElementStyleProperty)?.props);try{let n=this.parseIconProperty(e.find(isIconProperty));n&&(t.icon=n)}catch(e){this.logError(e)}return t}return this.parseStyleProps(e.props)}parseStyleProps(e){let t={};if(!e||e.length===0)return t;for(let n of e)if(this.isValid(n))try{switch(!0){case isBorderProperty(n):T(n.value)&&(t.border=n.value);break;case isColorProperty(n):{let e=toColor(n);T(e)&&(t.color=e);break}case isShapeProperty(n):T(n.value)&&(t.shape=n.value);break;case isIconProperty(n):{let e=this.parseIconProperty(n);T(e)&&(t.icon=e);break}case isIconColorProperty(n):{let e=toColor(n);T(e)&&(t.iconColor=e);break}case isIconSizeProperty(n):T(n.value)&&(t.iconSize=parseAstSizeValue(n));break;case isIconPositionProperty(n):T(n.value)&&(t.iconPosition=parseAstIconPositionValue(n));break;case isOpacityProperty(n):t.opacity=parseAstOpacityProperty(n);break;case isMultipleProperty(n):t.multiple=Wt(n.value)?n.value:!1;break;case isShapeSizeProperty(n):T(n.value)&&(t.size=parseAstSizeValue(n));break;case isPaddingSizeProperty(n):T(n.value)&&(t.padding=parseAstSizeValue(n));break;case isTextSizeProperty(n):T(n.value)&&(t.textSize=parseAstSizeValue(n));break;default:V(n)}}catch(e){this.logError(e,n)}return Ar(t)}parseBaseProps(e,t){let n=removeIndent(t?.title??parseMarkdownAsString(e.title)),r=t?.description?{txt:removeIndent(t.description)}:this.parseMarkdownOrString(e.description);return Ar({title:n,summary:t?.summary?{txt:removeIndent(t.summary)}:this.parseMarkdownOrString(e.summary),description:r,technology:toSingleLine(t?.technology)??removeIndent(parseMarkdownAsString(e.technology))})}};function*streamDeploymentModel(e){let t=br.from(e.parseResult.value.deployments.flatMap(e=>e.elements)),n=[],r;for(;r=t.shift();){if(isDeploymentRelation(r)){n.push(r);continue}if(r.body&&r.body.elements.length>0)for(let e of r.body.elements)t.push(e);yield r}yield*n}function DeploymentModelParser(e){return class DeploymentModelParser extends e{parseDeployment(){let e=this.doc;for(let t of streamDeploymentModel(e))try{switch(!0){case isDeploymentRelation(t):this.isValid(t)&&e.c4DeploymentRelations.push(this.parseDeploymentRelation(t));break;case isDeployedInstance(t):e.c4Deployments.push(this.parseDeployedInstance(t));break;case isDeploymentNode$1(t):e.c4Deployments.push(this.parseDeploymentNode(t));break;case isExtendDeployment(t):{let n=this.parseExtendDeployment(t);n&&e.c4ExtendDeployments.push(n);break}default:V(t)}}catch(e){this.logError(e,t,`deployment`)}}parseDeploymentNode(e){let t=this.isValid,n=this.resolveFqn(e),r=B(e.kind.ref,`DeploymentKind not resolved`).name,i=this.parseTags(e.body)??void 0,a=this.parseLinks(e.body),o=this.parseElementStyle(e.body?.props),s=this.getMetadata(e.body?.props.find(isMetadataProperty)),c=M(e.body?.props??[],j(t),j(isElementStringProperty),jn(e=>[e.key,e.value])),{title:l,...u}=this.parseBaseProps(c,{title:e.title,summary:e.summary});return Ar({id:n,kind:r,title:l??Wr(n),...u,tags:i,links:a,style:o,metadata:s})}parseDeployedInstance(e){let t=this.isValid,n=this.resolveFqn(e),r=this.parseFqnRef(e.target.modelElement);z(R.isModelRef(r)||R.isImportRef(r),`Target must be a model reference`);let i=this.parseTags(e.body)??void 0,a=this.parseElementStyle(e.body?.props),o=this.getMetadata(e.body?.props.find(isMetadataProperty)),s=M(e.body?.props??[],j(t),j(isElementStringProperty),jn(e=>[e.key,e.value])),c=this.parseBaseProps(s,{title:e.title,summary:e.summary});return Ar({id:n,element:r,tags:i,links:this.parseLinks(e.body),...c,style:a,metadata:o})}parseExtendDeployment(e){let t=this.parseTags(e.body),n=this.getMetadata(e.body?.props.find(isMetadataProperty)),r=this.parseLinks(e.body);return!t&&D(n??{})&&!r?null:Ar({id:this.resolveFqn(e),astPath:this.getAstNodePath(e),metadata:n,tags:t,links:r})}_resolveDeploymentRelationSource(e){if(k(e.source))return this.parseFqnRef(e.source);if(e.$container.$type===`DeploymentNodeBody`||e.$container.$type===`DeployedInstanceBody`)return{deployment:this.resolveFqn(e.$container.$container)};throw Error(`RelationRefError: Invalid container for sourceless relation`)}parseDeploymentRelation(e){let t=this.isValid,n=this.getAstNodePath(e),r=this._resolveDeploymentRelationSource(e);z(R.isDeploymentRef(r),`Invalid source for deployment relation`);let i=this.parseFqnRef(e.target);z(R.isDeploymentRef(i),`Invalid target for deployment relation`);let a=this.convertTags(e)??this.convertTags(e.body)??void 0,o=this.convertLinks(e.body),s=(e.kind??e.dotKind?.kind)?.ref?.name,c=this.getMetadata(e.body?.props.find(isMetadataProperty)),l=M(e.body?.props??[],j(isRelationStringProperty),j(e=>T(e.value)),jn(e=>[e.key,e.value])),u=M(e.body?.props??[],j(isRelationNavigateToProperty),wn())?.value.view.ref?.name,d=this.parseBaseProps(l,{title:e.title}),f=e.body?.props.find(isRelationStyleProperty);return Ar({id:stringHash$1(`deployment`,this.docUri,n,r.deployment,i.deployment),source:r,target:i,...d,metadata:c,kind:s,tags:a,links:o,...toRelationshipStyle(f?.props,t),navigateTo:u,astPath:n})}}}function DeploymentViewParser(e){return class DeploymentViewParser extends e{parseDeploymentView(e){let t=e.body;z(t,`DynamicElementView body is not defined`);let n=t.props.filter(this.isValid),r=this.getAstNodePath(e),i=e.name;i||=`deployment_`+stringHash$1(this.doc.uri.toString(),r);let{title:a=null,description:o=null}=this.parseBaseProps(M(n,j(isViewStringProperty),jn(e=>[e.key,e.value]))),s=this.convertTags(t),c=this.convertLinks(t);return Cc.writeId(e,i),{[mr._type]:`deployment`,id:i,astPath:r,title:toSingleLine(a)??null,description:o,tags:s,links:Vr(c)?c:null,rules:this.tryMap(`deployment`,t.rules,e=>this.parseDeploymentViewRule(e))}}parseDeploymentViewRule(e){if(isDeploymentViewRulePredicate(e))return this.parseDeploymentViewRulePredicate(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);if(isViewRuleAncestors(e))return{includeAncestors:e.value};if(isDeploymentViewRuleStyle(e))return this.parseDeploymentViewRuleStyle(e);V(e)}parseDeploymentViewRulePredicate(e){let t=[],n=e.expr;for(;n;){try{let e=n.value;w(e)&&this.isValid(e)&&t.unshift(this.parseExpressionV2(e))}catch(e){logWarnError(e)}n=n.prev}return e.isInclude?{include:t}:{exclude:t}}parseDeploymentViewRuleStyle(e){let t=this.parseStyleProps(e.props.filter(isStyleProperty)),n=removeIndent(parseMarkdownAsString(e.props.find(isNotationProperty)?.value));return{targets:this.parseFqnExpressions(e.targets),style:t,...n&&{notation:n}}}}}const parseMetadataEquals=({operator:e,not:t},n)=>e?.startsWith(`!=`)?{neq:n}:e?.startsWith(`=`)?{eq:n}:t?{neq:n}:{eq:n},parseEquals=({operator:e,not:t},n)=>e.startsWith(`!=`)?{neq:n}:e.startsWith(`=`)?{eq:n}:t?{neq:n}:{eq:n};function parseParticipant(e){return!isWhereRelationParticipantKind(e)&&!isWhereRelationParticipantTag(e)&&!isWhereRelationParticipantMetadata(e)?null:e.participant}function parseWhereClause(e){switch(!0){case isWhereTagEqual(e):{let t=e.value.tag.ref?.name,n=parseParticipant(e);z(t,`Expected tag name`);let r={tag:parseEquals(e,t)};return n?{participant:n,operator:r}:r}case isWhereKindEqual(e):{let t=e.value?.ref?.name,n=parseParticipant(e);z(t,`Expected kind name`);let r={kind:parseEquals(e,t)};return n?{participant:n,operator:r}:r}case isWhereMetadataEqual(e):{let t=e.key,n=parseParticipant(e);z(t,`Expected metadata key`);let r={metadata:{key:t,...e.value==null?{}:{value:parseMetadataEquals(e,String(e.value))}}};return n?{participant:n,operator:r}:r}case isWhereElementNegation(e)||isWhereRelationNegation(e):return{not:parseWhereClause(e.value)};case isWhereBinaryExpression(e):{let t=parseWhereClause(e.left),n=parseWhereClause(e.right);return createBinaryOperator(e.operator.toLowerCase(),t,n)}default:V(e)}}function createBinaryOperator(e,t,n){if(n===null)return t;switch(e){case`and`:{let e=[Pr(t)?t.and:t,Pr(n)?n.and:n].flat();return z(Vr(e),`Expected non-empty array`),{and:e}}case`or`:{let e=[Hr(t)?t.or:t,Hr(n)?n.or:n].flat();return z(Vr(e),`Expected non-empty array`),{or:e}}default:V(e)}}function ExpressionV2Parser(e){return class ExpressionV2Parser extends e{parseFqnRef(e){let t=B(e.value?.ref,()=>`Element "${e.$cstNode?.text}" is not resolved`);if(isImported(t)){let e={project:projectIdFrom(t),model:this.resolveFqn(B(t.imported.ref,`Imported "${t.$cstNode?.text}" is not resolved`))};return this.doc.c4Imports.set(e.project,e.model),e}if(isElement(t)){let n=importsRef(e);if(n){let e={project:projectIdFrom(n),model:this.resolveFqn(t)};return this.doc.c4Imports.set(e.project,e.model),e}let r=instanceRef(e);return r?{deployment:this.resolveFqn(r),element:this.resolveFqn(t)}:{model:this.resolveFqn(t)}}if(isDeploymentElement(t))return{deployment:this.resolveFqn(t)};V(t)}parseExpressionV2(e){if(isFqnExprOrWith(e))return this.parseFqnExprOrWith(e);if(isRelationExprOrWith(e))return this.parseRelationExprOrWith(e);V(e)}parseFqnExprOrWith(e){if(isFqnExprWith(e))return this.parseFqnExprWith(e);if(isFqnExprOrWhere(e))return this.parseFqnExprOrWhere(e);V(e)}parseFqnExprWith(e){let t=this.parseFqnExprOrWhere(e.subject);return(e.custom?.props??[]).reduce((e,t)=>{if(!this.isValid(t))return e;if(isNavigateToProperty(t)){let n=t.value.view.$refText;return T(n)&&(e.custom.navigateTo=n),e}if(isNotesProperty(t)){let n=this.parseMarkdownOrString(t.value);return n&&(e.custom[t.key]=n),e}if(isElementStringProperty(t)){if(t.key===`description`||t.key===`summary`){let n=this.parseMarkdownOrString(t.value);return n&&(e.custom.description=n),e}let n=removeIndent(parseMarkdownAsString(t.value));return n&&(e.custom[t.key]=n),e}if(isIconProperty(t)){let n=this.parseIconProperty(t);return k(n)&&(e.custom[t.key]=n),e}if(isColorProperty(t)){let n=toColor(t);return k(n)&&(e.custom[t.key]=n),e}if(isShapeProperty(t)||isBorderProperty(t))return k(t.value)&&(e.custom[t.key]=t.value),e;if(isOpacityProperty(t))return k(t.value)&&(e.custom[t.key]=parseAstOpacityProperty(t)),e;if(isIconColorProperty(t)){let n=toColor(t);return k(n)&&(e.custom[t.key]=n),e}if(isNotationProperty(t)){let n=T(t.value)?removeIndent(parseMarkdownAsString(t.value)):void 0;return n&&(e.custom[t.key]=n),e}if(isMultipleProperty(t))return Wt(t.value)&&(e.custom[t.key]=t.value),e;if(isShapeSizeProperty(t)||isTextSizeProperty(t)||isPaddingSizeProperty(t)||isIconSizeProperty(t))return T(t.value)&&(e.custom[t.key]=parseAstSizeValue(t)),e;if(isIconPositionProperty(t))return T(t.value)&&(e.custom[t.key]=t.value),e;V(t)},{custom:{expr:t}})}parseFqnExprOrWhere(e){if(isFqnExprWhere(e))return this.parseFqnExprWhere(e);if(isFqnExpr(e))return this.parseFqnExpr(e);V(e)}parseFqnExprWhere(e){return z(!isFqnExprWhere(e.subject),`FqnExprWhere is not allowed as subject of FqnExprWhere`),{where:{expr:this.parseFqnExpr(e.subject),condition:e.where?parseWhereClause(e.where):{kind:{neq:`--always-true--`}}}}}parseFqnExpr(e){if(isWildcardExpression(e))return{wildcard:!0};if(isElementKindExpression(e))return z(e.kind?.ref,`ElementKind "${e.$cstNode?.text}" is not resolved`),{elementKind:e.kind.ref.name,isEqual:e.isEqual};if(isElementTagExpression(e))return z(e.tag.tag.ref,`Tag ${e.$cstNode?.text} is not resolved`),{elementTag:e.tag.tag.$refText,isEqual:e.isEqual};if(isFqnRefExpr(e))return this.parseFqnRefExpr(e);V(e)}parseFqnRefExpr(e){let t=this.parseFqnRef(e.ref);switch(!0){case e.selector===`._`:return{ref:t,selector:`expanded`};case e.selector===`.**`:return{ref:t,selector:`descendants`};case e.selector===`.*`:return{ref:t,selector:`children`};default:return{ref:t}}}parseFqnExpressions(e){let t=[],n=e;for(;n;){try{w(n.value)&&this.isValid(n.value)&&t.push(this.parseFqnExpr(n.value))}catch(e){this.logError(e,n.value,`fqnref`)}n=n.prev}return t.reverse()}parseRelationExprOrWith(e){if(isRelationExprWith(e))return this.parseRelationExprWith(e);if(isRelationExprOrWhere(e))return this.parseRelationExprOrWhere(e);V(e)}parseRelationExprWith(e){let t=this.parseRelationExprOrWhere(e.subject);return{customRelation:{...this.parseCustomRelationProperties(e.custom),expr:t}}}parseCustomRelationProperties(e){return(e?.props??[]).reduce((e,t)=>{if(isNotesProperty(t)){let n=this.parseMarkdownOrString(t.value);return n&&(e[t.key]=n),e}if(isRelationStringProperty(t)||isNotationProperty(t)){if(t.key===`description`){let n=this.parseMarkdownOrString(t.value);return n&&(e.description=n),e}let n=removeIndent(parseMarkdownAsString(t.value));return n&&(e[t.key]=n),e}if(isArrowProperty(t))return T(t.value)&&(e[t.key]=t.value),e;if(isColorProperty(t)){let n=toColor(t);return T(n)&&(e[t.key]=n),e}if(isLineProperty(t))return T(t.value)&&(e[t.key]=t.value),e;if(isRelationNavigateToProperty(t)){let n=t.value.view.ref?.name;return T(n)&&(e[t.key]=n),e}if(isMultipleProperty(t))return Wt(t.value)&&(e[t.key]=t.value),e;V(t)},{})}parseRelationExprOrWhere(e){if(isRelationExprWhere(e))return this.parseRelationExprWhere(e);if(isRelationExpr(e))return this.parseRelationExpr(e);V(e)}parseRelationExprWhere(e){z(!isRelationExprWhere(e.subject),`RelationExprWhere is not allowed as subject of RelationExprWhere`);let t=this.parseRelationExpr(e.subject),n=t.where?.expr??t,r=t.where?.condition,i=e.where?parseWhereClause(e.where):null,a;return a=i&&r?createBinaryOperator(`and`,r,i):i??r??{kind:{neq:`--always-true--`}},{where:{expr:n,condition:a}}}parseRelationExpr(e){switch(e.$type){case`DirectedRelationExpr`:return this.wrapInWhere({source:this.parseFqnExpr(e.source.from),target:this.parseFqnExpr(e.target),isBidirectional:e.source.isBidirectional},this.parseInlineKindCondition(e.source));case`InOutRelationExpr`:return{inout:this.parseFqnExpr(e.inout.to)};case`OutgoingRelationExpr`:return this.wrapInWhere({outgoing:this.parseFqnExpr(e.from)},this.parseInlineKindCondition(e));case`IncomingRelationExpr`:return{incoming:this.parseFqnExpr(e.to)};default:V(e)}}parseInlineKindCondition(e){let t=e.kind??e.dotKind?.kind;return t?t.ref?{kind:{eq:t.ref?.name}}:(this.logError(`RelationshipKind "${t.$refText}" is not resolved`,e,`fqnref`),null):null}wrapInWhere(e,t){return t?{where:{expr:e,condition:t}}:e}}}function GlobalsParser(e){return class GlobalsParser extends e{parseGlobals(){let{parseResult:e,c4Globals:t}=this.doc,n=this.isValid,r=e.value.globals.filter(n),i=r.flatMap(e=>e.predicates.filter(n));for(let e of i)try{let n=e.name;if(!T(n))continue;if(n in t.predicates){this.logError(`Global predicate named "${n}" is already defined`,e,`globals`);continue}this.parseAndStoreGlobalPredicateGroupOrDynamic(e,n,t)}catch(t){this.logError(t,e,`globals`)}let a=r.flatMap(e=>e.styles.filter(n));for(let e of a)try{let n=e.id.name;if(!T(n))continue;if(n in t.styles){this.logError(`Global style named "${n}" is already defined`,e,`globals`);continue}let r=this.parseGlobalStyleOrGroup(e);A(r,1)&&(t.styles[n]=r)}catch(t){this.logError(t,e,`globals`)}}parseAndStoreGlobalPredicateGroupOrDynamic(e,t,n){if(isGlobalPredicateGroup(e)){let r=this.parseGlobalPredicateGroup(e);A(r,1)&&(n.predicates[t]=r);return}if(isGlobalDynamicPredicateGroup(e)){let r=this.parseGlobalDynamicPredicateGroup(e);A(r,1)&&(n.dynamicPredicates[t]=r);return}V(e)}parseGlobalPredicateGroup(e){return e.predicates.map(e=>this.parseViewRulePredicate(e))}parseGlobalDynamicPredicateGroup(e){return e.predicates.map(e=>this.parseDynamicViewIncludePredicate(e))}parseGlobalStyleOrGroup(e){if(isGlobalStyle(e))return[this.parseViewRuleStyle(e)];if(isGlobalStyleGroup(e))return e.styles.map(e=>this.parseViewRuleStyle(e));V(e)}}}function ImportsParser(e){return class ImportsParser extends e{parseImports(){let e=this.doc.parseResult.value.imports??[];for(let t of e){let e=t.project,n=t.imports;for(;n;){try{this.doc.c4Imports.set(e,this.resolveFqn(B(n.imported.ref,`ElementRef is empty of imported: ${n.imported.$refText}`)))}catch(e){this.logError(e,n,`imports`)}n=n.prev}}}}}function*streamModel(e){let t=br.from(e.parseResult.value.models.flatMap(e=>e.elements)),n=[],r;for(;r=t.shift();){if(isRelation(r)){n.push(r);continue}if(isExtendRelation(r)){n.push(r);continue}if(r.body?.elements&&A(r.body.elements,1))for(let e of r.body.elements)t.push(e);yield r}yield*n}function ModelParser(e){return class ModelParser extends e{parseModel(){let e=this.doc;for(let t of streamModel(e))try{if(isElement(t)){e.c4Elements.push(this.parseElement(t));continue}if(isRelation(t)){e.c4Relations.push(this.parseRelation(t));continue}if(isExtendElement(t)){let n=this.parseExtendElement(t);n&&e.c4ExtendElements.push(n);continue}if(isExtendRelation(t)){let n=this.parseExtendRelation(t);n&&e.c4ExtendRelations.push(n);continue}V(t)}catch(e){this.logError(e,t,`model`)}}parseElement(e){let t=this.isValid,n=this.resolveFqn(e),r=B(e.kind.ref,`Element kind is not resolved`).name,i=this.parseTags(e.body),a=this.parseElementStyle(e.body?.props),o=this.getMetadata(e.body?.props.find(isMetadataProperty)),s=this.getAstNodePath(e),[c,l,u]=e.props??[],d=M(e.body?.props??[],j(t),j(isElementStringProperty),jn(e=>[e.key,e.value])),{title:f,...p}=this.parseBaseProps(d,{title:c,summary:l,technology:u});return fr({id:n,kind:r,astPath:s,title:f,metadata:o,tags:i??void 0,links:this.parseLinks(e.body),...p,style:a})}parseExtendElement(e){let t=this.parseTags(e.body),n=this.getMetadata(e.body?.props.find(isMetadataProperty)),r=this.parseLinks(e.body);if(!t&&Yt(n)&&!r)return null;let i=this.getAstNodePath(e);return fr({id:this.resolveFqn(e),astPath:i,metadata:n,tags:t,links:r})}parseExtendRelation(e){let t=this.parseFqnRef(e.source),n=this.parseFqnRef(e.target);z(I.isModelRef(t)||I.isImportRef(t),`Source must be a model reference`),z(I.isModelRef(n)||I.isImportRef(n),`Target must be a model reference`);let r=this.parseTags(e.body),i=this.getMetadata(e.body?.props.find(isMetadataProperty)),a=this.getAstNodePath(e),o=this.parseLinks(e.body);if(!r&&D(i??{})&&!o)return null;let s=(e.kind??e.dotKind?.kind)?.ref?.name,{title:c=``}=this.parseBaseProps({},{title:e.title});return fr({id:stringHash$1(`extend-relation`,I.flatten(t),I.flatten(n),s??`default`,c),astPath:a,metadata:i,tags:r,links:o})}_resolveRelationSource(e){if(k(e.source)){let t=this.parseFqnRef(e.source);return z(I.isModelRef(t)||I.isImportRef(t),`Relation source must be a model reference`),t}if(isElementBody(e.$container)||isExtendElementBody(e.$container))return{model:this.resolveFqn(e.$container.$container)};throw Error(`RelationRefError: Invalid container for sourceless relation`)}parseRelation(e){let t=this.isValid,n=this._resolveRelationSource(e),r=this.parseFqnRef(e.target);z(I.isModelRef(r)||I.isImportRef(r),`Target must be a model reference`);let i=this.parseTags(e)??this.parseTags(e.body)??void 0,a=this.parseLinks(e.body),o=(e.kind??e.dotKind?.kind)?.ref?.name,s=this.getMetadata(e.body?.props.find(isMetadataProperty)),c=this.getAstNodePath(e),l=M(e.body?.props??[],j(isRelationStringProperty),j(e=>T(e.value)),jn(e=>[e.key,e.value])),u=M(e.body?.props??[],j(isRelationNavigateToProperty),N(e=>e.value.view.ref?.name),j(T),wn()),{title:d=``,description:f,technology:p}=this.parseBaseProps(l,{title:e.title,description:e.description,technology:e.technology}),m=e.body?.props.find(isRelationStyleProperty);return fr({id:stringHash$1(this.docUri,c,I.flatten(n),I.flatten(r)),astPath:c,source:n,target:r,title:d,metadata:s,kind:o,tags:i,links:a,navigateTo:u,description:f,technology:p,...toRelationshipStyle(m?.props,t)})}}}function PredicatesParser(e){return class PredicatesParser extends e{parsePredicate(e){return this.parseExpressionV2(e)}parseElementPredicate(e){if(isFqnExprWith(e))return this.parseFqnExprWith(e);if(isFqnExprOrWhere(e))return this.parseFqnExprOrWhere(e);V(e)}parseElementPredicateOrWhere(e){return this.parseFqnExprOrWhere(e)}parseElementExpression(e){return this.parseFqnExpr(e)}parseElementPredicateWhere(e){return this.parseFqnExprWhere(e)}parseElementPredicateWith(e){return this.parseFqnExprWith(e)}parseRelationPredicate(e){return this.parseRelationExprOrWith(e)}parseRelationPredicateOrWhere(e){return this.parseRelationExprOrWhere(e)}parseRelationPredicateWhere(e){return this.parseRelationExprWhere(e)}parseRelationPredicateWith(e){return this.parseRelationExprWith(e)}parseRelationExpression(e){return this.parseRelationExpr(e)}}}function SpecificationParser(e){return class SpecificationParser extends e{parseSpecification(){let{parseResult:{value:{specifications:e}},c4Specification:t}=this.doc,n=this.isValid;for(let r of e.flatMap(e=>e.elements.filter(n)))try{Object.assign(t.elements,this.parseElementSpecificationNode(r))}catch(e){this.logError(e,r,`specification`)}for(let r of e.flatMap(e=>e.deploymentNodes.filter(n)))try{Object.assign(t.deployments,this.parseElementSpecificationNode(r))}catch(e){this.logError(e,r,`specification`)}let r=e.flatMap(e=>e.relationships.filter(this.isValid));for(let{kind:e,props:n}of r)try{let r=e.name;if(!T(r))continue;if(r in t.relationships){this.logError(`Relationship kind "${r}" is already defined`,e,`specification`);continue}let i=M(n.filter(isSpecificationRelationshipStringProperty)??[],j(e=>this.isValid(e)&&w(e.value)),jn(e=>[e.key,removeIndent(parseMarkdownAsString(e.value))]),pn(O)),a=n.filter(isMultipleProperty);a.length>1&&this.logError(`Duplicate 'multiple' property for relationship "${r}", using the first one`,e,`specification`);let o=a[0];t.relationships[r]={...i,...toRelationshipStyle(n.filter(isRelationshipStyleProperty),this.isValid),...o&&{multiple:o.value}}}catch(t){this.logError(t,e,`specification`)}let i=e.flatMap(e=>e.tags.filter(this.isValid));for(let e of i)try{let n=e.tag.name,r=this.getAstNodePath(e.tag),i=e.color&&this.parseColorLiteral(e.color);if(n in t.tags){this.logError(`Tag ${n} is already defined, skipping duplicate`,e,`specification`);continue}T(n)&&(t.tags[n]={astPath:r,...i?{color:i}:{}})}catch(t){this.logError(t,e,`specification`)}let a=e.flatMap(e=>e.colors.filter(n));for(let{name:e,color:n}of a)try{let r=e.name;if(r in t.colors){this.logError(`Custom color "${r}" is already defined`,e,`specification`);continue}t.colors[r]={color:oi(this.parseColorLiteral(n),`Color "${r}" is not valid`)}}catch(e){this.logError(e,n,`specification`)}}parseElementSpecificationNode(e){let{kind:t,props:n}=e,r=t.name;if(!T(r))throw Error(`DeploymentNodeKind name is not resolved`);let i=this.parseTags(e),a=this.parseElementStyle(n.find(isElementStyleProperty)),o=this.parseLinks(e),s=M(n.filter(isSpecificationElementStringProperty)??[],j(e=>this.isValid(e)),jn(e=>[e.key,e.value])),c=this.parseBaseProps(s),l=removeIndent(parseMarkdownAsString(s.notation));return{[r]:Ar({...c,notation:l,tags:i??void 0,...o&&mr.isNonEmptyArray(o)&&{links:o},style:a})}}}}function ViewsParser(e){return class ViewsParser extends e{parseViews(){let e=this.isValid;for(let t of this.doc.parseResult.value.views){let n=t.styles.flatMap(t=>{try{return e(t)?this.parseViewRuleStyleOrGlobalRef(t):[]}catch(e){return this.logError(e,t,`views`),[]}}),r=t.folder&&!D(t.folder.trim())?toSingleLine(t.folder):null;for(let i of t.views)try{if(!e(i))continue;switch(!0){case isElementView$1(i):this.doc.c4Views.push(this.parseElementView(i,n));break;case isDynamicView$1(i):this.doc.c4Views.push(this.parseDynamicElementView(i,n));break;case isDeploymentView$1(i):this.doc.c4Views.push(this.parseDeploymentView(i));break;default:V(i)}if(r){let e=this.doc.c4Views.at(-1);e.title=r+` / `+(e.title||e.id)}}catch(e){this.logError(e,i,`views`)}}}parseElementView(e,t){let n=e.body;z(n,`ElementView body is not defined`);let r=this.getAstNodePath(e),i=null;if(`viewOf`in e){let t=elementRef(e.viewOf),n=t&&safeCall(()=>this.resolveFqn(t));if(n)i=n;else{let t=e.name??`unnamed`,n=e.viewOf.$cstNode?.text??`<unknown>`;this.logError(`viewOf ${t} not resolved ${n}`,e.viewOf)}}let a=e.name;a||=`view_`+stringHash$1(this.doc.uri.toString(),r,i??``);let{title:o=null,description:s=null}=this.parseBaseProps(M(n.props,j(e=>this.isValid(e)),j(isViewStringProperty),jn(e=>[e.key,e.value]))),c=this.convertTags(n),l=this.convertLinks(n),u={[mr._type]:`element`,id:a,astPath:r,title:toSingleLine(o)??null,description:s,tags:c,links:Vr(l)?l:null,rules:[...t,...this.tryMap(`views`,n.rules,e=>this.parseElementViewRule(e))],...i&&{viewOf:i}};if(Cc.writeId(e,u.id),`extends`in e){let t=e.extends.view.ref;return z(t?.name,`view extends is not resolved: `+e.$cstNode?.text),Object.assign(u,{extends:t.name})}return u}parseElementViewRule(e){if(isViewRulePredicate(e))return this.parseViewRulePredicate(e);if(isViewRuleGlobalPredicateRef(e))return this.parseViewRuleGlobalPredicateRef(e);if(isViewRuleStyleOrGlobalRef(e))return this.parseViewRuleStyleOrGlobalRef(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);if(isViewRuleGroup(e))return this.parseViewRuleGroup(e);if(isViewRuleRank(e))return this.parseViewRuleRank(e);V(e)}parseViewRulePredicate(e){let t=[],n=e.exprs;for(;n;){let{value:e,prev:r}=n;if(this.tryParse(`views`,e,()=>{let n=this.parsePredicate(e);t.unshift(n)}),!r)break;n=r}return e.isInclude?{include:t}:{exclude:t}}parseViewRuleGlobalPredicateRef(e){return{predicateId:e.predicate.$refText}}parseViewRuleStyleOrGlobalRef(e){if(isViewRuleStyle(e))return this.parseViewRuleStyle(e);if(isViewRuleGlobalStyle(e))return this.parseViewRuleGlobalStyle(e);V(e)}parseViewRuleGroup(e){let t=[];for(let n of e.groupRules)try{if(!this.isValid(n))continue;if(isViewRulePredicate(n)){t.push(this.parseViewRulePredicate(n));continue}if(isViewRuleGroup(n)){t.push(this.parseViewRuleGroup(n));continue}V(n)}catch(e){this.logError(e,n,`views`)}return{title:toSingleLine(e.title)??null,groupRules:t,...this.parseStyleProps(e.props)}}parseViewRuleRank(e){let t=this.parseFqnExpressions(e.targets).filter(e=>mr.ModelExpression.isFqnExpr(e));return{rank:e.value??`same`,targets:t}}parseViewRuleStyle(e){let t=this.parseFqnExpressions(e.targets).filter(e=>mr.ModelExpression.isFqnExpr(e)),n=this.parseStyleProps(e.props.filter(isStyleProperty)),r=removeIndent(parseMarkdownAsString(e.props.find(isNotationProperty)?.value));return{targets:t,style:n,...r&&{notation:r}}}parseViewRuleGlobalStyle(e){return{styleId:e.style.$refText}}parseDynamicElementView(e,t){let n=e.body;z(n,`DynamicElementView body is not defined`);let r=this.isValid,i=n.props.filter(r),a=this.getAstNodePath(e),o=e.name;o||=`dynamic_`+stringHash$1(this.doc.uri.toString(),a);let{title:s=null,description:c=null}=this.parseBaseProps(M(i,j(isViewStringProperty),jn(e=>[e.key,e.value]))),l=this.convertTags(n),u=this.convertLinks(n);Cc.writeId(e,o);let d=nn(i,isDynamicViewDisplayVariantProperty)?.value;return{[mr._type]:`dynamic`,id:o,astPath:a,title:toSingleLine(s)??null,description:c,tags:l,links:Vr(u)?u:null,variant:d,rules:[...t,...this.tryMap(`views`,n.rules,e=>this.parseDynamicViewRule(e))],steps:this.tryMap(`views`,n.steps,e=>isDynamicViewParallelSteps(e)?this.parseDynamicParallelSteps(e):this.parseDynamicStep(e))}}parseDynamicViewRule(e){if(isDynamicViewIncludePredicate(e))return this.parseDynamicViewIncludePredicate(e);if(isDynamicViewGlobalPredicateRef(e))return this.parseViewRuleGlobalPredicateRef(e);if(isViewRuleStyleOrGlobalRef(e))return this.parseViewRuleStyleOrGlobalRef(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);V(e)}parseDynamicViewIncludePredicate(e){let t=[],n=e.exprs;for(;n;)this.tryParse(`views`,n.value,e=>{if(isFqnExprOrWith(e)){let n=this.parseElementPredicate(e);t.unshift(n)}}),n=n.prev;return{include:t}}parseDynamicParallelSteps(e){let t=pathInsideDynamicView(e),n=this.tryMap(`views`,e.steps,e=>this.parseDynamicStep(e));return z(Vr(n),`Dynamic parallel steps must have at least one step`),{parallelId:t,__parallel:n}}parseDynamicStep(e){if(isDynamicStepSingle(e))return this.parseDynamicStepSingle(e);let t=this.recursiveParseDynamicStepChain(e);return z(Vr(t),`Dynamic step chain must have at least one step`),{seriesId:pathInsideDynamicView(e),__series:t}}recursiveParseDynamicStepChain(e,t){if(isDynamicStepSingle(e.source)){if(!this.isValid(e.source))return[];let n=this.parseDynamicStepSingle(e.source);if(n.isBackward)return[];let r={...this.parseAbstractDynamicStep(e),source:n.target};return r.target===n.source?r.isBackward=!0:t&&(t.push([n.source,n.target]),t.push([r.source,r.target])),[n,r]}t??=[];let n=this.recursiveParseDynamicStepChain(e.source,t);if(!Vr(n)||!this.isValid(e))return[];let r=cn(n),i={...this.parseAbstractDynamicStep(e),source:r.target},a=t.findIndex(([e,t])=>e===i.target&&t===i.source);return a===-1?t.push([i.source,i.target]):(i.isBackward=!0,t.splice(a,t.length-a)),[...n,i]}parseDynamicStepSingle(e){let t=elementRef(e.source);if(!t)throw Error(`Invalid reference to source`);let n={...this.parseAbstractDynamicStep(e),source:this.resolveFqn(t)};return e.isBackward&&(n={...n,source:n.target,target:n.source,isBackward:!0}),n}parseAbstractDynamicStep(e){let t=elementRef(e.target);if(!t)throw Error(`Invalid reference to target`);let n={target:this.resolveFqn(t),astPath:pathInsideDynamicView(e)},r=removeIndent(e.title);r&&(n.title=r);let i=e.kind?.ref?.name??e.dotKind?.kind.ref?.name;i&&(n.kind=i);for(let t of e.custom?.props??[])try{switch(!0){case isRelationNavigateToProperty(t):{let e=t.value.view.ref?.name;T(e)&&(n.navigateTo=e);break}case isRelationStringProperty(t):case isNotationProperty(t):if(k(t.value))if(t.key===`description`){let e=removeIndent(t.value);e&&(n.description=e)}else n[t.key]=removeIndent(parseMarkdownAsString(t.value))??``;break;case isNotesProperty(t):k(t.value)&&(n[t.key]=removeIndent(t.value));break;case isArrowProperty(t):k(t.value)&&(n[t.key]=t.value);break;case isColorProperty(t):{let e=toColor(t);k(e)&&(n[t.key]=e);break}case isLineProperty(t):k(t.value)&&(n[t.key]=t.value);break;case isMultipleProperty(t):break;default:V(t)}}catch(e){this.logError(e,t,`views`)}return n}}}function pathInsideDynamicView(e){let t=e,n=[];for(;!isDynamicViewBody(t);)Ht(t.$containerIndex)&&n.unshift(`@${t.$containerIndex}`),n.unshift(`/${t.$containerProperty??`__invalid__`}`),t=t.$container;return n.join(``)}Pe();const pl=M(BaseParser,ExpressionV2Parser,ImportsParser,ModelParser,DeploymentModelParser,DeploymentViewParser,PredicatesParser,SpecificationParser,ViewsParser,GlobalsParser);var DocumentParser=class extends pl{};const ml=G.getChild(`parser`),isError=e=>e.severity===he.Error;var LikeC4ModelParser=class{services;cachedParsers=new Jr(e=>this.createParser(e));constructor(e){this.services=e,e.shared.workspace.DocumentBuilder.onDocumentPhase(y.Linked,async e=>{this.cachedParsers.has(e)&&(ml.trace(`Linked: clear cached parser {projectId} document {doc}`,{projectId:e.likec4ProjectId,doc:_.basename(e.uri)}),this.cachedParsers.delete(e))}),e.shared.workspace.DocumentBuilder.onBuildPhase(y.Linked,async t=>{for(let n of t)if(!e.shared.workspace.ProjectsManager.isExcluded(n))try{this.parse(n)}catch(e){logWarnError(e)}}),e.shared.workspace.DocumentBuilder.onDocumentPhase(y.Validated,async e=>{e.diagnostics?.some(isError)&&this.cachedParsers.has(e)&&(ml.trace(`Validated: clear cached parser {projectId} document {doc} because of errors`,{projectId:e.likec4ProjectId,doc:_.basename(e.uri)}),this.cachedParsers.delete(e))})}documents(e){return this.services.shared.workspace.LangiumDocuments.projectDocuments(e).map(e=>this.parse(e))}parse(e){return this.forDocument(e).doc}forDocument(e){return this.cachedParsers.get(e)}createParser(e){U(isLikeC4LangiumDocument(e),`Document ${e.uri.toString()} is not a LikeC4 document`);let t=this.services.shared.workspace.ProjectsManager.getProject(e),n=_.relative(t.folderUri,e.uri);e.likec4ProjectId?ml.trace(`create parser {projectId} document {doc}`,{projectId:e.likec4ProjectId,doc:n}):ml.debug(`create parser for document without project {doc}`,{doc:e.uri.fsPath}),e.state<y.Linked&&ml.debug(`Document {doc} is not linked, state is {state}`,{doc:n,state:e.state});let r={c4Specification:{tags:{},elements:{},relationships:{},colors:{},deployments:{}},c4Elements:[],c4ExtendElements:[],c4ExtendDeployments:[],c4ExtendRelations:[],c4Relations:[],c4Deployments:[],c4DeploymentRelations:[],c4Globals:{predicates:{},dynamicPredicates:{},styles:{}},c4Views:[],c4Imports:new H(Set)};e=Object.assign(e,r);let i=new DocumentParser(this.services,e,t);try{i.parseSpecification(),i.parseImports(),i.parseModel(),i.parseDeployment(),i.parseGlobals(),i.parseViews()}catch(e){throw Error(`Error parsing document ${n}`,{cause:e})}return i}},LikeC4ValueConverter=class extends Ke{runConverter(e,t,n){return e.name===`MarkdownString`?((t.startsWith(`"""`)&&t.endsWith(`"""`)||t.startsWith(`'''`)&&t.endsWith(`'''`))&&(t=t.slice(2,-2)),re.convertString(t)):super.runConverter(e,t,n)}};Pe();const{findNodeForKeyword:hl}=we,asViewStyleRule=(e,t,n=0)=>{let r=n>0?` `.repeat(n):``;return[r+`style ${e} {`,...rn(t).map(([e,t])=>r+` ${e} ${e===`opacity`?t.toString()+`%`:t}`),r+`}`]},isMatchingViewRule=(e,t)=>n=>{if(!isViewRuleStyle(n)&&!isDeploymentViewRuleStyle(n))return!1;let r=n.targets.value;if(!r||T(n.targets.prev)||r.$type!==`FqnRefExpr`||T(r.selector))return!1;let i=r.ref?.value?.ref;return(i?t.resolve(i):null)===e};function changeElementStyle(e,{view:t,viewAst:n,targets:r,style:i}){z(n.body,`View ${t.id} has no body`);let a=n.$cstNode;z(a,`viewCstNode`);let o=cn(n.body.rules)?.$cstNode?.range.end??n.body.$cstNode?.range.end;z(o,`insertPos is not defined`);let s=a.range.start.character+2,c=e.likec4.FqnIndex,l=j(n.body.rules,e=>isViewRuleStyle(e)||isDeploymentViewRuleStyle(e)),u=t[Tr]===`element`?t.viewOf??null:null,d=[],f=[];r.forEach(e=>{let t=qt(l,isMatchingViewRule(e,c)),n=u&&Nr(u,e)?e.substring(u.length+1):e;t?d.push({fqn:n,rule:t}):f.push({fqn:n})});let p={start:o,end:o},includeRange=e=>{e.start.line<=p.start.line&&(e.start.line==p.start.line?p.start.character=Math.min(e.start.character,p.start.character):p.start=e.start),e.end.line>=p.end.line&&(e.end.line==p.end.line?p.end.character=Math.max(e.end.character,p.end.character):p.end=e.end)},m=[];if(f.length>0){let e=f.flatMap(({fqn:e})=>asViewStyleRule(e,i,s));m.push(Je.insert(o,`
|
|
94
|
+
`).join(` `)}}function removeIndent(e){if(e!=null)switch(!0){case Nn(e):return dedent(e).trim();case isMarkdownOrString(e)&&Nn(e.markdown):return{md:dedent(e.markdown).trim()};case isMarkdownOrString(e)&&Nn(e.text):return{txt:dedent(e.text).trim()};case isMarkdownOrString(e):return{txt:``};default:return}}var BaseParser=class{services;doc;project;isValid;docUri;docPathInProject;constructor(e,t,r){this.services=e,this.doc=t,this.project=r,this.isValid=checksFromDiagnostics(t).isValid,this.docUri=t.uri.toString(),this.docPathInProject=S.relative(r.folderUri,t.uri)}logError(e,t,r){let o=e instanceof Error?e.message:typeof e==`string`?e:String(e);if(at(t)){let e=this.services.references.NameProvider.getName(t);e=e?`"${e}" (${t.$type})`:`${t.$type}`;let r=t.$cstNode,s=r?`:${r.range.start.line+1}:${r.range.start.character+1}`:``;o+=`\n\tat ${e} (${this.doc.uri.fsPath}${s})`}else t&&`$refText`in t&&(o+=`\n\tat reference "${t.$refText}" (${this.doc.uri.fsPath})`);r&&r!==`base`?xl.getChild(r).debug(o):xl.debug(o)}tryParse(e,t,r){try{return!t||!this.isValid(t)?void 0:r(t)}catch(r){this.logError(r,t,e);return}}tryMap(e,t,r){return A(t,t=>this.tryParse(e,t,r)??[])}resolveFqn(e){if(isImported(e)){let t=projectIdFrom(e),r=this.resolveFqn(Gr(e.imported.ref,`FqnRef is empty of imported: ${e.$cstNode?.text}`));return this.doc.c4Imports.set(t,r),vr(t,r)}return isExtendElement(e)?readStrictFqn(e.element):isExtendDeployment(e)?readStrictFqn(e.deploymentNode):isDeploymentElement(e)?this.services.likec4.DeploymentsIndex.getFqn(e):this.services.likec4.FqnIndex.getFqn(e)}getAstNodePath(e){return this.services.workspace.AstNodeLocator.getAstNodePath(e)}getMetadata(e){if(!e||!this.isValid(e)||j(e.props))return;let extractValues=e=>{if(isMarkdownOrString(e)){let t=removeIndent(e);if(!t)return[];if(typeof t==`string`)return k(t)?[t]:[];{let e=t.md||t.txt;return k(e)?[e]:[]}}else if(isMetadataArray(e))return e.values.map(e=>removeIndent(e)).map(e=>typeof e==`string`?e:e.md||e.txt).filter(k);return[]},t=F(e.props,A(e=>e.value?extractValues(e.value).map(t=>[e.key,t]):[[e.key,String(e.boolValue)]]),P(([e,t])=>k(t)));if(j(t))return;let r=F(t,tn(([e])=>e),on(e=>e.map(([e,t])=>t))),o={};for(let[e,t]of Object.entries(r))t&&t.length>0&&(o[e]=t.length===1?t[0]:t);return j(o)?void 0:o}parseMarkdownOrString(e){if(isMarkdownOrString(e))return removeIndent(e)}convertTags(e){return this.parseTags(e)}parseTags(e){let t=e?.tags;if(!t)return null;let r=[];for(;t;)r.push(...this.tryMap(`base`,t.values,e=>Gr(e.tag.ref,`Tag reference is not resolved`).name).filter(k)),t=t.prev;return Vr(r)?En(r):null}convertLinks(e){return this.parseLinks(e)}parseLinks(e){if(!e?.props||e.props.length===0)return;let t=this.tryMap(`base`,P(e.props,isLinkProperty),e=>{let t=e.value;if(Yt(t))return;let r=k(e.title)?toSingleLine(e.title):void 0,o=this.services.lsp.DocumentLinkProvider.relativeLink(this.doc,t);return Ar({url:t,title:r,relative:o&&o!==t?o:void 0})});return Vr(t)?t:void 0}parseIconProperty(e){if(!e||!this.isValid(e))return;let{libicon:t,value:r}=e;switch(!0){case!!t:{let r=t.ref?.name;if(!r){this.logError(`Library icon ${t.$refText} is not a valid library icon`,e);return}return r}case r&&r===`none`:return r;case r&&_t(r):if(r.startsWith(`file:`)){this.logError(`Icon property '${r}' used the 'file' protocol which is not supported`,e);return}return r;case r&&r.startsWith(`@`):return this.parseImageAlias(r);case r&&ft(r):return lt(this.doc.uri.toString(),`../`,r);case r&&mt(r):return ht(this.project.folderUri.toString(),r);default:this.logError(`Icon property '${r}' is not a valid URL, library icon, image alias or 'none'`,e);return}}parseImageAlias(e){let t=e.indexOf(`/`),r=t>0?e.substring(0,t):e,o=t>0?e.substring(t+1):``,s={"@":`./images`,...this.project.config.imageAliases}[r];if(!s){xl.warn(`Image alias "${r}" not found in project configuration`);return}let c=o?ht(s,o):s;return ht(this.project.folderUri.toString(),c)}parseColorLiteral(e){if(this.isValid(e)){if(isHexColor(e))return`#${e.hex}`;if(isRGBAColor(e)){let t=Ht(e.alpha)?e.alpha:void 0;return Nn(e.alpha)&&(t=parseAstPercent(e.alpha)/100),t===void 0?`rgb(${e.red},${e.green},${e.blue})`:`rgba(${e.red},${e.green},${e.blue},${t})`}H(e)}}parseElementStyle(e){if(!e)return{};if(Kt(e)){let t=this.parseStyleProps(e.find(isElementStyleProperty)?.props);try{let r=this.parseIconProperty(e.find(isIconProperty));r&&(t.icon=r)}catch(e){this.logError(e)}return t}return this.parseStyleProps(e.props)}parseStyleProps(e){let t={};if(!e||e.length===0)return t;for(let r of e)if(this.isValid(r))try{switch(!0){case isBorderProperty(r):k(r.value)&&(t.border=r.value);break;case isColorProperty(r):{let e=toColor(r);k(e)&&(t.color=e);break}case isShapeProperty(r):k(r.value)&&(t.shape=r.value);break;case isIconProperty(r):{let e=this.parseIconProperty(r);k(e)&&(t.icon=e);break}case isIconColorProperty(r):{let e=toColor(r);k(e)&&(t.iconColor=e);break}case isIconSizeProperty(r):k(r.value)&&(t.iconSize=parseAstSizeValue(r));break;case isIconPositionProperty(r):k(r.value)&&(t.iconPosition=parseAstIconPositionValue(r));break;case isOpacityProperty(r):t.opacity=parseAstOpacityProperty(r);break;case isMultipleProperty(r):t.multiple=Wt(r.value)?r.value:!1;break;case isShapeSizeProperty(r):k(r.value)&&(t.size=parseAstSizeValue(r));break;case isPaddingSizeProperty(r):k(r.value)&&(t.padding=parseAstSizeValue(r));break;case isTextSizeProperty(r):k(r.value)&&(t.textSize=parseAstSizeValue(r));break;default:H(r)}}catch(e){this.logError(e,r)}return Ar(t)}parseBaseProps(e,t){let r=removeIndent(t?.title??parseMarkdownAsString(e.title)),o=t?.description?{txt:removeIndent(t.description)}:this.parseMarkdownOrString(e.description);return Ar({title:r,summary:t?.summary?{txt:removeIndent(t.summary)}:this.parseMarkdownOrString(e.summary),description:o,technology:toSingleLine(t?.technology)??removeIndent(parseMarkdownAsString(e.technology))})}};function*streamDeploymentModel(e){let t=br.from(e.parseResult.value.deployments.flatMap(e=>e.elements)),r=[],o;for(;o=t.shift();){if(isDeploymentRelation(o)){r.push(o);continue}if(o.body&&o.body.elements.length>0)for(let e of o.body.elements)t.push(e);yield o}yield*r}function DeploymentModelParser(e){return class DeploymentModelParser extends e{parseDeployment(){let e=this.doc;for(let t of streamDeploymentModel(e))try{switch(!0){case isDeploymentRelation(t):this.isValid(t)&&e.c4DeploymentRelations.push(this.parseDeploymentRelation(t));break;case isDeployedInstance(t):e.c4Deployments.push(this.parseDeployedInstance(t));break;case isDeploymentNode$1(t):e.c4Deployments.push(this.parseDeploymentNode(t));break;case isExtendDeployment(t):{let r=this.parseExtendDeployment(t);r&&e.c4ExtendDeployments.push(r);break}default:H(t)}}catch(e){this.logError(e,t,`deployment`)}}parseDeploymentNode(e){let t=this.isValid,r=this.resolveFqn(e),o=Gr(e.kind.ref,`DeploymentKind not resolved`).name,s=this.parseTags(e.body)??void 0,c=this.parseLinks(e.body),u=this.parseElementStyle(e.body?.props),d=this.getMetadata(e.body?.props.find(isMetadataProperty)),p=F(e.body?.props??[],P(t),P(isElementStringProperty),Mn(e=>[e.key,e.value])),{title:m,...h}=this.parseBaseProps(p,{title:e.title,summary:e.summary});return Ar({id:r,kind:o,title:m??Wr(r),...h,tags:s,links:c,style:u,metadata:d})}parseDeployedInstance(e){let t=this.isValid,r=this.resolveFqn(e),o=this.parseFqnRef(e.target.modelElement);V(z.isModelRef(o)||z.isImportRef(o),`Target must be a model reference`);let s=this.parseTags(e.body)??void 0,c=this.parseElementStyle(e.body?.props),u=this.getMetadata(e.body?.props.find(isMetadataProperty)),d=F(e.body?.props??[],P(t),P(isElementStringProperty),Mn(e=>[e.key,e.value])),p=this.parseBaseProps(d,{title:e.title,summary:e.summary});return Ar({id:r,element:o,tags:s,links:this.parseLinks(e.body),...p,style:c,metadata:u})}parseExtendDeployment(e){let t=this.parseTags(e.body),r=this.getMetadata(e.body?.props.find(isMetadataProperty)),o=this.parseLinks(e.body);return!t&&j(r??{})&&!o?null:Ar({id:this.resolveFqn(e),astPath:this.getAstNodePath(e),metadata:r,tags:t,links:o})}_resolveDeploymentRelationSource(e){if(Xt(e.source))return this.parseFqnRef(e.source);if(e.$container.$type===`DeploymentNodeBody`||e.$container.$type===`DeployedInstanceBody`)return{deployment:this.resolveFqn(e.$container.$container)};throw Error(`RelationRefError: Invalid container for sourceless relation`)}parseDeploymentRelation(e){let t=this.isValid,r=this.getAstNodePath(e),o=this._resolveDeploymentRelationSource(e);V(z.isDeploymentRef(o),`Invalid source for deployment relation`);let s=this.parseFqnRef(e.target);V(z.isDeploymentRef(s),`Invalid target for deployment relation`);let c=this.convertTags(e)??this.convertTags(e.body)??void 0,u=this.convertLinks(e.body),d=(e.kind??e.dotKind?.kind)?.ref?.name,p=this.getMetadata(e.body?.props.find(isMetadataProperty)),m=F(e.body?.props??[],P(isRelationStringProperty),P(e=>k(e.value)),Mn(e=>[e.key,e.value])),h=F(e.body?.props??[],P(isRelationNavigateToProperty),Tn())?.value.view.ref?.name,g=this.parseBaseProps(m,{title:e.title}),_=e.body?.props.find(isRelationStyleProperty);return Ar({id:stringHash$1(`deployment`,this.docUri,r,o.deployment,s.deployment),source:o,target:s,...g,metadata:p,kind:d,tags:c,links:u,...toRelationshipStyle(_?.props,t),navigateTo:h,astPath:r})}}}function DeploymentViewParser(e){return class DeploymentViewParser extends e{parseDeploymentView(e){let t=e.body;V(t,`DynamicElementView body is not defined`);let r=t.props.filter(this.isValid),o=this.getAstNodePath(e),s=e.name;s||=`deployment_`+stringHash$1(this.doc.uri.toString(),o);let{title:c=null,description:u=null}=this.parseBaseProps(F(r,P(isViewStringProperty),Mn(e=>[e.key,e.value]))),d=this.convertTags(t),p=this.convertLinks(t);return Ac.writeId(e,s),{[mr._type]:`deployment`,id:s,astPath:o,title:toSingleLine(c)??null,description:u,tags:d,links:Vr(p)?p:null,rules:this.tryMap(`deployment`,t.rules,e=>this.parseDeploymentViewRule(e))}}parseDeploymentViewRule(e){if(isDeploymentViewRulePredicate(e))return this.parseDeploymentViewRulePredicate(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);if(isViewRuleAncestors(e))return{includeAncestors:e.value};if(isDeploymentViewRuleStyle(e))return this.parseDeploymentViewRuleStyle(e);H(e)}parseDeploymentViewRulePredicate(e){let t=[],r=e.expr;for(;r;){try{let e=r.value;D(e)&&this.isValid(e)&&t.unshift(this.parseExpressionV2(e))}catch(e){logWarnError(e)}r=r.prev}return e.isInclude?{include:t}:{exclude:t}}parseDeploymentViewRuleStyle(e){let t=this.parseStyleProps(e.props.filter(isStyleProperty)),r=removeIndent(parseMarkdownAsString(e.props.find(isNotationProperty)?.value));return{targets:this.parseFqnExpressions(e.targets),style:t,...r&&{notation:r}}}}}const parseMetadataEquals=({operator:e,not:t},r)=>e?.startsWith(`!=`)?{neq:r}:e?.startsWith(`=`)?{eq:r}:t?{neq:r}:{eq:r},parseEquals=({operator:e,not:t},r)=>e.startsWith(`!=`)?{neq:r}:e.startsWith(`=`)?{eq:r}:t?{neq:r}:{eq:r};function parseParticipant(e){return!isWhereRelationParticipantKind(e)&&!isWhereRelationParticipantTag(e)&&!isWhereRelationParticipantMetadata(e)?null:e.participant}function parseWhereClause(e){switch(!0){case isWhereTagEqual(e):{let t=e.value.tag.ref?.name,r=parseParticipant(e);V(t,`Expected tag name`);let o={tag:parseEquals(e,t)};return r?{participant:r,operator:o}:o}case isWhereKindEqual(e):{let t=e.value?.ref?.name,r=parseParticipant(e);V(t,`Expected kind name`);let o={kind:parseEquals(e,t)};return r?{participant:r,operator:o}:o}case isWhereMetadataEqual(e):{let t=e.key,r=parseParticipant(e);V(t,`Expected metadata key`);let o={metadata:{key:t,...e.value==null?{}:{value:parseMetadataEquals(e,String(e.value))}}};return r?{participant:r,operator:o}:o}case isWhereElementNegation(e)||isWhereRelationNegation(e):return{not:parseWhereClause(e.value)};case isWhereBinaryExpression(e):{let t=parseWhereClause(e.left),r=parseWhereClause(e.right);return createBinaryOperator(e.operator.toLowerCase(),t,r)}default:H(e)}}function createBinaryOperator(e,t,r){if(r===null)return t;switch(e){case`and`:{let e=[Pr(t)?t.and:t,Pr(r)?r.and:r].flat();return V(Vr(e),`Expected non-empty array`),{and:e}}case`or`:{let e=[Hr(t)?t.or:t,Hr(r)?r.or:r].flat();return V(Vr(e),`Expected non-empty array`),{or:e}}default:H(e)}}function ExpressionV2Parser(e){return class ExpressionV2Parser extends e{parseFqnRef(e){let t=Gr(e.value?.ref,()=>`Element "${e.$cstNode?.text}" is not resolved`);if(isImported(t)){let e={project:projectIdFrom(t),model:this.resolveFqn(Gr(t.imported.ref,`Imported "${t.$cstNode?.text}" is not resolved`))};return this.doc.c4Imports.set(e.project,e.model),e}if(isElement(t)){let r=importsRef(e);if(r){let e={project:projectIdFrom(r),model:this.resolveFqn(t)};return this.doc.c4Imports.set(e.project,e.model),e}let o=instanceRef(e);return o?{deployment:this.resolveFqn(o),element:this.resolveFqn(t)}:{model:this.resolveFqn(t)}}if(isDeploymentElement(t))return{deployment:this.resolveFqn(t)};H(t)}parseExpressionV2(e){if(isFqnExprOrWith(e))return this.parseFqnExprOrWith(e);if(isRelationExprOrWith(e))return this.parseRelationExprOrWith(e);H(e)}parseFqnExprOrWith(e){if(isFqnExprWith(e))return this.parseFqnExprWith(e);if(isFqnExprOrWhere(e))return this.parseFqnExprOrWhere(e);H(e)}parseFqnExprWith(e){let t=this.parseFqnExprOrWhere(e.subject);return(e.custom?.props??[]).reduce((e,t)=>{if(!this.isValid(t))return e;if(isNavigateToProperty(t)){let r=t.value.view.$refText;return k(r)&&(e.custom.navigateTo=r),e}if(isNotesProperty(t)){let r=this.parseMarkdownOrString(t.value);return r&&(e.custom[t.key]=r),e}if(isElementStringProperty(t)){if(t.key===`description`||t.key===`summary`){let r=this.parseMarkdownOrString(t.value);return r&&(e.custom.description=r),e}let r=removeIndent(parseMarkdownAsString(t.value));return r&&(e.custom[t.key]=r),e}if(isIconProperty(t)){let r=this.parseIconProperty(t);return Xt(r)&&(e.custom[t.key]=r),e}if(isColorProperty(t)){let r=toColor(t);return Xt(r)&&(e.custom[t.key]=r),e}if(isShapeProperty(t)||isBorderProperty(t))return Xt(t.value)&&(e.custom[t.key]=t.value),e;if(isOpacityProperty(t))return Xt(t.value)&&(e.custom[t.key]=parseAstOpacityProperty(t)),e;if(isIconColorProperty(t)){let r=toColor(t);return Xt(r)&&(e.custom[t.key]=r),e}if(isNotationProperty(t)){let r=k(t.value)?removeIndent(parseMarkdownAsString(t.value)):void 0;return r&&(e.custom[t.key]=r),e}if(isMultipleProperty(t))return Wt(t.value)&&(e.custom[t.key]=t.value),e;if(isShapeSizeProperty(t)||isTextSizeProperty(t)||isPaddingSizeProperty(t)||isIconSizeProperty(t))return k(t.value)&&(e.custom[t.key]=parseAstSizeValue(t)),e;if(isIconPositionProperty(t))return k(t.value)&&(e.custom[t.key]=t.value),e;H(t)},{custom:{expr:t}})}parseFqnExprOrWhere(e){if(isFqnExprWhere(e))return this.parseFqnExprWhere(e);if(isFqnExpr(e))return this.parseFqnExpr(e);H(e)}parseFqnExprWhere(e){return V(!isFqnExprWhere(e.subject),`FqnExprWhere is not allowed as subject of FqnExprWhere`),{where:{expr:this.parseFqnExpr(e.subject),condition:e.where?parseWhereClause(e.where):{kind:{neq:`--always-true--`}}}}}parseFqnExpr(e){if(isWildcardExpression(e))return{wildcard:!0};if(isElementKindExpression(e))return V(e.kind?.ref,`ElementKind "${e.$cstNode?.text}" is not resolved`),{elementKind:e.kind.ref.name,isEqual:e.isEqual};if(isElementTagExpression(e))return V(e.tag.tag.ref,`Tag ${e.$cstNode?.text} is not resolved`),{elementTag:e.tag.tag.$refText,isEqual:e.isEqual};if(isFqnRefExpr(e))return this.parseFqnRefExpr(e);H(e)}parseFqnRefExpr(e){let t=this.parseFqnRef(e.ref);switch(!0){case e.selector===`._`:return{ref:t,selector:`expanded`};case e.selector===`.**`:return{ref:t,selector:`descendants`};case e.selector===`.*`:return{ref:t,selector:`children`};default:return{ref:t}}}parseFqnExpressions(e){let t=[],r=e;for(;r;){try{D(r.value)&&this.isValid(r.value)&&t.push(this.parseFqnExpr(r.value))}catch(e){this.logError(e,r.value,`fqnref`)}r=r.prev}return t.reverse()}parseRelationExprOrWith(e){if(isRelationExprWith(e))return this.parseRelationExprWith(e);if(isRelationExprOrWhere(e))return this.parseRelationExprOrWhere(e);H(e)}parseRelationExprWith(e){let t=this.parseRelationExprOrWhere(e.subject);return{customRelation:{...this.parseCustomRelationProperties(e.custom),expr:t}}}parseCustomRelationProperties(e){return(e?.props??[]).reduce((e,t)=>{if(isNotesProperty(t)){let r=this.parseMarkdownOrString(t.value);return r&&(e[t.key]=r),e}if(isRelationStringProperty(t)||isNotationProperty(t)){if(t.key===`description`){let r=this.parseMarkdownOrString(t.value);return r&&(e.description=r),e}let r=removeIndent(parseMarkdownAsString(t.value));return r&&(e[t.key]=r),e}if(isArrowProperty(t))return k(t.value)&&(e[t.key]=t.value),e;if(isColorProperty(t)){let r=toColor(t);return k(r)&&(e[t.key]=r),e}if(isLineProperty(t))return k(t.value)&&(e[t.key]=t.value),e;if(isRelationNavigateToProperty(t)){let r=t.value.view.ref?.name;return k(r)&&(e[t.key]=r),e}if(isMultipleProperty(t))return Wt(t.value)&&(e[t.key]=t.value),e;H(t)},{})}parseRelationExprOrWhere(e){if(isRelationExprWhere(e))return this.parseRelationExprWhere(e);if(isRelationExpr(e))return this.parseRelationExpr(e);H(e)}parseRelationExprWhere(e){V(!isRelationExprWhere(e.subject),`RelationExprWhere is not allowed as subject of RelationExprWhere`);let t=this.parseRelationExpr(e.subject),r=t.where?.expr??t,o=t.where?.condition,s=e.where?parseWhereClause(e.where):null,c;return c=s&&o?createBinaryOperator(`and`,o,s):s??o??{kind:{neq:`--always-true--`}},{where:{expr:r,condition:c}}}parseRelationExpr(e){switch(e.$type){case`DirectedRelationExpr`:return this.wrapInWhere({source:this.parseFqnExpr(e.source.from),target:this.parseFqnExpr(e.target),isBidirectional:e.source.isBidirectional},this.parseInlineKindCondition(e.source));case`InOutRelationExpr`:return{inout:this.parseFqnExpr(e.inout.to)};case`OutgoingRelationExpr`:return this.wrapInWhere({outgoing:this.parseFqnExpr(e.from)},this.parseInlineKindCondition(e));case`IncomingRelationExpr`:return{incoming:this.parseFqnExpr(e.to)};default:H(e)}}parseInlineKindCondition(e){let t=e.kind??e.dotKind?.kind;return t?t.ref?{kind:{eq:t.ref?.name}}:(this.logError(`RelationshipKind "${t.$refText}" is not resolved`,e,`fqnref`),null):null}wrapInWhere(e,t){return t?{where:{expr:e,condition:t}}:e}}}function GlobalsParser(e){return class GlobalsParser extends e{parseGlobals(){let{parseResult:e,c4Globals:t}=this.doc,r=this.isValid,o=e.value.globals.filter(r),s=o.flatMap(e=>e.predicates.filter(r));for(let e of s)try{let r=e.name;if(!k(r))continue;if(r in t.predicates){this.logError(`Global predicate named "${r}" is already defined`,e,`globals`);continue}this.parseAndStoreGlobalPredicateGroupOrDynamic(e,r,t)}catch(t){this.logError(t,e,`globals`)}let c=o.flatMap(e=>e.styles.filter(r));for(let e of c)try{let r=e.id.name;if(!k(r))continue;if(r in t.styles){this.logError(`Global style named "${r}" is already defined`,e,`globals`);continue}let o=this.parseGlobalStyleOrGroup(e);N(o,1)&&(t.styles[r]=o)}catch(t){this.logError(t,e,`globals`)}}parseAndStoreGlobalPredicateGroupOrDynamic(e,t,r){if(isGlobalPredicateGroup(e)){let o=this.parseGlobalPredicateGroup(e);N(o,1)&&(r.predicates[t]=o);return}if(isGlobalDynamicPredicateGroup(e)){let o=this.parseGlobalDynamicPredicateGroup(e);N(o,1)&&(r.dynamicPredicates[t]=o);return}H(e)}parseGlobalPredicateGroup(e){return e.predicates.map(e=>this.parseViewRulePredicate(e))}parseGlobalDynamicPredicateGroup(e){return e.predicates.map(e=>this.parseDynamicViewIncludePredicate(e))}parseGlobalStyleOrGroup(e){if(isGlobalStyle(e))return[this.parseViewRuleStyle(e)];if(isGlobalStyleGroup(e))return e.styles.map(e=>this.parseViewRuleStyle(e));H(e)}}}function ImportsParser(e){return class ImportsParser extends e{parseImports(){let e=this.doc.parseResult.value.imports??[];for(let t of e){let e=t.project,r=t.imports;for(;r;){try{this.doc.c4Imports.set(e,this.resolveFqn(Gr(r.imported.ref,`ElementRef is empty of imported: ${r.imported.$refText}`)))}catch(e){this.logError(e,r,`imports`)}r=r.prev}}}}}function*streamModel(e){let t=br.from(e.parseResult.value.models.flatMap(e=>e.elements)),r=[],o;for(;o=t.shift();){if(isRelation(o)){r.push(o);continue}if(isExtendRelation(o)){r.push(o);continue}if(o.body?.elements&&N(o.body.elements,1))for(let e of o.body.elements)t.push(e);yield o}yield*r}function ModelParser(e){return class ModelParser extends e{parseModel(){let e=this.doc;for(let t of streamModel(e))try{if(isElement(t)){e.c4Elements.push(this.parseElement(t));continue}if(isRelation(t)){e.c4Relations.push(this.parseRelation(t));continue}if(isExtendElement(t)){let r=this.parseExtendElement(t);r&&e.c4ExtendElements.push(r);continue}if(isExtendRelation(t)){let r=this.parseExtendRelation(t);r&&e.c4ExtendRelations.push(r);continue}H(t)}catch(e){this.logError(e,t,`model`)}}parseElement(e){let t=this.isValid,r=this.resolveFqn(e),o=Gr(e.kind.ref,`Element kind is not resolved`).name,s=this.parseTags(e.body),c=this.parseElementStyle(e.body?.props),u=this.getMetadata(e.body?.props.find(isMetadataProperty)),d=this.getAstNodePath(e),[p,m,h]=e.props??[],g=F(e.body?.props??[],P(t),P(isElementStringProperty),Mn(e=>[e.key,e.value])),{title:_,...v}=this.parseBaseProps(g,{title:p,summary:m,technology:h});return fr({id:r,kind:o,astPath:d,title:_,metadata:u,tags:s??void 0,links:this.parseLinks(e.body),...v,style:c})}parseExtendElement(e){let t=this.parseTags(e.body),r=this.getMetadata(e.body?.props.find(isMetadataProperty)),o=this.parseLinks(e.body);if(!t&&Yt(r)&&!o)return null;let s=this.getAstNodePath(e);return fr({id:this.resolveFqn(e),astPath:s,metadata:r,tags:t,links:o})}parseExtendRelation(e){let t=this.parseFqnRef(e.source),r=this.parseFqnRef(e.target);V(L.isModelRef(t)||L.isImportRef(t),`Source must be a model reference`),V(L.isModelRef(r)||L.isImportRef(r),`Target must be a model reference`);let o=this.parseTags(e.body),s=this.getMetadata(e.body?.props.find(isMetadataProperty)),c=this.getAstNodePath(e),u=this.parseLinks(e.body);if(!o&&j(s??{})&&!u)return null;let d=(e.kind??e.dotKind?.kind)?.ref?.name,{title:p=``}=this.parseBaseProps({},{title:e.title});return fr({id:stringHash$1(`extend-relation`,L.flatten(t),L.flatten(r),d??`default`,p),astPath:c,metadata:s,tags:o,links:u})}_resolveRelationSource(e){if(Xt(e.source)){let t=this.parseFqnRef(e.source);return V(L.isModelRef(t)||L.isImportRef(t),`Relation source must be a model reference`),t}if(isElementBody(e.$container)||isExtendElementBody(e.$container))return{model:this.resolveFqn(e.$container.$container)};throw Error(`RelationRefError: Invalid container for sourceless relation`)}parseRelation(e){let t=this.isValid,r=this._resolveRelationSource(e),o=this.parseFqnRef(e.target);V(L.isModelRef(o)||L.isImportRef(o),`Target must be a model reference`);let s=this.parseTags(e)??this.parseTags(e.body)??void 0,c=this.parseLinks(e.body),u=(e.kind??e.dotKind?.kind)?.ref?.name,d=this.getMetadata(e.body?.props.find(isMetadataProperty)),p=this.getAstNodePath(e),m=F(e.body?.props??[],P(isRelationStringProperty),P(e=>k(e.value)),Mn(e=>[e.key,e.value])),h=F(e.body?.props??[],P(isRelationNavigateToProperty),I(e=>e.value.view.ref?.name),P(k),Tn()),{title:g=``,description:_,technology:v}=this.parseBaseProps(m,{title:e.title,description:e.description,technology:e.technology}),y=e.body?.props.find(isRelationStyleProperty);return fr({id:stringHash$1(this.docUri,p,L.flatten(r),L.flatten(o)),astPath:p,source:r,target:o,title:g,metadata:d,kind:u,tags:s,links:c,navigateTo:h,description:_,technology:v,...toRelationshipStyle(y?.props,t)})}}}function PredicatesParser(e){return class PredicatesParser extends e{parsePredicate(e){return this.parseExpressionV2(e)}parseElementPredicate(e){if(isFqnExprWith(e))return this.parseFqnExprWith(e);if(isFqnExprOrWhere(e))return this.parseFqnExprOrWhere(e);H(e)}parseElementPredicateOrWhere(e){return this.parseFqnExprOrWhere(e)}parseElementExpression(e){return this.parseFqnExpr(e)}parseElementPredicateWhere(e){return this.parseFqnExprWhere(e)}parseElementPredicateWith(e){return this.parseFqnExprWith(e)}parseRelationPredicate(e){return this.parseRelationExprOrWith(e)}parseRelationPredicateOrWhere(e){return this.parseRelationExprOrWhere(e)}parseRelationPredicateWhere(e){return this.parseRelationExprWhere(e)}parseRelationPredicateWith(e){return this.parseRelationExprWith(e)}parseRelationExpression(e){return this.parseRelationExpr(e)}}}function SpecificationParser(e){return class SpecificationParser extends e{parseSpecification(){let{parseResult:{value:{specifications:e}},c4Specification:t}=this.doc,r=this.isValid;for(let o of e.flatMap(e=>e.elements.filter(r)))try{Object.assign(t.elements,this.parseElementSpecificationNode(o))}catch(e){this.logError(e,o,`specification`)}for(let o of e.flatMap(e=>e.deploymentNodes.filter(r)))try{Object.assign(t.deployments,this.parseElementSpecificationNode(o))}catch(e){this.logError(e,o,`specification`)}let o=e.flatMap(e=>e.relationships.filter(this.isValid));for(let{kind:e,props:r}of o)try{let o=e.name;if(!k(o))continue;if(o in t.relationships){this.logError(`Relationship kind "${o}" is already defined`,e,`specification`);continue}let s=F(r.filter(isSpecificationRelationshipStringProperty)??[],P(e=>this.isValid(e)&&D(e.value)),Mn(e=>[e.key,removeIndent(parseMarkdownAsString(e.value))]),mn(M)),c=r.filter(isMultipleProperty);c.length>1&&this.logError(`Duplicate 'multiple' property for relationship "${o}", using the first one`,e,`specification`);let u=c[0];t.relationships[o]={...s,...toRelationshipStyle(r.filter(isRelationshipStyleProperty),this.isValid),...u&&{multiple:u.value}}}catch(t){this.logError(t,e,`specification`)}let s=e.flatMap(e=>e.tags.filter(this.isValid));for(let e of s)try{let r=e.tag.name,o=this.getAstNodePath(e.tag),s=e.color&&this.parseColorLiteral(e.color);if(r in t.tags){this.logError(`Tag ${r} is already defined, skipping duplicate`,e,`specification`);continue}k(r)&&(t.tags[r]={astPath:o,...s?{color:s}:{}})}catch(t){this.logError(t,e,`specification`)}let c=e.flatMap(e=>e.colors.filter(r));for(let{name:e,color:r}of c)try{let o=e.name;if(o in t.colors){this.logError(`Custom color "${o}" is already defined`,e,`specification`);continue}t.colors[o]={color:si(this.parseColorLiteral(r),`Color "${o}" is not valid`)}}catch(e){this.logError(e,r,`specification`)}}parseElementSpecificationNode(e){let{kind:t,props:r}=e,o=t.name;if(!k(o))throw Error(`DeploymentNodeKind name is not resolved`);let s=this.parseTags(e),c=this.parseElementStyle(r.find(isElementStyleProperty)),u=this.parseLinks(e),d=F(r.filter(isSpecificationElementStringProperty)??[],P(e=>this.isValid(e)),Mn(e=>[e.key,e.value])),p=this.parseBaseProps(d),m=removeIndent(parseMarkdownAsString(d.notation));return{[o]:Ar({...p,notation:m,tags:s??void 0,...u&&mr.isNonEmptyArray(u)&&{links:u},style:c})}}}}function ViewsParser(e){return class ViewsParser extends e{parseViews(){let e=this.isValid;for(let t of this.doc.parseResult.value.views){let r=t.styles.flatMap(t=>{try{return e(t)?this.parseViewRuleStyleOrGlobalRef(t):[]}catch(e){return this.logError(e,t,`views`),[]}}),o=t.folder&&!j(t.folder.trim())?toSingleLine(t.folder):null;for(let s of t.views)try{if(!e(s))continue;switch(!0){case isElementView$1(s):this.doc.c4Views.push(this.parseElementView(s,r));break;case isDynamicView$1(s):this.doc.c4Views.push(this.parseDynamicElementView(s,r));break;case isDeploymentView$1(s):this.doc.c4Views.push(this.parseDeploymentView(s));break;default:H(s)}if(o){let e=this.doc.c4Views.at(-1);e.title=o+` / `+(e.title||e.id)}}catch(e){this.logError(e,s,`views`)}}}parseElementView(e,t){let r=e.body;V(r,`ElementView body is not defined`);let o=this.getAstNodePath(e),s=null;if(`viewOf`in e){let t=elementRef(e.viewOf),r=t&&safeCall(()=>this.resolveFqn(t));if(r)s=r;else{let t=e.name??`unnamed`,r=e.viewOf.$cstNode?.text??`<unknown>`;this.logError(`viewOf ${t} not resolved ${r}`,e.viewOf)}}let c=e.name;c||=`view_`+stringHash$1(this.doc.uri.toString(),o,s??``);let{title:u=null,description:d=null}=this.parseBaseProps(F(r.props,P(e=>this.isValid(e)),P(isViewStringProperty),Mn(e=>[e.key,e.value]))),p=this.convertTags(r),m=this.convertLinks(r),h={[mr._type]:`element`,id:c,astPath:o,title:toSingleLine(u)??null,description:d,tags:p,links:Vr(m)?m:null,rules:[...t,...this.tryMap(`views`,r.rules,e=>this.parseElementViewRule(e))],...s&&{viewOf:s}};if(Ac.writeId(e,h.id),`extends`in e){let t=e.extends.view.ref;return V(t?.name,`view extends is not resolved: `+e.$cstNode?.text),Object.assign(h,{extends:t.name})}return h}parseElementViewRule(e){if(isViewRulePredicate(e))return this.parseViewRulePredicate(e);if(isViewRuleGlobalPredicateRef(e))return this.parseViewRuleGlobalPredicateRef(e);if(isViewRuleStyleOrGlobalRef(e))return this.parseViewRuleStyleOrGlobalRef(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);if(isViewRuleGroup(e))return this.parseViewRuleGroup(e);if(isViewRuleRank(e))return this.parseViewRuleRank(e);H(e)}parseViewRulePredicate(e){let t=[],r=e.exprs;for(;r;){let{value:e,prev:o}=r;if(this.tryParse(`views`,e,()=>{let r=this.parsePredicate(e);t.unshift(r)}),!o)break;r=o}return e.isInclude?{include:t}:{exclude:t}}parseViewRuleGlobalPredicateRef(e){return{predicateId:e.predicate.$refText}}parseViewRuleStyleOrGlobalRef(e){if(isViewRuleStyle(e))return this.parseViewRuleStyle(e);if(isViewRuleGlobalStyle(e))return this.parseViewRuleGlobalStyle(e);H(e)}parseViewRuleGroup(e){let t=[];for(let r of e.groupRules)try{if(!this.isValid(r))continue;if(isViewRulePredicate(r)){t.push(this.parseViewRulePredicate(r));continue}if(isViewRuleGroup(r)){t.push(this.parseViewRuleGroup(r));continue}H(r)}catch(e){this.logError(e,r,`views`)}return{title:toSingleLine(e.title)??null,groupRules:t,...this.parseStyleProps(e.props)}}parseViewRuleRank(e){let t=this.parseFqnExpressions(e.targets).filter(e=>mr.ModelExpression.isFqnExpr(e));return{rank:e.value??`same`,targets:t}}parseViewRuleStyle(e){let t=this.parseFqnExpressions(e.targets).filter(e=>mr.ModelExpression.isFqnExpr(e)),r=this.parseStyleProps(e.props.filter(isStyleProperty)),o=removeIndent(parseMarkdownAsString(e.props.find(isNotationProperty)?.value));return{targets:t,style:r,...o&&{notation:o}}}parseViewRuleGlobalStyle(e){return{styleId:e.style.$refText}}parseDynamicElementView(e,t){let r=e.body;V(r,`DynamicElementView body is not defined`);let o=this.isValid,s=r.props.filter(o),c=this.getAstNodePath(e),u=e.name;u||=`dynamic_`+stringHash$1(this.doc.uri.toString(),c);let{title:d=null,description:p=null}=this.parseBaseProps(F(s,P(isViewStringProperty),Mn(e=>[e.key,e.value]))),m=this.convertTags(r),h=this.convertLinks(r);Ac.writeId(e,u);let g=rn(s,isDynamicViewDisplayVariantProperty)?.value;return{[mr._type]:`dynamic`,id:u,astPath:c,title:toSingleLine(d)??null,description:p,tags:m,links:Vr(h)?h:null,variant:g,rules:[...t,...this.tryMap(`views`,r.rules,e=>this.parseDynamicViewRule(e))],steps:this.tryMap(`views`,r.steps,e=>isDynamicViewParallelSteps(e)?this.parseDynamicParallelSteps(e):this.parseDynamicStep(e))}}parseDynamicViewRule(e){if(isDynamicViewIncludePredicate(e))return this.parseDynamicViewIncludePredicate(e);if(isDynamicViewGlobalPredicateRef(e))return this.parseViewRuleGlobalPredicateRef(e);if(isViewRuleStyleOrGlobalRef(e))return this.parseViewRuleStyleOrGlobalRef(e);if(isViewRuleAutoLayout(e))return toAutoLayout(e);H(e)}parseDynamicViewIncludePredicate(e){let t=[],r=e.exprs;for(;r;)this.tryParse(`views`,r.value,e=>{if(isFqnExprOrWith(e)){let r=this.parseElementPredicate(e);t.unshift(r)}}),r=r.prev;return{include:t}}parseDynamicParallelSteps(e){let t=pathInsideDynamicView(e),r=e.steps.filter(e=>!isDynamicViewParallelSteps(e)),o=this.tryMap(`views`,r,e=>this.parseDynamicStep(e));return V(Vr(o),`Dynamic parallel steps must have at least one step`),{parallelId:t,__parallel:o}}parseDynamicStep(e){if(isDynamicStepSingle(e))return this.parseDynamicStepSingle(e);let t=this.recursiveParseDynamicStepChain(e);return V(Vr(t),`Dynamic step chain must have at least one step`),{seriesId:pathInsideDynamicView(e),__series:t}}recursiveParseDynamicStepChain(e,t){if(isDynamicStepSingle(e.source)){if(!this.isValid(e.source))return[];let r=this.parseDynamicStepSingle(e.source);if(r.isBackward)return[];let o={...this.parseAbstractDynamicStep(e),source:r.target};return o.target===r.source?o.isBackward=!0:t&&(t.push([r.source,r.target]),t.push([o.source,o.target])),[r,o]}t??=[];let r=this.recursiveParseDynamicStepChain(e.source,t);if(!Vr(r)||!this.isValid(e))return[];let o=ln(r),s={...this.parseAbstractDynamicStep(e),source:o.target},c=t.findIndex(([e,t])=>e===s.target&&t===s.source);return c===-1?t.push([s.source,s.target]):(s.isBackward=!0,t.splice(c,t.length-c)),[...r,s]}parseDynamicStepSingle(e){let t=elementRef(e.source);if(!t)throw Error(`Invalid reference to source`);let r={...this.parseAbstractDynamicStep(e),source:this.resolveFqn(t)};return e.isBackward&&(r={...r,source:r.target,target:r.source,isBackward:!0}),r}parseAbstractDynamicStep(e){let t=elementRef(e.target);if(!t)throw Error(`Invalid reference to target`);let r={target:this.resolveFqn(t),astPath:pathInsideDynamicView(e)},o=removeIndent(e.title);o&&(r.title=o);let s=e.kind?.ref?.name??e.dotKind?.kind.ref?.name;s&&(r.kind=s);for(let t of e.custom?.props??[])try{switch(!0){case isRelationNavigateToProperty(t):{let e=t.value.view.ref?.name;k(e)&&(r.navigateTo=e);break}case isRelationStringProperty(t):case isNotationProperty(t):if(Xt(t.value))if(t.key===`description`){let e=removeIndent(t.value);e&&(r.description=e)}else r[t.key]=removeIndent(parseMarkdownAsString(t.value))??``;break;case isNotesProperty(t):Xt(t.value)&&(r[t.key]=removeIndent(t.value));break;case isArrowProperty(t):Xt(t.value)&&(r[t.key]=t.value);break;case isColorProperty(t):{let e=toColor(t);Xt(e)&&(r[t.key]=e);break}case isLineProperty(t):Xt(t.value)&&(r[t.key]=t.value);break;case isMultipleProperty(t):break;default:H(t)}}catch(e){this.logError(e,t,`views`)}return r}}}function pathInsideDynamicView(e){let t=e,r=[];for(;!isDynamicViewBody(t);)Ht(t.$containerIndex)&&r.unshift(`@${t.$containerIndex}`),r.unshift(`/${t.$containerProperty??`__invalid__`}`),t=t.$container;return r.join(``)}Pe();const Sl=F(BaseParser,ExpressionV2Parser,ImportsParser,ModelParser,DeploymentModelParser,DeploymentViewParser,PredicatesParser,SpecificationParser,ViewsParser,GlobalsParser);var DocumentParser=class extends Sl{};const Cl=q.getChild(`parser`),isError=e=>e.severity===me.Error;var LikeC4ModelParser=class extends ADisposable{services;cachedParsers=new Yr(e=>this.createParser(e));constructor(e){super(),this.services=e,this.onDispose(b.create(()=>{this.cachedParsers.clear()}),e.shared.workspace.DocumentBuilder.onDocumentPhase(w.Linked,async e=>{this.cachedParsers.has(e)&&(Cl.trace(`Linked: clear cached parser {projectId} document {doc}`,{projectId:e.likec4ProjectId,doc:S.basename(e.uri)}),this.cachedParsers.delete(e))}),e.shared.workspace.DocumentBuilder.onBuildPhase(w.Linked,async t=>{for(let r of t)if(!e.shared.workspace.ProjectsManager.isExcluded(r))try{this.parse(r)}catch(e){logWarnError(e)}}),e.shared.workspace.DocumentBuilder.onDocumentPhase(w.Validated,async e=>{e.diagnostics?.some(isError)&&this.cachedParsers.has(e)&&(Cl.trace(`Validated: clear cached parser {projectId} document {doc} because of errors`,{projectId:e.likec4ProjectId,doc:S.basename(e.uri)}),this.cachedParsers.delete(e))}))}documents(e){return this.services.shared.workspace.LangiumDocuments.projectDocuments(e).map(e=>this.parse(e))}parse(e){return this.forDocument(e).doc}forDocument(e){return this.cachedParsers.get(e)}createParser(e){W(isLikeC4LangiumDocument(e),`Document ${e.uri.toString()} is not a LikeC4 document`);let t=this.services.shared.workspace.ProjectsManager.getProject(e),r=S.relative(t.folderUri,e.uri);e.likec4ProjectId?Cl.trace(`create parser {projectId} document {doc}`,{projectId:e.likec4ProjectId,doc:r}):Cl.debug(`create parser for document without project {doc}`,{doc:e.uri.fsPath}),e.state<w.Linked&&Cl.debug(`Document {doc} is not linked, state is {state}`,{doc:r,state:e.state});let o={c4Specification:{tags:{},elements:{},relationships:{},colors:{},deployments:{}},c4Elements:[],c4ExtendElements:[],c4ExtendDeployments:[],c4ExtendRelations:[],c4Relations:[],c4Deployments:[],c4DeploymentRelations:[],c4Globals:{predicates:{},dynamicPredicates:{},styles:{}},c4Views:[],c4Imports:new U(Set)};e=Object.assign(e,o);let s=new DocumentParser(this.services,e,t);try{s.parseSpecification(),s.parseImports(),s.parseModel(),s.parseDeployment(),s.parseGlobals(),s.parseViews()}catch(e){throw Error(`Error parsing document ${r}`,{cause:e})}return s}},LikeC4ValueConverter=class extends Ke{runConverter(e,t,r){return e.name===`MarkdownString`?((t.startsWith(`"""`)&&t.endsWith(`"""`)||t.startsWith(`'''`)&&t.endsWith(`'''`))&&(t=t.slice(2,-2)),ne.convertString(t)):super.runConverter(e,t,r)}};Pe();const{findNodeForKeyword:wl}=Ce,asViewStyleRule=(e,t,r=0)=>{let o=r>0?` `.repeat(r):``;return[o+`style ${e} {`,...an(t).map(([e,t])=>o+` ${e} ${e===`opacity`?t.toString()+`%`:t}`),o+`}`]},isMatchingViewRule=(e,t)=>r=>{if(!isViewRuleStyle(r)&&!isDeploymentViewRuleStyle(r))return!1;let o=r.targets.value;if(!o||k(r.targets.prev)||o.$type!==`FqnRefExpr`||k(o.selector))return!1;let s=o.ref?.value?.ref;return(s?t.resolve(s):null)===e};function changeElementStyle(e,{view:t,viewAst:r,targets:o,style:s}){V(r.body,`View ${t.id} has no body`);let c=r.$cstNode;V(c,`viewCstNode`);let u=ln(r.body.rules)?.$cstNode?.range.end??r.body.$cstNode?.range.end;V(u,`insertPos is not defined`);let d=c.range.start.character+2,p=e.likec4.FqnIndex,m=P(r.body.rules,e=>isViewRuleStyle(e)||isDeploymentViewRuleStyle(e)),h=t[Tr]===`element`?t.viewOf??null:null,g=[],_=[];o.forEach(e=>{let t=qt(m,isMatchingViewRule(e,p)),r=h&&Nr(h,e)?e.substring(h.length+1):e;t?g.push({fqn:r,rule:t}):_.push({fqn:r})});let v={start:u,end:u},includeRange=e=>{e.start.line<=v.start.line&&(e.start.line==v.start.line?v.start.character=Math.min(e.start.character,v.start.character):v.start=e.start),e.end.line>=v.end.line&&(e.end.line==v.end.line?v.end.character=Math.max(e.end.character,v.end.character):v.end=e.end)},y=[];if(_.length>0){let e=_.flatMap(({fqn:e})=>asViewStyleRule(e,s,d));y.push(Je.insert(u,`
|
|
84
95
|
`+e.join(`
|
|
85
|
-
`))),
|
|
86
|
-
`+
|
|
87
|
-
`)}function executeOnCtx(e,t,...
|
|
88
|
-
`)?multilineText(r)({ctx:r,out:n}):inlineText()({ctx:r,out:n})})}const _l=`'`.repeat(3);function markdown(e){return operation(function markdown(t){let n=e??t.ctx;if(!O(n))return z(Mn(n),`Value must be a string - got `+typeof n),multilineText(n,_l)(t)})}function markdownOrString$1(e){return operation(function markdownOrString(t){let n=e??t.ctx;if(!O(n)){if(typeof n==`string`)return text(n)(t);if(`md`in n)return markdown(n.md)(t);if(`txt`in n)return multilineText(n.txt)(t);throw Error(`Invalid MarkdownOrString value: `+n)}})}t(markdownOrString$1,`markdownOrString`);function join$1(e){return operation(function joinOp({ctx:t,out:n}){let{operations:r,...i}=e,a=Array.isArray(r)?r:[r];z(A(a,1),`At least one operation is required`);let o;return o=a.length===1?a[0](fresh(t)).out.contents:M(eachOnFresh(t,a),N(e=>e.out)),o=j(o,hasContentOrNewLine),n.appendIf(o.length>0,Ze(o,i))})}t(join$1,`join`);function spaceBetween(...e){return join$1({operations:e,suffix:(e,t,n)=>!n&&hasContent(e)?` `:void 0})}function lines(...e){let t=Cn(e);if(Ht(t)){let e=fresh(void 0);for(let n=0;n<t;n++)e.out.appendNewLine();return(...t)=>join$1({operations:t,suffix:(t,n,r)=>r?void 0:e.out})}return join$1({operations:e,appendNewLineIfNotEmpty:!0,skipNewLineAfterLastItem:!0})}function withctx(...e){let t=e[0];if(e.length===1)return(...e)=>operation(function withctx1({out:n}){executeOnCtx({ctx:t,out:n},e)});let n=e.slice(1);return operation(function withctx2({out:e}){executeOnCtx({ctx:t,out:e},n)})}function property(e,t){return operation(function propertyOp({ctx:n,out:r}){let i=Ut(n)&&Mr(n,e)?n[e]:void 0;if(i!=null){if(!t){z(isPrintable(i),`Property ${e} is not printable "${i}"`),r.append(e,` `,String(i));return}t({ctx:i,out:r})}})}function execToOut(e){return(t,...n)=>executeOnCtx({ctx:t,out:e},n)}function zodOp(e){return t=>()=>({ctx:n,out:r})=>{let i=Tt(e,n);if(i.success){let e=t({ctx:i.data,out:r,exec:execToOut(r)});return e instanceof Ve?{ctx:n,out:e}:typeof e==`function`?{ctx:n,out:r,...e({ctx:n,out:r})}:{ctx:n,out:r}}throw i.error}}C().regex(/^[a-zA-Z0-9_.-]+$/,`id must consist of alphanumeric characters, underscores or hyphens`).transform(e=>e),C().regex(/^[a-zA-Z0-9_.-]+$/,`FQN must consist of alphanumeric characters, dots, underscores or hyphens`).transform(e=>e),C().regex(/^[a-zA-Z0-9_-]+$/,`Kind must consist of alphanumeric characters, underscores or hyphens`).transform(e=>e);const vl=kt().min(0,`Opacity must be between 0 and 100`).max(100,`Opacity must be between 0 and 100`),yl=Dt(tr),bl=C().nonempty(`Icon cannot be empty`).transform(e=>e),xl=Dt(er),Sl=Dt(ar),Cl=Dt(nr);Dt(ir),Dt([`dashed`,`solid`,`dotted`]);const wl=xt(Mt([C(),Ot({title:C().optional(),url:C()})]).transform(e=>fr(typeof e==`string`?{url:e}:e))).readonly(),Tl=Dt(or),El=jt().refine(e=>typeof e==`string`,`Custom color name must be a string`).transform(e=>e),Dl=xt(C().nonempty(`Tag cannot be empty`).transform(e=>e.startsWith(`#`)?e.slice(1):e)).readonly(),Ol=Mt([C(),wt({md:C()}),wt({txt:C()})]).transform(e=>typeof e==`string`?{txt:e}:e),kl=Tl.or(El),Al=Ot({shape:yl,icon:bl,iconColor:kl,iconSize:Sl,iconPosition:Cl,color:kl,border:xl,opacity:vl,size:Sl,padding:Sl,textSize:Sl,multiple:Et()}).partial(),jl=Mt([C(),Et(),Ct()]),Ml=At(C(),jl.or(xt(jl)));Ot({tags:Dl.nullable(),title:C(),summary:Ol.nullable(),description:Ol.nullable(),notation:C().nullable(),technology:C().nullable(),links:wl.nullable(),metadata:Ml}).partial();const titleProperty=()=>property(`title`,spaceBetween(print(`title`),text())),descriptionProperty=()=>property(`description`,spaceBetween(print(`description`),markdownOrString$1()));function colorProperty(){return property(`color`,spaceBetween(print(`color`),print()))}function opacityProperty(){return property(`opacity`,spaceBetween(print(`opacity`),print(e=>`${e}%`)))}function iconProperty(){return property(`icon`,spaceBetween(print(`icon`),print()))}zodOp(Al)(lines(property(`shape`),colorProperty(),iconProperty(),property(`iconColor`),property(`iconSize`),property(`iconPosition`),property(`border`),opacityProperty(),property(`size`),property(`padding`),property(`textSize`),property(`multiple`)));function printOperation(e,t,n){return materialize(withctx(t??{},e),n?.indentation)}function preparePayload(e,t){let n=t.shared.workspace,{viewId:r,projectId:i,change:a}=e,o=n.ProjectsManager.ensureProject(i),s=t.likec4.ModelLocator.locateViewAst(r,o.id);if(!s)throw Error(`View ${r} not found in project ${o.id}`);return{viewId:r,change:a,services:t,project:o,doc:s.doc,viewAst:s.viewAst,workspace:n}}function viewChangeHandler(e,t){return n=>{if(n.change.op===e)return t(n)}}const Nl=viewChangeHandler(`change-property`,({change:e,viewAst:t})=>{let{title:n,description:r}=e,i=[];return n!==void 0&&i.push(updateViewTitle(t,n)),r!==void 0&&i.push(...updateViewDescription(t,r)),e.tag!==void 0&&i.push(...updateViewTags(t,e.tag)),i});function findExistingViewProperty(e,t){let n=e.body?.props;if(!(!n||!A(n,1)))return qt(n,e=>e.key===t&&e.$cstNode!==void 0)}function findInsertPosition(e,t){let n=t(B(e.body,`View body is required`));if(!n)return K.Position.create(0,0);let{line:r,character:i}=n;return K.Position.create(r,i+1)}const doubleIndent=e=>un(newline(),indent(indent(e)));function updateViewTitle(e,t){let n=findExistingViewProperty(e,`title`),r=withctx({title:t})(titleProperty());return n?K.TextEdit.replace(n.$cstNode.range,printOperation(r)):K.TextEdit.insert(findInsertPosition(e,e=>e.tags?.$cstNode?.range.end??e.$cstNode?.range.start),materialize(doubleIndent(r)).trimEnd())}function collectAllTagRefs(e){let t=[],n=e;for(;n;){let e=[];for(let t of n.values)t.$cstNode&&e.push(t);t.push(e),n=n.prev}return t.reverse().flat()}function addTag(e,t,n){let r=t.tags;return r?.$cstNode?K.TextEdit.insert(r.$cstNode.range.end,`, #${n}`):K.TextEdit.insert(findInsertPosition(e,e=>e.$cstNode?.range.start),materialize(doubleIndent(print(`#${n}`))).trimEnd())}function removeTag(e,t){let n=collectAllTagRefs(e.tags),r=n.findIndex(e=>e.tag.ref?.name===t);if(r<0)return;if(n.length===1){let t=e.tags;if(t?.$cstNode){let{start:e}=t.$cstNode.range;return K.TextEdit.del({start:K.Position.create(e.line,0),end:K.Position.create(e.line+1,0)})}return}let i=n[r];if(r>0){let e=n[r-1];return K.TextEdit.del({start:e.$cstNode.range.end,end:i.$cstNode.range.end})}let a=n[r+1];return K.TextEdit.del({start:i.$cstNode.range.start,end:a.$cstNode.range.start})}function updateViewTags(e,t){let n=[],r=B(e.body,`View body is required`);if(t.add){let i=Array.isArray(t.add)?t.add:[t.add];for(let t of i)t&&n.push(addTag(e,r,t))}if(t.remove){let e=Array.isArray(t.remove)?t.remove:[t.remove];for(let t of e){let e=t?removeTag(r,t):void 0;e&&n.push(e)}}return n}function updateViewDescription(e,t){let n=findExistingViewProperty(e,`description`),r=withctx({description:t},indent(indent(descriptionProperty())));if(n)return[K.TextEdit.replace({start:{line:n.$cstNode.range.start.line,character:0},end:n.$cstNode.range.end},materialize(r).trimEnd())];let i=findInsertPosition(e,e=>M(e.props,N(e=>e.$cstNode?.range.end),j(T),cn())??e.tags?.$cstNode?.range.end??e.$cstNode?.range.start);return[K.TextEdit.insert({line:i.line+1,character:0},materialize(r))]}Pe();const Pl=G.getChild(`model-changes`);var LikeC4ModelChanges=class{services;locator;constructor(e){this.services=e,this.locator=e.likec4.ModelLocator}async applyChange(e){let{viewId:t,projectId:n,change:r}=e;if(r.op===`change-property`){let t=preparePayload(e,this.services),n=Nl(t);if(!n)return{success:!1,error:`No changes to apply`};let r=Array.isArray(n)?n:[n];return await this.applyTextEdits(t.doc,r)?{success:!0,location:null}:{success:!1,error:`Failed to apply text edits`}}let i=this.services.shared.workspace;try{let e=i.ProjectsManager.ensureProject(n);Pl.debug`Applying model change ${r.op} to view ${t} in project ${e.id}`;let a=this.locator.locateViewAst(t,e.id);if(!a)throw Error(`View ${t} not found in project ${e.id}`);let o={uri:a.doc.textDocument.uri,version:a.doc.textDocument.version};if(r.op===`save-view-snapshot`)return z(t===r.layout.id,`View ID does not match, expected `+t+`, got `+r.layout.id),{success:!0,location:await i.ManualLayouts.write(e,r.layout)};if(r.op===`reset-manual-layout`)return{success:!0,location:await i.ManualLayouts.remove(e,t)};let{edits:s,modifiedRange:c}=this.convertToTextEdit({lookup:a,change:r});return s.length?await this.applyTextEdits(a.doc,s)?{success:!0,location:{uri:o.uri,range:c}}:{success:!1,error:`Failed to apply changes`}:{success:!1,error:`No changes to apply`}}catch(t){let n=loggable(wrapError(t,`Failed to apply change ${e.change.op} ${e.viewId}`));return Pl.warn(n),{success:!1,error:n}}}convertToTextEdit({lookup:e,change:t}){switch(t.op){case`change-element-style`:return changeElementStyle(this.services,{...e,targets:t.targets,style:t.style});case`change-autolayout`:{let n=changeViewLayout(this.services,{...e,layout:t.layout});return{modifiedRange:n.range,edits:[n]}}default:V(t)}}async applyTextEdits(e,t){let n=this.services.shared.lsp.Connection,r=this.services.shared.workspace;if(!n){let n=me.applyEdits(e.textDocument,t);return await r.FileSystemProvider.writeFile(e.uri,n),await r.DocumentBuilder.update([e.uri],[]),!0}let i=await n.workspace.applyEdit({label:`LikeC4 - change view`,edit:{changes:{[e.textDocument.uri]:t}}});return i.applied?(await r.DocumentBuilder.update([e.uri],[]),i.applied):(Pl.warn`Failed to apply text edits to document ${e.textDocument.uri}: ${i.failureReason}`,n.window.showErrorMessage(`Failed to apply changes: ${i.failureReason}`),!1)}},LikeC4NameProvider=class extends de{services;constructor(e){super(),this.services=e}getNameStrict(e){return B(this.getName(e),`Failed getName for ${this.services.workspace.AstNodeLocator.getAstNodePath(e)}`)}getName(e){if(st(e))return e.name;if(isImported(e))return e.imported.$refText;if(isDeployedInstance(e))return e.target.modelElement.value.$refText}getNameNode(e){if(st(e))return super.getNameNode(e);if(isImported(e))return e.imported.$refNode;if(isDeployedInstance(e))return e.target.modelElement.value.$refNode}};function uniqueDescriptions(e){return M(e,en(e=>`${e.type}.${e.name}`),rn(),E(([e,t])=>t.length===1?t:[]))}var LikeC4ScopeComputation=class extends ne{constructor(e){super(e)}async computeExports(e,t){let n=[];try{let{specifications:t,models:r,views:i,globals:a,likec4lib:o,deployments:s}=e.parseResult.value;this.exportLibrary(o,n,e),this.exportSpecification(t,n,e),this.exportModel(r,n,e),this.exportViews(i,n,e),this.exportGlobals(a,n,e),this.exportDeployments(s,n,e)}catch(e){logWarnError(e)}return n}exportViews(e,t,n){let r=e?.flatMap(e=>e.views);if(!(O(r)||r.length===0))for(let e of r)try{T(e.name)&&t.push(this.descriptions.createDescription(e,e.name,n))}catch(e){logWarnError(e)}}exportGlobals(e,t,n){if(!(O(e)||e.length===0)){for(let r of e.flatMap(e=>e.predicates))try{let e=r;T(e.name)&&t.push(this.descriptions.createDescription(e,e.name,n))}catch(e){logWarnError(e)}for(let r of e.flatMap(e=>e.styles))try{let e=r.id;T(e.name)&&t.push(this.descriptions.createDescription(e,e.name,n))}catch(e){logWarnError(e)}}}exportModel(e,t,n){if(!(O(e)||e.length===0))for(let r of e.flatMap(e=>e.elements))try{isElement(r)&&T(r.name)&&t.push(this.descriptions.createDescription(r,r.name,n))}catch(e){logWarnError(e)}}exportLibrary(e,t,n){if(!O(e))try{for(let r of e.flatMap(e=>e.icons))t.push(this.descriptions.createDescription(r,r.name,n))}catch(e){logWarnError(e)}}exportSpecification(e,t,n){if(!(O(e)||e.length===0))for(let r of e.flatMap(e=>[...e.elements,...e.relationships,...e.deploymentNodes,...e.tags,...e.colors]))try{switch(!0){case isSpecificationDeploymentNodeKind(r):case isSpecificationElementKind(r):T(r.kind.name)&&t.push(this.descriptions.createDescription(r.kind,r.kind.name,n));continue;case isSpecificationTag(r):T(r.tag.name)&&t.push(this.descriptions.createDescription(r.tag,r.tag.name,n));continue;case isSpecificationRelationshipKind(r):T(r.kind.name)&&t.push(this.descriptions.createDescription(r.kind,r.kind.name,n));continue;case isSpecificationColor(r):T(r.name.name)&&t.push(this.descriptions.createDescription(r.name,r.name.name,n));continue;default:V(r)}}catch(e){logWarnError(e)}}exportDeployments(e,t,n){let r=e?.flatMap(e=>e.elements);if(!(O(r)||r.length===0))for(let e of r)try{isDeploymentNode$1(e)&&T(e.name)&&t.push(this.descriptions.createDescription(e,e.name,n))}catch(e){logWarnError(e)}}computeLocalScopes(e,t){return new Promise(t=>{let n=e.parseResult.value,r=[],i=new ae;for(let t of n.models)try{r.push(...this.processContainer(t,i,e))}catch(e){logWarnError(e)}for(let t of n.deployments)try{r.push(...this.processDeployments(t,i,e))}catch(e){logWarnError(e)}for(let e of n.imports.flatMap(e=>e.imports))try{let t=e;for(;t;)r.push(this.descriptions.createDescription(t,t.imported.$refText)),t=t.prev}catch(e){logWarnError(e)}uniqueDescriptions(r).forEach(e=>{i.add(n,e)}),t(i)})}processContainer(e,t,n){let r=new ae,i=[];for(let a of e.elements){if(isRelation(a))continue;let e;if(isElement(a)?(T(a.name)&&r.add(a.name,this.descriptions.createDescription(a,a.name,n)),e=a.body,e&&(t.add(e,this.descriptions.createDescription(a,`this`,n)),t.add(e,this.descriptions.createDescription(a,`it`,n)))):isExtendElement(a)&&(e=a.body),e&&e.elements.length>0)try{i.push(...this.processContainer(e,t,n))}catch(e){logWarnError(e)}}i.length&&M(i,j(e=>!r.has(e.name)),en(e=>e.name),$t((e,t)=>{e.length===1&&r.add(t,e[0])}));let a=[...r.values()];return t.addAll(e,a),a}processDeployments(e,t,n){let r=new ae,i=[];for(let a of e.elements){if(isDeploymentRelation(a))continue;let e=a.body;if(!isExtendDeployment(a)){let i=this.nameProvider.getName(a);if(T(i)){let e=this.descriptions.createDescription(a,i,n);r.add(i,e)}e&&(t.add(e,this.descriptions.createDescription(a,`this`,n)),t.add(e,this.descriptions.createDescription(a,`it`,n)))}if(e)try{i.push(...this.processDeployments(e,t,n))}catch(e){logWarnError(e)}}i.length&&M(i,j(e=>!r.has(e.name)),en(e=>e.name),$t((e,t)=>{e.length===1&&r.add(t,e[0])}));let a=[...r.values()];return t.addAll(e,a),a}};const{getDocument:Fl}=Re;var LikeC4ScopeProvider=class extends Ie{deploymentsIndex;fqnIndex;indexManager;constructor(e){super(e),this.indexManager=e.shared.workspace.IndexManager,this.fqnIndex=e.likec4.FqnIndex,this.deploymentsIndex=e.likec4.DeploymentsIndex}getScope(e){try{let t=projectIdFrom(e.container),n=this.reflection.getReferenceType(e);try{let r=e.container;if(isFqnRef(r))return new ee(this.streamForFqnRef(t,r,e));if(isStrictFqnRef(r))return this.getScopeForStrictFqnRef(t,r,e);if(n!==`Element`)return this.getProjectScope(t,n,e);if(isImported(r)){let e=projectIdFrom(r);return new ee(this.fqnIndex.rootElements(e))}if(isStrictFqnElementRef(r)&&e.property===`el`){let i=r.parent;return i?new ee(this.fqnIndex.directChildrenOf(t,readStrictFqn(i))):this.getProjectScope(t,n,e)}return new ee(S(this.computeScope(t,e)))}catch(r){return logWarnError(r),this.getProjectScope(t,n,e)}}catch(e){return logWarnError(e),se}}*genUniqueDescedants(e){if(!e)return;let t=projectIdFrom(e);if(isElement(e)){let n=this.fqnIndex.getFqn(e);yield*this.fqnIndex.uniqueDescedants(t,n);return}if(isDeploymentNode$1(e)){let n=this.deploymentsIndex.getFqn(e);yield*this.deploymentsIndex.uniqueDescedants(t,n)}}*genScopeExtendElement({element:e}){e.el.$nodeDescription&&(yield e.el.$nodeDescription,yield{...e.el.$nodeDescription,name:`this`},yield{...e.el.$nodeDescription,name:`it`}),yield*this.genUniqueDescedants(elementRef(e))}*genScopeElementView({viewOf:e,extends:t}){if(e){e.modelElement.value.$nodeDescription&&(yield e.modelElement.value.$nodeDescription),yield*this.genUniqueDescedants(elementRef(e));return}if(t){let e=t.view.ref;e&&(yield*this.genScopeElementView(e))}}getScopeForStrictFqnRef(e,t,n){let r=t.parent;return r?new ee(this.deploymentsIndex.directChildrenOf(e,readStrictFqn(r)).filter(e=>this.reflection.isSubtype(e.type,eo))):this.getProjectScope(e,eo,n)}*genScopeExtendDeployment({deploymentNode:e}){e.value.$nodeDescription&&(yield e.value.$nodeDescription);let t=e.value.ref;t&&isDeploymentNode$1(t)&&(yield*this.genUniqueDescedants(t))}streamForFqnRef(e,t,n){let r=t.parent;if(!r)return S(this.genScopeForParentlessFqnRef(e,t,n));let i=r.value.ref;if(!i)return nt;if(isImported(i))return S(this.genUniqueDescedants(i.imported.ref));if(isDeploymentNode$1(i))return S(this.genUniqueDescedants(i));if(isDeployedInstance(i)){let e=i.target.modelElement.value.ref,t=isImported(e)?e.imported.ref:isElement(e)?e:void 0;return S(this.genUniqueDescedants(t))}return isElement(i)?S(this.genUniqueDescedants(i)):V(i)}*genScopeForParentlessFqnRef(e,t,n){Oe(t,isElementRef)||isFqnRefInsideModel(t)?yield*this.computeScope(e,n,vo):isFqnRefInsideGlobals(t)?(yield*this.computeScope(e,n,vo),yield*this.computeScope(e,n,eo),yield*this.computeScope(e,n,Qa)):(yield*this.computeScope(e,n,eo),yield*this.computeScope(e,n,Qa),Oe(t,isDeploymentViewBody)&&(yield*this.computeScope(e,n,vo)));let r=Fl(t).precomputedScopes;r&&(yield*r.values().filter(e=>this.reflection.isSubtype(e.type,Qo)))}*computeScope(e,t,n=this.reflection.getReferenceType(t)){let r=this.reflection.isSubtype(n,vo),i=this.reflection.isSubtype(n,ua),a=Fl(t.container).precomputedScopes;if(!a){yield*this.getProjectScope(e,n,t).getAllElements();return}let byReferenceType=e=>this.reflection.isSubtype(e.type,n),o=t.container;for(;o;){let e=a.get(o).filter(byReferenceType);e.length>0&&(yield*e),i&&isExtendDeploymentBody(o)&&(yield*this.genScopeExtendDeployment(o.$container)),r&&isExtendElementBody(o)&&(yield*this.genScopeExtendElement(o.$container)),r&&isElementViewBody(o)&&(yield*this.genScopeElementView(o.$container)),o=o.$container}yield*this.getProjectScope(e,n,t).getAllElements()}getProjectScope(e,t,n){return t===`LibIcon`?super.getGlobalScope(t,n):this.globalScopeCache.get(`${e}::${t}`,()=>new le(this.indexManager.projectElements(e,t)))}getGlobalScope(e,t){if(e===`LibIcon`)return super.getGlobalScope(e,t);let n=projectIdFrom(t.container);return this.getProjectScope(n,e,t)}},Q=xe();let Il;(function(e){e.type=new Q.NotificationType(`likec4/onDidChangeModel`)})(Il||={});let Ll;(function(e){e.type=new Q.NotificationType0(`likec4/onDidChangeProjects`)})(Ll||={});let Rl;(function(e){e.type=new Q.NotificationType(e.Method=`likec4/onDidChangeSnapshot`)})(Rl||={});let zl;(function(e){e.type=new Q.NotificationType(`likec4/onRequestOpenView`)})(zl||={});let Bl;(function(e){e.req=new Q.RequestType(`likec4/fetchComputedModel`)})(Bl||={});let Vl;(function(e){e.req=new Q.RequestType0(`likec4/fetchViewsFromAllProjects`)})(Vl||={});let Hl;(function(e){e.req=new Q.RequestType(`likec4/fetchLayoutedModel`)})(Hl||={});let Ul;(function(e){e.req=new Q.RequestType(`likec4/layout-view`)})(Ul||={});let Wl;(function(e){e.req=new Q.RequestType(`likec4/validate-layout`)})(Wl||={});let Gl;(function(e){e.req=new Q.RequestType0(`likec4/reload-projects`)})(Gl||={});let Kl;(function(e){e.req=new Q.RequestType0(`likec4/fetch-projects`)})(Kl||={});let ql;(function(e){e.req=new Q.RequestType(`likec4/register-project`)})(ql||={});let Jl;(function(e){e.req=new Q.RequestType(`likec4/build`)})(Jl||={});let Yl;(function(e){e.req=new Q.RequestType(`likec4/locate`)})(Yl||={});let Xl;(function(e){e.req=new Q.RequestType(`likec4/change-view`)})(Xl||={});let Zl;(function(e){e.req=new Q.RequestType0(`likec4/metrics`)})(Zl||={});let Ql;(function(e){e.req=new Q.RequestType(`likec4/document-tags`)})(Ql||={});let $l;(function(e){e.req=new Q.RequestType0(`likec4/fetch-projects-overview`)})($l||={});const $=G.getChild(`rpc`);var Rpc=class extends ADisposable{services;constructor(e){super(),this.services=e}init=yn(()=>{let e=this.services.shared.lsp.Connection;if(!e){$.info(`no connection, skip init ServerRpc`);return}$.info(`init ServerRpc`);let t=this.services.likec4,n=this.services.shared.workspace,r=n.LangiumDocuments,i=n.DocumentBuilder,sendDidChangeModelNotification=t=>{$.debug`send ${`onDidChangeModel`} for project ${t}`,e.sendNotification(Il.type,{projectId:t}).catch(e=>{$.warn(`[ServerRpc] error sending onDidChangeModel for project {project}`,{error:e,project:t})})},a=Gt(e=>{if(typeof e==`string`){sendDidChangeModelNotification(e);return}for(let t of e)sendDidChangeModelNotification(t)},{reducer:(e,t)=>!e||e===t?t:e instanceof Set?(e.add(t),e):new Set([e,t]),triggerAt:`end`,minQuietPeriodMs:130,maxBurstDurationMs:400}),o=Gt(t=>{t>1?$.debug`send ${`DidChangeProjectsNotification`} (${t} batched)`:$.debug`send ${`DidChangeProjectsNotification`}`,e.sendNotification(Ll.type).catch(e=>{$.warn(`[ServerRpc] error sending DidChangeProjectsNotification:`,{error:e})})},{reducer:(e,t)=>(e??0)+t,triggerAt:`end`,minQuietPeriodMs:250,maxBurstDurationMs:700}),s=!0;this.onDispose(t.ModelBuilder.onModelParsed(e=>a.call(e)),n.ProjectsManager.onProjectsUpdate(()=>o.call(1)),e.onRequest(Bl.req,async({projectId:e,cleanCaches:r=!1},i)=>{$.debug`received request ${`fetchComputedModel`} for project ${e}`,r&&($.debug`cleanCaches: ${r}`,e?await n.ProjectsManager.rebuildProject(e):await n.WorkspaceManager.rebuildAll());let a=await t.ModelBuilder.computeModel(e,i);return a===_i.EMPTY?{model:null}:{model:a.$data}}),e.onNotification(Rl.type,async e=>{let t=v.parse(e.update??e.delete),r=`update`in e?{update:t}:{delete:t};$.debug`received notification ${`onDidChangeSnapshot`} with ${e}`,await n.ManualLayouts.handleFileSystemUpdate(r)}),e.onRequest(Hl.req,async({projectId:e},n)=>{$.debug`received request ${`fetchLayoutedModel`} for project ${e}`;let r=await t.LanguageServices.layoutedModel(e);if(r===null)return{model:null};let i=await t.Views.diagrams(e,n);return{model:{...r.$data,_stage:`layouted`,views:Jt(i,e=>e.id)}}}),e.onRequest(Ul.req,async({viewId:e,projectId:n,layoutType:r,hints:i},a)=>($.debug`received request ${`layoutView`} for ${e} from project ${n} (layout type: ${r??`not set`})`,{result:await t.Views.layoutView({viewId:e,projectId:n,layoutType:r,layoutHints:i,cancelToken:a})})),e.onRequest(Wl.req,async({projectId:e},n)=>($.debug`received request ${`validateLayout`} for project ${e}`,{result:reportLayoutDrift((await t.Views.layoutAllViews(e,n)).map(e=>e.diagram))})),e.onRequest(Kl.req,async()=>($.debug`received request ${`FetchProjects`}`,{projects:an(r.groupedByProject(),(e,t)=>{let{folderUri:r,config:{name:i,title:a}}=n.ProjectsManager.getProject(t);return{folder:r.toString(),config:{name:i,title:a},docs:N(e,e=>e.uri.toString())}})})),e.onRequest(Gl.req,async e=>{$.debug`received request ${`ReloadProjects`}`,n.ManualLayouts.clearCaches(),await n.ProjectsManager.reloadProjects(e)}),e.onRequest(ql.req,async(e,t)=>{$.debug`received request ${`RegisterProject`}`,n.ManualLayouts.clearCaches();let r;return r=`configUri`in e?await n.ProjectsManager.registerConfigFile(v.parse(e.configUri),t):await n.ProjectsManager.registerProject(e,t),{id:r.id}}),e.onRequest(Vl.req,async e=>{$.debug`received request ${`FetchViewsFromAllProjects`}`;let r=[];for(let i of n.ProjectsManager.all){await te(e);try{let n=await t.Views.computedViews(i,e);r.push(...M(n,N(e=>({id:e.id,title:e.title??e.id,projectId:i})),Sn((e,t)=>e.id===`index`?-1:t.id===`index`?1:e.title.localeCompare(t.title))))}catch(e){$.warn(`Failed to fetch views for project ${i}:`,{error:e})}}return{views:r}}),e.onRequest(Jl.req,async({docs:t},n)=>{let a=t.map(e=>v.parse(e)),isNotChanged=e=>!a.some(t=>_.equals(t,e)),o=r.userDocuments.map(e=>e.uri).filter(isNotChanged).toArray();$.debug(`[ServerRpc] received request to build:
|
|
89
|
-
changed (total ${
|
|
96
|
+
`))),v.start={line:u.line+1,character:d},v.end={line:u.line+e.length,character:ln(e)?.length??0}}if(g.length>0)for(let{rule:e}of g){let t=e.$cstNode;V(t,`RuleCstNode not found`);for(let[r,o]of an(s)){let s=r===`opacity`?o.toString()+`%`:o,c=e.props.find(e=>e.key===r);if(c&&c.$cstNode){let{range:{start:e,end:t}}=c.$cstNode;includeRange({start:e,end:t}),y.push(Je.replace({start:e,end:t},r+` `+s));continue}let u=wl(t,`{`)?.range.end;V(u,`Opening brace not found`);let d=` `.repeat(t.range.start.character)+` `,p=d+r+` `+s;y.push(Je.insert(u,`
|
|
97
|
+
`+p)),includeRange({start:{line:u.line+1,character:d.length},end:{line:u.line+1,character:p.length}})}}return{modifiedRange:v,edits:y}}Pe();const{findNodeForKeyword:Tl}=Ce;function changeViewLayout(e,{view:t,viewAst:r,layout:o}){V(r.body,`View ${t.id} has no body`);let s=r.$cstNode;V(s,`viewCstNode`);let c=toAstViewLayoutDirection(o.direction),u=qt(r.body.rules,isViewRuleAutoLayout),d=`autoLayout ${c}`;if(Ht(o.rankSep)&&(d+=` ${o.rankSep}`,Ht(o.nodeSep)&&(d+=` ${o.nodeSep}`)),u&&u.$cstNode)return Je.replace(u.$cstNode.range,d);let p=Tl(r.body.$cstNode,`}`)?.range.start;V(p,`Closing brace not found`);let m=`\t${d}\n\t`;return Je.insert(p,m)}function hasContent(e){return typeof e==`string`?e.trimStart().length!==0:e instanceof Ve?e.contents.some(e=>hasContent(e)):!1}function hasContentOrNewLine(e){return typeof e==`string`?e.trimStart().length!==0:e instanceof Ne?!e.ifNotEmpty:e instanceof Ve?e.contents.some(e=>hasContentOrNewLine(e)):!1}function fresh(e){return{ctx:e??void 0,out:new Ve}}function materialize(e,t=2){return ve(_n(e)?executeOnFresh(void 0,[e]).out:e.out,t).replaceAll(/\r\n/g,`
|
|
98
|
+
`)}function executeOnCtx(e,t,...r){Kt(t)?(V(r.length===0,`When first argument is an array, no additional operations are allowed`),r=t):r=[t,...r];for(let t of r)e=t(e);return e}function executeOnFresh(e,t,...r){return Kt(t)?executeOnCtx(fresh(e),t):executeOnCtx(fresh(e),[t,...r])}function eachOnFresh(e,t){return t.map(t=>t(fresh(e)))}function operation(e,t){let r=typeof e==`function`?e:t,wrapped=e=>{let t=r(e);return t instanceof Ve?{...e,out:t}:e};return typeof e==`string`&&r.name==``&&Object.defineProperties(wrapped,{name:{value:`wrapped(${e})`}}),wrapped}function isPrintable(e){return typeof e==`string`||typeof e==`number`||typeof e==`boolean`}function print(e){return operation(function printOp({ctx:t,out:r}){let o=typeof e==`function`?e(t):e??t;M(o)||o===``||(V(isPrintable(o),`Value must be a string, number or boolean - got `+typeof o),r.append(String(o)))})}function noop(){return Zt()}function newline(e){return operation(({out:t})=>{e===`ifNotEmpty`?t.appendNewLineIfNotEmpty():t.appendNewLine()})}function merge(...e){return operation(function merge({ctx:t,out:r}){let o=executeOnFresh(t,e);r.appendIf(hasContent(o.out),o.out)})}function indent(...e){if(e.length===1&&typeof e[0]==`string`){let t=dedent(e[0]);return t.trimStart().length===0?noop():operation(function indent1({out:e}){e.appendNewLineIfNotEmpty().indent({indentEmptyLines:!0,indentedChildren:[Ze(t.split(/\r?\n/),{separator:qe})]}).appendNewLineIfNotEmpty()})}let t=e;return operation(function indent2({ctx:e,out:r}){let o=executeOnFresh(e,t);hasContent(o.out)&&r.appendNewLineIfNotEmpty().indent({indentEmptyLines:!0,indentedChildren:o.out.contents}).appendNewLineIfNotEmpty()})}function inlineText(e){return operation(({ctx:t,out:r})=>{let o=e??t;if(M(o))return;V(Nn(o),`Value must be a string - got `+typeof o);let s=o.replace(/(\r?\n|\t)+/g,` `).replaceAll(`'`,`\\'`).trim();r.append(`'${s}'`)})}function multilineText(e,t=`'`){return merge(print(t),indent(e.replaceAll(`'`,`\\'`)),print(t))}function text(e){return operation(function text({ctx:t,out:r}){let o=typeof e==`function`?e(t):e??t;if(!M(o))return V(Nn(o),`Value must be a string - got `+typeof o),o.includes(`
|
|
99
|
+
`)?multilineText(o)({ctx:o,out:r}):inlineText()({ctx:o,out:r})})}const El=`'`.repeat(3);function markdown(e){return operation(function markdown(t){let r=e??t.ctx;if(!M(r))return V(Nn(r),`Value must be a string - got `+typeof r),multilineText(r,El)(t)})}function markdownOrString$1(e){return operation(function markdownOrString(t){let r=e??t.ctx;if(!M(r)){if(typeof r==`string`)return text(r)(t);if(`md`in r)return markdown(r.md)(t);if(`txt`in r)return multilineText(r.txt)(t);throw Error(`Invalid MarkdownOrString value: `+r)}})}t(markdownOrString$1,`markdownOrString`);function join$1(e){return operation(function joinOp({ctx:t,out:r}){let{operations:o,...s}=e,c=Array.isArray(o)?o:[o];V(N(c,1),`At least one operation is required`);let u;return u=c.length===1?c[0](fresh(t)).out.contents:F(eachOnFresh(t,c),I(e=>e.out)),u=P(u,hasContentOrNewLine),r.appendIf(u.length>0,Ze(u,s))})}t(join$1,`join`);function spaceBetween(...e){return join$1({operations:e,suffix:(e,t,r)=>!r&&hasContent(e)?` `:void 0})}function lines(...e){let t=wn(e);if(Ht(t)){let e=fresh(void 0);for(let r=0;r<t;r++)e.out.appendNewLine();return(...t)=>join$1({operations:t,suffix:(t,r,o)=>o?void 0:e.out})}return join$1({operations:e,appendNewLineIfNotEmpty:!0,skipNewLineAfterLastItem:!0})}function withctx(...e){let t=e[0];if(e.length===1)return(...e)=>operation(function withctx1({out:r}){executeOnCtx({ctx:t,out:r},e)});let r=e.slice(1);return operation(function withctx2({out:e}){executeOnCtx({ctx:t,out:e},r)})}function property(e,t){return operation(function propertyOp({ctx:r,out:o}){let s=Ut(r)&&Mr(r,e)?r[e]:void 0;if(s!=null){if(!t){V(isPrintable(s),`Property ${e} is not printable "${s}"`),o.append(e,` `,String(s));return}t({ctx:s,out:o})}})}function execToOut(e){return(t,...r)=>executeOnCtx({ctx:t,out:e},r)}function zodOp(e){return t=>()=>({ctx:r,out:o})=>{let s=St(e,r);if(s.success){let e=t({ctx:s.data,out:o,exec:execToOut(o)});return e instanceof Ve?{ctx:r,out:e}:typeof e==`function`?{ctx:r,out:o,...e({ctx:r,out:o})}:{ctx:r,out:o}}throw s.error}}E().regex(/^[a-zA-Z0-9_.-]+$/,`id must consist of alphanumeric characters, underscores or hyphens`).transform(e=>e),E().regex(/^[a-zA-Z0-9_.-]+$/,`FQN must consist of alphanumeric characters, dots, underscores or hyphens`).transform(e=>e),E().regex(/^[a-zA-Z0-9_-]+$/,`Kind must consist of alphanumeric characters, underscores or hyphens`).transform(e=>e);const Dl=Et().min(0,`Opacity must be between 0 and 100`).max(100,`Opacity must be between 0 and 100`),Ol=kt(er),kl=E().nonempty(`Icon cannot be empty`).transform(e=>e),Al=kt($n),jl=kt(ir),Ml=kt(tr);kt(rr),kt([`dashed`,`solid`,`dotted`]);const Nl=Tt(xt([E(),Ct({title:E().optional(),url:E()})]).transform(e=>fr(typeof e==`string`?{url:e}:e))).readonly(),Pl=kt(ar),Fl=jt().refine(e=>typeof e==`string`,`Custom color name must be a string`).transform(e=>e),Il=Tt(E().nonempty(`Tag cannot be empty`).transform(e=>e.startsWith(`#`)?e.slice(1):e)).readonly(),Ll=xt([E(),Mt({md:E()}),Mt({txt:E()})]).transform(e=>typeof e==`string`?{txt:e}:e),Rl=Pl.or(Fl),zl=Ct({shape:Ol,icon:kl,iconColor:Rl,iconSize:jl,iconPosition:Ml,color:Rl,border:Al,opacity:Dl,size:jl,padding:jl,textSize:jl,multiple:Ot()}).partial(),Bl=xt([E(),Ot(),Dt()]),Vl=wt(E(),Bl.or(Tt(Bl)));Ct({tags:Il.nullable(),title:E(),summary:Ll.nullable(),description:Ll.nullable(),notation:E().nullable(),technology:E().nullable(),links:Nl.nullable(),metadata:Vl}).partial();const titleProperty=()=>property(`title`,spaceBetween(print(`title`),text())),descriptionProperty=()=>property(`description`,spaceBetween(print(`description`),markdownOrString$1()));function colorProperty(){return property(`color`,spaceBetween(print(`color`),print()))}function opacityProperty(){return property(`opacity`,spaceBetween(print(`opacity`),print(e=>`${e}%`)))}function iconProperty(){return property(`icon`,spaceBetween(print(`icon`),print()))}zodOp(zl)(lines(property(`shape`),colorProperty(),iconProperty(),property(`iconColor`),property(`iconSize`),property(`iconPosition`),property(`border`),opacityProperty(),property(`size`),property(`padding`),property(`textSize`),property(`multiple`)));function printOperation(e,t,r){return materialize(withctx(t??{},e),r?.indentation)}function preparePayload(e,t){let r=t.shared.workspace,{viewId:o,projectId:s,change:c}=e,u=r.ProjectsManager.ensureProject(s),d=t.likec4.ModelLocator.locateViewAst(o,u.id);if(!d)throw Error(`View ${o} not found in project ${u.id}`);return{viewId:o,change:c,services:t,project:u,doc:d.doc,viewAst:d.viewAst,workspace:r}}function viewChangeHandler(e,t){return r=>{if(r.change.op===e)return t(r)}}const Hl=viewChangeHandler(`change-property`,({change:e,viewAst:t})=>{let{title:r,description:o}=e,s=[];return r!==void 0&&s.push(updateViewTitle(t,r)),o!==void 0&&s.push(...updateViewDescription(t,o)),e.tag!==void 0&&s.push(...updateViewTags(t,e.tag)),s});function findExistingViewProperty(e,t){let r=e.body?.props;if(!(!r||!N(r,1)))return qt(r,e=>e.key===t&&e.$cstNode!==void 0)}function findInsertPosition(e,t){let r=t(Gr(e.body,`View body is required`));if(!r)return oa.Position.create(0,0);let{line:o,character:s}=r;return oa.Position.create(o,s+1)}const doubleIndent=e=>dn(newline(),indent(indent(e)));function updateViewTitle(e,t){let r=findExistingViewProperty(e,`title`),o=withctx({title:t})(titleProperty());return r?oa.TextEdit.replace(r.$cstNode.range,printOperation(o)):oa.TextEdit.insert(findInsertPosition(e,e=>e.tags?.$cstNode?.range.end??e.$cstNode?.range.start),materialize(doubleIndent(o)).trimEnd())}function collectAllTagRefs(e){let t=[],r=e;for(;r;){let e=[];for(let t of r.values)t.$cstNode&&e.push(t);t.push(e),r=r.prev}return t.reverse().flat()}function addTag(e,t,r){let o=t.tags;return o?.$cstNode?oa.TextEdit.insert(o.$cstNode.range.end,`, #${r}`):oa.TextEdit.insert(findInsertPosition(e,e=>e.$cstNode?.range.start),materialize(doubleIndent(print(`#${r}`))).trimEnd())}function removeTag(e,t){let r=collectAllTagRefs(e.tags),o=r.findIndex(e=>e.tag.ref?.name===t);if(o<0)return;if(r.length===1){let t=e.tags;if(t?.$cstNode){let{start:e}=t.$cstNode.range;return oa.TextEdit.del({start:oa.Position.create(e.line,0),end:oa.Position.create(e.line+1,0)})}return}let s=r[o];if(o>0){let e=r[o-1];return oa.TextEdit.del({start:e.$cstNode.range.end,end:s.$cstNode.range.end})}let c=r[o+1];return oa.TextEdit.del({start:s.$cstNode.range.start,end:c.$cstNode.range.start})}function updateViewTags(e,t){let r=[],o=Gr(e.body,`View body is required`);if(t.add){let s=Array.isArray(t.add)?t.add:[t.add];for(let t of s)t&&r.push(addTag(e,o,t))}if(t.remove){let e=Array.isArray(t.remove)?t.remove:[t.remove];for(let t of e){let e=t?removeTag(o,t):void 0;e&&r.push(e)}}return r}function updateViewDescription(e,t){let r=findExistingViewProperty(e,`description`),o=withctx({description:t},indent(indent(descriptionProperty())));if(r)return[oa.TextEdit.replace({start:{line:r.$cstNode.range.start.line,character:0},end:r.$cstNode.range.end},materialize(o).trimEnd())];let s=findInsertPosition(e,e=>F(e.props,I(e=>e.$cstNode?.range.end),P(k),ln())??e.tags?.$cstNode?.range.end??e.$cstNode?.range.start);return[oa.TextEdit.insert({line:s.line+1,character:0},materialize(o))]}Pe();const Ul=q.getChild(`model-changes`);var LikeC4ModelChanges=class{services;locator;constructor(e){this.services=e,this.locator=e.likec4.ModelLocator}async applyChange(e){let{viewId:t,projectId:r,change:o}=e;if(o.op===`change-property`){let t=preparePayload(e,this.services),r=Hl(t);if(!r)return{success:!1,error:`No changes to apply`};let o=Array.isArray(r)?r:[r];return await this.applyTextEdits(t.doc,o)?{success:!0,location:null}:{success:!1,error:`Failed to apply text edits`}}let s=this.services.shared.workspace;try{let e=s.ProjectsManager.ensureProject(r);Ul.debug`Applying model change ${o.op} to view ${t} in project ${e.id}`;let c=this.locator.locateViewAst(t,e.id);if(!c)throw Error(`View ${t} not found in project ${e.id}`);let u={uri:c.doc.textDocument.uri,version:c.doc.textDocument.version};if(o.op===`save-view-snapshot`)return V(t===o.layout.id,`View ID does not match, expected `+t+`, got `+o.layout.id),{success:!0,location:await s.ManualLayouts.write(e,o.layout)};if(o.op===`reset-manual-layout`)return{success:!0,location:await s.ManualLayouts.remove(e,t)};let{edits:d,modifiedRange:p}=this.convertToTextEdit({lookup:c,change:o});return d.length?await this.applyTextEdits(c.doc,d)?{success:!0,location:{uri:u.uri,range:p}}:{success:!1,error:`Failed to apply changes`}:{success:!1,error:`No changes to apply`}}catch(t){let r=loggable(wrapError(t,`Failed to apply change ${e.change.op} ${e.viewId}`));return Ul.warn(r),{success:!1,error:r}}}convertToTextEdit({lookup:e,change:t}){switch(t.op){case`change-element-style`:return changeElementStyle(this.services,{...e,targets:t.targets,style:t.style});case`change-autolayout`:{let r=changeViewLayout(this.services,{...e,layout:t.layout});return{modifiedRange:r.range,edits:[r]}}default:H(t)}}async applyTextEdits(e,t){let r=this.services.shared.lsp.Connection,o=this.services.shared.workspace;if(!r){let r=pe.applyEdits(e.textDocument,t);return await o.FileSystemProvider.writeFile(e.uri,r),await o.DocumentBuilder.update([e.uri],[]),!0}let s=await r.workspace.applyEdit({label:`LikeC4 - change view`,edit:{changes:{[e.textDocument.uri]:t}}});return s.applied?(await o.DocumentBuilder.update([e.uri],[]),s.applied):(Ul.warn`Failed to apply text edits to document ${e.textDocument.uri}: ${s.failureReason}`,r.window.showErrorMessage(`Failed to apply changes: ${s.failureReason}`),!1)}},LikeC4NameProvider=class extends ue{services;constructor(e){super(),this.services=e}getNameStrict(e){return Gr(this.getName(e),`Failed getName for ${this.services.workspace.AstNodeLocator.getAstNodePath(e)}`)}getName(e){if(ct(e))return e.name;if(isImported(e))return e.imported.$refText;if(isDeployedInstance(e))return e.target.modelElement.value.$refText}getNameNode(e){if(ct(e))return super.getNameNode(e);if(isImported(e))return e.imported.$refNode;if(isDeployedInstance(e))return e.target.modelElement.value.$refNode}};function uniqueDescriptions(e){return F(e,tn(e=>`${e.type}.${e.name}`),an(),A(([e,t])=>t.length===1?t:[]))}var LikeC4ScopeComputation=class extends te{constructor(e){super(e)}async computeExports(e,t){let r=[];try{let{specifications:t,models:o,views:s,globals:c,likec4lib:u,deployments:d}=e.parseResult.value;this.exportLibrary(u,r,e),this.exportSpecification(t,r,e),this.exportModel(o,r,e),this.exportViews(s,r,e),this.exportGlobals(c,r,e),this.exportDeployments(d,r,e)}catch(e){logWarnError(e)}return r}exportViews(e,t,r){let o=e?.flatMap(e=>e.views);if(!(M(o)||o.length===0))for(let e of o)try{k(e.name)&&t.push(this.descriptions.createDescription(e,e.name,r))}catch(e){logWarnError(e)}}exportGlobals(e,t,r){if(!(M(e)||e.length===0)){for(let o of e.flatMap(e=>e.predicates))try{let e=o;k(e.name)&&t.push(this.descriptions.createDescription(e,e.name,r))}catch(e){logWarnError(e)}for(let o of e.flatMap(e=>e.styles))try{let e=o.id;k(e.name)&&t.push(this.descriptions.createDescription(e,e.name,r))}catch(e){logWarnError(e)}}}exportModel(e,t,r){if(!(M(e)||e.length===0))for(let o of e.flatMap(e=>e.elements))try{isElement(o)&&k(o.name)&&t.push(this.descriptions.createDescription(o,o.name,r))}catch(e){logWarnError(e)}}exportLibrary(e,t,r){if(!M(e))try{for(let o of e.flatMap(e=>e.icons))t.push(this.descriptions.createDescription(o,o.name,r))}catch(e){logWarnError(e)}}exportSpecification(e,t,r){if(!(M(e)||e.length===0))for(let o of e.flatMap(e=>[...e.elements,...e.relationships,...e.deploymentNodes,...e.tags,...e.colors]))try{switch(!0){case isSpecificationDeploymentNodeKind(o):case isSpecificationElementKind(o):k(o.kind.name)&&t.push(this.descriptions.createDescription(o.kind,o.kind.name,r));continue;case isSpecificationTag(o):k(o.tag.name)&&t.push(this.descriptions.createDescription(o.tag,o.tag.name,r));continue;case isSpecificationRelationshipKind(o):k(o.kind.name)&&t.push(this.descriptions.createDescription(o.kind,o.kind.name,r));continue;case isSpecificationColor(o):k(o.name.name)&&t.push(this.descriptions.createDescription(o.name,o.name.name,r));continue;default:H(o)}}catch(e){logWarnError(e)}}exportDeployments(e,t,r){let o=e?.flatMap(e=>e.elements);if(!(M(o)||o.length===0))for(let e of o)try{isDeploymentNode$1(e)&&k(e.name)&&t.push(this.descriptions.createDescription(e,e.name,r))}catch(e){logWarnError(e)}}computeLocalScopes(e,t){return new Promise(t=>{let r=e.parseResult.value,o=[],s=new ie;for(let t of r.models)try{o.push(...this.processContainer(t,s,e))}catch(e){logWarnError(e)}for(let t of r.deployments)try{o.push(...this.processDeployments(t,s,e))}catch(e){logWarnError(e)}for(let e of r.imports.flatMap(e=>e.imports))try{let t=e;for(;t;)o.push(this.descriptions.createDescription(t,t.imported.$refText)),t=t.prev}catch(e){logWarnError(e)}uniqueDescriptions(o).forEach(e=>{s.add(r,e)}),t(s)})}processContainer(e,t,r){let o=new ie,s=[];for(let c of e.elements){if(isRelation(c))continue;let e;if(isElement(c)?(k(c.name)&&o.add(c.name,this.descriptions.createDescription(c,c.name,r)),e=c.body,e&&(t.add(e,this.descriptions.createDescription(c,`this`,r)),t.add(e,this.descriptions.createDescription(c,`it`,r)))):isExtendElement(c)&&(e=c.body),e&&e.elements.length>0)try{s.push(...this.processContainer(e,t,r))}catch(e){logWarnError(e)}}s.length&&F(s,P(e=>!o.has(e.name)),tn(e=>e.name),en((e,t)=>{e.length===1&&o.add(t,e[0])}));let c=[...o.values()];return t.addAll(e,c),c}processDeployments(e,t,r){let o=new ie,s=[];for(let c of e.elements){if(isDeploymentRelation(c))continue;let e=c.body;if(!isExtendDeployment(c)){let s=this.nameProvider.getName(c);if(k(s)){let e=this.descriptions.createDescription(c,s,r);o.add(s,e)}e&&(t.add(e,this.descriptions.createDescription(c,`this`,r)),t.add(e,this.descriptions.createDescription(c,`it`,r)))}if(e)try{s.push(...this.processDeployments(e,t,r))}catch(e){logWarnError(e)}}s.length&&F(s,P(e=>!o.has(e.name)),tn(e=>e.name),en((e,t)=>{e.length===1&&o.add(t,e[0])}));let c=[...o.values()];return t.addAll(e,c),c}};const{getDocument:Wl}=Re;var LikeC4ScopeProvider=class extends Ie{deploymentsIndex;fqnIndex;indexManager;constructor(e){super(e),this.indexManager=e.shared.workspace.IndexManager,this.fqnIndex=e.likec4.FqnIndex,this.deploymentsIndex=e.likec4.DeploymentsIndex}getScope(e){try{let t=projectIdFrom(e.container),r=this.reflection.getReferenceType(e);try{let o=e.container;if(isFqnRef(o))return new x(this.streamForFqnRef(t,o,e));if(isStrictFqnRef(o))return this.getScopeForStrictFqnRef(t,o,e);if(r!==`Element`)return this.getProjectScope(t,r,e);if(isImported(o)){let e=projectIdFrom(o);return new x(this.fqnIndex.rootElements(e))}if(isStrictFqnElementRef(o)&&e.property===`el`){let s=o.parent;return s?new x(this.fqnIndex.directChildrenOf(t,readStrictFqn(s))):this.getProjectScope(t,r,e)}return new x(st(this.computeScope(t,e)))}catch(o){return logWarnError(o),this.getProjectScope(t,r,e)}}catch(e){return logWarnError(e),oe}}*genUniqueDescedants(e){if(!e)return;let t=projectIdFrom(e);if(isElement(e)){let r=this.fqnIndex.getFqn(e);yield*this.fqnIndex.uniqueDescedants(t,r);return}if(isDeploymentNode$1(e)){let r=this.deploymentsIndex.getFqn(e);yield*this.deploymentsIndex.uniqueDescedants(t,r)}}*genScopeExtendElement({element:e}){e.el.$nodeDescription&&(yield e.el.$nodeDescription,yield{...e.el.$nodeDescription,name:`this`},yield{...e.el.$nodeDescription,name:`it`}),yield*this.genUniqueDescedants(elementRef(e))}*genScopeElementView({viewOf:e,extends:t}){if(e){e.modelElement.value.$nodeDescription&&(yield e.modelElement.value.$nodeDescription),yield*this.genUniqueDescedants(elementRef(e));return}if(t){let e=t.view.ref;e&&(yield*this.genScopeElementView(e))}}getScopeForStrictFqnRef(e,t,r){let o=t.parent;return o?new x(this.deploymentsIndex.directChildrenOf(e,readStrictFqn(o)).filter(e=>this.reflection.isSubtype(e.type,so))):this.getProjectScope(e,so,r)}*genScopeExtendDeployment({deploymentNode:e}){e.value.$nodeDescription&&(yield e.value.$nodeDescription);let t=e.value.ref;t&&isDeploymentNode$1(t)&&(yield*this.genUniqueDescedants(t))}streamForFqnRef(e,t,r){let o=t.parent;if(!o)return st(this.genScopeForParentlessFqnRef(e,t,r));let s=o.value.ref;if(!s)return nt;if(isImported(s))return st(this.genUniqueDescedants(s.imported.ref));if(isDeploymentNode$1(s))return st(this.genUniqueDescedants(s));if(isDeployedInstance(s)){let e=s.target.modelElement.value.ref,t=isImported(e)?e.imported.ref:isElement(e)?e:void 0;return st(this.genUniqueDescedants(t))}return isElement(s)?st(this.genUniqueDescedants(s)):H(s)}*genScopeForParentlessFqnRef(e,t,r){Oe(t,isElementRef)||isFqnRefInsideModel(t)?yield*this.computeScope(e,r,To):isFqnRefInsideGlobals(t)?(yield*this.computeScope(e,r,To),yield*this.computeScope(e,r,so),yield*this.computeScope(e,r,ao)):(yield*this.computeScope(e,r,so),yield*this.computeScope(e,r,ao),Oe(t,isDeploymentViewBody)&&(yield*this.computeScope(e,r,To)));let o=Wl(t).precomputedScopes;o&&(yield*o.values().filter(e=>this.reflection.isSubtype(e.type,as)))}*computeScope(e,t,r=this.reflection.getReferenceType(t)){let o=this.reflection.isSubtype(r,To),s=this.reflection.isSubtype(r,_a),c=Wl(t.container).precomputedScopes;if(!c){yield*this.getProjectScope(e,r,t).getAllElements();return}let byReferenceType=e=>this.reflection.isSubtype(e.type,r),u=t.container;for(;u;){let e=c.get(u).filter(byReferenceType);e.length>0&&(yield*e),s&&isExtendDeploymentBody(u)&&(yield*this.genScopeExtendDeployment(u.$container)),o&&isExtendElementBody(u)&&(yield*this.genScopeExtendElement(u.$container)),o&&isElementViewBody(u)&&(yield*this.genScopeElementView(u.$container)),u=u.$container}yield*this.getProjectScope(e,r,t).getAllElements()}getProjectScope(e,t,r){return t===`LibIcon`?super.getGlobalScope(t,r):this.globalScopeCache.get(`${e}::${t}`,()=>new ce(this.indexManager.projectElements(e,t)))}getGlobalScope(e,t){if(e===`LibIcon`)return super.getGlobalScope(e,t);let r=projectIdFrom(t.container);return this.getProjectScope(r,e,t)}},Q=be();let Gl;(function(e){e.type=new Q.NotificationType(`likec4/onDidChangeModel`)})(Gl||={});let Kl;(function(e){e.type=new Q.NotificationType0(`likec4/onDidChangeProjects`)})(Kl||={});let ql;(function(e){e.type=new Q.NotificationType(e.Method=`likec4/onDidChangeSnapshot`)})(ql||={});let Jl;(function(e){e.type=new Q.NotificationType(`likec4/onRequestOpenView`)})(Jl||={});let Yl;(function(e){e.req=new Q.RequestType(`likec4/fetchComputedModel`)})(Yl||={});let Xl;(function(e){e.req=new Q.RequestType0(`likec4/fetchViewsFromAllProjects`)})(Xl||={});let Zl;(function(e){e.req=new Q.RequestType(`likec4/fetchLayoutedModel`)})(Zl||={});let Ql;(function(e){e.req=new Q.RequestType(`likec4/layout-view`)})(Ql||={});let $l;(function(e){e.req=new Q.RequestType(`likec4/validate-layout`)})($l||={});let eu;(function(e){e.req=new Q.RequestType0(`likec4/reload-projects`)})(eu||={});let tu;(function(e){e.req=new Q.RequestType0(`likec4/fetch-projects`)})(tu||={});let nu;(function(e){e.req=new Q.RequestType(`likec4/register-project`)})(nu||={});let ru;(function(e){e.req=new Q.RequestType(`likec4/build`)})(ru||={});let iu;(function(e){e.req=new Q.RequestType(`likec4/locate`)})(iu||={});let au;(function(e){e.req=new Q.RequestType(`likec4/change-view`)})(au||={});let ou;(function(e){e.req=new Q.RequestType0(`likec4/metrics`)})(ou||={});let su;(function(e){e.req=new Q.RequestType(`likec4/document-tags`)})(su||={});let cu;(function(e){e.req=new Q.RequestType0(`likec4/fetch-projects-overview`)})(cu||={});const $=q.getChild(`rpc`);var Rpc=class extends ADisposable{services;constructor(e){super(),this.services=e}init=bn(()=>{let e=this.services.shared.lsp.Connection;if(!e){$.info(`no connection, skip init ServerRpc`);return}$.info(`init ServerRpc`);let t=this.services.likec4,r=this.services.shared.workspace,o=r.LangiumDocuments,s=r.DocumentBuilder,sendDidChangeModelNotification=t=>{$.debug`send ${`onDidChangeModel`} for project ${t}`,e.sendNotification(Gl.type,{projectId:t}).catch(e=>{$.warn(`[ServerRpc] error sending onDidChangeModel for project {project}`,{error:e,project:t})})},c=Gt(e=>{if(typeof e==`string`){sendDidChangeModelNotification(e);return}for(let t of e)sendDidChangeModelNotification(t)},{reducer:(e,t)=>!e||e===t?t:e instanceof Set?(e.add(t),e):new Set([e,t]),triggerAt:`end`,minQuietPeriodMs:130,maxBurstDurationMs:400}),u=Gt(t=>{t>1?$.debug`send ${`DidChangeProjectsNotification`} (${t} batched)`:$.debug`send ${`DidChangeProjectsNotification`}`,e.sendNotification(Kl.type).catch(e=>{$.warn(`[ServerRpc] error sending DidChangeProjectsNotification:`,{error:e})})},{reducer:(e,t)=>(e??0)+t,triggerAt:`end`,minQuietPeriodMs:250,maxBurstDurationMs:700}),d=!0;this.onDispose(b.create(()=>{c.cancel(),u.cancel()}),t.ModelBuilder.onModelParsed(e=>c.call(e)),r.ProjectsManager.onProjectsUpdate(()=>u.call(1)),e.onRequest(Yl.req,async({projectId:e,cleanCaches:o=!1},s)=>{$.debug`received request ${`fetchComputedModel`} for project ${e}`,o&&($.debug`cleanCaches: ${o}`,e?(r.ManualLayouts.clearCaches(),await r.ProjectsManager.rebuildProject(e)):await r.WorkspaceManager.rebuildAll());let c=await t.ModelBuilder.computeModel(e,s);return c===vi.EMPTY?{model:null}:{model:c.$data}}),e.onNotification(ql.type,async e=>{let t=C.parse(e.update??e.delete),o=`update`in e?{update:t}:{delete:t};$.debug`received notification ${`onDidChangeSnapshot`} with ${e}`,await r.ManualLayouts.handleFileSystemUpdate(o)}),e.onRequest(Zl.req,async({projectId:e},r)=>{$.debug`received request ${`fetchLayoutedModel`} for project ${e}`;let o=await t.LanguageServices.layoutedModel(e);if(o===null)return{model:null};let s=await t.Views.diagrams(e,r);return{model:{...o.$data,_stage:`layouted`,views:Jt(s,e=>e.id)}}}),e.onRequest(Ql.req,async({viewId:e,projectId:r,layoutType:o,hints:s},c)=>($.debug`received request ${`layoutView`} for ${e} from project ${r} (layout type: ${o??`not set`})`,{result:await t.Views.layoutView({viewId:e,projectId:r,layoutType:o,layoutHints:s,cancelToken:c})})),e.onRequest($l.req,async({projectId:e},r)=>($.debug`received request ${`validateLayout`} for project ${e}`,{result:reportLayoutDrift((await t.Views.layoutAllViews(e,r)).map(e=>e.diagram))})),e.onRequest(tu.req,async()=>($.debug`received request ${`FetchProjects`}`,{projects:on(o.groupedByProject(),(e,t)=>{let{folderUri:o,config:{name:s,title:c}}=r.ProjectsManager.getProject(t);return{folder:o.toString(),config:{name:s,title:c},docs:I(e,e=>e.uri.toString())}})})),e.onRequest(eu.req,async e=>{$.debug`received request ${`ReloadProjects`}`,r.ManualLayouts.clearCaches(),await r.ProjectsManager.reloadProjects(e)}),e.onRequest(nu.req,async(e,t)=>{$.debug`received request ${`RegisterProject`}`,r.ManualLayouts.clearCaches();let o;return o=`configUri`in e?await r.ProjectsManager.registerConfigFile(C.parse(e.configUri),t):await r.ProjectsManager.registerProject(e,t),{id:o.id}}),e.onRequest(Xl.req,async e=>{$.debug`received request ${`FetchViewsFromAllProjects`}`;let o=[];for(let s of r.ProjectsManager.all){await ee(e);try{let r=await t.Views.computedViews(s,e);o.push(...F(r,I(e=>({id:e.id,title:e.title??e.id,projectId:s})),Cn((e,t)=>e.id===`index`?-1:t.id===`index`?1:e.title.localeCompare(t.title))))}catch(e){$.warn(`Failed to fetch views for project ${s}:`,{error:e})}}return{views:o}}),e.onRequest(ru.req,async({docs:t},r)=>{let c=t.map(e=>C.parse(e)),isNotChanged=e=>!c.some(t=>S.equals(t,e)),u=o.userDocuments.map(e=>e.uri).filter(isNotChanged).toArray();$.debug(`[ServerRpc] received request to build:
|
|
100
|
+
changed (total ${c.length}):${t.map(e=>`
|
|
90
101
|
- `+e).join(``)}
|
|
91
|
-
deleted (total ${
|
|
102
|
+
deleted (total ${u.length}):${u.map(e=>`
|
|
92
103
|
- `+e.toString()).join(`
|
|
93
|
-
`)}`),!s&&a.length+o.length>0&&await Promise.allSettled([...a,...o].map(async t=>{let n=t.toString();$.debug(`clear diagnostics for ${n}`);try{await e.sendDiagnostics({uri:n,diagnostics:[]})}catch(e){$.warn(`error clearing diagnostics for ${n}: ${e}`)}})),s=!1,await te(n),await i.update(a,o,n)}),e.onRequest(Yl.req,e=>{$.debug`received request ${`locate`}, ${e}`;let n=e.projectId;switch(!0){case`element`in e:return t.ModelLocator.locateElement(e.element,n);case`relation`in e:return t.ModelLocator.locateRelation(e.relation,n);case`astPath`in e:return t.ModelLocator.locateDynamicViewStep({view:e.view,astPath:e.astPath,projectId:n});case`view`in e:return t.ModelLocator.locateView(e.view,n);case`deployment`in e:return t.ModelLocator.locateDeploymentElement(e.deployment,n);default:V(e)}}),e.onRequest(Xl.req,async e=>($.debug`received request ${`changeView`} of ${e.viewId} from project ${e.projectId}`,await t.ModelChanges.applyChange(e))),e.onRequest(Zl.req,async e=>{let r=null;for(let i of n.ProjectsManager.all)try{let n=await t.ModelBuilder.computeModel(i,e);if(n===_i.EMPTY)continue;r??={elementKinds:0,deploymentKinds:0,relationshipKinds:0,tags:0,customColors:0,elements:0,deploymentNodes:0,relationships:0,views:0,projects:0},r.elementKinds+=Nn(n.specification.elements).length,r.deploymentKinds+=Nn(n.specification.deployments).length,r.relationshipKinds+=Nn(n.specification.relationships).length,r.tags+=Nn(n.specification.tags).length,r.customColors+=Nn(n.specification.customColors??{}).length,r.elements+=Nn(n.$data.elements).length,r.deploymentNodes+=[...n.deployment.nodes()].length,r.relationships+=Nn(n.$data.relations).length,r.views+=Nn(n.$data.views).length,r.projects+=1}catch(e){$.warn(`Error fetching telemetry metrics for project ${i}`,{err:e})}return await te(e),{metrics:r}}),e.onRequest(Ql.req,async({documentUri:e},r)=>{let i=v.parse(e);$.debug`received request ${`GetDocumentTags`} for document ${i}`;let a=await t.ModelLocator.locateDocumentTags(i,r);return{projectId:n.ProjectsManager.ownerProjectId(i),tags:a??[]}}),e.onRequest($l.req,async e=>($.debug`received request ${`FetchProjectsOverview`}`,{projectsView:await t.LanguageServices.projectsOverview(e)})),g.create(()=>{a.cancel()}));function reportLayoutDrift(e){return M(e,j(e=>!!e.hasLayoutDrift),N(e=>{let n=t.ModelLocator.locateView(e.id);return z(n,`View ${e.id} not found`),{uri:n.uri,viewId:e.id,severity:K.DiagnosticSeverity.Warning,message:`Layout drift detected for view '${e.id}'`,range:n.range}}))}});async openView(e){let t=this.services.shared.lsp.Connection;if(!t){$.warn(`No LSP connection`);return}await t.sendNotification(zl.type,e)}};Pe();var NodeKindProvider=class{services;constructor(e){this.services=e}getSymbolKind(e){let t=at(e)?e.$type:e.type,hasType=(...e)=>e.some(e=>this.services.AstReflection.isSubtype(t,e));switch(!0){case hasType(vo,Mo,eo,Qa,Qo):return He.Constructor;case hasType(ds,ps,fs,Uo,zs):return He.Namespace;case hasType(Sa):return He.Struct;case hasType(`Tag`,ns,Ya,Bs):return He.EnumMember;case hasType(Ds,Ls):return He.Event;case hasType(bo,no,Fs,Ps):return He.TypeParameter}return He.Field}getCompletionItemKind(e){let t=at(e)?e.$type:e.type,hasType=(...e)=>e.some(e=>this.services.AstReflection.isSubtype(t,e));switch(!0){case hasType(Ya):return b.Color;case hasType(vo,eo,Qa,Mo,Qo):return b.Constructor;case hasType(ds,ps,fs,Uo,zs):return b.Module;case hasType(Sa):return b.Class;case hasType(`Tag`,ns,Ya,Bs):return b.EnumMember;case hasType(Ds,Ls):return b.Event;case hasType(bo,Fs,no,Ps):return b.TypeParameter;default:return b.Reference}}},WorkspaceSymbolProvider=class extends De{};const eu=G.getChild(`views`);var DefaultLikeC4Views=class{services;#e;#t=new hr(e=>new ProjectStorage({projectId:e,storage:Jn(this.#e,e),layouter:e=>this.layouter.layout(e)}));ModelBuilder;constructor(e){this.services=e,this.ModelBuilder=e.likec4.ModelBuilder,this.#e=Yn(),e.shared.workspace.WorkspaceManager.onForceCleanCache(()=>{eu.info`force clean cache`,this.#e.clear()}),e.shared.workspace.ManualLayouts.onManualLayoutUpdate(({projectId:e,viewId:t})=>{this.#t.has(e)&&t&&this.projectStorage(e).clearView(t)})}get layouter(){return this.services.likec4.Layouter}async computedViews(e,t){return On((await this.ModelBuilder.computeModel(e,t)).$data.views)}async _layoutAllViews(e,t){let n=On(e.$data.views);if(n.length===0)return[];let r=e.project.id,i=eu.getChild(r),a=this.projectStorage(r),o=[],s=e.$styles,c=[];for(let e of n){let t={view:e,styles:s},n=await a.get(t);if(n){c.push(n);continue}o.push(t)}if(c.length>0&&(o.length>0?i.trace`cached ${c.length} views, need to layout ${o.length} views`:i.trace`cached all ${c.length} views`),o.length>0){let e=performanceMark();await this.layouter.batchLayout({batch:o,cancelToken:t,onSuccess:(e,t)=>{c.push(a.remember(e,t))},onError:(e,t)=>{i.warn(`Fail layout view ${e.view.id}`,{error:t})}}),i.debug`layouted ${o.length} views in ${e.pretty}`}return t&&t.isCancellationRequested&&await te(t),c.length!==n.length&&i.warn`layouted ${c.length} of ${n.length} views`,c}async layoutAllViews(e,t){let n=await this.ModelBuilder.computeModel(e,t);return await this._layoutAllViews(n,t)}async layoutView({viewId:e,layoutType:t,projectId:n,cancelToken:r,layoutHints:i}){let a=await this.ModelBuilder.computeModel(n,r),o=a.findView(e)?.$view;n=a.project.id;let s=eu.getChild(n);if(i){z(o,`View ${e} not found in model`),s.debug`using provided AI layout hints for view ${e}`;let{dot:t,diagram:n}=await this.layouter.aiLayout({view:o,styles:a.$styles},i);return{dot:t,diagram:n}}if(!o){s.warn`view ${e} not found in model`;let t=a.findManualLayout(e);if(t){s.info`found manual layout for ${e}`;let n={...t};return n.drifts=[`not-exists`],n._layout=`manual`,{diagram:n,dot:`# manual layout`}}return null}let c=this.projectStorage(n);try{let e={view:o,styles:a.$styles},n=await c.getOrExecute(e);return T(t)?{dot:n.dot,diagram:this.withLayoutType(n.diagram,a,t)}:n}catch(e){let t=loggable(e);return s.warn(t),this.reportViewError(o,n,t),Promise.reject(e)}}async diagrams(e,t){let n=await this.ModelBuilder.computeModel(e,t);return(await this._layoutAllViews(n,t)).map(({diagram:e})=>this.withLayoutType(e,n,`manual`))}async viewsAsGraphvizOut(e,t){let n=`All-LayoutedViews-DotWithSvg`,r=this.services.shared.workspace.Cache;if(r.has(n))return await Promise.resolve(r.get(n));let i=await this.ModelBuilder.computeModel(e,t),a=On(i.$data.views);if(a.length===0)return[];let o=a.map(async e=>{let{dot:t,svg:n}=await this.layouter.svg({view:e,styles:i.$styles});return{id:e.id,dot:t,svg:n}}),s=[],c=await Promise.allSettled(o);for(let e of c)e.status===`fulfilled`?s.push(e.value):logWarnError(e.reason);return r.set(n,s),s}async openView(e,t){await this.services.Rpc.openView({viewId:e,projectId:t})}async adhocView(e,t){eu.trace`layouting adhoc view...`;let n=await this.ModelBuilder.computeModel(t),r=Ni(n,e),{diagram:i}=await this.layouter.layout({view:{...r,hash:``,_type:`element`},styles:n.$styles});return eu.debug`layouting adhoc view... done`,i}reportViewError(e,t,n){this.projectStorage(t).reportViewError(e,()=>{this.services.shared.lsp.Connection?.window.showErrorMessage(`LikeC4: ${n}`)})}withLayoutType(e,t,n){if(!n)return e;let r=t.findManualLayout(e.id);return r?n===`manual`?e[Cr]===`manual`?(eu.error`View ${e.id} already has manual layout, this should not happen`,e):Or(e,r):kr(e,r):e}projectStorage(e){return this.#t.get(e)}},ProjectStorage=class{#e;#t;#n;constructor(e){this.#e=eu.getChild(e.projectId),this.#t=e.storage,this.#n=e.layouter}async get(e){let t=cacheKey(e),n=await this.#t.get(t);if(n)return this.#e.trace`cache hit for ${e.view.id}`,mergeWithCachedLayout(e.view,n);this.#e.trace`cache miss for ${e.view.id}`}async getOrExecute(e){let t=cacheKey(e),n=await this.#t.get(t);if(n)return this.#e.trace`cache hit for ${e.view.id}`,mergeWithCachedLayout(e.view,n);this.#e.trace`cache miss for ${e.view.id}`;let r=performanceMark(),i=await this.#n(e);return this.#e.trace(`layouted {view} in ${r.pretty}`,{view:e.view.id}),await this.#t.set(t,i),this.resetViewError(e.view),i}remember=(e,t)=>{let n=cacheKey(e);return t&&(this.#t.set(n,t).catch(e=>{this.#e.error(e)}),this.resetViewError(e.view)),t};reportViewError(e,t){let n=`error:${e.id}`;this.#t.has(n).then(e=>{e||(this.#t.set(n,`true`),t())})}async clearView(e){this.resetViewError(e);let t=await this.#t.keys(`v:${e}:`);if(t.length!==0){this.#e.trace`clear ${t.length} cached entries for view ${e}`;for(let e of t)await this.#t.remove(e)}}clearAll(){this.#e.trace`clear caches`,this.#t.clear()}resetViewError(e){let t=typeof e==`string`?e:e.id;this.#t.del(`error:${t}`)}};function cacheKey(e){return`v:${e.view.id}:${e.view.hash}:${e.styles.fingerprint}`}function mergeWithCachedLayout(e,t){return{dot:t.dot,diagram:Dr(e,t.diagram)}}const tu={graphviz(){return new Yi}};function WithGraphviz(e){return{graphviz(){return e}}}function createLikeC4SharedModule(e){return{lsp:{NodeKindProvider:e=>new NodeKindProvider(e),WorkspaceSymbolProvider:e=>new WorkspaceSymbolProvider(e)},workspace:{Cache:e=>new oe(e,y.Validated),IndexManager:e=>new IndexManager(e),LangiumDocuments:e=>new LangiumDocuments(e),ProjectsManager:e=>new jc(e),WorkspaceManager:e=>new LikeC4WorkspaceManager(e),FileSystemProvider:()=>e.fileSystemProvider(),FileSystemWatcher:t=>e.fileSystemWatcher(t),ManualLayouts:t=>e.manualLayouts(t)}}}function bind(e){return t=>new e(t)}function createLikeC4Module(e){return{documentation:{DocumentationProvider:bind(LikeC4DocumentationProvider)},validation:{DocumentValidator:bind(LikeC4DocumentValidator)},Rpc:bind(Rpc),likec4:{LanguageServices:bind(DefaultLikeC4LanguageServices),Graphviz:t=>e.graphviz(t),Layouter:e=>new QueueGraphvizLayoter({graphviz:e.likec4.Graphviz}),Views:bind(DefaultLikeC4Views),DeploymentsIndex:bind(DeploymentsIndex),ModelChanges:bind(LikeC4ModelChanges),FqnIndex:bind(FqnIndex),ModelParser:bind(LikeC4ModelParser),ModelBuilder:bind(DefaultLikeC4ModelBuilder),ModelLocator:bind(LikeC4ModelLocator),LastSeen:bind(LastSeenArtifacts)},lsp:{CompletionProvider:bind(LikeC4CompletionProvider),DocumentHighlightProvider:bind(LikeC4DocumentHighlightProvider),DocumentSymbolProvider:bind(LikeC4DocumentSymbolProvider),SemanticTokenProvider:bind(LikeC4SemanticTokenProvider),HoverProvider:bind(LikeC4HoverProvider),CodeLensProvider:bind(LikeC4CodeLensProvider),DocumentLinkProvider:bind(LikeC4DocumentLinkProvider),Formatter:bind(LikeC4Formatter),CodeActionProvider:bind(LikeC4CodeActionProvider)},workspace:{AstNodeDescriptionProvider:bind(AstNodeDescriptionProvider)},references:{NameProvider:bind(LikeC4NameProvider),ScopeComputation:bind(LikeC4ScopeComputation),ScopeProvider:bind(LikeC4ScopeProvider)},parser:{ValueConverter:bind(LikeC4ValueConverter)}}}function createLanguageServices$1(e={},t,n,r){let i=createSharedServices(e),a=fe([$e({shared:i}),xc,createLikeC4Module({...Bc,...Vc,...tu,...e}),t,n,r].reduce(_merge,{}));return i.ServiceRegistry.register(a),registerValidationChecks(a),e.connection?ci(()=>a.Rpc.init()):i.workspace.ConfigurationProvider.initialized({}),{shared:i,likec4:a}}t(createLanguageServices$1,`createLanguageServices`);function createSharedServices(e={}){let t={...Bc,...Vc,...e};return fe(Te(t),bc,createLikeC4SharedModule(t))}function _merge(e,t){if(t)for(let[n,r]of Object.entries(t)){if(n===`__proto__`||n===`constructor`||n===`prototype`||r===void 0)continue;let t=Object.hasOwn(e,n),i=e[n];t&&i!==null&&r!==null&&typeof i==`object`&&typeof r==`object`?e[n]=_merge(i,r):e[n]=r}return e}function graphvizBinPath(){try{return Qi.default.sync(`dot`)}catch(e){return G.error(`Error checking for native Graphviz:`,{error:e}),null}}const nu={likec4:{Layouter(e){G.debug(`Creating ConfigurableLayouter`);let t=e.likec4.Graphviz,n=new QueueGraphvizLayoter({graphviz:t});return e.shared.workspace.ConfigurationProvider.onConfigurationSectionUpdate(t=>{if(G.debug(`Configuration update: {update}`,{update:t}),t.section!==e.LanguageMetaData.languageId){G.debug(`Ignoring configuration update as it is not for ${e.LanguageMetaData.languageId}`);return}try{let{mode:r,path:i}=t.configuration.graphviz??{mode:`wasm`,path:``};if(r!==`wasm`){let t=D(i)?graphvizBinPath():i;if(!D(t)){n.changePort(new GraphvizBinaryAdapter(t)),G.info`use graphviz binary: ${t}`;return}G.warn(`No Graphviz binaries found on PATH, use graphviz wasm`),e.shared.lsp.Connection?.window.showWarningMessage(`No Graphviz binaries found on PATH, set path to binaries in settings.`)}n.changePort(new Yi),G.info(`use graphviz wasm`)}catch(e){G.error(`Failed to update configuration`,{error:e})}}),n}}};function startLanguageServer(e){let t=e?.connection,n=u(e,{enableWatcher:!0,enableManualLayouts:!0,graphviz:`wasm`,configureLogger:!1});n.configureLogger!==!1&&(n.configureLogger===`stderr`?configureLanguageServerLogger({lspConnection:t,enableTelemetry:!1,useStdErr:!0}):n.configureLogger===`console`&&configureLanguageServerLogger({lspConnection:t})),t?G.info(`Starting LikeC4 language server`):G.warn(`Starting LikeC4 language server (headless - no LSP connection)`);let r=createLanguageServices$1({...t&&{connection:t},...WithFileSystem(n.enableWatcher),...n.enableManualLayouts&&Ic,...WithGraphviz(n.graphviz===`binary`?new GraphvizBinaryAdapter:new Yi)},t?{likec4:{...nu.likec4}}:void 0);return We(r.shared),r}function configureLogger(e){let t=e?.configureLogger??!1;if(t!==!1){if(t===`stderr`){configureLanguageServerLogger({useStdErr:!0,colors:!1,logLevel:e?.logLevel});return}configureLanguageServerLogger({colors:Ei,logLevel:e?.logLevel})}}function createLanguageServices(e){let t=W.getChild(`lang`),n=u(e,{useFileSystem:!0,manualLayouts:!0,watch:!1,graphviz:`wasm`}),r=n.graphviz===`binary`;return t.info(`${ct.dim(`layout`)} ${r?`binary`:`wasm`}`),createLanguageServices$1({...n.useFileSystem?{...WithFileSystem(n.watch),...n.manualLayouts?Ic:Vc}:{...Bc,...Vc},...WithGraphviz(r?new GraphvizBinaryAdapter:new Yi)})}async function fromWorkspace(e,t){let n=$n(e),r=pt(v.file(n).toString()),i=W.getChild(`lang`),a=u(t,{...Vi,useFileSystem:!0,manualLayouts:!0,watch:!1});configureLogger(a);let o=createLanguageServices(a),s={name:Xn(n),uri:r},c=o.shared.workspace.WorkspaceManager;i.info(`${ct.dim(`workspace:`)} ${n}`),c.initialize({capabilities:{},processId:null,rootUri:s.uri,workspaceFolders:[s]}),await c.initialized({});let l=o.shared.workspace.LangiumDocuments.userDocuments.toArray();if(l.length===0&&(i.error(`no LikeC4 sources found`),t?.throwIfInvalid))throw Error(`no LikeC4 sources found`);return i.info(`${ct.dim(`workspace:`)} found ${l.length} source files`),handleInitOptions(o,W,t)}async function fromSources(e,t){configureLogger(t);let n=W.getChild(`lang`);return await createFromSources(createLanguageServices(u(t,{...Vi,useFileSystem:!1,watch:!1,manualLayouts:!1})),n,e,t)}async function fromSource(e,t){return fromSources({"source.c4":e},t)}export{ia as a,createLogger as c,getAnsiColorFormatter as d,getConsoleFormatter as f,ra as i,W as l,fromWorkspace as n,configureLanguageServerLogger as o,loggable as p,startLanguageServer as r,configureLogger$1 as s,fromSource as t,getConsoleSink as u};
|
|
104
|
+
`)}`),!d&&c.length+u.length>0&&await Promise.allSettled([...c,...u].map(async t=>{let r=t.toString();$.debug(`clear diagnostics for ${r}`);try{await e.sendDiagnostics({uri:r,diagnostics:[]})}catch(e){$.warn(`error clearing diagnostics for ${r}: ${e}`)}})),d=!1,await ee(r),await s.update(c,u,r)}),e.onRequest(iu.req,e=>{$.debug`received request ${`locate`}, ${e}`;let r=e.projectId;switch(!0){case`element`in e:return t.ModelLocator.locateElement(e.element,r);case`relation`in e:return t.ModelLocator.locateRelation(e.relation,r);case`astPath`in e:return t.ModelLocator.locateDynamicViewStep({view:e.view,astPath:e.astPath,projectId:r});case`view`in e:return t.ModelLocator.locateView(e.view,r);case`deployment`in e:return t.ModelLocator.locateDeploymentElement(e.deployment,r);default:H(e)}}),e.onRequest(au.req,async e=>($.debug`received request ${`changeView`} of ${e.viewId} from project ${e.projectId}`,await t.ModelChanges.applyChange(e))),e.onRequest(ou.req,async e=>{let o=null;for(let s of r.ProjectsManager.all)try{let r=await t.ModelBuilder.computeModel(s,e);if(r===vi.EMPTY)continue;o??={elementKinds:0,deploymentKinds:0,relationshipKinds:0,tags:0,customColors:0,elements:0,deploymentNodes:0,relationships:0,views:0,projects:0},o.elementKinds+=Pn(r.specification.elements).length,o.deploymentKinds+=Pn(r.specification.deployments).length,o.relationshipKinds+=Pn(r.specification.relationships).length,o.tags+=Pn(r.specification.tags).length,o.customColors+=Pn(r.specification.customColors??{}).length,o.elements+=Pn(r.$data.elements).length,o.deploymentNodes+=[...r.deployment.nodes()].length,o.relationships+=Pn(r.$data.relations).length,o.views+=Pn(r.$data.views).length,o.projects+=1}catch(e){$.warn(`Error fetching telemetry metrics for project ${s}`,{err:e})}return await ee(e),{metrics:o}}),e.onRequest(su.req,async({documentUri:e},o)=>{let s=C.parse(e);$.debug`received request ${`GetDocumentTags`} for document ${s}`;let c=await t.ModelLocator.locateDocumentTags(s,o);return{projectId:r.ProjectsManager.ownerProjectId(s),tags:c??[]}}),e.onRequest(cu.req,async e=>($.debug`received request ${`FetchProjectsOverview`}`,{projectsView:await t.LanguageServices.projectsOverview(e)})));function reportLayoutDrift(e){return F(e,P(e=>!!e.hasLayoutDrift),I(e=>{let r=t.ModelLocator.locateView(e.id);return V(r,`View ${e.id} not found`),{uri:r.uri,viewId:e.id,severity:oa.DiagnosticSeverity.Warning,message:`Layout drift detected for view '${e.id}'`,range:r.range}}))}});async openView(e){let t=this.services.shared.lsp.Connection;if(!t){$.warn(`No LSP connection`);return}await t.sendNotification(Jl.type,e)}};Pe();var NodeKindProvider=class{services;constructor(e){this.services=e}getSymbolKind(e){let t=at(e)?e.$type:e.type,hasType=(...e)=>e.some(e=>this.services.AstReflection.isSubtype(t,e));switch(!0){case hasType(To,zo,so,ao,as):return He.Constructor;case hasType(vs,bs,ys,Xo,Ks):return He.Namespace;case hasType(ka):return He.Struct;case hasType(`Tag`,ls,no,qs):return He.EnumMember;case hasType(Ps,Ws):return He.Event;case hasType(Do,lo,Hs,Vs):return He.TypeParameter}return He.Field}getCompletionItemKind(e){let t=at(e)?e.$type:e.type,hasType=(...e)=>e.some(e=>this.services.AstReflection.isSubtype(t,e));switch(!0){case hasType(no):return T.Color;case hasType(To,so,ao,zo,as):return T.Constructor;case hasType(vs,bs,ys,Xo,Ks):return T.Module;case hasType(ka):return T.Class;case hasType(`Tag`,ls,no,qs):return T.EnumMember;case hasType(Ps,Ws):return T.Event;case hasType(Do,Hs,lo,Vs):return T.TypeParameter;default:return T.Reference}}},WorkspaceSymbolProvider=class extends De{};const lu=q.getChild(`views`);var DefaultLikeC4Views=class extends ADisposable{services;#e;#t=new hr(e=>new ProjectStorage({projectId:e,storage:qn(this.#e,e),layouter:e=>this.layouter.layout(e)}));ModelBuilder;constructor(e){super(),this.services=e,this.ModelBuilder=e.likec4.ModelBuilder,this.#e=Jn(),this.onDispose(this.#e,b.create(()=>{this.#t.clear()}),e.shared.workspace.WorkspaceManager.onForceCleanCache(()=>{lu.info`force clean cache`,this.#e.clear()}),e.shared.workspace.ManualLayouts.onManualLayoutUpdate(({projectId:e,viewId:t})=>{this.#t.has(e)&&t&&this.projectStorage(e).clearView(t)}))}get layouter(){return this.services.likec4.Layouter}async computedViews(e,t){return kn((await this.ModelBuilder.computeModel(e,t)).$data.views)}async _layoutAllViews(e,t){let r=kn(e.$data.views);if(r.length===0)return[];let o=e.project.id,s=lu.getChild(o),c=this.projectStorage(o),u=[],d=e.$styles,p=[];for(let e of r){let t={view:e,styles:d},r=await c.get(t);if(r){p.push(r);continue}u.push(t)}if(p.length>0&&(u.length>0?s.trace`cached ${p.length} views, need to layout ${u.length} views`:s.trace`cached all ${p.length} views`),u.length>0){let e=performanceMark();await this.layouter.batchLayout({batch:u,cancelToken:t,onSuccess:(e,t)=>{p.push(c.remember(e,t))},onError:(e,t)=>{s.warn(`Fail layout view ${e.view.id}`,{error:t})}}),s.debug`layouted ${u.length} views in ${e.pretty}`}return t&&t.isCancellationRequested&&await ee(t),p.length!==r.length&&s.warn`layouted ${p.length} of ${r.length} views`,p}async layoutAllViews(e,t){let r=await this.ModelBuilder.computeModel(e,t);return await this._layoutAllViews(r,t)}async layoutView({viewId:e,layoutType:t,projectId:r,cancelToken:o,layoutHints:s}){let c=await this.ModelBuilder.computeModel(r,o),u=c.findView(e)?.$view;r=c.project.id;let d=lu.getChild(r);if(s){V(u,`View ${e} not found in model`),d.debug`using provided AI layout hints for view ${e}`;let{dot:t,diagram:r}=await this.layouter.aiLayout({view:u,styles:c.$styles},s);return{dot:t,diagram:r}}if(!u){d.warn`view ${e} not found in model`;let t=c.findManualLayout(e);if(t){d.info`found manual layout for ${e}`;let r={...t};return r.drifts=[`not-exists`],r._layout=`manual`,{diagram:r,dot:`# manual layout`}}return null}let p=this.projectStorage(r);try{let e={view:u,styles:c.$styles},r=await p.getOrExecute(e);return k(t)?{dot:r.dot,diagram:this.withLayoutType(r.diagram,c,t)}:r}catch(e){let t=loggable(e);return d.warn(t),this.reportViewError(u,r,t),Promise.reject(e)}}async diagrams(e,t){let r=await this.ModelBuilder.computeModel(e,t);return(await this._layoutAllViews(r,t)).map(({diagram:e})=>this.withLayoutType(e,r,`manual`))}async viewsAsGraphvizOut(e,t){let r=`All-LayoutedViews-DotWithSvg`,o=this.services.shared.workspace.Cache;if(o.has(r))return await Promise.resolve(o.get(r));let s=await this.ModelBuilder.computeModel(e,t),c=kn(s.$data.views);if(c.length===0)return[];let u=c.map(async e=>{let{dot:t,svg:r}=await this.layouter.svg({view:e,styles:s.$styles});return{id:e.id,dot:t,svg:r}}),d=[],p=await Promise.allSettled(u);for(let e of p)e.status===`fulfilled`?d.push(e.value):logWarnError(e.reason);return o.set(r,d),d}async openView(e,t){await this.services.Rpc.openView({viewId:e,projectId:t})}async adhocView(e,t){lu.trace`layouting adhoc view...`;let r=await this.ModelBuilder.computeModel(t),o=Pi(r,e),{diagram:s}=await this.layouter.layout({view:{...o,hash:``,_type:`element`},styles:r.$styles});return lu.debug`layouting adhoc view... done`,s}reportViewError(e,t,r){this.projectStorage(t).reportViewError(e,()=>{this.services.shared.lsp.Connection?.window.showErrorMessage(`LikeC4: ${r}`)})}withLayoutType(e,t,r){if(!r)return e;let o=t.findManualLayout(e.id);return o?r===`manual`?e[Cr]===`manual`?(lu.error`View ${e.id} already has manual layout, this should not happen`,e):Or(e,o):kr(e,o):e}projectStorage(e){return this.#t.get(e)}},ProjectStorage=class{#e;#t;#n;constructor(e){this.#e=lu.getChild(e.projectId),this.#t=e.storage,this.#n=e.layouter}async get(e){let t=cacheKey(e),r=await this.#t.get(t);if(r)return this.#e.trace`cache hit for ${e.view.id}`,mergeWithCachedLayout(e.view,r);this.#e.trace`cache miss for ${e.view.id}`}async getOrExecute(e){let t=cacheKey(e),r=await this.#t.get(t);if(r)return this.#e.trace`cache hit for ${e.view.id}`,mergeWithCachedLayout(e.view,r);this.#e.trace`cache miss for ${e.view.id}`;let o=performanceMark(),s=await this.#n(e);return this.#e.trace(`layouted {view} in ${o.pretty}`,{view:e.view.id}),await this.#t.set(t,s),this.resetViewError(e.view),s}remember=(e,t)=>{let r=cacheKey(e);return t&&(this.#t.set(r,t).catch(e=>{this.#e.error(e)}),this.resetViewError(e.view)),t};reportViewError(e,t){let r=`error:${e.id}`;this.#t.has(r).then(e=>{e||(this.#t.set(r,`true`),t())})}async clearView(e){this.resetViewError(e);let t=await this.#t.keys(`v:${e}:`);if(t.length!==0){this.#e.trace`clear ${t.length} cached entries for view ${e}`;for(let e of t)await this.#t.remove(e)}}clearAll(){this.#e.trace`clear caches`,this.#t.clear()}resetViewError(e){let t=typeof e==`string`?e:e.id;this.#t.del(`error:${t}`)}};function cacheKey(e){return`v:${e.view.id}:${e.view.hash}:${e.styles.fingerprint}`}function mergeWithCachedLayout(e,t){return{dot:t.dot,diagram:Dr(e,t.diagram)}}const uu={graphviz(){return new ta}};function WithGraphviz(e){return{graphviz(){return e}}}function createLikeC4SharedModule(e){return{lsp:{NodeKindProvider:e=>new NodeKindProvider(e),WorkspaceSymbolProvider:e=>new WorkspaceSymbolProvider(e)},workspace:{Cache:e=>new ae(e,w.Validated),IndexManager:e=>new IndexManager(e),LangiumDocuments:e=>new LangiumDocuments(e),ProjectsManager:e=>new Rc(e),WorkspaceManager:e=>new LikeC4WorkspaceManager(e),FileSystemProvider:()=>e.fileSystemProvider(),FileSystemWatcher:t=>e.fileSystemWatcher(t),ManualLayouts:t=>e.manualLayouts(t)}}}function bind(e){return t=>new e(t)}function createLikeC4Module(e){return{documentation:{DocumentationProvider:bind(LikeC4DocumentationProvider)},validation:{DocumentValidator:bind(LikeC4DocumentValidator)},Rpc:bind(Rpc),likec4:{LanguageServices:bind(DefaultLikeC4LanguageServices),Graphviz:t=>e.graphviz(t),Layouter:e=>new QueueGraphvizLayoter({graphviz:e.likec4.Graphviz}),Views:bind(DefaultLikeC4Views),DeploymentsIndex:bind(DeploymentsIndex),ModelChanges:bind(LikeC4ModelChanges),FqnIndex:bind(FqnIndex),ModelParser:bind(LikeC4ModelParser),ModelBuilder:bind(DefaultLikeC4ModelBuilder),ModelLocator:bind(LikeC4ModelLocator),LastSeen:bind(LastSeenArtifacts)},lsp:{CompletionProvider:bind(LikeC4CompletionProvider),DocumentHighlightProvider:bind(LikeC4DocumentHighlightProvider),DocumentSymbolProvider:bind(LikeC4DocumentSymbolProvider),SemanticTokenProvider:bind(LikeC4SemanticTokenProvider),HoverProvider:bind(LikeC4HoverProvider),CodeLensProvider:bind(LikeC4CodeLensProvider),DocumentLinkProvider:bind(LikeC4DocumentLinkProvider),Formatter:bind(LikeC4Formatter),CodeActionProvider:bind(LikeC4CodeActionProvider)},workspace:{AstNodeDescriptionProvider:bind(AstNodeDescriptionProvider)},references:{NameProvider:bind(LikeC4NameProvider),ScopeComputation:bind(LikeC4ScopeComputation),ScopeProvider:bind(LikeC4ScopeProvider)},parser:{ValueConverter:bind(LikeC4ValueConverter)}}}function createLanguageServices$1(e={},t,r,o){let s=createSharedServices(e),c=de([$e({shared:s}),Oc,createLikeC4Module({...Yc,...Xc,...uu,...e}),t,r,o].reduce(_merge,{}));return s.ServiceRegistry.register(c),registerValidationChecks(c),e.connection?li(()=>c.Rpc.init()):s.workspace.ConfigurationProvider.initialized({}),{shared:s,likec4:c}}t(createLanguageServices$1,`createLanguageServices`);function createSharedServices(e={}){let t={...Yc,...Xc,...e};return de(we(t),Dc,createLikeC4SharedModule(t))}function _merge(e,t){if(t)for(let[r,o]of Object.entries(t)){if(r===`__proto__`||r===`constructor`||r===`prototype`||o===void 0)continue;let t=Object.hasOwn(e,r),s=e[r];t&&s!==null&&o!==null&&typeof s==`object`&&typeof o==`object`?e[r]=_merge(s,o):e[r]=o}return e}function graphvizBinPath(){try{return ia.default.sync(`dot`)}catch(e){return q.error(`Error checking for native Graphviz:`,{error:e}),null}}const du={likec4:{Layouter(e){q.debug(`Creating ConfigurableLayouter`);let t=e.likec4.Graphviz,r=new QueueGraphvizLayoter({graphviz:t});return e.shared.workspace.ConfigurationProvider.onConfigurationSectionUpdate(t=>{if(q.debug(`Configuration update: {update}`,{update:t}),t.section!==e.LanguageMetaData.languageId){q.debug(`Ignoring configuration update as it is not for ${e.LanguageMetaData.languageId}`);return}try{let{mode:o,path:s}=t.configuration.graphviz??{mode:`wasm`,path:``};if(o!==`wasm`){let t=j(s)?graphvizBinPath():s;if(!j(t)){r.changePort(new GraphvizBinaryAdapter(t)),q.info`use graphviz binary: ${t}`;return}q.warn(`No Graphviz binaries found on PATH, use graphviz wasm`),e.shared.lsp.Connection?.window.showWarningMessage(`No Graphviz binaries found on PATH, set path to binaries in settings.`)}r.changePort(new ta),q.info(`use graphviz wasm`)}catch(e){q.error(`Failed to update configuration`,{error:e})}}),r}}};function startLanguageServer(e){let t=e?.connection,r=Vi(e,{enableWatcher:!0,enableManualLayouts:!0,graphviz:`wasm`,configureLogger:!1});r.configureLogger!==!1&&(r.configureLogger===`stderr`?configureLanguageServerLogger({lspConnection:t,enableTelemetry:!1,useStdErr:!0}):r.configureLogger===`console`&&configureLanguageServerLogger({lspConnection:t})),t?q.info(`Starting LikeC4 language server`):q.warn(`Starting LikeC4 language server (headless - no LSP connection)`);let o=createLanguageServices$1({...t&&{connection:t},...WithFileSystem(r.enableWatcher),...r.enableManualLayouts&&Wc,...WithGraphviz(r.graphviz===`binary`?new GraphvizBinaryAdapter:new ta)},t?{likec4:{...du.likec4}}:void 0);return We(o.shared),o}function configureLogger(e){let t=e?.configureLogger??!1;if(t!==!1){if(t===`stderr`){configureLanguageServerLogger({useStdErr:!0,colors:!1,logLevel:e?.logLevel});return}configureLanguageServerLogger({colors:Di,logLevel:e?.logLevel})}}function createLanguageServices(e){let t=G.getChild(`lang`),r=Vi(e,{useFileSystem:!0,manualLayouts:!0,watch:!1,graphviz:`wasm`}),o=r.graphviz===`binary`;return t.info(`${Ui.dim(`layout`)} ${o?`binary`:`wasm`}`),createLanguageServices$1({...r.useFileSystem?{...WithFileSystem(r.watch),...r.manualLayouts?Wc:Xc}:{...Yc,...Xc},...WithGraphviz(o?new GraphvizBinaryAdapter:new ta)})}async function fromWorkspace(e,t){let r=Qn(e),o=pt(C.file(r).toString()),s=G.getChild(`lang`),c=Vi(t,{...Gi,useFileSystem:!0,manualLayouts:!0,watch:!1});configureLogger(c);let u=createLanguageServices(c),d={name:Yn(r),uri:o},p=u.shared.workspace.WorkspaceManager;s.info(`${Ui.dim(`workspace:`)} ${r}`),p.initialize({capabilities:{},processId:null,rootUri:d.uri,workspaceFolders:[d]}),await p.initialized({});let m=u.shared.workspace.LangiumDocuments.userDocuments.toArray();if(m.length===0&&(s.error(`no LikeC4 sources found`),t?.throwIfInvalid))throw await u.likec4.likec4.LanguageServices.dispose(),Error(`no LikeC4 sources found`);return s.info(`${Ui.dim(`workspace:`)} found ${m.length} source files`),handleInitOptions(u,G,t)}async function fromSources(e,t){configureLogger(t);let r=G.getChild(`lang`);return await createFromSources(createLanguageServices(Vi(t,{...Gi,useFileSystem:!1,watch:!1,manualLayouts:!1})),r,e,t)}function fromSource(e,t){return fromSources({"source.c4":e},t)}export{ua as a,Ui as c,createLogger as d,G as f,loggable as g,getConsoleFormatter as h,stripIndent as i,Vi as l,getAnsiColorFormatter as m,fromWorkspace as n,da as o,getConsoleSink as p,startLanguageServer as r,configureLanguageServerLogger as s,fromSource as t,configureLogger$1 as u};
|