wgsl-edit 0.0.2

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.
@@ -0,0 +1,134 @@
1
+ (function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const s of document.querySelectorAll('link[rel="modulepreload"]'))n(s);new MutationObserver(s=>{for(const r of s)if(r.type==="childList")for(const o of r.addedNodes)o.tagName==="LINK"&&o.rel==="modulepreload"&&n(o)}).observe(document,{childList:!0,subtree:!0});function t(s){const r={};return s.integrity&&(r.integrity=s.integrity),s.referrerPolicy&&(r.referrerPolicy=s.referrerPolicy),s.crossOrigin==="use-credentials"?r.credentials="include":s.crossOrigin==="anonymous"?r.credentials="omit":r.credentials="same-origin",r}function n(s){if(s.ep)return;s.ep=!0;const r=t(s);fetch(s.href,r)}})();const Cc=1024;let Lp=0,wr=class{constructor(e,t){this.from=e,this.to=t}};class N{constructor(e={}){this.id=Lp++,this.perNode=!!e.perNode,this.deserialize=e.deserialize||(()=>{throw new Error("This node type doesn't define a deserialize function")})}add(e){if(this.perNode)throw new RangeError("Can't add per-node props to node types");return typeof e!="function"&&(e=De.match(e)),t=>{let n=e(t);return n===void 0?null:[this,n]}}}N.closedBy=new N({deserialize:i=>i.split(" ")});N.openedBy=new N({deserialize:i=>i.split(" ")});N.group=new N({deserialize:i=>i.split(" ")});N.isolate=new N({deserialize:i=>{if(i&&i!="rtl"&&i!="ltr"&&i!="auto")throw new RangeError("Invalid value for isolate: "+i);return i||"auto"}});N.contextHash=new N({perNode:!0});N.lookAhead=new N({perNode:!0});N.mounted=new N({perNode:!0});class ks{constructor(e,t,n){this.tree=e,this.overlay=t,this.parser=n}static get(e){return e&&e.props&&e.props[N.mounted.id]}}const Np=Object.create(null);class De{constructor(e,t,n,s=0){this.name=e,this.props=t,this.id=n,this.flags=s}static define(e){let t=e.props&&e.props.length?Object.create(null):Np,n=(e.top?1:0)|(e.skipped?2:0)|(e.error?4:0)|(e.name==null?8:0),s=new De(e.name||"",t,e.id,n);if(e.props){for(let r of e.props)if(Array.isArray(r)||(r=r(s)),r){if(r[0].perNode)throw new RangeError("Can't store a per-node prop on a node type");t[r[0].id]=r[1]}}return s}prop(e){return this.props[e.id]}get isTop(){return(this.flags&1)>0}get isSkipped(){return(this.flags&2)>0}get isError(){return(this.flags&4)>0}get isAnonymous(){return(this.flags&8)>0}is(e){if(typeof e=="string"){if(this.name==e)return!0;let t=this.prop(N.group);return t?t.indexOf(e)>-1:!1}return this.id==e}static match(e){let t=Object.create(null);for(let n in e)for(let s of n.split(" "))t[s]=e[n];return n=>{for(let s=n.prop(N.group),r=-1;r<(s?s.length:0);r++){let o=t[r<0?n.name:s[r]];if(o)return o}}}}De.none=new De("",Object.create(null),0,8);class Xo{constructor(e){this.types=e;for(let t=0;t<e.length;t++)if(e[t].id!=t)throw new RangeError("Node type ids should correspond to array positions when creating a node set")}extend(...e){let t=[];for(let n of this.types){let s=null;for(let r of e){let o=r(n);o&&(s||(s=Object.assign({},n.props)),s[o[0].id]=o[1])}t.push(s?new De(n.name,s,n.id,n.flags):n)}return new Xo(t)}}const Ln=new WeakMap,jl=new WeakMap;var ce;(function(i){i[i.ExcludeBuffers=1]="ExcludeBuffers",i[i.IncludeAnonymous=2]="IncludeAnonymous",i[i.IgnoreMounts=4]="IgnoreMounts",i[i.IgnoreOverlays=8]="IgnoreOverlays"})(ce||(ce={}));class re{constructor(e,t,n,s,r){if(this.type=e,this.children=t,this.positions=n,this.length=s,this.props=null,r&&r.length){this.props=Object.create(null);for(let[o,l]of r)this.props[typeof o=="number"?o:o.id]=l}}toString(){let e=ks.get(this);if(e&&!e.overlay)return e.tree.toString();let t="";for(let n of this.children){let s=n.toString();s&&(t&&(t+=","),t+=s)}return this.type.name?(/\W/.test(this.type.name)&&!this.type.isError?JSON.stringify(this.type.name):this.type.name)+(t.length?"("+t+")":""):t}cursor(e=0){return new Jr(this.topNode,e)}cursorAt(e,t=0,n=0){let s=Ln.get(this)||this.topNode,r=new Jr(s);return r.moveTo(e,t),Ln.set(this,r._tree),r}get topNode(){return new We(this,0,0,null)}resolve(e,t=0){let n=hn(Ln.get(this)||this.topNode,e,t,!1);return Ln.set(this,n),n}resolveInner(e,t=0){let n=hn(jl.get(this)||this.topNode,e,t,!0);return jl.set(this,n),n}resolveStack(e,t=0){return Kp(this,e,t)}iterate(e){let{enter:t,leave:n,from:s=0,to:r=this.length}=e,o=e.mode||0,l=(o&ce.IncludeAnonymous)>0;for(let a=this.cursor(o|ce.IncludeAnonymous);;){let h=!1;if(a.from<=r&&a.to>=s&&(!l&&a.type.isAnonymous||t(a)!==!1)){if(a.firstChild())continue;h=!0}for(;h&&n&&(l||!a.type.isAnonymous)&&n(a),!a.nextSibling();){if(!a.parent())return;h=!0}}}prop(e){return e.perNode?this.props?this.props[e.id]:void 0:this.type.prop(e)}get propValues(){let e=[];if(this.props)for(let t in this.props)e.push([+t,this.props[t]]);return e}balance(e={}){return this.children.length<=8?this:Zo(De.none,this.children,this.positions,0,this.children.length,0,this.length,(t,n,s)=>new re(this.type,t,n,s,this.propValues),e.makeTree||((t,n,s)=>new re(De.none,t,n,s)))}static build(e){return zp(e)}}re.empty=new re(De.none,[],[],0);class jo{constructor(e,t){this.buffer=e,this.index=t}get id(){return this.buffer[this.index-4]}get start(){return this.buffer[this.index-3]}get end(){return this.buffer[this.index-2]}get size(){return this.buffer[this.index-1]}get pos(){return this.index}next(){this.index-=4}fork(){return new jo(this.buffer,this.index)}}class Vt{constructor(e,t,n){this.buffer=e,this.length=t,this.set=n}get type(){return De.none}toString(){let e=[];for(let t=0;t<this.buffer.length;)e.push(this.childString(t)),t=this.buffer[t+3];return e.join(",")}childString(e){let t=this.buffer[e],n=this.buffer[e+3],s=this.set.types[t],r=s.name;if(/\W/.test(r)&&!s.isError&&(r=JSON.stringify(r)),e+=4,n==e)return r;let o=[];for(;e<n;)o.push(this.childString(e)),e=this.buffer[e+3];return r+"("+o.join(",")+")"}findChild(e,t,n,s,r){let{buffer:o}=this,l=-1;for(let a=e;a!=t&&!(vc(r,s,o[a+1],o[a+2])&&(l=a,n>0));a=o[a+3]);return l}slice(e,t,n){let s=this.buffer,r=new Uint16Array(t-e),o=0;for(let l=e,a=0;l<t;){r[a++]=s[l++],r[a++]=s[l++]-n;let h=r[a++]=s[l++]-n;r[a++]=s[l++]-e,o=Math.max(o,h)}return new Vt(r,o,this.set)}}function vc(i,e,t,n){switch(i){case-2:return t<e;case-1:return n>=e&&t<e;case 0:return t<e&&n>e;case 1:return t<=e&&n>e;case 2:return n>e;case 4:return!0}}function hn(i,e,t,n){for(var s;i.from==i.to||(t<1?i.from>=e:i.from>e)||(t>-1?i.to<=e:i.to<e);){let o=!n&&i instanceof We&&i.index<0?null:i.parent;if(!o)return i;i=o}let r=n?0:ce.IgnoreOverlays;if(n)for(let o=i,l=o.parent;l;o=l,l=o.parent)o instanceof We&&o.index<0&&((s=l.enter(e,t,r))===null||s===void 0?void 0:s.from)!=o.from&&(i=l);for(;;){let o=i.enter(e,t,r);if(!o)return i;i=o}}class xc{cursor(e=0){return new Jr(this,e)}getChild(e,t=null,n=null){let s=Jl(this,e,t,n);return s.length?s[0]:null}getChildren(e,t=null,n=null){return Jl(this,e,t,n)}resolve(e,t=0){return hn(this,e,t,!1)}resolveInner(e,t=0){return hn(this,e,t,!0)}matchContext(e){return jr(this.parent,e)}enterUnfinishedNodesBefore(e){let t=this.childBefore(e),n=this;for(;t;){let s=t.lastChild;if(!s||s.to!=t.to)break;s.type.isError&&s.from==s.to?(n=t,t=s.prevSibling):t=s}return n}get node(){return this}get next(){return this.parent}}class We extends xc{constructor(e,t,n,s){super(),this._tree=e,this.from=t,this.index=n,this._parent=s}get type(){return this._tree.type}get name(){return this._tree.type.name}get to(){return this.from+this._tree.length}nextChild(e,t,n,s,r=0){for(let o=this;;){for(let{children:l,positions:a}=o._tree,h=t>0?l.length:-1;e!=h;e+=t){let c=l[e],f=a[e]+o.from;if(vc(s,n,f,f+c.length)){if(c instanceof Vt){if(r&ce.ExcludeBuffers)continue;let u=c.findChild(0,c.buffer.length,t,n-f,s);if(u>-1)return new Lt(new $p(o,c,e,f),null,u)}else if(r&ce.IncludeAnonymous||!c.type.isAnonymous||Jo(c)){let u;if(!(r&ce.IgnoreMounts)&&(u=ks.get(c))&&!u.overlay)return new We(u.tree,f,e,o);let d=new We(c,f,e,o);return r&ce.IncludeAnonymous||!d.type.isAnonymous?d:d.nextChild(t<0?c.children.length-1:0,t,n,s)}}}if(r&ce.IncludeAnonymous||!o.type.isAnonymous||(o.index>=0?e=o.index+t:e=t<0?-1:o._parent._tree.children.length,o=o._parent,!o))return null}}get firstChild(){return this.nextChild(0,1,0,4)}get lastChild(){return this.nextChild(this._tree.children.length-1,-1,0,4)}childAfter(e){return this.nextChild(0,1,e,2)}childBefore(e){return this.nextChild(this._tree.children.length-1,-1,e,-2)}enter(e,t,n=0){let s;if(!(n&ce.IgnoreOverlays)&&(s=ks.get(this._tree))&&s.overlay){let r=e-this.from;for(let{from:o,to:l}of s.overlay)if((t>0?o<=r:o<r)&&(t<0?l>=r:l>r))return new We(s.tree,s.overlay[0].from+this.from,-1,this)}return this.nextChild(0,1,e,t,n)}nextSignificantParent(){let e=this;for(;e.type.isAnonymous&&e._parent;)e=e._parent;return e}get parent(){return this._parent?this._parent.nextSignificantParent():null}get nextSibling(){return this._parent&&this.index>=0?this._parent.nextChild(this.index+1,1,0,4):null}get prevSibling(){return this._parent&&this.index>=0?this._parent.nextChild(this.index-1,-1,0,4):null}get tree(){return this._tree}toTree(){return this._tree}toString(){return this._tree.toString()}}function Jl(i,e,t,n){let s=i.cursor(),r=[];if(!s.firstChild())return r;if(t!=null){for(let o=!1;!o;)if(o=s.type.is(t),!s.nextSibling())return r}for(;;){if(n!=null&&s.type.is(n))return r;if(s.type.is(e)&&r.push(s.node),!s.nextSibling())return n==null?r:[]}}function jr(i,e,t=e.length-1){for(let n=i;t>=0;n=n.parent){if(!n)return!1;if(!n.type.isAnonymous){if(e[t]&&e[t]!=n.name)return!1;t--}}return!0}class $p{constructor(e,t,n,s){this.parent=e,this.buffer=t,this.index=n,this.start=s}}class Lt extends xc{get name(){return this.type.name}get from(){return this.context.start+this.context.buffer.buffer[this.index+1]}get to(){return this.context.start+this.context.buffer.buffer[this.index+2]}constructor(e,t,n){super(),this.context=e,this._parent=t,this.index=n,this.type=e.buffer.set.types[e.buffer.buffer[n]]}child(e,t,n){let{buffer:s}=this.context,r=s.findChild(this.index+4,s.buffer[this.index+3],e,t-this.context.start,n);return r<0?null:new Lt(this.context,this,r)}get firstChild(){return this.child(1,0,4)}get lastChild(){return this.child(-1,0,4)}childAfter(e){return this.child(1,e,2)}childBefore(e){return this.child(-1,e,-2)}enter(e,t,n=0){if(n&ce.ExcludeBuffers)return null;let{buffer:s}=this.context,r=s.findChild(this.index+4,s.buffer[this.index+3],t>0?1:-1,e-this.context.start,t);return r<0?null:new Lt(this.context,this,r)}get parent(){return this._parent||this.context.parent.nextSignificantParent()}externalSibling(e){return this._parent?null:this.context.parent.nextChild(this.context.index+e,e,0,4)}get nextSibling(){let{buffer:e}=this.context,t=e.buffer[this.index+3];return t<(this._parent?e.buffer[this._parent.index+3]:e.buffer.length)?new Lt(this.context,this._parent,t):this.externalSibling(1)}get prevSibling(){let{buffer:e}=this.context,t=this._parent?this._parent.index+4:0;return this.index==t?this.externalSibling(-1):new Lt(this.context,this._parent,e.findChild(t,this.index,-1,0,4))}get tree(){return null}toTree(){let e=[],t=[],{buffer:n}=this.context,s=this.index+4,r=n.buffer[this.index+3];if(r>s){let o=n.buffer[this.index+1];e.push(n.slice(s,r,o)),t.push(0)}return new re(this.type,e,t,this.to-this.from)}toString(){return this.context.buffer.childString(this.index)}}function Sc(i){if(!i.length)return null;let e=0,t=i[0];for(let r=1;r<i.length;r++){let o=i[r];(o.from>t.from||o.to<t.to)&&(t=o,e=r)}let n=t instanceof We&&t.index<0?null:t.parent,s=i.slice();return n?s[e]=n:s.splice(e,1),new Fp(s,t)}class Fp{constructor(e,t){this.heads=e,this.node=t}get next(){return Sc(this.heads)}}function Kp(i,e,t){let n=i.resolveInner(e,t),s=null;for(let r=n instanceof We?n:n.context.parent;r;r=r.parent)if(r.index<0){let o=r.parent;(s||(s=[n])).push(o.resolve(e,t)),r=o}else{let o=ks.get(r.tree);if(o&&o.overlay&&o.overlay[0].from<=e&&o.overlay[o.overlay.length-1].to>=e){let l=new We(o.tree,o.overlay[0].from+r.from,-1,r);(s||(s=[n])).push(hn(l,e,t,!1))}}return s?Sc(s):n}class Jr{get name(){return this.type.name}constructor(e,t=0){if(this.mode=t,this.buffer=null,this.stack=[],this.index=0,this.bufferNode=null,e instanceof We)this.yieldNode(e);else{this._tree=e.context.parent,this.buffer=e.context;for(let n=e._parent;n;n=n._parent)this.stack.unshift(n.index);this.bufferNode=e,this.yieldBuf(e.index)}}yieldNode(e){return e?(this._tree=e,this.type=e.type,this.from=e.from,this.to=e.to,!0):!1}yieldBuf(e,t){this.index=e;let{start:n,buffer:s}=this.buffer;return this.type=t||s.set.types[s.buffer[e]],this.from=n+s.buffer[e+1],this.to=n+s.buffer[e+2],!0}yield(e){return e?e instanceof We?(this.buffer=null,this.yieldNode(e)):(this.buffer=e.context,this.yieldBuf(e.index,e.type)):!1}toString(){return this.buffer?this.buffer.buffer.childString(this.index):this._tree.toString()}enterChild(e,t,n){if(!this.buffer)return this.yield(this._tree.nextChild(e<0?this._tree._tree.children.length-1:0,e,t,n,this.mode));let{buffer:s}=this.buffer,r=s.findChild(this.index+4,s.buffer[this.index+3],e,t-this.buffer.start,n);return r<0?!1:(this.stack.push(this.index),this.yieldBuf(r))}firstChild(){return this.enterChild(1,0,4)}lastChild(){return this.enterChild(-1,0,4)}childAfter(e){return this.enterChild(1,e,2)}childBefore(e){return this.enterChild(-1,e,-2)}enter(e,t,n=this.mode){return this.buffer?n&ce.ExcludeBuffers?!1:this.enterChild(1,e,t):this.yield(this._tree.enter(e,t,n))}parent(){if(!this.buffer)return this.yieldNode(this.mode&ce.IncludeAnonymous?this._tree._parent:this._tree.parent);if(this.stack.length)return this.yieldBuf(this.stack.pop());let e=this.mode&ce.IncludeAnonymous?this.buffer.parent:this.buffer.parent.nextSignificantParent();return this.buffer=null,this.yieldNode(e)}sibling(e){if(!this.buffer)return this._tree._parent?this.yield(this._tree.index<0?null:this._tree._parent.nextChild(this._tree.index+e,e,0,4,this.mode)):!1;let{buffer:t}=this.buffer,n=this.stack.length-1;if(e<0){let s=n<0?0:this.stack[n]+4;if(this.index!=s)return this.yieldBuf(t.findChild(s,this.index,-1,0,4))}else{let s=t.buffer[this.index+3];if(s<(n<0?t.buffer.length:t.buffer[this.stack[n]+3]))return this.yieldBuf(s)}return n<0?this.yield(this.buffer.parent.nextChild(this.buffer.index+e,e,0,4,this.mode)):!1}nextSibling(){return this.sibling(1)}prevSibling(){return this.sibling(-1)}atLastNode(e){let t,n,{buffer:s}=this;if(s){if(e>0){if(this.index<s.buffer.buffer.length)return!1}else for(let r=0;r<this.index;r++)if(s.buffer.buffer[r+3]<this.index)return!1;({index:t,parent:n}=s)}else({index:t,_parent:n}=this._tree);for(;n;{index:t,_parent:n}=n)if(t>-1)for(let r=t+e,o=e<0?-1:n._tree.children.length;r!=o;r+=e){let l=n._tree.children[r];if(this.mode&ce.IncludeAnonymous||l instanceof Vt||!l.type.isAnonymous||Jo(l))return!1}return!0}move(e,t){if(t&&this.enterChild(e,0,4))return!0;for(;;){if(this.sibling(e))return!0;if(this.atLastNode(e)||!this.parent())return!1}}next(e=!0){return this.move(1,e)}prev(e=!0){return this.move(-1,e)}moveTo(e,t=0){for(;(this.from==this.to||(t<1?this.from>=e:this.from>e)||(t>-1?this.to<=e:this.to<e))&&this.parent(););for(;this.enterChild(1,e,t););return this}get node(){if(!this.buffer)return this._tree;let e=this.bufferNode,t=null,n=0;if(e&&e.context==this.buffer)e:for(let s=this.index,r=this.stack.length;r>=0;){for(let o=e;o;o=o._parent)if(o.index==s){if(s==this.index)return o;t=o,n=r+1;break e}s=this.stack[--r]}for(let s=n;s<this.stack.length;s++)t=new Lt(this.buffer,t,this.stack[s]);return this.bufferNode=new Lt(this.buffer,t,this.index)}get tree(){return this.buffer?null:this._tree._tree}iterate(e,t){for(let n=0;;){let s=!1;if(this.type.isAnonymous||e(this)!==!1){if(this.firstChild()){n++;continue}this.type.isAnonymous||(s=!0)}for(;;){if(s&&t&&t(this),s=this.type.isAnonymous,!n)return;if(this.nextSibling())break;this.parent(),n--,s=!0}}}matchContext(e){if(!this.buffer)return jr(this.node.parent,e);let{buffer:t}=this.buffer,{types:n}=t.set;for(let s=e.length-1,r=this.stack.length-1;s>=0;r--){if(r<0)return jr(this._tree,e,s);let o=n[t.buffer[this.stack[r]]];if(!o.isAnonymous){if(e[s]&&e[s]!=o.name)return!1;s--}}return!0}}function Jo(i){return i.children.some(e=>e instanceof Vt||!e.type.isAnonymous||Jo(e))}function zp(i){var e;let{buffer:t,nodeSet:n,maxBufferLength:s=Cc,reused:r=[],minRepeatType:o=n.types.length}=i,l=Array.isArray(t)?new jo(t,t.length):t,a=n.types,h=0,c=0;function f(y,C,x,I,T,V){let{id:M,start:P,end:W,size:z}=l,H=c,te=h;for(;z<0;)if(l.next(),z==-1){let je=r[M];x.push(je),I.push(P-y);return}else if(z==-3){h=M;return}else if(z==-4){c=M;return}else throw new RangeError(`Unrecognized record size: ${z}`);let he=a[M],Ie,X,Qe=P-y;if(W-P<=s&&(X=g(l.pos-C,T))){let je=new Uint16Array(X.size-X.skip),Ae=l.pos-X.size,ue=je.length;for(;l.pos>Ae;)ue=O(X.start,je,ue);Ie=new Vt(je,W-X.start,n),Qe=X.start-y}else{let je=l.pos-z;l.next();let Ae=[],ue=[],ot=M>=o?M:-1,Ke=0,Mt=W;for(;l.pos>je;)ot>=0&&l.id==ot&&l.size>=0?(l.end<=Mt-s&&(p(Ae,ue,P,Ke,l.end,Mt,ot,H,te),Ke=Ae.length,Mt=l.end),l.next()):V>2500?u(P,je,Ae,ue):f(P,je,Ae,ue,ot,V+1);if(ot>=0&&Ke>0&&Ke<Ae.length&&p(Ae,ue,P,Ke,P,Mt,ot,H,te),Ae.reverse(),ue.reverse(),ot>-1&&Ke>0){let pi=d(he,te);Ie=Zo(he,Ae,ue,0,Ae.length,0,W-P,pi,pi)}else Ie=m(he,Ae,ue,W-P,H-W,te)}x.push(Ie),I.push(Qe)}function u(y,C,x,I){let T=[],V=0,M=-1;for(;l.pos>C;){let{id:P,start:W,end:z,size:H}=l;if(H>4)l.next();else{if(M>-1&&W<M)break;M<0&&(M=z-s),T.push(P,W,z),V++,l.next()}}if(V){let P=new Uint16Array(V*4),W=T[T.length-2];for(let z=T.length-3,H=0;z>=0;z-=3)P[H++]=T[z],P[H++]=T[z+1]-W,P[H++]=T[z+2]-W,P[H++]=H;x.push(new Vt(P,T[2]-W,n)),I.push(W-y)}}function d(y,C){return(x,I,T)=>{let V=0,M=x.length-1,P,W;if(M>=0&&(P=x[M])instanceof re){if(!M&&P.type==y&&P.length==T)return P;(W=P.prop(N.lookAhead))&&(V=I[M]+P.length+W)}return m(y,x,I,T,V,C)}}function p(y,C,x,I,T,V,M,P,W){let z=[],H=[];for(;y.length>I;)z.push(y.pop()),H.push(C.pop()+x-T);y.push(m(n.types[M],z,H,V-T,P-V,W)),C.push(T-x)}function m(y,C,x,I,T,V,M){if(V){let P=[N.contextHash,V];M=M?[P].concat(M):[P]}if(T>25){let P=[N.lookAhead,T];M=M?[P].concat(M):[P]}return new re(y,C,x,I,M)}function g(y,C){let x=l.fork(),I=0,T=0,V=0,M=x.end-s,P={size:0,start:0,skip:0};e:for(let W=x.pos-y;x.pos>W;){let z=x.size;if(x.id==C&&z>=0){P.size=I,P.start=T,P.skip=V,V+=4,I+=4,x.next();continue}let H=x.pos-z;if(z<0||H<W||x.start<M)break;let te=x.id>=o?4:0,he=x.start;for(x.next();x.pos>H;){if(x.size<0)if(x.size==-3)te+=4;else break e;else x.id>=o&&(te+=4);x.next()}T=he,I+=z,V+=te}return(C<0||I==y)&&(P.size=I,P.start=T,P.skip=V),P.size>4?P:void 0}function O(y,C,x){let{id:I,start:T,end:V,size:M}=l;if(l.next(),M>=0&&I<o){let P=x;if(M>4){let W=l.pos-(M-4);for(;l.pos>W;)x=O(y,C,x)}C[--x]=P,C[--x]=V-y,C[--x]=T-y,C[--x]=I}else M==-3?h=I:M==-4&&(c=I);return x}let w=[],k=[];for(;l.pos>0;)f(i.start||0,i.bufferStart||0,w,k,-1,0);let v=(e=i.length)!==null&&e!==void 0?e:w.length?k[0]+w[0].length:0;return new re(a[i.topID],w.reverse(),k.reverse(),v)}const Zl=new WeakMap;function cs(i,e){if(!i.isAnonymous||e instanceof Vt||e.type!=i)return 1;let t=Zl.get(e);if(t==null){t=1;for(let n of e.children){if(n.type!=i||!(n instanceof re)){t=1;break}t+=cs(i,n)}Zl.set(e,t)}return t}function Zo(i,e,t,n,s,r,o,l,a){let h=0;for(let p=n;p<s;p++)h+=cs(i,e[p]);let c=Math.ceil(h*1.5/8),f=[],u=[];function d(p,m,g,O,w){for(let k=g;k<O;){let v=k,y=m[k],C=cs(i,p[k]);for(k++;k<O;k++){let x=cs(i,p[k]);if(C+x>=c)break;C+=x}if(k==v+1){if(C>c){let x=p[v];d(x.children,x.positions,0,x.children.length,m[v]+w);continue}f.push(p[v])}else{let x=m[k-1]+p[k-1].length-y;f.push(Zo(i,p,m,v,k,y,x,null,a))}u.push(y+w-r)}}return d(e,t,n,s,0),(l||a)(f,u,o)}class ni{constructor(e,t,n,s,r=!1,o=!1){this.from=e,this.to=t,this.tree=n,this.offset=s,this.open=(r?1:0)|(o?2:0)}get openStart(){return(this.open&1)>0}get openEnd(){return(this.open&2)>0}static addTree(e,t=[],n=!1){let s=[new ni(0,e.length,e,0,!1,n)];for(let r of t)r.to>e.length&&s.push(r);return s}static applyChanges(e,t,n=128){if(!t.length)return e;let s=[],r=1,o=e.length?e[0]:null;for(let l=0,a=0,h=0;;l++){let c=l<t.length?t[l]:null,f=c?c.fromA:1e9;if(f-a>=n)for(;o&&o.from<f;){let u=o;if(a>=u.from||f<=u.to||h){let d=Math.max(u.from,a)-h,p=Math.min(u.to,f)-h;u=d>=p?null:new ni(d,p,u.tree,u.offset+h,l>0,!!c)}if(u&&s.push(u),o.to>f)break;o=r<e.length?e[r++]:null}if(!c)break;a=c.toA,h=c.toA-c.toB}return s}}class Qc{startParse(e,t,n){return typeof e=="string"&&(e=new _p(e)),n=n?n.length?n.map(s=>new wr(s.from,s.to)):[new wr(0,0)]:[new wr(0,e.length)],this.createParse(e,t||[],n)}parse(e,t,n){let s=this.startParse(e,t,n);for(;;){let r=s.advance();if(r)return r}}}class _p{constructor(e){this.string=e}get length(){return this.string.length}chunk(e){return this.string.slice(e)}get lineChunks(){return!1}read(e,t){return this.string.slice(e,t)}}new N({perNode:!0});let Zr=[],Ec=[];(()=>{let i="lc,34,7n,7,7b,19,,,,2,,2,,,20,b,1c,l,g,,2t,7,2,6,2,2,,4,z,,u,r,2j,b,1m,9,9,,o,4,,9,,3,,5,17,3,3b,f,,w,1j,,,,4,8,4,,3,7,a,2,t,,1m,,,,2,4,8,,9,,a,2,q,,2,2,1l,,4,2,4,2,2,3,3,,u,2,3,,b,2,1l,,4,5,,2,4,,k,2,m,6,,,1m,,,2,,4,8,,7,3,a,2,u,,1n,,,,c,,9,,14,,3,,1l,3,5,3,,4,7,2,b,2,t,,1m,,2,,2,,3,,5,2,7,2,b,2,s,2,1l,2,,,2,4,8,,9,,a,2,t,,20,,4,,2,3,,,8,,29,,2,7,c,8,2q,,2,9,b,6,22,2,r,,,,,,1j,e,,5,,2,5,b,,10,9,,2u,4,,6,,2,2,2,p,2,4,3,g,4,d,,2,2,6,,f,,jj,3,qa,3,t,3,t,2,u,2,1s,2,,7,8,,2,b,9,,19,3,3b,2,y,,3a,3,4,2,9,,6,3,63,2,2,,1m,,,7,,,,,2,8,6,a,2,,1c,h,1r,4,1c,7,,,5,,14,9,c,2,w,4,2,2,,3,1k,,,2,3,,,3,1m,8,2,2,48,3,,d,,7,4,,6,,3,2,5i,1m,,5,ek,,5f,x,2da,3,3x,,2o,w,fe,6,2x,2,n9w,4,,a,w,2,28,2,7k,,3,,4,,p,2,5,,47,2,q,i,d,,12,8,p,b,1a,3,1c,,2,4,2,2,13,,1v,6,2,2,2,2,c,,8,,1b,,1f,,,3,2,2,5,2,,,16,2,8,,6m,,2,,4,,fn4,,kh,g,g,g,a6,2,gt,,6a,,45,5,1ae,3,,2,5,4,14,3,4,,4l,2,fx,4,ar,2,49,b,4w,,1i,f,1k,3,1d,4,2,2,1x,3,10,5,,8,1q,,c,2,1g,9,a,4,2,,2n,3,2,,,2,6,,4g,,3,8,l,2,1l,2,,,,,m,,e,7,3,5,5f,8,2,3,,,n,,29,,2,6,,,2,,,2,,2,6j,,2,4,6,2,,2,r,2,2d,8,2,,,2,2y,,,,2,6,,,2t,3,2,4,,5,77,9,,2,6t,,a,2,,,4,,40,4,2,2,4,,w,a,14,6,2,4,8,,9,6,2,3,1a,d,,2,ba,7,,6,,,2a,m,2,7,,2,,2,3e,6,3,,,2,,7,,,20,2,3,,,,9n,2,f0b,5,1n,7,t4,,1r,4,29,,f5k,2,43q,,,3,4,5,8,8,2,7,u,4,44,3,1iz,1j,4,1e,8,,e,,m,5,,f,11s,7,,h,2,7,,2,,5,79,7,c5,4,15s,7,31,7,240,5,gx7k,2o,3k,6o".split(",").map(e=>e?parseInt(e,36):1);for(let e=0,t=0;e<i.length;e++)(e%2?Ec:Zr).push(t=t+i[e])})();function Vp(i){if(i<768)return!1;for(let e=0,t=Zr.length;;){let n=e+t>>1;if(i<Zr[n])t=n;else if(i>=Ec[n])e=n+1;else return!0;if(e==t)return!1}}function ea(i){return i>=127462&&i<=127487}const ta=8205;function Wp(i,e,t=!0,n=!0){return(t?Bc:Hp)(i,e,n)}function Bc(i,e,t){if(e==i.length)return e;e&&Pc(i.charCodeAt(e))&&Mc(i.charCodeAt(e-1))&&e--;let n=yr(i,e);for(e+=ia(n);e<i.length;){let s=yr(i,e);if(n==ta||s==ta||t&&Vp(s))e+=ia(s),n=s;else if(ea(s)){let r=0,o=e-2;for(;o>=0&&ea(yr(i,o));)r++,o-=2;if(r%2==0)break;e+=2}else break}return e}function Hp(i,e,t){for(;e>0;){let n=Bc(i,e-2,t);if(n<e)return n;e--}return 0}function yr(i,e){let t=i.charCodeAt(e);if(!Mc(t)||e+1==i.length)return t;let n=i.charCodeAt(e+1);return Pc(n)?(t-55296<<10)+(n-56320)+65536:t}function Pc(i){return i>=56320&&i<57344}function Mc(i){return i>=55296&&i<56320}function ia(i){return i<65536?1:2}class ${lineAt(e){if(e<0||e>this.length)throw new RangeError(`Invalid position ${e} in document of length ${this.length}`);return this.lineInner(e,!1,1,0)}line(e){if(e<1||e>this.lines)throw new RangeError(`Invalid line number ${e} in ${this.lines}-line document`);return this.lineInner(e,!0,1,0)}replace(e,t,n){[e,t]=Mi(this,e,t);let s=[];return this.decompose(0,e,s,2),n.length&&n.decompose(0,n.length,s,3),this.decompose(t,this.length,s,1),ut.from(s,this.length-(t-e)+n.length)}append(e){return this.replace(this.length,this.length,e)}slice(e,t=this.length){[e,t]=Mi(this,e,t);let n=[];return this.decompose(e,t,n,0),ut.from(n,t-e)}eq(e){if(e==this)return!0;if(e.length!=this.length||e.lines!=this.lines)return!1;let t=this.scanIdentical(e,1),n=this.length-this.scanIdentical(e,-1),s=new tn(this),r=new tn(e);for(let o=t,l=t;;){if(s.next(o),r.next(o),o=0,s.lineBreak!=r.lineBreak||s.done!=r.done||s.value!=r.value)return!1;if(l+=s.value.length,s.done||l>=n)return!0}}iter(e=1){return new tn(this,e)}iterRange(e,t=this.length){return new Dc(this,e,t)}iterLines(e,t){let n;if(e==null)n=this.iter();else{t==null&&(t=this.lines+1);let s=this.line(e).from;n=this.iterRange(s,Math.max(s,t==this.lines+1?this.length:t<=1?0:this.line(t-1).to))}return new Ic(n)}toString(){return this.sliceString(0)}toJSON(){let e=[];return this.flatten(e),e}constructor(){}static of(e){if(e.length==0)throw new RangeError("A document must have at least one line");return e.length==1&&!e[0]?$.empty:e.length<=32?new ie(e):ut.from(ie.split(e,[]))}}class ie extends ${constructor(e,t=qp(e)){super(),this.text=e,this.length=t}get lines(){return this.text.length}get children(){return null}lineInner(e,t,n,s){for(let r=0;;r++){let o=this.text[r],l=s+o.length;if((t?n:l)>=e)return new Gp(s,l,n,o);s=l+1,n++}}decompose(e,t,n,s){let r=e<=0&&t>=this.length?this:new ie(na(this.text,e,t),Math.min(t,this.length)-Math.max(0,e));if(s&1){let o=n.pop(),l=fs(r.text,o.text.slice(),0,r.length);if(l.length<=32)n.push(new ie(l,o.length+r.length));else{let a=l.length>>1;n.push(new ie(l.slice(0,a)),new ie(l.slice(a)))}}else n.push(r)}replace(e,t,n){if(!(n instanceof ie))return super.replace(e,t,n);[e,t]=Mi(this,e,t);let s=fs(this.text,fs(n.text,na(this.text,0,e)),t),r=this.length+n.length-(t-e);return s.length<=32?new ie(s,r):ut.from(ie.split(s,[]),r)}sliceString(e,t=this.length,n=`
2
+ `){[e,t]=Mi(this,e,t);let s="";for(let r=0,o=0;r<=t&&o<this.text.length;o++){let l=this.text[o],a=r+l.length;r>e&&o&&(s+=n),e<a&&t>r&&(s+=l.slice(Math.max(0,e-r),t-r)),r=a+1}return s}flatten(e){for(let t of this.text)e.push(t)}scanIdentical(){return 0}static split(e,t){let n=[],s=-1;for(let r of e)n.push(r),s+=r.length+1,n.length==32&&(t.push(new ie(n,s)),n=[],s=-1);return s>-1&&t.push(new ie(n,s)),t}}class ut extends ${constructor(e,t){super(),this.children=e,this.length=t,this.lines=0;for(let n of e)this.lines+=n.lines}lineInner(e,t,n,s){for(let r=0;;r++){let o=this.children[r],l=s+o.length,a=n+o.lines-1;if((t?a:l)>=e)return o.lineInner(e,t,n,s);s=l+1,n=a+1}}decompose(e,t,n,s){for(let r=0,o=0;o<=t&&r<this.children.length;r++){let l=this.children[r],a=o+l.length;if(e<=a&&t>=o){let h=s&((o<=e?1:0)|(a>=t?2:0));o>=e&&a<=t&&!h?n.push(l):l.decompose(e-o,t-o,n,h)}o=a+1}}replace(e,t,n){if([e,t]=Mi(this,e,t),n.lines<this.lines)for(let s=0,r=0;s<this.children.length;s++){let o=this.children[s],l=r+o.length;if(e>=r&&t<=l){let a=o.replace(e-r,t-r,n),h=this.lines-o.lines+a.lines;if(a.lines<h>>4&&a.lines>h>>6){let c=this.children.slice();return c[s]=a,new ut(c,this.length-(t-e)+n.length)}return super.replace(r,l,a)}r=l+1}return super.replace(e,t,n)}sliceString(e,t=this.length,n=`
3
+ `){[e,t]=Mi(this,e,t);let s="";for(let r=0,o=0;r<this.children.length&&o<=t;r++){let l=this.children[r],a=o+l.length;o>e&&r&&(s+=n),e<a&&t>o&&(s+=l.sliceString(e-o,t-o,n)),o=a+1}return s}flatten(e){for(let t of this.children)t.flatten(e)}scanIdentical(e,t){if(!(e instanceof ut))return 0;let n=0,[s,r,o,l]=t>0?[0,0,this.children.length,e.children.length]:[this.children.length-1,e.children.length-1,-1,-1];for(;;s+=t,r+=t){if(s==o||r==l)return n;let a=this.children[s],h=e.children[r];if(a!=h)return n+a.scanIdentical(h,t);n+=a.length+1}}static from(e,t=e.reduce((n,s)=>n+s.length+1,-1)){let n=0;for(let d of e)n+=d.lines;if(n<32){let d=[];for(let p of e)p.flatten(d);return new ie(d,t)}let s=Math.max(32,n>>5),r=s<<1,o=s>>1,l=[],a=0,h=-1,c=[];function f(d){let p;if(d.lines>r&&d instanceof ut)for(let m of d.children)f(m);else d.lines>o&&(a>o||!a)?(u(),l.push(d)):d instanceof ie&&a&&(p=c[c.length-1])instanceof ie&&d.lines+p.lines<=32?(a+=d.lines,h+=d.length+1,c[c.length-1]=new ie(p.text.concat(d.text),p.length+1+d.length)):(a+d.lines>s&&u(),a+=d.lines,h+=d.length+1,c.push(d))}function u(){a!=0&&(l.push(c.length==1?c[0]:ut.from(c,h)),h=-1,a=c.length=0)}for(let d of e)f(d);return u(),l.length==1?l[0]:new ut(l,t)}}$.empty=new ie([""],0);function qp(i){let e=-1;for(let t of i)e+=t.length+1;return e}function fs(i,e,t=0,n=1e9){for(let s=0,r=0,o=!0;r<i.length&&s<=n;r++){let l=i[r],a=s+l.length;a>=t&&(a>n&&(l=l.slice(0,n-s)),s<t&&(l=l.slice(t-s)),o?(e[e.length-1]+=l,o=!1):e.push(l)),s=a+1}return e}function na(i,e,t){return fs(i,[""],e,t)}class tn{constructor(e,t=1){this.dir=t,this.done=!1,this.lineBreak=!1,this.value="",this.nodes=[e],this.offsets=[t>0?1:(e instanceof ie?e.text.length:e.children.length)<<1]}nextInner(e,t){for(this.done=this.lineBreak=!1;;){let n=this.nodes.length-1,s=this.nodes[n],r=this.offsets[n],o=r>>1,l=s instanceof ie?s.text.length:s.children.length;if(o==(t>0?l:0)){if(n==0)return this.done=!0,this.value="",this;t>0&&this.offsets[n-1]++,this.nodes.pop(),this.offsets.pop()}else if((r&1)==(t>0?0:1)){if(this.offsets[n]+=t,e==0)return this.lineBreak=!0,this.value=`
4
+ `,this;e--}else if(s instanceof ie){let a=s.text[o+(t<0?-1:0)];if(this.offsets[n]+=t,a.length>Math.max(0,e))return this.value=e==0?a:t>0?a.slice(e):a.slice(0,a.length-e),this;e-=a.length}else{let a=s.children[o+(t<0?-1:0)];e>a.length?(e-=a.length,this.offsets[n]+=t):(t<0&&this.offsets[n]--,this.nodes.push(a),this.offsets.push(t>0?1:(a instanceof ie?a.text.length:a.children.length)<<1))}}}next(e=0){return e<0&&(this.nextInner(-e,-this.dir),e=this.value.length),this.nextInner(e,this.dir)}}class Dc{constructor(e,t,n){this.value="",this.done=!1,this.cursor=new tn(e,t>n?-1:1),this.pos=t>n?e.length:0,this.from=Math.min(t,n),this.to=Math.max(t,n)}nextInner(e,t){if(t<0?this.pos<=this.from:this.pos>=this.to)return this.value="",this.done=!0,this;e+=Math.max(0,t<0?this.pos-this.to:this.from-this.pos);let n=t<0?this.pos-this.from:this.to-this.pos;e>n&&(e=n),n-=e;let{value:s}=this.cursor.next(e);return this.pos+=(s.length+e)*t,this.value=s.length<=n?s:t<0?s.slice(s.length-n):s.slice(0,n),this.done=!this.value,this}next(e=0){return e<0?e=Math.max(e,this.from-this.pos):e>0&&(e=Math.min(e,this.to-this.pos)),this.nextInner(e,this.cursor.dir)}get lineBreak(){return this.cursor.lineBreak&&this.value!=""}}class Ic{constructor(e){this.inner=e,this.afterBreak=!0,this.value="",this.done=!1}next(e=0){let{done:t,lineBreak:n,value:s}=this.inner.next(e);return t&&this.afterBreak?(this.value="",this.afterBreak=!1):t?(this.done=!0,this.value=""):n?this.afterBreak?this.value="":(this.afterBreak=!0,this.next()):(this.value=s,this.afterBreak=!1),this}get lineBreak(){return!1}}typeof Symbol<"u"&&($.prototype[Symbol.iterator]=function(){return this.iter()},tn.prototype[Symbol.iterator]=Dc.prototype[Symbol.iterator]=Ic.prototype[Symbol.iterator]=function(){return this});class Gp{constructor(e,t,n,s){this.from=e,this.to=t,this.number=n,this.text=s}get length(){return this.to-this.from}}function Mi(i,e,t){return e=Math.max(0,Math.min(i.length,e)),[e,Math.max(e,Math.min(i.length,t))]}function me(i,e,t=!0,n=!0){return Wp(i,e,t,n)}function Up(i){return i>=56320&&i<57344}function Yp(i){return i>=55296&&i<56320}function Ee(i,e){let t=i.charCodeAt(e);if(!Yp(t)||e+1==i.length)return t;let n=i.charCodeAt(e+1);return Up(n)?(t-55296<<10)+(n-56320)+65536:t}function el(i){return i<=65535?String.fromCharCode(i):(i-=65536,String.fromCharCode((i>>10)+55296,(i&1023)+56320))}function dt(i){return i<65536?1:2}const eo=/\r\n?|\n/;var Ce=(function(i){return i[i.Simple=0]="Simple",i[i.TrackDel=1]="TrackDel",i[i.TrackBefore=2]="TrackBefore",i[i.TrackAfter=3]="TrackAfter",i})(Ce||(Ce={}));class Ot{constructor(e){this.sections=e}get length(){let e=0;for(let t=0;t<this.sections.length;t+=2)e+=this.sections[t];return e}get newLength(){let e=0;for(let t=0;t<this.sections.length;t+=2){let n=this.sections[t+1];e+=n<0?this.sections[t]:n}return e}get empty(){return this.sections.length==0||this.sections.length==2&&this.sections[1]<0}iterGaps(e){for(let t=0,n=0,s=0;t<this.sections.length;){let r=this.sections[t++],o=this.sections[t++];o<0?(e(n,s,r),s+=r):s+=o,n+=r}}iterChangedRanges(e,t=!1){to(this,e,t)}get invertedDesc(){let e=[];for(let t=0;t<this.sections.length;){let n=this.sections[t++],s=this.sections[t++];s<0?e.push(n,s):e.push(s,n)}return new Ot(e)}composeDesc(e){return this.empty?e:e.empty?this:Tc(this,e)}mapDesc(e,t=!1){return e.empty?this:io(this,e,t)}mapPos(e,t=-1,n=Ce.Simple){let s=0,r=0;for(let o=0;o<this.sections.length;){let l=this.sections[o++],a=this.sections[o++],h=s+l;if(a<0){if(h>e)return r+(e-s);r+=l}else{if(n!=Ce.Simple&&h>=e&&(n==Ce.TrackDel&&s<e&&h>e||n==Ce.TrackBefore&&s<e||n==Ce.TrackAfter&&h>e))return null;if(h>e||h==e&&t<0&&!l)return e==s||t<0?r:r+a;r+=a}s=h}if(e>s)throw new RangeError(`Position ${e} is out of range for changeset of length ${s}`);return r}touchesRange(e,t=e){for(let n=0,s=0;n<this.sections.length&&s<=t;){let r=this.sections[n++],o=this.sections[n++],l=s+r;if(o>=0&&s<=t&&l>=e)return s<e&&l>t?"cover":!0;s=l}return!1}toString(){let e="";for(let t=0;t<this.sections.length;){let n=this.sections[t++],s=this.sections[t++];e+=(e?" ":"")+n+(s>=0?":"+s:"")}return e}toJSON(){return this.sections}static fromJSON(e){if(!Array.isArray(e)||e.length%2||e.some(t=>typeof t!="number"))throw new RangeError("Invalid JSON representation of ChangeDesc");return new Ot(e)}static create(e){return new Ot(e)}}class le extends Ot{constructor(e,t){super(e),this.inserted=t}apply(e){if(this.length!=e.length)throw new RangeError("Applying change set to a document with the wrong length");return to(this,(t,n,s,r,o)=>e=e.replace(s,s+(n-t),o),!1),e}mapDesc(e,t=!1){return io(this,e,t,!0)}invert(e){let t=this.sections.slice(),n=[];for(let s=0,r=0;s<t.length;s+=2){let o=t[s],l=t[s+1];if(l>=0){t[s]=l,t[s+1]=o;let a=s>>1;for(;n.length<a;)n.push($.empty);n.push(o?e.slice(r,r+o):$.empty)}r+=o}return new le(t,n)}compose(e){return this.empty?e:e.empty?this:Tc(this,e,!0)}map(e,t=!1){return e.empty?this:io(this,e,t,!0)}iterChanges(e,t=!1){to(this,e,t)}get desc(){return Ot.create(this.sections)}filter(e){let t=[],n=[],s=[],r=new cn(this);e:for(let o=0,l=0;;){let a=o==e.length?1e9:e[o++];for(;l<a||l==a&&r.len==0;){if(r.done)break e;let c=Math.min(r.len,a-l);Oe(s,c,-1);let f=r.ins==-1?-1:r.off==0?r.ins:0;Oe(t,c,f),f>0&&Nt(n,t,r.text),r.forward(c),l+=c}let h=e[o++];for(;l<h;){if(r.done)break e;let c=Math.min(r.len,h-l);Oe(t,c,-1),Oe(s,c,r.ins==-1?-1:r.off==0?r.ins:0),r.forward(c),l+=c}}return{changes:new le(t,n),filtered:Ot.create(s)}}toJSON(){let e=[];for(let t=0;t<this.sections.length;t+=2){let n=this.sections[t],s=this.sections[t+1];s<0?e.push(n):s==0?e.push([n]):e.push([n].concat(this.inserted[t>>1].toJSON()))}return e}static of(e,t,n){let s=[],r=[],o=0,l=null;function a(c=!1){if(!c&&!s.length)return;o<t&&Oe(s,t-o,-1);let f=new le(s,r);l=l?l.compose(f.map(l)):f,s=[],r=[],o=0}function h(c){if(Array.isArray(c))for(let f of c)h(f);else if(c instanceof le){if(c.length!=t)throw new RangeError(`Mismatched change set length (got ${c.length}, expected ${t})`);a(),l=l?l.compose(c.map(l)):c}else{let{from:f,to:u=f,insert:d}=c;if(f>u||f<0||u>t)throw new RangeError(`Invalid change range ${f} to ${u} (in doc of length ${t})`);let p=d?typeof d=="string"?$.of(d.split(n||eo)):d:$.empty,m=p.length;if(f==u&&m==0)return;f<o&&a(),f>o&&Oe(s,f-o,-1),Oe(s,u-f,m),Nt(r,s,p),o=u}}return h(e),a(!l),l}static empty(e){return new le(e?[e,-1]:[],[])}static fromJSON(e){if(!Array.isArray(e))throw new RangeError("Invalid JSON representation of ChangeSet");let t=[],n=[];for(let s=0;s<e.length;s++){let r=e[s];if(typeof r=="number")t.push(r,-1);else{if(!Array.isArray(r)||typeof r[0]!="number"||r.some((o,l)=>l&&typeof o!="string"))throw new RangeError("Invalid JSON representation of ChangeSet");if(r.length==1)t.push(r[0],0);else{for(;n.length<s;)n.push($.empty);n[s]=$.of(r.slice(1)),t.push(r[0],n[s].length)}}}return new le(t,n)}static createSet(e,t){return new le(e,t)}}function Oe(i,e,t,n=!1){if(e==0&&t<=0)return;let s=i.length-2;s>=0&&t<=0&&t==i[s+1]?i[s]+=e:s>=0&&e==0&&i[s]==0?i[s+1]+=t:n?(i[s]+=e,i[s+1]+=t):i.push(e,t)}function Nt(i,e,t){if(t.length==0)return;let n=e.length-2>>1;if(n<i.length)i[i.length-1]=i[i.length-1].append(t);else{for(;i.length<n;)i.push($.empty);i.push(t)}}function to(i,e,t){let n=i.inserted;for(let s=0,r=0,o=0;o<i.sections.length;){let l=i.sections[o++],a=i.sections[o++];if(a<0)s+=l,r+=l;else{let h=s,c=r,f=$.empty;for(;h+=l,c+=a,a&&n&&(f=f.append(n[o-2>>1])),!(t||o==i.sections.length||i.sections[o+1]<0);)l=i.sections[o++],a=i.sections[o++];e(s,h,r,c,f),s=h,r=c}}}function io(i,e,t,n=!1){let s=[],r=n?[]:null,o=new cn(i),l=new cn(e);for(let a=-1;;){if(o.done&&l.len||l.done&&o.len)throw new Error("Mismatched change set lengths");if(o.ins==-1&&l.ins==-1){let h=Math.min(o.len,l.len);Oe(s,h,-1),o.forward(h),l.forward(h)}else if(l.ins>=0&&(o.ins<0||a==o.i||o.off==0&&(l.len<o.len||l.len==o.len&&!t))){let h=l.len;for(Oe(s,l.ins,-1);h;){let c=Math.min(o.len,h);o.ins>=0&&a<o.i&&o.len<=c&&(Oe(s,0,o.ins),r&&Nt(r,s,o.text),a=o.i),o.forward(c),h-=c}l.next()}else if(o.ins>=0){let h=0,c=o.len;for(;c;)if(l.ins==-1){let f=Math.min(c,l.len);h+=f,c-=f,l.forward(f)}else if(l.ins==0&&l.len<c)c-=l.len,l.next();else break;Oe(s,h,a<o.i?o.ins:0),r&&a<o.i&&Nt(r,s,o.text),a=o.i,o.forward(o.len-c)}else{if(o.done&&l.done)return r?le.createSet(s,r):Ot.create(s);throw new Error("Mismatched change set lengths")}}}function Tc(i,e,t=!1){let n=[],s=t?[]:null,r=new cn(i),o=new cn(e);for(let l=!1;;){if(r.done&&o.done)return s?le.createSet(n,s):Ot.create(n);if(r.ins==0)Oe(n,r.len,0,l),r.next();else if(o.len==0&&!o.done)Oe(n,0,o.ins,l),s&&Nt(s,n,o.text),o.next();else{if(r.done||o.done)throw new Error("Mismatched change set lengths");{let a=Math.min(r.len2,o.len),h=n.length;if(r.ins==-1){let c=o.ins==-1?-1:o.off?0:o.ins;Oe(n,a,c,l),s&&c&&Nt(s,n,o.text)}else o.ins==-1?(Oe(n,r.off?0:r.len,a,l),s&&Nt(s,n,r.textBit(a))):(Oe(n,r.off?0:r.len,o.off?0:o.ins,l),s&&!o.off&&Nt(s,n,o.text));l=(r.ins>a||o.ins>=0&&o.len>a)&&(l||n.length>h),r.forward2(a),o.forward(a)}}}}class cn{constructor(e){this.set=e,this.i=0,this.next()}next(){let{sections:e}=this.set;this.i<e.length?(this.len=e[this.i++],this.ins=e[this.i++]):(this.len=0,this.ins=-2),this.off=0}get done(){return this.ins==-2}get len2(){return this.ins<0?this.len:this.ins}get text(){let{inserted:e}=this.set,t=this.i-2>>1;return t>=e.length?$.empty:e[t]}textBit(e){let{inserted:t}=this.set,n=this.i-2>>1;return n>=t.length&&!e?$.empty:t[n].slice(this.off,e==null?void 0:this.off+e)}forward(e){e==this.len?this.next():(this.len-=e,this.off+=e)}forward2(e){this.ins==-1?this.forward(e):e==this.ins?this.next():(this.ins-=e,this.off+=e)}}class ti{constructor(e,t,n){this.from=e,this.to=t,this.flags=n}get anchor(){return this.flags&32?this.to:this.from}get head(){return this.flags&32?this.from:this.to}get empty(){return this.from==this.to}get assoc(){return this.flags&8?-1:this.flags&16?1:0}get bidiLevel(){let e=this.flags&7;return e==7?null:e}get goalColumn(){let e=this.flags>>6;return e==16777215?void 0:e}map(e,t=-1){let n,s;return this.empty?n=s=e.mapPos(this.from,t):(n=e.mapPos(this.from,1),s=e.mapPos(this.to,-1)),n==this.from&&s==this.to?this:new ti(n,s,this.flags)}extend(e,t=e){if(e<=this.anchor&&t>=this.anchor)return b.range(e,t);let n=Math.abs(e-this.anchor)>Math.abs(t-this.anchor)?e:t;return b.range(this.anchor,n)}eq(e,t=!1){return this.anchor==e.anchor&&this.head==e.head&&(!t||!this.empty||this.assoc==e.assoc)}toJSON(){return{anchor:this.anchor,head:this.head}}static fromJSON(e){if(!e||typeof e.anchor!="number"||typeof e.head!="number")throw new RangeError("Invalid JSON representation for SelectionRange");return b.range(e.anchor,e.head)}static create(e,t,n){return new ti(e,t,n)}}class b{constructor(e,t){this.ranges=e,this.mainIndex=t}map(e,t=-1){return e.empty?this:b.create(this.ranges.map(n=>n.map(e,t)),this.mainIndex)}eq(e,t=!1){if(this.ranges.length!=e.ranges.length||this.mainIndex!=e.mainIndex)return!1;for(let n=0;n<this.ranges.length;n++)if(!this.ranges[n].eq(e.ranges[n],t))return!1;return!0}get main(){return this.ranges[this.mainIndex]}asSingle(){return this.ranges.length==1?this:new b([this.main],0)}addRange(e,t=!0){return b.create([e].concat(this.ranges),t?0:this.mainIndex+1)}replaceRange(e,t=this.mainIndex){let n=this.ranges.slice();return n[t]=e,b.create(n,this.mainIndex)}toJSON(){return{ranges:this.ranges.map(e=>e.toJSON()),main:this.mainIndex}}static fromJSON(e){if(!e||!Array.isArray(e.ranges)||typeof e.main!="number"||e.main>=e.ranges.length)throw new RangeError("Invalid JSON representation for EditorSelection");return new b(e.ranges.map(t=>ti.fromJSON(t)),e.main)}static single(e,t=e){return new b([b.range(e,t)],0)}static create(e,t=0){if(e.length==0)throw new RangeError("A selection needs at least one range");for(let n=0,s=0;s<e.length;s++){let r=e[s];if(r.empty?r.from<=n:r.from<n)return b.normalized(e.slice(),t);n=r.to}return new b(e,t)}static cursor(e,t=0,n,s){return ti.create(e,e,(t==0?0:t<0?8:16)|(n==null?7:Math.min(6,n))|(s??16777215)<<6)}static range(e,t,n,s){let r=(n??16777215)<<6|(s==null?7:Math.min(6,s));return t<e?ti.create(t,e,48|r):ti.create(e,t,(t>e?8:0)|r)}static normalized(e,t=0){let n=e[t];e.sort((s,r)=>s.from-r.from),t=e.indexOf(n);for(let s=1;s<e.length;s++){let r=e[s],o=e[s-1];if(r.empty?r.from<=o.to:r.from<o.to){let l=o.from,a=Math.max(r.to,o.to);s<=t&&t--,e.splice(--s,2,r.anchor>r.head?b.range(a,l):b.range(l,a))}}return new b(e,t)}}function Rc(i,e){for(let t of i.ranges)if(t.to>e)throw new RangeError("Selection points outside of document")}let tl=0;class B{constructor(e,t,n,s,r){this.combine=e,this.compareInput=t,this.compare=n,this.isStatic=s,this.id=tl++,this.default=e([]),this.extensions=typeof r=="function"?r(this):r}get reader(){return this}static define(e={}){return new B(e.combine||(t=>t),e.compareInput||((t,n)=>t===n),e.compare||(e.combine?(t,n)=>t===n:il),!!e.static,e.enables)}of(e){return new us([],this,0,e)}compute(e,t){if(this.isStatic)throw new Error("Can't compute a static facet");return new us(e,this,1,t)}computeN(e,t){if(this.isStatic)throw new Error("Can't compute a static facet");return new us(e,this,2,t)}from(e,t){return t||(t=n=>n),this.compute([e],n=>t(n.field(e)))}}function il(i,e){return i==e||i.length==e.length&&i.every((t,n)=>t===e[n])}class us{constructor(e,t,n,s){this.dependencies=e,this.facet=t,this.type=n,this.value=s,this.id=tl++}dynamicSlot(e){var t;let n=this.value,s=this.facet.compareInput,r=this.id,o=e[r]>>1,l=this.type==2,a=!1,h=!1,c=[];for(let f of this.dependencies)f=="doc"?a=!0:f=="selection"?h=!0:(((t=e[f.id])!==null&&t!==void 0?t:1)&1)==0&&c.push(e[f.id]);return{create(f){return f.values[o]=n(f),1},update(f,u){if(a&&u.docChanged||h&&(u.docChanged||u.selection)||no(f,c)){let d=n(f);if(l?!sa(d,f.values[o],s):!s(d,f.values[o]))return f.values[o]=d,1}return 0},reconfigure:(f,u)=>{let d,p=u.config.address[r];if(p!=null){let m=vs(u,p);if(this.dependencies.every(g=>g instanceof B?u.facet(g)===f.facet(g):g instanceof ge?u.field(g,!1)==f.field(g,!1):!0)||(l?sa(d=n(f),m,s):s(d=n(f),m)))return f.values[o]=m,0}else d=n(f);return f.values[o]=d,1}}}}function sa(i,e,t){if(i.length!=e.length)return!1;for(let n=0;n<i.length;n++)if(!t(i[n],e[n]))return!1;return!0}function no(i,e){let t=!1;for(let n of e)nn(i,n)&1&&(t=!0);return t}function Xp(i,e,t){let n=t.map(a=>i[a.id]),s=t.map(a=>a.type),r=n.filter(a=>!(a&1)),o=i[e.id]>>1;function l(a){let h=[];for(let c=0;c<n.length;c++){let f=vs(a,n[c]);if(s[c]==2)for(let u of f)h.push(u);else h.push(f)}return e.combine(h)}return{create(a){for(let h of n)nn(a,h);return a.values[o]=l(a),1},update(a,h){if(!no(a,r))return 0;let c=l(a);return e.compare(c,a.values[o])?0:(a.values[o]=c,1)},reconfigure(a,h){let c=no(a,n),f=h.config.facets[e.id],u=h.facet(e);if(f&&!c&&il(t,f))return a.values[o]=u,0;let d=l(a);return e.compare(d,u)?(a.values[o]=u,0):(a.values[o]=d,1)}}}const Nn=B.define({static:!0});class ge{constructor(e,t,n,s,r){this.id=e,this.createF=t,this.updateF=n,this.compareF=s,this.spec=r,this.provides=void 0}static define(e){let t=new ge(tl++,e.create,e.update,e.compare||((n,s)=>n===s),e);return e.provide&&(t.provides=e.provide(t)),t}create(e){let t=e.facet(Nn).find(n=>n.field==this);return(t?.create||this.createF)(e)}slot(e){let t=e[this.id]>>1;return{create:n=>(n.values[t]=this.create(n),1),update:(n,s)=>{let r=n.values[t],o=this.updateF(r,s);return this.compareF(r,o)?0:(n.values[t]=o,1)},reconfigure:(n,s)=>{let r=n.facet(Nn),o=s.facet(Nn),l;return(l=r.find(a=>a.field==this))&&l!=o.find(a=>a.field==this)?(n.values[t]=l.create(n),1):s.config.address[this.id]!=null?(n.values[t]=s.field(this),0):(n.values[t]=this.create(n),1)}}}init(e){return[this,Nn.of({field:this,create:e})]}get extension(){return this}}const Jt={lowest:4,low:3,default:2,high:1,highest:0};function Hi(i){return e=>new Lc(e,i)}const di={highest:Hi(Jt.highest),high:Hi(Jt.high),default:Hi(Jt.default),low:Hi(Jt.low),lowest:Hi(Jt.lowest)};class Lc{constructor(e,t){this.inner=e,this.prec=t}}class $t{of(e){return new so(this,e)}reconfigure(e){return $t.reconfigure.of({compartment:this,extension:e})}get(e){return e.config.compartments.get(this)}}class so{constructor(e,t){this.compartment=e,this.inner=t}}class Cs{constructor(e,t,n,s,r,o){for(this.base=e,this.compartments=t,this.dynamicSlots=n,this.address=s,this.staticValues=r,this.facets=o,this.statusTemplate=[];this.statusTemplate.length<n.length;)this.statusTemplate.push(0)}staticFacet(e){let t=this.address[e.id];return t==null?e.default:this.staticValues[t>>1]}static resolve(e,t,n){let s=[],r=Object.create(null),o=new Map;for(let u of jp(e,t,o))u instanceof ge?s.push(u):(r[u.facet.id]||(r[u.facet.id]=[])).push(u);let l=Object.create(null),a=[],h=[];for(let u of s)l[u.id]=h.length<<1,h.push(d=>u.slot(d));let c=n?.config.facets;for(let u in r){let d=r[u],p=d[0].facet,m=c&&c[u]||[];if(d.every(g=>g.type==0))if(l[p.id]=a.length<<1|1,il(m,d))a.push(n.facet(p));else{let g=p.combine(d.map(O=>O.value));a.push(n&&p.compare(g,n.facet(p))?n.facet(p):g)}else{for(let g of d)g.type==0?(l[g.id]=a.length<<1|1,a.push(g.value)):(l[g.id]=h.length<<1,h.push(O=>g.dynamicSlot(O)));l[p.id]=h.length<<1,h.push(g=>Xp(g,p,d))}}let f=h.map(u=>u(l));return new Cs(e,o,f,l,a,r)}}function jp(i,e,t){let n=[[],[],[],[],[]],s=new Map;function r(o,l){let a=s.get(o);if(a!=null){if(a<=l)return;let h=n[a].indexOf(o);h>-1&&n[a].splice(h,1),o instanceof so&&t.delete(o.compartment)}if(s.set(o,l),Array.isArray(o))for(let h of o)r(h,l);else if(o instanceof so){if(t.has(o.compartment))throw new RangeError("Duplicate use of compartment in extensions");let h=e.get(o.compartment)||o.inner;t.set(o.compartment,h),r(h,l)}else if(o instanceof Lc)r(o.inner,o.prec);else if(o instanceof ge)n[l].push(o),o.provides&&r(o.provides,l);else if(o instanceof us)n[l].push(o),o.facet.extensions&&r(o.facet.extensions,Jt.default);else{let h=o.extension;if(!h)throw new Error(`Unrecognized extension value in extension set (${o}). This sometimes happens because multiple instances of @codemirror/state are loaded, breaking instanceof checks.`);r(h,l)}}return r(i,Jt.default),n.reduce((o,l)=>o.concat(l))}function nn(i,e){if(e&1)return 2;let t=e>>1,n=i.status[t];if(n==4)throw new Error("Cyclic dependency between fields and/or facets");if(n&2)return n;i.status[t]=4;let s=i.computeSlot(i,i.config.dynamicSlots[t]);return i.status[t]=2|s}function vs(i,e){return e&1?i.config.staticValues[e>>1]:i.values[e>>1]}const Nc=B.define(),ro=B.define({combine:i=>i.some(e=>e),static:!0}),$c=B.define({combine:i=>i.length?i[0]:void 0,static:!0}),Fc=B.define(),Kc=B.define(),zc=B.define(),_c=B.define({combine:i=>i.length?i[0]:!1});class Pt{constructor(e,t){this.type=e,this.value=t}static define(){return new Jp}}class Jp{of(e){return new Pt(this,e)}}class Zp{constructor(e){this.map=e}of(e){return new R(this,e)}}class R{constructor(e,t){this.type=e,this.value=t}map(e){let t=this.type.map(this.value,e);return t===void 0?void 0:t==this.value?this:new R(this.type,t)}is(e){return this.type==e}static define(e={}){return new Zp(e.map||(t=>t))}static mapEffects(e,t){if(!e.length)return e;let n=[];for(let s of e){let r=s.map(t);r&&n.push(r)}return n}}R.reconfigure=R.define();R.appendConfig=R.define();class ae{constructor(e,t,n,s,r,o){this.startState=e,this.changes=t,this.selection=n,this.effects=s,this.annotations=r,this.scrollIntoView=o,this._doc=null,this._state=null,n&&Rc(n,t.newLength),r.some(l=>l.type==ae.time)||(this.annotations=r.concat(ae.time.of(Date.now())))}static create(e,t,n,s,r,o){return new ae(e,t,n,s,r,o)}get newDoc(){return this._doc||(this._doc=this.changes.apply(this.startState.doc))}get newSelection(){return this.selection||this.startState.selection.map(this.changes)}get state(){return this._state||this.startState.applyTransaction(this),this._state}annotation(e){for(let t of this.annotations)if(t.type==e)return t.value}get docChanged(){return!this.changes.empty}get reconfigured(){return this.startState.config!=this.state.config}isUserEvent(e){let t=this.annotation(ae.userEvent);return!!(t&&(t==e||t.length>e.length&&t.slice(0,e.length)==e&&t[e.length]=="."))}}ae.time=Pt.define();ae.userEvent=Pt.define();ae.addToHistory=Pt.define();ae.remote=Pt.define();function em(i,e){let t=[];for(let n=0,s=0;;){let r,o;if(n<i.length&&(s==e.length||e[s]>=i[n]))r=i[n++],o=i[n++];else if(s<e.length)r=e[s++],o=e[s++];else return t;!t.length||t[t.length-1]<r?t.push(r,o):t[t.length-1]<o&&(t[t.length-1]=o)}}function Vc(i,e,t){var n;let s,r,o;return t?(s=e.changes,r=le.empty(e.changes.length),o=i.changes.compose(e.changes)):(s=e.changes.map(i.changes),r=i.changes.mapDesc(e.changes,!0),o=i.changes.compose(s)),{changes:o,selection:e.selection?e.selection.map(r):(n=i.selection)===null||n===void 0?void 0:n.map(s),effects:R.mapEffects(i.effects,s).concat(R.mapEffects(e.effects,r)),annotations:i.annotations.length?i.annotations.concat(e.annotations):e.annotations,scrollIntoView:i.scrollIntoView||e.scrollIntoView}}function oo(i,e,t){let n=e.selection,s=vi(e.annotations);return e.userEvent&&(s=s.concat(ae.userEvent.of(e.userEvent))),{changes:e.changes instanceof le?e.changes:le.of(e.changes||[],t,i.facet($c)),selection:n&&(n instanceof b?n:b.single(n.anchor,n.head)),effects:vi(e.effects),annotations:s,scrollIntoView:!!e.scrollIntoView}}function Wc(i,e,t){let n=oo(i,e.length?e[0]:{},i.doc.length);e.length&&e[0].filter===!1&&(t=!1);for(let r=1;r<e.length;r++){e[r].filter===!1&&(t=!1);let o=!!e[r].sequential;n=Vc(n,oo(i,e[r],o?n.changes.newLength:i.doc.length),o)}let s=ae.create(i,n.changes,n.selection,n.effects,n.annotations,n.scrollIntoView);return im(t?tm(s):s)}function tm(i){let e=i.startState,t=!0;for(let s of e.facet(Fc)){let r=s(i);if(r===!1){t=!1;break}Array.isArray(r)&&(t=t===!0?r:em(t,r))}if(t!==!0){let s,r;if(t===!1)r=i.changes.invertedDesc,s=le.empty(e.doc.length);else{let o=i.changes.filter(t);s=o.changes,r=o.filtered.mapDesc(o.changes).invertedDesc}i=ae.create(e,s,i.selection&&i.selection.map(r),R.mapEffects(i.effects,r),i.annotations,i.scrollIntoView)}let n=e.facet(Kc);for(let s=n.length-1;s>=0;s--){let r=n[s](i);r instanceof ae?i=r:Array.isArray(r)&&r.length==1&&r[0]instanceof ae?i=r[0]:i=Wc(e,vi(r),!1)}return i}function im(i){let e=i.startState,t=e.facet(zc),n=i;for(let s=t.length-1;s>=0;s--){let r=t[s](i);r&&Object.keys(r).length&&(n=Vc(n,oo(e,r,i.changes.newLength),!0))}return n==i?i:ae.create(e,i.changes,i.selection,n.effects,n.annotations,n.scrollIntoView)}const nm=[];function vi(i){return i==null?nm:Array.isArray(i)?i:[i]}var ee=(function(i){return i[i.Word=0]="Word",i[i.Space=1]="Space",i[i.Other=2]="Other",i})(ee||(ee={}));const sm=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;let lo;try{lo=new RegExp("[\\p{Alphabetic}\\p{Number}_]","u")}catch{}function rm(i){if(lo)return lo.test(i);for(let e=0;e<i.length;e++){let t=i[e];if(/\w/.test(t)||t>"€"&&(t.toUpperCase()!=t.toLowerCase()||sm.test(t)))return!0}return!1}function om(i){return e=>{if(!/\S/.test(e))return ee.Space;if(rm(e))return ee.Word;for(let t=0;t<i.length;t++)if(e.indexOf(i[t])>-1)return ee.Word;return ee.Other}}class K{constructor(e,t,n,s,r,o){this.config=e,this.doc=t,this.selection=n,this.values=s,this.status=e.statusTemplate.slice(),this.computeSlot=r,o&&(o._state=this);for(let l=0;l<this.config.dynamicSlots.length;l++)nn(this,l<<1);this.computeSlot=null}field(e,t=!0){let n=this.config.address[e.id];if(n==null){if(t)throw new RangeError("Field is not present in this state");return}return nn(this,n),vs(this,n)}update(...e){return Wc(this,e,!0)}applyTransaction(e){let t=this.config,{base:n,compartments:s}=t;for(let l of e.effects)l.is($t.reconfigure)?(t&&(s=new Map,t.compartments.forEach((a,h)=>s.set(h,a)),t=null),s.set(l.value.compartment,l.value.extension)):l.is(R.reconfigure)?(t=null,n=l.value):l.is(R.appendConfig)&&(t=null,n=vi(n).concat(l.value));let r;t?r=e.startState.values.slice():(t=Cs.resolve(n,s,this),r=new K(t,this.doc,this.selection,t.dynamicSlots.map(()=>null),(a,h)=>h.reconfigure(a,this),null).values);let o=e.startState.facet(ro)?e.newSelection:e.newSelection.asSingle();new K(t,e.newDoc,o,r,(l,a)=>a.update(l,e),e)}replaceSelection(e){return typeof e=="string"&&(e=this.toText(e)),this.changeByRange(t=>({changes:{from:t.from,to:t.to,insert:e},range:b.cursor(t.from+e.length)}))}changeByRange(e){let t=this.selection,n=e(t.ranges[0]),s=this.changes(n.changes),r=[n.range],o=vi(n.effects);for(let l=1;l<t.ranges.length;l++){let a=e(t.ranges[l]),h=this.changes(a.changes),c=h.map(s);for(let u=0;u<l;u++)r[u]=r[u].map(c);let f=s.mapDesc(h,!0);r.push(a.range.map(f)),s=s.compose(c),o=R.mapEffects(o,c).concat(R.mapEffects(vi(a.effects),f))}return{changes:s,selection:b.create(r,t.mainIndex),effects:o}}changes(e=[]){return e instanceof le?e:le.of(e,this.doc.length,this.facet(K.lineSeparator))}toText(e){return $.of(e.split(this.facet(K.lineSeparator)||eo))}sliceDoc(e=0,t=this.doc.length){return this.doc.sliceString(e,t,this.lineBreak)}facet(e){let t=this.config.address[e.id];return t==null?e.default:(nn(this,t),vs(this,t))}toJSON(e){let t={doc:this.sliceDoc(),selection:this.selection.toJSON()};if(e)for(let n in e){let s=e[n];s instanceof ge&&this.config.address[s.id]!=null&&(t[n]=s.spec.toJSON(this.field(e[n]),this))}return t}static fromJSON(e,t={},n){if(!e||typeof e.doc!="string")throw new RangeError("Invalid JSON representation for EditorState");let s=[];if(n){for(let r in n)if(Object.prototype.hasOwnProperty.call(e,r)){let o=n[r],l=e[r];s.push(o.init(a=>o.spec.fromJSON(l,a)))}}return K.create({doc:e.doc,selection:b.fromJSON(e.selection),extensions:t.extensions?s.concat([t.extensions]):s})}static create(e={}){let t=Cs.resolve(e.extensions||[],new Map),n=e.doc instanceof $?e.doc:$.of((e.doc||"").split(t.staticFacet(K.lineSeparator)||eo)),s=e.selection?e.selection instanceof b?e.selection:b.single(e.selection.anchor,e.selection.head):b.single(0);return Rc(s,n.length),t.staticFacet(ro)||(s=s.asSingle()),new K(t,n,s,t.dynamicSlots.map(()=>null),(r,o)=>o.create(r),null)}get tabSize(){return this.facet(K.tabSize)}get lineBreak(){return this.facet(K.lineSeparator)||`
5
+ `}get readOnly(){return this.facet(_c)}phrase(e,...t){for(let n of this.facet(K.phrases))if(Object.prototype.hasOwnProperty.call(n,e)){e=n[e];break}return t.length&&(e=e.replace(/\$(\$|\d*)/g,(n,s)=>{if(s=="$")return"$";let r=+(s||1);return!r||r>t.length?n:t[r-1]})),e}languageDataAt(e,t,n=-1){let s=[];for(let r of this.facet(Nc))for(let o of r(this,t,n))Object.prototype.hasOwnProperty.call(o,e)&&s.push(o[e]);return s}charCategorizer(e){return om(this.languageDataAt("wordChars",e).join(""))}wordAt(e){let{text:t,from:n,length:s}=this.doc.lineAt(e),r=this.charCategorizer(e),o=e-n,l=e-n;for(;o>0;){let a=me(t,o,!1);if(r(t.slice(a,o))!=ee.Word)break;o=a}for(;l<s;){let a=me(t,l);if(r(t.slice(l,a))!=ee.Word)break;l=a}return o==l?null:b.range(o+n,l+n)}}K.allowMultipleSelections=ro;K.tabSize=B.define({combine:i=>i.length?i[0]:4});K.lineSeparator=$c;K.readOnly=_c;K.phrases=B.define({compare(i,e){let t=Object.keys(i),n=Object.keys(e);return t.length==n.length&&t.every(s=>i[s]==e[s])}});K.languageData=Nc;K.changeFilter=Fc;K.transactionFilter=Kc;K.transactionExtender=zc;$t.reconfigure=R.define();function yt(i,e,t={}){let n={};for(let s of i)for(let r of Object.keys(s)){let o=s[r],l=n[r];if(l===void 0)n[r]=o;else if(!(l===o||o===void 0))if(Object.hasOwnProperty.call(t,r))n[r]=t[r](l,o);else throw new Error("Config merge conflict for field "+r)}for(let s in e)n[s]===void 0&&(n[s]=e[s]);return n}class li{eq(e){return this==e}range(e,t=e){return fn.create(e,t,this)}}li.prototype.startSide=li.prototype.endSide=0;li.prototype.point=!1;li.prototype.mapMode=Ce.TrackDel;class fn{constructor(e,t,n){this.from=e,this.to=t,this.value=n}static create(e,t,n){return new fn(e,t,n)}}function ao(i,e){return i.from-e.from||i.value.startSide-e.value.startSide}class nl{constructor(e,t,n,s){this.from=e,this.to=t,this.value=n,this.maxPoint=s}get length(){return this.to[this.to.length-1]}findIndex(e,t,n,s=0){let r=n?this.to:this.from;for(let o=s,l=r.length;;){if(o==l)return o;let a=o+l>>1,h=r[a]-e||(n?this.value[a].endSide:this.value[a].startSide)-t;if(a==o)return h>=0?o:l;h>=0?l=a:o=a+1}}between(e,t,n,s){for(let r=this.findIndex(t,-1e9,!0),o=this.findIndex(n,1e9,!1,r);r<o;r++)if(s(this.from[r]+e,this.to[r]+e,this.value[r])===!1)return!1}map(e,t){let n=[],s=[],r=[],o=-1,l=-1;for(let a=0;a<this.value.length;a++){let h=this.value[a],c=this.from[a]+e,f=this.to[a]+e,u,d;if(c==f){let p=t.mapPos(c,h.startSide,h.mapMode);if(p==null||(u=d=p,h.startSide!=h.endSide&&(d=t.mapPos(c,h.endSide),d<u)))continue}else if(u=t.mapPos(c,h.startSide),d=t.mapPos(f,h.endSide),u>d||u==d&&h.startSide>0&&h.endSide<=0)continue;(d-u||h.endSide-h.startSide)<0||(o<0&&(o=u),h.point&&(l=Math.max(l,d-u)),n.push(h),s.push(u-o),r.push(d-o))}return{mapped:n.length?new nl(s,r,n,l):null,pos:o}}}class _{constructor(e,t,n,s){this.chunkPos=e,this.chunk=t,this.nextLayer=n,this.maxPoint=s}static create(e,t,n,s){return new _(e,t,n,s)}get length(){let e=this.chunk.length-1;return e<0?0:Math.max(this.chunkEnd(e),this.nextLayer.length)}get size(){if(this.isEmpty)return 0;let e=this.nextLayer.size;for(let t of this.chunk)e+=t.value.length;return e}chunkEnd(e){return this.chunkPos[e]+this.chunk[e].length}update(e){let{add:t=[],sort:n=!1,filterFrom:s=0,filterTo:r=this.length}=e,o=e.filter;if(t.length==0&&!o)return this;if(n&&(t=t.slice().sort(ao)),this.isEmpty)return t.length?_.of(t):this;let l=new Hc(this,null,-1).goto(0),a=0,h=[],c=new Qt;for(;l.value||a<t.length;)if(a<t.length&&(l.from-t[a].from||l.startSide-t[a].value.startSide)>=0){let f=t[a++];c.addInner(f.from,f.to,f.value)||h.push(f)}else l.rangeIndex==1&&l.chunkIndex<this.chunk.length&&(a==t.length||this.chunkEnd(l.chunkIndex)<t[a].from)&&(!o||s>this.chunkEnd(l.chunkIndex)||r<this.chunkPos[l.chunkIndex])&&c.addChunk(this.chunkPos[l.chunkIndex],this.chunk[l.chunkIndex])?l.nextChunk():((!o||s>l.to||r<l.from||o(l.from,l.to,l.value))&&(c.addInner(l.from,l.to,l.value)||h.push(fn.create(l.from,l.to,l.value))),l.next());return c.finishInner(this.nextLayer.isEmpty&&!h.length?_.empty:this.nextLayer.update({add:h,filter:o,filterFrom:s,filterTo:r}))}map(e){if(e.empty||this.isEmpty)return this;let t=[],n=[],s=-1;for(let o=0;o<this.chunk.length;o++){let l=this.chunkPos[o],a=this.chunk[o],h=e.touchesRange(l,l+a.length);if(h===!1)s=Math.max(s,a.maxPoint),t.push(a),n.push(e.mapPos(l));else if(h===!0){let{mapped:c,pos:f}=a.map(l,e);c&&(s=Math.max(s,c.maxPoint),t.push(c),n.push(f))}}let r=this.nextLayer.map(e);return t.length==0?r:new _(n,t,r||_.empty,s)}between(e,t,n){if(!this.isEmpty){for(let s=0;s<this.chunk.length;s++){let r=this.chunkPos[s],o=this.chunk[s];if(t>=r&&e<=r+o.length&&o.between(r,e-r,t-r,n)===!1)return}this.nextLayer.between(e,t,n)}}iter(e=0){return un.from([this]).goto(e)}get isEmpty(){return this.nextLayer==this}static iter(e,t=0){return un.from(e).goto(t)}static compare(e,t,n,s,r=-1){let o=e.filter(f=>f.maxPoint>0||!f.isEmpty&&f.maxPoint>=r),l=t.filter(f=>f.maxPoint>0||!f.isEmpty&&f.maxPoint>=r),a=ra(o,l,n),h=new qi(o,a,r),c=new qi(l,a,r);n.iterGaps((f,u,d)=>oa(h,f,c,u,d,s)),n.empty&&n.length==0&&oa(h,0,c,0,0,s)}static eq(e,t,n=0,s){s==null&&(s=999999999);let r=e.filter(c=>!c.isEmpty&&t.indexOf(c)<0),o=t.filter(c=>!c.isEmpty&&e.indexOf(c)<0);if(r.length!=o.length)return!1;if(!r.length)return!0;let l=ra(r,o),a=new qi(r,l,0).goto(n),h=new qi(o,l,0).goto(n);for(;;){if(a.to!=h.to||!ho(a.active,h.active)||a.point&&(!h.point||!a.point.eq(h.point)))return!1;if(a.to>s)return!0;a.next(),h.next()}}static spans(e,t,n,s,r=-1){let o=new qi(e,null,r).goto(t),l=t,a=o.openStart;for(;;){let h=Math.min(o.to,n);if(o.point){let c=o.activeForPoint(o.to),f=o.pointFrom<t?c.length+1:o.point.startSide<0?c.length:Math.min(c.length,a);s.point(l,h,o.point,c,f,o.pointRank),a=Math.min(o.openEnd(h),c.length)}else h>l&&(s.span(l,h,o.active,a),a=o.openEnd(h));if(o.to>n)return a+(o.point&&o.to>n?1:0);l=o.to,o.next()}}static of(e,t=!1){let n=new Qt;for(let s of e instanceof fn?[e]:t?lm(e):e)n.add(s.from,s.to,s.value);return n.finish()}static join(e){if(!e.length)return _.empty;let t=e[e.length-1];for(let n=e.length-2;n>=0;n--)for(let s=e[n];s!=_.empty;s=s.nextLayer)t=new _(s.chunkPos,s.chunk,t,Math.max(s.maxPoint,t.maxPoint));return t}}_.empty=new _([],[],null,-1);function lm(i){if(i.length>1)for(let e=i[0],t=1;t<i.length;t++){let n=i[t];if(ao(e,n)>0)return i.slice().sort(ao);e=n}return i}_.empty.nextLayer=_.empty;class Qt{finishChunk(e){this.chunks.push(new nl(this.from,this.to,this.value,this.maxPoint)),this.chunkPos.push(this.chunkStart),this.chunkStart=-1,this.setMaxPoint=Math.max(this.setMaxPoint,this.maxPoint),this.maxPoint=-1,e&&(this.from=[],this.to=[],this.value=[])}constructor(){this.chunks=[],this.chunkPos=[],this.chunkStart=-1,this.last=null,this.lastFrom=-1e9,this.lastTo=-1e9,this.from=[],this.to=[],this.value=[],this.maxPoint=-1,this.setMaxPoint=-1,this.nextLayer=null}add(e,t,n){this.addInner(e,t,n)||(this.nextLayer||(this.nextLayer=new Qt)).add(e,t,n)}addInner(e,t,n){let s=e-this.lastTo||n.startSide-this.last.endSide;if(s<=0&&(e-this.lastFrom||n.startSide-this.last.startSide)<0)throw new Error("Ranges must be added sorted by `from` position and `startSide`");return s<0?!1:(this.from.length==250&&this.finishChunk(!0),this.chunkStart<0&&(this.chunkStart=e),this.from.push(e-this.chunkStart),this.to.push(t-this.chunkStart),this.last=n,this.lastFrom=e,this.lastTo=t,this.value.push(n),n.point&&(this.maxPoint=Math.max(this.maxPoint,t-e)),!0)}addChunk(e,t){if((e-this.lastTo||t.value[0].startSide-this.last.endSide)<0)return!1;this.from.length&&this.finishChunk(!0),this.setMaxPoint=Math.max(this.setMaxPoint,t.maxPoint),this.chunks.push(t),this.chunkPos.push(e);let n=t.value.length-1;return this.last=t.value[n],this.lastFrom=t.from[n]+e,this.lastTo=t.to[n]+e,!0}finish(){return this.finishInner(_.empty)}finishInner(e){if(this.from.length&&this.finishChunk(!1),this.chunks.length==0)return e;let t=_.create(this.chunkPos,this.chunks,this.nextLayer?this.nextLayer.finishInner(e):e,this.setMaxPoint);return this.from=null,t}}function ra(i,e,t){let n=new Map;for(let r of i)for(let o=0;o<r.chunk.length;o++)r.chunk[o].maxPoint<=0&&n.set(r.chunk[o],r.chunkPos[o]);let s=new Set;for(let r of e)for(let o=0;o<r.chunk.length;o++){let l=n.get(r.chunk[o]);l!=null&&(t?t.mapPos(l):l)==r.chunkPos[o]&&!t?.touchesRange(l,l+r.chunk[o].length)&&s.add(r.chunk[o])}return s}class Hc{constructor(e,t,n,s=0){this.layer=e,this.skip=t,this.minPoint=n,this.rank=s}get startSide(){return this.value?this.value.startSide:0}get endSide(){return this.value?this.value.endSide:0}goto(e,t=-1e9){return this.chunkIndex=this.rangeIndex=0,this.gotoInner(e,t,!1),this}gotoInner(e,t,n){for(;this.chunkIndex<this.layer.chunk.length;){let s=this.layer.chunk[this.chunkIndex];if(!(this.skip&&this.skip.has(s)||this.layer.chunkEnd(this.chunkIndex)<e||s.maxPoint<this.minPoint))break;this.chunkIndex++,n=!1}if(this.chunkIndex<this.layer.chunk.length){let s=this.layer.chunk[this.chunkIndex].findIndex(e-this.layer.chunkPos[this.chunkIndex],t,!0);(!n||this.rangeIndex<s)&&this.setRangeIndex(s)}this.next()}forward(e,t){(this.to-e||this.endSide-t)<0&&this.gotoInner(e,t,!0)}next(){for(;;)if(this.chunkIndex==this.layer.chunk.length){this.from=this.to=1e9,this.value=null;break}else{let e=this.layer.chunkPos[this.chunkIndex],t=this.layer.chunk[this.chunkIndex],n=e+t.from[this.rangeIndex];if(this.from=n,this.to=e+t.to[this.rangeIndex],this.value=t.value[this.rangeIndex],this.setRangeIndex(this.rangeIndex+1),this.minPoint<0||this.value.point&&this.to-this.from>=this.minPoint)break}}setRangeIndex(e){if(e==this.layer.chunk[this.chunkIndex].value.length){if(this.chunkIndex++,this.skip)for(;this.chunkIndex<this.layer.chunk.length&&this.skip.has(this.layer.chunk[this.chunkIndex]);)this.chunkIndex++;this.rangeIndex=0}else this.rangeIndex=e}nextChunk(){this.chunkIndex++,this.rangeIndex=0,this.next()}compare(e){return this.from-e.from||this.startSide-e.startSide||this.rank-e.rank||this.to-e.to||this.endSide-e.endSide}}class un{constructor(e){this.heap=e}static from(e,t=null,n=-1){let s=[];for(let r=0;r<e.length;r++)for(let o=e[r];!o.isEmpty;o=o.nextLayer)o.maxPoint>=n&&s.push(new Hc(o,t,n,r));return s.length==1?s[0]:new un(s)}get startSide(){return this.value?this.value.startSide:0}goto(e,t=-1e9){for(let n of this.heap)n.goto(e,t);for(let n=this.heap.length>>1;n>=0;n--)kr(this.heap,n);return this.next(),this}forward(e,t){for(let n of this.heap)n.forward(e,t);for(let n=this.heap.length>>1;n>=0;n--)kr(this.heap,n);(this.to-e||this.value.endSide-t)<0&&this.next()}next(){if(this.heap.length==0)this.from=this.to=1e9,this.value=null,this.rank=-1;else{let e=this.heap[0];this.from=e.from,this.to=e.to,this.value=e.value,this.rank=e.rank,e.value&&e.next(),kr(this.heap,0)}}}function kr(i,e){for(let t=i[e];;){let n=(e<<1)+1;if(n>=i.length)break;let s=i[n];if(n+1<i.length&&s.compare(i[n+1])>=0&&(s=i[n+1],n++),t.compare(s)<0)break;i[n]=t,i[e]=s,e=n}}class qi{constructor(e,t,n){this.minPoint=n,this.active=[],this.activeTo=[],this.activeRank=[],this.minActive=-1,this.point=null,this.pointFrom=0,this.pointRank=0,this.to=-1e9,this.endSide=0,this.openStart=-1,this.cursor=un.from(e,t,n)}goto(e,t=-1e9){return this.cursor.goto(e,t),this.active.length=this.activeTo.length=this.activeRank.length=0,this.minActive=-1,this.to=e,this.endSide=t,this.openStart=-1,this.next(),this}forward(e,t){for(;this.minActive>-1&&(this.activeTo[this.minActive]-e||this.active[this.minActive].endSide-t)<0;)this.removeActive(this.minActive);this.cursor.forward(e,t)}removeActive(e){$n(this.active,e),$n(this.activeTo,e),$n(this.activeRank,e),this.minActive=la(this.active,this.activeTo)}addActive(e){let t=0,{value:n,to:s,rank:r}=this.cursor;for(;t<this.activeRank.length&&(r-this.activeRank[t]||s-this.activeTo[t])>0;)t++;Fn(this.active,t,n),Fn(this.activeTo,t,s),Fn(this.activeRank,t,r),e&&Fn(e,t,this.cursor.from),this.minActive=la(this.active,this.activeTo)}next(){let e=this.to,t=this.point;this.point=null;let n=this.openStart<0?[]:null;for(;;){let s=this.minActive;if(s>-1&&(this.activeTo[s]-this.cursor.from||this.active[s].endSide-this.cursor.startSide)<0){if(this.activeTo[s]>e){this.to=this.activeTo[s],this.endSide=this.active[s].endSide;break}this.removeActive(s),n&&$n(n,s)}else if(this.cursor.value)if(this.cursor.from>e){this.to=this.cursor.from,this.endSide=this.cursor.startSide;break}else{let r=this.cursor.value;if(!r.point)this.addActive(n),this.cursor.next();else if(t&&this.cursor.to==this.to&&this.cursor.from<this.cursor.to)this.cursor.next();else{this.point=r,this.pointFrom=this.cursor.from,this.pointRank=this.cursor.rank,this.to=this.cursor.to,this.endSide=r.endSide,this.cursor.next(),this.forward(this.to,this.endSide);break}}else{this.to=this.endSide=1e9;break}}if(n){this.openStart=0;for(let s=n.length-1;s>=0&&n[s]<e;s--)this.openStart++}}activeForPoint(e){if(!this.active.length)return this.active;let t=[];for(let n=this.active.length-1;n>=0&&!(this.activeRank[n]<this.pointRank);n--)(this.activeTo[n]>e||this.activeTo[n]==e&&this.active[n].endSide>=this.point.endSide)&&t.push(this.active[n]);return t.reverse()}openEnd(e){let t=0;for(let n=this.activeTo.length-1;n>=0&&this.activeTo[n]>e;n--)t++;return t}}function oa(i,e,t,n,s,r){i.goto(e),t.goto(n);let o=n+s,l=n,a=n-e;for(;;){let h=i.to+a-t.to,c=h||i.endSide-t.endSide,f=c<0?i.to+a:t.to,u=Math.min(f,o);if(i.point||t.point?i.point&&t.point&&(i.point==t.point||i.point.eq(t.point))&&ho(i.activeForPoint(i.to),t.activeForPoint(t.to))||r.comparePoint(l,u,i.point,t.point):u>l&&!ho(i.active,t.active)&&r.compareRange(l,u,i.active,t.active),f>o)break;(h||i.openEnd!=t.openEnd)&&r.boundChange&&r.boundChange(f),l=f,c<=0&&i.next(),c>=0&&t.next()}}function ho(i,e){if(i.length!=e.length)return!1;for(let t=0;t<i.length;t++)if(i[t]!=e[t]&&!i[t].eq(e[t]))return!1;return!0}function $n(i,e){for(let t=e,n=i.length-1;t<n;t++)i[t]=i[t+1];i.pop()}function Fn(i,e,t){for(let n=i.length-1;n>=e;n--)i[n+1]=i[n];i[e]=t}function la(i,e){let t=-1,n=1e9;for(let s=0;s<e.length;s++)(e[s]-n||i[s].endSide-i[t].endSide)<0&&(t=s,n=e[s]);return t}function $i(i,e,t=i.length){let n=0;for(let s=0;s<t&&s<i.length;)i.charCodeAt(s)==9?(n+=e-n%e,s++):(n++,s=me(i,s));return n}function co(i,e,t,n){for(let s=0,r=0;;){if(r>=e)return s;if(s==i.length)break;r+=i.charCodeAt(s)==9?t-r%t:1,s=me(i,s)}return n===!0?-1:i.length}const fo="ͼ",aa=typeof Symbol>"u"?"__"+fo:Symbol.for(fo),uo=typeof Symbol>"u"?"__styleSet"+Math.floor(Math.random()*1e8):Symbol("styleSet"),ha=typeof globalThis<"u"?globalThis:typeof window<"u"?window:{};class Wt{constructor(e,t){this.rules=[];let{finish:n}=t||{};function s(o){return/^@/.test(o)?[o]:o.split(/,\s*/)}function r(o,l,a,h){let c=[],f=/^@(\w+)\b/.exec(o[0]),u=f&&f[1]=="keyframes";if(f&&l==null)return a.push(o[0]+";");for(let d in l){let p=l[d];if(/&/.test(d))r(d.split(/,\s*/).map(m=>o.map(g=>m.replace(/&/,g))).reduce((m,g)=>m.concat(g)),p,a);else if(p&&typeof p=="object"){if(!f)throw new RangeError("The value of a property ("+d+") should be a primitive value.");r(s(d),p,c,u)}else p!=null&&c.push(d.replace(/_.*/,"").replace(/[A-Z]/g,m=>"-"+m.toLowerCase())+": "+p+";")}(c.length||u)&&a.push((n&&!f&&!h?o.map(n):o).join(", ")+" {"+c.join(" ")+"}")}for(let o in e)r(s(o),e[o],this.rules)}getRules(){return this.rules.join(`
6
+ `)}static newName(){let e=ha[aa]||1;return ha[aa]=e+1,fo+e.toString(36)}static mount(e,t,n){let s=e[uo],r=n&&n.nonce;s?r&&s.setNonce(r):s=new am(e,r),s.mount(Array.isArray(t)?t:[t],e)}}let ca=new Map;class am{constructor(e,t){let n=e.ownerDocument||e,s=n.defaultView;if(!e.head&&e.adoptedStyleSheets&&s.CSSStyleSheet){let r=ca.get(n);if(r)return e[uo]=r;this.sheet=new s.CSSStyleSheet,ca.set(n,this)}else this.styleTag=n.createElement("style"),t&&this.styleTag.setAttribute("nonce",t);this.modules=[],e[uo]=this}mount(e,t){let n=this.sheet,s=0,r=0;for(let o=0;o<e.length;o++){let l=e[o],a=this.modules.indexOf(l);if(a<r&&a>-1&&(this.modules.splice(a,1),r--,a=-1),a==-1){if(this.modules.splice(r++,0,l),n)for(let h=0;h<l.rules.length;h++)n.insertRule(l.rules[h],s++)}else{for(;r<a;)s+=this.modules[r++].rules.length;s+=l.rules.length,r++}}if(n)t.adoptedStyleSheets.indexOf(this.sheet)<0&&(t.adoptedStyleSheets=[this.sheet,...t.adoptedStyleSheets]);else{let o="";for(let a=0;a<this.modules.length;a++)o+=this.modules[a].getRules()+`
7
+ `;this.styleTag.textContent=o;let l=t.head||t;this.styleTag.parentNode!=l&&l.insertBefore(this.styleTag,l.firstChild)}}setNonce(e){this.styleTag&&this.styleTag.getAttribute("nonce")!=e&&this.styleTag.setAttribute("nonce",e)}}var Ht={8:"Backspace",9:"Tab",10:"Enter",12:"NumLock",13:"Enter",16:"Shift",17:"Control",18:"Alt",20:"CapsLock",27:"Escape",32:" ",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"ArrowLeft",38:"ArrowUp",39:"ArrowRight",40:"ArrowDown",44:"PrintScreen",45:"Insert",46:"Delete",59:";",61:"=",91:"Meta",92:"Meta",106:"*",107:"+",108:",",109:"-",110:".",111:"/",144:"NumLock",145:"ScrollLock",160:"Shift",161:"Shift",162:"Control",163:"Control",164:"Alt",165:"Alt",173:"-",186:";",187:"=",188:",",189:"-",190:".",191:"/",192:"`",219:"[",220:"\\",221:"]",222:"'"},dn={48:")",49:"!",50:"@",51:"#",52:"$",53:"%",54:"^",55:"&",56:"*",57:"(",59:":",61:"+",173:"_",186:":",187:"+",188:"<",189:"_",190:">",191:"?",192:"~",219:"{",220:"|",221:"}",222:'"'},hm=typeof navigator<"u"&&/Mac/.test(navigator.platform),cm=typeof navigator<"u"&&/MSIE \d|Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(navigator.userAgent);for(var pe=0;pe<10;pe++)Ht[48+pe]=Ht[96+pe]=String(pe);for(var pe=1;pe<=24;pe++)Ht[pe+111]="F"+pe;for(var pe=65;pe<=90;pe++)Ht[pe]=String.fromCharCode(pe+32),dn[pe]=String.fromCharCode(pe);for(var Cr in Ht)dn.hasOwnProperty(Cr)||(dn[Cr]=Ht[Cr]);function fm(i){var e=hm&&i.metaKey&&i.shiftKey&&!i.ctrlKey&&!i.altKey||cm&&i.shiftKey&&i.key&&i.key.length==1||i.key=="Unidentified",t=!e&&i.key||(i.shiftKey?dn:Ht)[i.keyCode]||i.key||"Unidentified";return t=="Esc"&&(t="Escape"),t=="Del"&&(t="Delete"),t=="Left"&&(t="ArrowLeft"),t=="Up"&&(t="ArrowUp"),t=="Right"&&(t="ArrowRight"),t=="Down"&&(t="ArrowDown"),t}function G(){var i=arguments[0];typeof i=="string"&&(i=document.createElement(i));var e=1,t=arguments[1];if(t&&typeof t=="object"&&t.nodeType==null&&!Array.isArray(t)){for(var n in t)if(Object.prototype.hasOwnProperty.call(t,n)){var s=t[n];typeof s=="string"?i.setAttribute(n,s):s!=null&&(i[n]=s)}e++}for(;e<arguments.length;e++)qc(i,arguments[e]);return i}function qc(i,e){if(typeof e=="string")i.appendChild(document.createTextNode(e));else if(e!=null)if(e.nodeType!=null)i.appendChild(e);else if(Array.isArray(e))for(var t=0;t<e.length;t++)qc(i,e[t]);else throw new RangeError("Unsupported child node: "+e)}function pn(i){let e;return i.nodeType==11?e=i.getSelection?i:i.ownerDocument:e=i,e.getSelection()}function po(i,e){return e?i==e||i.contains(e.nodeType!=1?e.parentNode:e):!1}function ds(i,e){if(!e.anchorNode)return!1;try{return po(i,e.anchorNode)}catch{return!1}}function mn(i){return i.nodeType==3?hi(i,0,i.nodeValue.length).getClientRects():i.nodeType==1?i.getClientRects():[]}function sn(i,e,t,n){return t?fa(i,e,t,n,-1)||fa(i,e,t,n,1):!1}function ai(i){for(var e=0;;e++)if(i=i.previousSibling,!i)return e}function xs(i){return i.nodeType==1&&/^(DIV|P|LI|UL|OL|BLOCKQUOTE|DD|DT|H\d|SECTION|PRE)$/.test(i.nodeName)}function fa(i,e,t,n,s){for(;;){if(i==t&&e==n)return!0;if(e==(s<0?0:bt(i))){if(i.nodeName=="DIV")return!1;let r=i.parentNode;if(!r||r.nodeType!=1)return!1;e=ai(i)+(s<0?0:1),i=r}else if(i.nodeType==1){if(i=i.childNodes[e+(s<0?-1:0)],i.nodeType==1&&i.contentEditable=="false")return!1;e=s<0?bt(i):0}else return!1}}function bt(i){return i.nodeType==3?i.nodeValue.length:i.childNodes.length}function js(i,e){let t=e?i.left:i.right;return{left:t,right:t,top:i.top,bottom:i.bottom}}function um(i){let e=i.visualViewport;return e?{left:0,right:e.width,top:0,bottom:e.height}:{left:0,right:i.innerWidth,top:0,bottom:i.innerHeight}}function Gc(i,e){let t=e.width/i.offsetWidth,n=e.height/i.offsetHeight;return(t>.995&&t<1.005||!isFinite(t)||Math.abs(e.width-i.offsetWidth)<1)&&(t=1),(n>.995&&n<1.005||!isFinite(n)||Math.abs(e.height-i.offsetHeight)<1)&&(n=1),{scaleX:t,scaleY:n}}function dm(i,e,t,n,s,r,o,l){let a=i.ownerDocument,h=a.defaultView||window;for(let c=i,f=!1;c&&!f;)if(c.nodeType==1){let u,d=c==a.body,p=1,m=1;if(d)u=um(h);else{if(/^(fixed|sticky)$/.test(getComputedStyle(c).position)&&(f=!0),c.scrollHeight<=c.clientHeight&&c.scrollWidth<=c.clientWidth){c=c.assignedSlot||c.parentNode;continue}let w=c.getBoundingClientRect();({scaleX:p,scaleY:m}=Gc(c,w)),u={left:w.left,right:w.left+c.clientWidth*p,top:w.top,bottom:w.top+c.clientHeight*m}}let g=0,O=0;if(s=="nearest")e.top<u.top?(O=e.top-(u.top+o),t>0&&e.bottom>u.bottom+O&&(O=e.bottom-u.bottom+o)):e.bottom>u.bottom&&(O=e.bottom-u.bottom+o,t<0&&e.top-O<u.top&&(O=e.top-(u.top+o)));else{let w=e.bottom-e.top,k=u.bottom-u.top;O=(s=="center"&&w<=k?e.top+w/2-k/2:s=="start"||s=="center"&&t<0?e.top-o:e.bottom-k+o)-u.top}if(n=="nearest"?e.left<u.left?(g=e.left-(u.left+r),t>0&&e.right>u.right+g&&(g=e.right-u.right+r)):e.right>u.right&&(g=e.right-u.right+r,t<0&&e.left<u.left+g&&(g=e.left-(u.left+r))):g=(n=="center"?e.left+(e.right-e.left)/2-(u.right-u.left)/2:n=="start"==l?e.left-r:e.right-(u.right-u.left)+r)-u.left,g||O)if(d)h.scrollBy(g,O);else{let w=0,k=0;if(O){let v=c.scrollTop;c.scrollTop+=O/m,k=(c.scrollTop-v)*m}if(g){let v=c.scrollLeft;c.scrollLeft+=g/p,w=(c.scrollLeft-v)*p}e={left:e.left-w,top:e.top-k,right:e.right-w,bottom:e.bottom-k},w&&Math.abs(w-g)<1&&(n="nearest"),k&&Math.abs(k-O)<1&&(s="nearest")}if(d)break;(e.top<u.top||e.bottom>u.bottom||e.left<u.left||e.right>u.right)&&(e={left:Math.max(e.left,u.left),right:Math.min(e.right,u.right),top:Math.max(e.top,u.top),bottom:Math.min(e.bottom,u.bottom)}),c=c.assignedSlot||c.parentNode}else if(c.nodeType==11)c=c.host;else break}function pm(i){let e=i.ownerDocument,t,n;for(let s=i.parentNode;s&&!(s==e.body||t&&n);)if(s.nodeType==1)!n&&s.scrollHeight>s.clientHeight&&(n=s),!t&&s.scrollWidth>s.clientWidth&&(t=s),s=s.assignedSlot||s.parentNode;else if(s.nodeType==11)s=s.host;else break;return{x:t,y:n}}class mm{constructor(){this.anchorNode=null,this.anchorOffset=0,this.focusNode=null,this.focusOffset=0}eq(e){return this.anchorNode==e.anchorNode&&this.anchorOffset==e.anchorOffset&&this.focusNode==e.focusNode&&this.focusOffset==e.focusOffset}setRange(e){let{anchorNode:t,focusNode:n}=e;this.set(t,Math.min(e.anchorOffset,t?bt(t):0),n,Math.min(e.focusOffset,n?bt(n):0))}set(e,t,n,s){this.anchorNode=e,this.anchorOffset=t,this.focusNode=n,this.focusOffset=s}}let mi=null;function Uc(i){if(i.setActive)return i.setActive();if(mi)return i.focus(mi);let e=[];for(let t=i;t&&(e.push(t,t.scrollTop,t.scrollLeft),t!=t.ownerDocument);t=t.parentNode);if(i.focus(mi==null?{get preventScroll(){return mi={preventScroll:!0},!0}}:void 0),!mi){mi=!1;for(let t=0;t<e.length;){let n=e[t++],s=e[t++],r=e[t++];n.scrollTop!=s&&(n.scrollTop=s),n.scrollLeft!=r&&(n.scrollLeft=r)}}}let ua;function hi(i,e,t=e){let n=ua||(ua=document.createRange());return n.setEnd(i,t),n.setStart(i,e),n}function xi(i,e,t,n){let s={key:e,code:e,keyCode:t,which:t,cancelable:!0};n&&({altKey:s.altKey,ctrlKey:s.ctrlKey,shiftKey:s.shiftKey,metaKey:s.metaKey}=n);let r=new KeyboardEvent("keydown",s);r.synthetic=!0,i.dispatchEvent(r);let o=new KeyboardEvent("keyup",s);return o.synthetic=!0,i.dispatchEvent(o),r.defaultPrevented||o.defaultPrevented}function gm(i){for(;i;){if(i&&(i.nodeType==9||i.nodeType==11&&i.host))return i;i=i.assignedSlot||i.parentNode}return null}function Yc(i){for(;i.attributes.length;)i.removeAttributeNode(i.attributes[0])}function Am(i,e){let t=e.focusNode,n=e.focusOffset;if(!t||e.anchorNode!=t||e.anchorOffset!=n)return!1;for(n=Math.min(n,bt(t));;)if(n){if(t.nodeType!=1)return!1;let s=t.childNodes[n-1];s.contentEditable=="false"?n--:(t=s,n=bt(t))}else{if(t==i)return!0;n=ai(t),t=t.parentNode}}function Xc(i){return i.scrollTop>Math.max(1,i.scrollHeight-i.clientHeight-4)}function jc(i,e){for(let t=i,n=e;;){if(t.nodeType==3&&n>0)return{node:t,offset:n};if(t.nodeType==1&&n>0){if(t.contentEditable=="false")return null;t=t.childNodes[n-1],n=bt(t)}else if(t.parentNode&&!xs(t))n=ai(t),t=t.parentNode;else return null}}function Jc(i,e){for(let t=i,n=e;;){if(t.nodeType==3&&n<t.nodeValue.length)return{node:t,offset:n};if(t.nodeType==1&&n<t.childNodes.length){if(t.contentEditable=="false")return null;t=t.childNodes[n],n=0}else if(t.parentNode&&!xs(t))n=ai(t)+1,t=t.parentNode;else return null}}class be{constructor(e,t,n=!0){this.node=e,this.offset=t,this.precise=n}static before(e,t){return new be(e.parentNode,ai(e),t)}static after(e,t){return new be(e.parentNode,ai(e)+1,t)}}const sl=[];class Y{constructor(){this.parent=null,this.dom=null,this.flags=2}get overrideDOMText(){return null}get posAtStart(){return this.parent?this.parent.posBefore(this):0}get posAtEnd(){return this.posAtStart+this.length}posBefore(e){let t=this.posAtStart;for(let n of this.children){if(n==e)return t;t+=n.length+n.breakAfter}throw new RangeError("Invalid child in posBefore")}posAfter(e){return this.posBefore(e)+e.length}sync(e,t){if(this.flags&2){let n=this.dom,s=null,r;for(let o of this.children){if(o.flags&7){if(!o.dom&&(r=s?s.nextSibling:n.firstChild)){let l=Y.get(r);(!l||!l.parent&&l.canReuseDOM(o))&&o.reuseDOM(r)}o.sync(e,t),o.flags&=-8}if(r=s?s.nextSibling:n.firstChild,t&&!t.written&&t.node==n&&r!=o.dom&&(t.written=!0),o.dom.parentNode==n)for(;r&&r!=o.dom;)r=da(r);else n.insertBefore(o.dom,r);s=o.dom}for(r=s?s.nextSibling:n.firstChild,r&&t&&t.node==n&&(t.written=!0);r;)r=da(r)}else if(this.flags&1)for(let n of this.children)n.flags&7&&(n.sync(e,t),n.flags&=-8)}reuseDOM(e){}localPosFromDOM(e,t){let n;if(e==this.dom)n=this.dom.childNodes[t];else{let s=bt(e)==0?0:t==0?-1:1;for(;;){let r=e.parentNode;if(r==this.dom)break;s==0&&r.firstChild!=r.lastChild&&(e==r.firstChild?s=-1:s=1),e=r}s<0?n=e:n=e.nextSibling}if(n==this.dom.firstChild)return 0;for(;n&&!Y.get(n);)n=n.nextSibling;if(!n)return this.length;for(let s=0,r=0;;s++){let o=this.children[s];if(o.dom==n)return r;r+=o.length+o.breakAfter}}domBoundsAround(e,t,n=0){let s=-1,r=-1,o=-1,l=-1;for(let a=0,h=n,c=n;a<this.children.length;a++){let f=this.children[a],u=h+f.length;if(h<e&&u>t)return f.domBoundsAround(e,t,h);if(u>=e&&s==-1&&(s=a,r=h),h>t&&f.dom.parentNode==this.dom){o=a,l=c;break}c=u,h=u+f.breakAfter}return{from:r,to:l<0?n+this.length:l,startDOM:(s?this.children[s-1].dom.nextSibling:null)||this.dom.firstChild,endDOM:o<this.children.length&&o>=0?this.children[o].dom:null}}markDirty(e=!1){this.flags|=2,this.markParentsDirty(e)}markParentsDirty(e){for(let t=this.parent;t;t=t.parent){if(e&&(t.flags|=2),t.flags&1)return;t.flags|=1,e=!1}}setParent(e){this.parent!=e&&(this.parent=e,this.flags&7&&this.markParentsDirty(!0))}setDOM(e){this.dom!=e&&(this.dom&&(this.dom.cmView=null),this.dom=e,e.cmView=this)}get rootView(){for(let e=this;;){let t=e.parent;if(!t)return e;e=t}}replaceChildren(e,t,n=sl){this.markDirty();for(let s=e;s<t;s++){let r=this.children[s];r.parent==this&&n.indexOf(r)<0&&r.destroy()}n.length<250?this.children.splice(e,t-e,...n):this.children=[].concat(this.children.slice(0,e),n,this.children.slice(t));for(let s=0;s<n.length;s++)n[s].setParent(this)}ignoreMutation(e){return!1}ignoreEvent(e){return!1}childCursor(e=this.length){return new Zc(this.children,e,this.children.length)}childPos(e,t=1){return this.childCursor().findPos(e,t)}toString(){let e=this.constructor.name.replace("View","");return e+(this.children.length?"("+this.children.join()+")":this.length?"["+(e=="Text"?this.text:this.length)+"]":"")+(this.breakAfter?"#":"")}static get(e){return e.cmView}get isEditable(){return!0}get isWidget(){return!1}get isHidden(){return!1}merge(e,t,n,s,r,o){return!1}become(e){return!1}canReuseDOM(e){return e.constructor==this.constructor&&!((this.flags|e.flags)&8)}getSide(){return 0}destroy(){for(let e of this.children)e.parent==this&&e.destroy();this.parent=null}}Y.prototype.breakAfter=0;function da(i){let e=i.nextSibling;return i.parentNode.removeChild(i),e}class Zc{constructor(e,t,n){this.children=e,this.pos=t,this.i=n,this.off=0}findPos(e,t=1){for(;;){if(e>this.pos||e==this.pos&&(t>0||this.i==0||this.children[this.i-1].breakAfter))return this.off=e-this.pos,this;let n=this.children[--this.i];this.pos-=n.length+n.breakAfter}}}function ef(i,e,t,n,s,r,o,l,a){let{children:h}=i,c=h.length?h[e]:null,f=r.length?r[r.length-1]:null,u=f?f.breakAfter:o;if(!(e==n&&c&&!o&&!u&&r.length<2&&c.merge(t,s,r.length?f:null,t==0,l,a))){if(n<h.length){let d=h[n];d&&(s<d.length||d.breakAfter&&f?.breakAfter)?(e==n&&(d=d.split(s),s=0),!u&&f&&d.merge(0,s,f,!0,0,a)?r[r.length-1]=d:((s||d.children.length&&!d.children[0].length)&&d.merge(0,s,null,!1,0,a),r.push(d))):d?.breakAfter&&(f?f.breakAfter=1:o=1),n++}for(c&&(c.breakAfter=o,t>0&&(!o&&r.length&&c.merge(t,c.length,r[0],!1,l,0)?c.breakAfter=r.shift().breakAfter:(t<c.length||c.children.length&&c.children[c.children.length-1].length==0)&&c.merge(t,c.length,null,!1,l,0),e++));e<n&&r.length;)if(h[n-1].become(r[r.length-1]))n--,r.pop(),a=r.length?0:l;else if(h[e].become(r[0]))e++,r.shift(),l=r.length?0:a;else break;!r.length&&e&&n<h.length&&!h[e-1].breakAfter&&h[n].merge(0,0,h[e-1],!1,l,a)&&e--,(e<n||r.length)&&i.replaceChildren(e,n,r)}}function tf(i,e,t,n,s,r){let o=i.childCursor(),{i:l,off:a}=o.findPos(t,1),{i:h,off:c}=o.findPos(e,-1),f=e-t;for(let u of n)f+=u.length;i.length+=f,ef(i,h,c,l,a,n,0,s,r)}let Be=typeof navigator<"u"?navigator:{userAgent:"",vendor:"",platform:""},mo=typeof document<"u"?document:{documentElement:{style:{}}};const go=/Edge\/(\d+)/.exec(Be.userAgent),nf=/MSIE \d/.test(Be.userAgent),Ao=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(Be.userAgent),Js=!!(nf||Ao||go),pa=!Js&&/gecko\/(\d+)/i.test(Be.userAgent),vr=!Js&&/Chrome\/(\d+)/.exec(Be.userAgent),Om="webkitFontSmoothing"in mo.documentElement.style,sf=!Js&&/Apple Computer/.test(Be.vendor),ma=sf&&(/Mobile\/\w+/.test(Be.userAgent)||Be.maxTouchPoints>2);var E={mac:ma||/Mac/.test(Be.platform),windows:/Win/.test(Be.platform),linux:/Linux|X11/.test(Be.platform),ie:Js,ie_version:nf?mo.documentMode||6:Ao?+Ao[1]:go?+go[1]:0,gecko:pa,gecko_version:pa?+(/Firefox\/(\d+)/.exec(Be.userAgent)||[0,0])[1]:0,chrome:!!vr,chrome_version:vr?+vr[1]:0,ios:ma,android:/Android\b/.test(Be.userAgent),safari:sf,webkit_version:Om?+(/\bAppleWebKit\/(\d+)/.exec(Be.userAgent)||[0,0])[1]:0,tabSize:mo.documentElement.style.tabSize!=null?"tab-size":"-moz-tab-size"};const bm=256;class it extends Y{constructor(e){super(),this.text=e}get length(){return this.text.length}createDOM(e){this.setDOM(e||document.createTextNode(this.text))}sync(e,t){this.dom||this.createDOM(),this.dom.nodeValue!=this.text&&(t&&t.node==this.dom&&(t.written=!0),this.dom.nodeValue=this.text)}reuseDOM(e){e.nodeType==3&&this.createDOM(e)}merge(e,t,n){return this.flags&8||n&&(!(n instanceof it)||this.length-(t-e)+n.length>bm||n.flags&8)?!1:(this.text=this.text.slice(0,e)+(n?n.text:"")+this.text.slice(t),this.markDirty(),!0)}split(e){let t=new it(this.text.slice(e));return this.text=this.text.slice(0,e),this.markDirty(),t.flags|=this.flags&8,t}localPosFromDOM(e,t){return e==this.dom?t:t?this.text.length:0}domAtPos(e){return new be(this.dom,e)}domBoundsAround(e,t,n){return{from:n,to:n+this.length,startDOM:this.dom,endDOM:this.dom.nextSibling}}coordsAt(e,t){return wm(this.dom,e,t)}}class Et extends Y{constructor(e,t=[],n=0){super(),this.mark=e,this.children=t,this.length=n;for(let s of t)s.setParent(this)}setAttrs(e){if(Yc(e),this.mark.class&&(e.className=this.mark.class),this.mark.attrs)for(let t in this.mark.attrs)e.setAttribute(t,this.mark.attrs[t]);return e}canReuseDOM(e){return super.canReuseDOM(e)&&!((this.flags|e.flags)&8)}reuseDOM(e){e.nodeName==this.mark.tagName.toUpperCase()&&(this.setDOM(e),this.flags|=6)}sync(e,t){this.dom?this.flags&4&&this.setAttrs(this.dom):this.setDOM(this.setAttrs(document.createElement(this.mark.tagName))),super.sync(e,t)}merge(e,t,n,s,r,o){return n&&(!(n instanceof Et&&n.mark.eq(this.mark))||e&&r<=0||t<this.length&&o<=0)?!1:(tf(this,e,t,n?n.children.slice():[],r-1,o-1),this.markDirty(),!0)}split(e){let t=[],n=0,s=-1,r=0;for(let l of this.children){let a=n+l.length;a>e&&t.push(n<e?l.split(e-n):l),s<0&&n>=e&&(s=r),n=a,r++}let o=this.length-e;return this.length=e,s>-1&&(this.children.length=s,this.markDirty()),new Et(this.mark,t,o)}domAtPos(e){return rf(this,e)}coordsAt(e,t){return lf(this,e,t)}}function wm(i,e,t){let n=i.nodeValue.length;e>n&&(e=n);let s=e,r=e,o=0;e==0&&t<0||e==n&&t>=0?E.chrome||E.gecko||(e?(s--,o=1):r<n&&(r++,o=-1)):t<0?s--:r<n&&r++;let l=hi(i,s,r).getClientRects();if(!l.length)return null;let a=l[(o?o<0:t>=0)?0:l.length-1];return E.safari&&!o&&a.width==0&&(a=Array.prototype.find.call(l,h=>h.width)||a),o?js(a,o<0):a||null}class Ft extends Y{static create(e,t,n){return new Ft(e,t,n)}constructor(e,t,n){super(),this.widget=e,this.length=t,this.side=n,this.prevWidget=null}split(e){let t=Ft.create(this.widget,this.length-e,this.side);return this.length-=e,t}sync(e){(!this.dom||!this.widget.updateDOM(this.dom,e))&&(this.dom&&this.prevWidget&&this.prevWidget.destroy(this.dom),this.prevWidget=null,this.setDOM(this.widget.toDOM(e)),this.widget.editable||(this.dom.contentEditable="false"))}getSide(){return this.side}merge(e,t,n,s,r,o){return n&&(!(n instanceof Ft)||!this.widget.compare(n.widget)||e>0&&r<=0||t<this.length&&o<=0)?!1:(this.length=e+(n?n.length:0)+(this.length-t),!0)}become(e){return e instanceof Ft&&e.side==this.side&&this.widget.constructor==e.widget.constructor?(this.widget.compare(e.widget)||this.markDirty(!0),this.dom&&!this.prevWidget&&(this.prevWidget=this.widget),this.widget=e.widget,this.length=e.length,!0):!1}ignoreMutation(){return!0}ignoreEvent(e){return this.widget.ignoreEvent(e)}get overrideDOMText(){if(this.length==0)return $.empty;let e=this;for(;e.parent;)e=e.parent;let{view:t}=e,n=t&&t.state.doc,s=this.posAtStart;return n?n.slice(s,s+this.length):$.empty}domAtPos(e){return(this.length?e==0:this.side>0)?be.before(this.dom):be.after(this.dom,e==this.length)}domBoundsAround(){return null}coordsAt(e,t){let n=this.widget.coordsAt(this.dom,e,t);if(n)return n;let s=this.dom.getClientRects(),r=null;if(!s.length)return null;let o=this.side?this.side<0:e>0;for(let l=o?s.length-1:0;r=s[l],!(e>0?l==0:l==s.length-1||r.top<r.bottom);l+=o?-1:1);return js(r,!o)}get isEditable(){return!1}get isWidget(){return!0}get isHidden(){return this.widget.isHidden}destroy(){super.destroy(),this.dom&&this.widget.destroy(this.dom)}}class Di extends Y{constructor(e){super(),this.side=e}get length(){return 0}merge(){return!1}become(e){return e instanceof Di&&e.side==this.side}split(){return new Di(this.side)}sync(){if(!this.dom){let e=document.createElement("img");e.className="cm-widgetBuffer",e.setAttribute("aria-hidden","true"),this.setDOM(e)}}getSide(){return this.side}domAtPos(e){return this.side>0?be.before(this.dom):be.after(this.dom)}localPosFromDOM(){return 0}domBoundsAround(){return null}coordsAt(e){return this.dom.getBoundingClientRect()}get overrideDOMText(){return $.empty}get isHidden(){return!0}}it.prototype.children=Ft.prototype.children=Di.prototype.children=sl;function rf(i,e){let t=i.dom,{children:n}=i,s=0;for(let r=0;s<n.length;s++){let o=n[s],l=r+o.length;if(!(l==r&&o.getSide()<=0)){if(e>r&&e<l&&o.dom.parentNode==t)return o.domAtPos(e-r);if(e<=r)break;r=l}}for(let r=s;r>0;r--){let o=n[r-1];if(o.dom.parentNode==t)return o.domAtPos(o.length)}for(let r=s;r<n.length;r++){let o=n[r];if(o.dom.parentNode==t)return o.domAtPos(0)}return new be(t,0)}function of(i,e,t){let n,{children:s}=i;t>0&&e instanceof Et&&s.length&&(n=s[s.length-1])instanceof Et&&n.mark.eq(e.mark)?of(n,e.children[0],t-1):(s.push(e),e.setParent(i)),i.length+=e.length}function lf(i,e,t){let n=null,s=-1,r=null,o=-1;function l(h,c){for(let f=0,u=0;f<h.children.length&&u<=c;f++){let d=h.children[f],p=u+d.length;p>=c&&(d.children.length?l(d,c-u):(!r||r.isHidden&&(t>0||km(r,d)))&&(p>c||u==p&&d.getSide()>0)?(r=d,o=c-u):(u<c||u==p&&d.getSide()<0&&!d.isHidden)&&(n=d,s=c-u)),u=p}}l(i,e);let a=(t<0?n:r)||n||r;return a?a.coordsAt(Math.max(0,a==n?s:o),t):ym(i)}function ym(i){let e=i.dom.lastChild;if(!e)return i.dom.getBoundingClientRect();let t=mn(e);return t[t.length-1]||null}function km(i,e){let t=i.coordsAt(0,1),n=e.coordsAt(0,1);return t&&n&&n.top<t.bottom}function Oo(i,e){for(let t in i)t=="class"&&e.class?e.class+=" "+i.class:t=="style"&&e.style?e.style+=";"+i.style:e[t]=i[t];return e}const ga=Object.create(null);function Ss(i,e,t){if(i==e)return!0;i||(i=ga),e||(e=ga);let n=Object.keys(i),s=Object.keys(e);if(n.length-(t&&n.indexOf(t)>-1?1:0)!=s.length-(t&&s.indexOf(t)>-1?1:0))return!1;for(let r of n)if(r!=t&&(s.indexOf(r)==-1||i[r]!==e[r]))return!1;return!0}function bo(i,e,t){let n=!1;if(e)for(let s in e)t&&s in t||(n=!0,s=="style"?i.style.cssText="":i.removeAttribute(s));if(t)for(let s in t)e&&e[s]==t[s]||(n=!0,s=="style"?i.style.cssText=t[s]:i.setAttribute(s,t[s]));return n}function Cm(i){let e=Object.create(null);for(let t=0;t<i.attributes.length;t++){let n=i.attributes[t];e[n.name]=n.value}return e}class Ut{eq(e){return!1}updateDOM(e,t){return!1}compare(e){return this==e||this.constructor==e.constructor&&this.eq(e)}get estimatedHeight(){return-1}get lineBreaks(){return 0}ignoreEvent(e){return!0}coordsAt(e,t,n){return null}get isHidden(){return!1}get editable(){return!1}destroy(e){}}var xe=(function(i){return i[i.Text=0]="Text",i[i.WidgetBefore=1]="WidgetBefore",i[i.WidgetAfter=2]="WidgetAfter",i[i.WidgetRange=3]="WidgetRange",i})(xe||(xe={}));class D extends li{constructor(e,t,n,s){super(),this.startSide=e,this.endSide=t,this.widget=n,this.spec=s}get heightRelevant(){return!1}static mark(e){return new En(e)}static widget(e){let t=Math.max(-1e4,Math.min(1e4,e.side||0)),n=!!e.block;return t+=n&&!e.inlineOrder?t>0?3e8:-4e8:t>0?1e8:-1e8,new qt(e,t,t,n,e.widget||null,!1)}static replace(e){let t=!!e.block,n,s;if(e.isBlockGap)n=-5e8,s=4e8;else{let{start:r,end:o}=af(e,t);n=(r?t?-3e8:-1:5e8)-1,s=(o?t?2e8:1:-6e8)+1}return new qt(e,n,s,t,e.widget||null,!0)}static line(e){return new Bn(e)}static set(e,t=!1){return _.of(e,t)}hasHeight(){return this.widget?this.widget.estimatedHeight>-1:!1}}D.none=_.empty;class En extends D{constructor(e){let{start:t,end:n}=af(e);super(t?-1:5e8,n?1:-6e8,null,e),this.tagName=e.tagName||"span",this.class=e.class||"",this.attrs=e.attributes||null}eq(e){var t,n;return this==e||e instanceof En&&this.tagName==e.tagName&&(this.class||((t=this.attrs)===null||t===void 0?void 0:t.class))==(e.class||((n=e.attrs)===null||n===void 0?void 0:n.class))&&Ss(this.attrs,e.attrs,"class")}range(e,t=e){if(e>=t)throw new RangeError("Mark decorations may not be empty");return super.range(e,t)}}En.prototype.point=!1;class Bn extends D{constructor(e){super(-2e8,-2e8,null,e)}eq(e){return e instanceof Bn&&this.spec.class==e.spec.class&&Ss(this.spec.attributes,e.spec.attributes)}range(e,t=e){if(t!=e)throw new RangeError("Line decoration ranges must be zero-length");return super.range(e,t)}}Bn.prototype.mapMode=Ce.TrackBefore;Bn.prototype.point=!0;class qt extends D{constructor(e,t,n,s,r,o){super(t,n,r,e),this.block=s,this.isReplace=o,this.mapMode=s?t<=0?Ce.TrackBefore:Ce.TrackAfter:Ce.TrackDel}get type(){return this.startSide!=this.endSide?xe.WidgetRange:this.startSide<=0?xe.WidgetBefore:xe.WidgetAfter}get heightRelevant(){return this.block||!!this.widget&&(this.widget.estimatedHeight>=5||this.widget.lineBreaks>0)}eq(e){return e instanceof qt&&vm(this.widget,e.widget)&&this.block==e.block&&this.startSide==e.startSide&&this.endSide==e.endSide}range(e,t=e){if(this.isReplace&&(e>t||e==t&&this.startSide>0&&this.endSide<=0))throw new RangeError("Invalid range for replacement decoration");if(!this.isReplace&&t!=e)throw new RangeError("Widget decorations can only have zero-length ranges");return super.range(e,t)}}qt.prototype.point=!0;function af(i,e=!1){let{inclusiveStart:t,inclusiveEnd:n}=i;return t==null&&(t=i.inclusive),n==null&&(n=i.inclusive),{start:t??e,end:n??e}}function vm(i,e){return i==e||!!(i&&e&&i.compare(e))}function ps(i,e,t,n=0){let s=t.length-1;s>=0&&t[s]+n>=i?t[s]=Math.max(t[s],e):t.push(i,e)}class se extends Y{constructor(){super(...arguments),this.children=[],this.length=0,this.prevAttrs=void 0,this.attrs=null,this.breakAfter=0}merge(e,t,n,s,r,o){if(n){if(!(n instanceof se))return!1;this.dom||n.transferDOM(this)}return s&&this.setDeco(n?n.attrs:null),tf(this,e,t,n?n.children.slice():[],r,o),!0}split(e){let t=new se;if(t.breakAfter=this.breakAfter,this.length==0)return t;let{i:n,off:s}=this.childPos(e);s&&(t.append(this.children[n].split(s),0),this.children[n].merge(s,this.children[n].length,null,!1,0,0),n++);for(let r=n;r<this.children.length;r++)t.append(this.children[r],0);for(;n>0&&this.children[n-1].length==0;)this.children[--n].destroy();return this.children.length=n,this.markDirty(),this.length=e,t}transferDOM(e){this.dom&&(this.markDirty(),e.setDOM(this.dom),e.prevAttrs=this.prevAttrs===void 0?this.attrs:this.prevAttrs,this.prevAttrs=void 0,this.dom=null)}setDeco(e){Ss(this.attrs,e)||(this.dom&&(this.prevAttrs=this.attrs,this.markDirty()),this.attrs=e)}append(e,t){of(this,e,t)}addLineDeco(e){let t=e.spec.attributes,n=e.spec.class;t&&(this.attrs=Oo(t,this.attrs||{})),n&&(this.attrs=Oo({class:n},this.attrs||{}))}domAtPos(e){return rf(this,e)}reuseDOM(e){e.nodeName=="DIV"&&(this.setDOM(e),this.flags|=6)}sync(e,t){var n;this.dom?this.flags&4&&(Yc(this.dom),this.dom.className="cm-line",this.prevAttrs=this.attrs?null:void 0):(this.setDOM(document.createElement("div")),this.dom.className="cm-line",this.prevAttrs=this.attrs?null:void 0),this.prevAttrs!==void 0&&(bo(this.dom,this.prevAttrs,this.attrs),this.dom.classList.add("cm-line"),this.prevAttrs=void 0),super.sync(e,t);let s=this.dom.lastChild;for(;s&&Y.get(s)instanceof Et;)s=s.lastChild;if(!s||!this.length||s.nodeName!="BR"&&((n=Y.get(s))===null||n===void 0?void 0:n.isEditable)==!1&&(!E.ios||!this.children.some(r=>r instanceof it))){let r=document.createElement("BR");r.cmIgnore=!0,this.dom.appendChild(r)}}measureTextSize(){if(this.children.length==0||this.length>20)return null;let e=0,t;for(let n of this.children){if(!(n instanceof it)||/[^ -~]/.test(n.text))return null;let s=mn(n.dom);if(s.length!=1)return null;e+=s[0].width,t=s[0].height}return e?{lineHeight:this.dom.getBoundingClientRect().height,charWidth:e/this.length,textHeight:t}:null}coordsAt(e,t){let n=lf(this,e,t);if(!this.children.length&&n&&this.parent){let{heightOracle:s}=this.parent.view.viewState,r=n.bottom-n.top;if(Math.abs(r-s.lineHeight)<2&&s.textHeight<r){let o=(r-s.textHeight)/2;return{top:n.top+o,bottom:n.bottom-o,left:n.left,right:n.left}}}return n}become(e){return e instanceof se&&this.children.length==0&&e.children.length==0&&Ss(this.attrs,e.attrs)&&this.breakAfter==e.breakAfter}covers(){return!0}static find(e,t){for(let n=0,s=0;n<e.children.length;n++){let r=e.children[n],o=s+r.length;if(o>=t){if(r instanceof se)return r;if(o>t)break}s=o+r.breakAfter}return null}}class St extends Y{constructor(e,t,n){super(),this.widget=e,this.length=t,this.deco=n,this.breakAfter=0,this.prevWidget=null}merge(e,t,n,s,r,o){return n&&(!(n instanceof St)||!this.widget.compare(n.widget)||e>0&&r<=0||t<this.length&&o<=0)?!1:(this.length=e+(n?n.length:0)+(this.length-t),!0)}domAtPos(e){return e==0?be.before(this.dom):be.after(this.dom,e==this.length)}split(e){let t=this.length-e;this.length=e;let n=new St(this.widget,t,this.deco);return n.breakAfter=this.breakAfter,n}get children(){return sl}sync(e){(!this.dom||!this.widget.updateDOM(this.dom,e))&&(this.dom&&this.prevWidget&&this.prevWidget.destroy(this.dom),this.prevWidget=null,this.setDOM(this.widget.toDOM(e)),this.widget.editable||(this.dom.contentEditable="false"))}get overrideDOMText(){return this.parent?this.parent.view.state.doc.slice(this.posAtStart,this.posAtEnd):$.empty}domBoundsAround(){return null}become(e){return e instanceof St&&e.widget.constructor==this.widget.constructor?(e.widget.compare(this.widget)||this.markDirty(!0),this.dom&&!this.prevWidget&&(this.prevWidget=this.widget),this.widget=e.widget,this.length=e.length,this.deco=e.deco,this.breakAfter=e.breakAfter,!0):!1}ignoreMutation(){return!0}ignoreEvent(e){return this.widget.ignoreEvent(e)}get isEditable(){return!1}get isWidget(){return!0}coordsAt(e,t){let n=this.widget.coordsAt(this.dom,e,t);return n||(this.widget instanceof wo?null:js(this.dom.getBoundingClientRect(),this.length?e==0:t<=0))}destroy(){super.destroy(),this.dom&&this.widget.destroy(this.dom)}covers(e){let{startSide:t,endSide:n}=this.deco;return t==n?!1:e<0?t<0:n>0}}class wo extends Ut{constructor(e){super(),this.height=e}toDOM(){let e=document.createElement("div");return e.className="cm-gap",this.updateDOM(e),e}eq(e){return e.height==this.height}updateDOM(e){return e.style.height=this.height+"px",!0}get editable(){return!0}get estimatedHeight(){return this.height}ignoreEvent(){return!1}}class rn{constructor(e,t,n,s){this.doc=e,this.pos=t,this.end=n,this.disallowBlockEffectsFor=s,this.content=[],this.curLine=null,this.breakAtStart=0,this.pendingBuffer=0,this.bufferMarks=[],this.atCursorPos=!0,this.openStart=-1,this.openEnd=-1,this.text="",this.textOff=0,this.cursor=e.iter(),this.skip=t}posCovered(){if(this.content.length==0)return!this.breakAtStart&&this.doc.lineAt(this.pos).from!=this.pos;let e=this.content[this.content.length-1];return!(e.breakAfter||e instanceof St&&e.deco.endSide<0)}getLine(){return this.curLine||(this.content.push(this.curLine=new se),this.atCursorPos=!0),this.curLine}flushBuffer(e=this.bufferMarks){this.pendingBuffer&&(this.curLine.append(Kn(new Di(-1),e),e.length),this.pendingBuffer=0)}addBlockWidget(e){this.flushBuffer(),this.curLine=null,this.content.push(e)}finish(e){this.pendingBuffer&&e<=this.bufferMarks.length?this.flushBuffer():this.pendingBuffer=0,!this.posCovered()&&!(e&&this.content.length&&this.content[this.content.length-1]instanceof St)&&this.getLine()}buildText(e,t,n){for(;e>0;){if(this.textOff==this.text.length){let{value:r,lineBreak:o,done:l}=this.cursor.next(this.skip);if(this.skip=0,l)throw new Error("Ran out of text content when drawing inline views");if(o){this.posCovered()||this.getLine(),this.content.length?this.content[this.content.length-1].breakAfter=1:this.breakAtStart=1,this.flushBuffer(),this.curLine=null,this.atCursorPos=!0,e--;continue}else this.text=r,this.textOff=0}let s=Math.min(this.text.length-this.textOff,e,512);this.flushBuffer(t.slice(t.length-n)),this.getLine().append(Kn(new it(this.text.slice(this.textOff,this.textOff+s)),t),n),this.atCursorPos=!0,this.textOff+=s,e-=s,n=0}}span(e,t,n,s){this.buildText(t-e,n,s),this.pos=t,this.openStart<0&&(this.openStart=s)}point(e,t,n,s,r,o){if(this.disallowBlockEffectsFor[o]&&n instanceof qt){if(n.block)throw new RangeError("Block decorations may not be specified via plugins");if(t>this.doc.lineAt(this.pos).to)throw new RangeError("Decorations that replace line breaks may not be specified via plugins")}let l=t-e;if(n instanceof qt)if(n.block)n.startSide>0&&!this.posCovered()&&this.getLine(),this.addBlockWidget(new St(n.widget||Ii.block,l,n));else{let a=Ft.create(n.widget||Ii.inline,l,l?0:n.startSide),h=this.atCursorPos&&!a.isEditable&&r<=s.length&&(e<t||n.startSide>0),c=!a.isEditable&&(e<t||r>s.length||n.startSide<=0),f=this.getLine();this.pendingBuffer==2&&!h&&!a.isEditable&&(this.pendingBuffer=0),this.flushBuffer(s),h&&(f.append(Kn(new Di(1),s),r),r=s.length+Math.max(0,r-s.length)),f.append(Kn(a,s),r),this.atCursorPos=c,this.pendingBuffer=c?e<t||r>s.length?1:2:0,this.pendingBuffer&&(this.bufferMarks=s.slice())}else this.doc.lineAt(this.pos).from==this.pos&&this.getLine().addLineDeco(n);l&&(this.textOff+l<=this.text.length?this.textOff+=l:(this.skip+=l-(this.text.length-this.textOff),this.text="",this.textOff=0),this.pos=t),this.openStart<0&&(this.openStart=r)}static build(e,t,n,s,r){let o=new rn(e,t,n,r);return o.openEnd=_.spans(s,t,n,o),o.openStart<0&&(o.openStart=o.openEnd),o.finish(o.openEnd),o}}function Kn(i,e){for(let t of e)i=new Et(t,[i],i.length);return i}class Ii extends Ut{constructor(e){super(),this.tag=e}eq(e){return e.tag==this.tag}toDOM(){return document.createElement(this.tag)}updateDOM(e){return e.nodeName.toLowerCase()==this.tag}get isHidden(){return!0}}Ii.inline=new Ii("span");Ii.block=new Ii("div");var Z=(function(i){return i[i.LTR=0]="LTR",i[i.RTL=1]="RTL",i})(Z||(Z={}));const ci=Z.LTR,rl=Z.RTL;function hf(i){let e=[];for(let t=0;t<i.length;t++)e.push(1<<+i[t]);return e}const xm=hf("88888888888888888888888888888888888666888888787833333333337888888000000000000000000000000008888880000000000000000000000000088888888888888888888888888888888888887866668888088888663380888308888800000000000000000000000800000000000000000000000000000008"),Sm=hf("4444448826627288999999999992222222222222222222222222222222222222222222222229999999999999999999994444444444644222822222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222999999949999999229989999223333333333"),yo=Object.create(null),lt=[];for(let i of["()","[]","{}"]){let e=i.charCodeAt(0),t=i.charCodeAt(1);yo[e]=t,yo[t]=-e}function cf(i){return i<=247?xm[i]:1424<=i&&i<=1524?2:1536<=i&&i<=1785?Sm[i-1536]:1774<=i&&i<=2220?4:8192<=i&&i<=8204?256:64336<=i&&i<=65023?4:1}const Qm=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac\ufb50-\ufdff]/;class Kt{get dir(){return this.level%2?rl:ci}constructor(e,t,n){this.from=e,this.to=t,this.level=n}side(e,t){return this.dir==t==e?this.to:this.from}forward(e,t){return e==(this.dir==t)}static find(e,t,n,s){let r=-1;for(let o=0;o<e.length;o++){let l=e[o];if(l.from<=t&&l.to>=t){if(l.level==n)return o;(r<0||(s!=0?s<0?l.from<t:l.to>t:e[r].level>l.level))&&(r=o)}}if(r<0)throw new RangeError("Index out of range");return r}}function ff(i,e){if(i.length!=e.length)return!1;for(let t=0;t<i.length;t++){let n=i[t],s=e[t];if(n.from!=s.from||n.to!=s.to||n.direction!=s.direction||!ff(n.inner,s.inner))return!1}return!0}const U=[];function Em(i,e,t,n,s){for(let r=0;r<=n.length;r++){let o=r?n[r-1].to:e,l=r<n.length?n[r].from:t,a=r?256:s;for(let h=o,c=a,f=a;h<l;h++){let u=cf(i.charCodeAt(h));u==512?u=c:u==8&&f==4&&(u=16),U[h]=u==4?2:u,u&7&&(f=u),c=u}for(let h=o,c=a,f=a;h<l;h++){let u=U[h];if(u==128)h<l-1&&c==U[h+1]&&c&24?u=U[h]=c:U[h]=256;else if(u==64){let d=h+1;for(;d<l&&U[d]==64;)d++;let p=h&&c==8||d<t&&U[d]==8?f==1?1:8:256;for(let m=h;m<d;m++)U[m]=p;h=d-1}else u==8&&f==1&&(U[h]=1);c=u,u&7&&(f=u)}}}function Bm(i,e,t,n,s){let r=s==1?2:1;for(let o=0,l=0,a=0;o<=n.length;o++){let h=o?n[o-1].to:e,c=o<n.length?n[o].from:t;for(let f=h,u,d,p;f<c;f++)if(d=yo[u=i.charCodeAt(f)])if(d<0){for(let m=l-3;m>=0;m-=3)if(lt[m+1]==-d){let g=lt[m+2],O=g&2?s:g&4?g&1?r:s:0;O&&(U[f]=U[lt[m]]=O),l=m;break}}else{if(lt.length==189)break;lt[l++]=f,lt[l++]=u,lt[l++]=a}else if((p=U[f])==2||p==1){let m=p==s;a=m?0:1;for(let g=l-3;g>=0;g-=3){let O=lt[g+2];if(O&2)break;if(m)lt[g+2]|=2;else{if(O&4)break;lt[g+2]|=4}}}}}function Pm(i,e,t,n){for(let s=0,r=n;s<=t.length;s++){let o=s?t[s-1].to:i,l=s<t.length?t[s].from:e;for(let a=o;a<l;){let h=U[a];if(h==256){let c=a+1;for(;;)if(c==l){if(s==t.length)break;c=t[s++].to,l=s<t.length?t[s].from:e}else if(U[c]==256)c++;else break;let f=r==1,u=(c<e?U[c]:n)==1,d=f==u?f?1:2:n;for(let p=c,m=s,g=m?t[m-1].to:i;p>a;)p==g&&(p=t[--m].from,g=m?t[m-1].to:i),U[--p]=d;a=c}else r=h,a++}}}function ko(i,e,t,n,s,r,o){let l=n%2?2:1;if(n%2==s%2)for(let a=e,h=0;a<t;){let c=!0,f=!1;if(h==r.length||a<r[h].from){let m=U[a];m!=l&&(c=!1,f=m==16)}let u=!c&&l==1?[]:null,d=c?n:n+1,p=a;e:for(;;)if(h<r.length&&p==r[h].from){if(f)break e;let m=r[h];if(!c)for(let g=m.to,O=h+1;;){if(g==t)break e;if(O<r.length&&r[O].from==g)g=r[O++].to;else{if(U[g]==l)break e;break}}if(h++,u)u.push(m);else{m.from>a&&o.push(new Kt(a,m.from,d));let g=m.direction==ci!=!(d%2);Co(i,g?n+1:n,s,m.inner,m.from,m.to,o),a=m.to}p=m.to}else{if(p==t||(c?U[p]!=l:U[p]==l))break;p++}u?ko(i,a,p,n+1,s,u,o):a<p&&o.push(new Kt(a,p,d)),a=p}else for(let a=t,h=r.length;a>e;){let c=!0,f=!1;if(!h||a>r[h-1].to){let m=U[a-1];m!=l&&(c=!1,f=m==16)}let u=!c&&l==1?[]:null,d=c?n:n+1,p=a;e:for(;;)if(h&&p==r[h-1].to){if(f)break e;let m=r[--h];if(!c)for(let g=m.from,O=h;;){if(g==e)break e;if(O&&r[O-1].to==g)g=r[--O].from;else{if(U[g-1]==l)break e;break}}if(u)u.push(m);else{m.to<a&&o.push(new Kt(m.to,a,d));let g=m.direction==ci!=!(d%2);Co(i,g?n+1:n,s,m.inner,m.from,m.to,o),a=m.from}p=m.from}else{if(p==e||(c?U[p-1]!=l:U[p-1]==l))break;p--}u?ko(i,p,a,n+1,s,u,o):p<a&&o.push(new Kt(p,a,d)),a=p}}function Co(i,e,t,n,s,r,o){let l=e%2?2:1;Em(i,s,r,n,l),Bm(i,s,r,n,l),Pm(s,r,n,l),ko(i,s,r,e,t,n,o)}function Mm(i,e,t){if(!i)return[new Kt(0,0,e==rl?1:0)];if(e==ci&&!t.length&&!Qm.test(i))return uf(i.length);if(t.length)for(;i.length>U.length;)U[U.length]=256;let n=[],s=e==ci?0:1;return Co(i,s,s,t,0,i.length,n),n}function uf(i){return[new Kt(0,i,0)]}let df="";function Dm(i,e,t,n,s){var r;let o=n.head-i.from,l=Kt.find(e,o,(r=n.bidiLevel)!==null&&r!==void 0?r:-1,n.assoc),a=e[l],h=a.side(s,t);if(o==h){let u=l+=s?1:-1;if(u<0||u>=e.length)return null;a=e[l=u],o=a.side(!s,t),h=a.side(s,t)}let c=me(i.text,o,a.forward(s,t));(c<a.from||c>a.to)&&(c=h),df=i.text.slice(Math.min(o,c),Math.max(o,c));let f=l==(s?e.length-1:0)?null:e[l+(s?1:-1)];return f&&c==h&&f.level+(s?0:1)<a.level?b.cursor(f.side(!s,t)+i.from,f.forward(s,t)?1:-1,f.level):b.cursor(c+i.from,a.forward(s,t)?-1:1,a.level)}function Im(i,e,t){for(let n=e;n<t;n++){let s=cf(i.charCodeAt(n));if(s==1)return ci;if(s==2||s==4)return rl}return ci}const pf=B.define(),mf=B.define(),gf=B.define(),Af=B.define(),vo=B.define(),Of=B.define(),bf=B.define(),ol=B.define(),ll=B.define(),wf=B.define({combine:i=>i.some(e=>e)}),yf=B.define({combine:i=>i.some(e=>e)}),kf=B.define();class Si{constructor(e,t="nearest",n="nearest",s=5,r=5,o=!1){this.range=e,this.y=t,this.x=n,this.yMargin=s,this.xMargin=r,this.isSnapshot=o}map(e){return e.empty?this:new Si(this.range.map(e),this.y,this.x,this.yMargin,this.xMargin,this.isSnapshot)}clip(e){return this.range.to<=e.doc.length?this:new Si(b.cursor(e.doc.length),this.y,this.x,this.yMargin,this.xMargin,this.isSnapshot)}}const zn=R.define({map:(i,e)=>i.map(e)}),Cf=R.define();function ve(i,e,t){let n=i.facet(Af);n.length?n[0](e):window.onerror&&window.onerror(String(e),t,void 0,void 0,e)||(t?console.error(t+":",e):console.error(e))}const xt=B.define({combine:i=>i.length?i[0]:!0});let Tm=0;const bi=B.define({combine(i){return i.filter((e,t)=>{for(let n=0;n<t;n++)if(i[n].plugin==e.plugin)return!1;return!0})}});class ne{constructor(e,t,n,s,r){this.id=e,this.create=t,this.domEventHandlers=n,this.domEventObservers=s,this.baseExtensions=r(this),this.extension=this.baseExtensions.concat(bi.of({plugin:this,arg:void 0}))}of(e){return this.baseExtensions.concat(bi.of({plugin:this,arg:e}))}static define(e,t){const{eventHandlers:n,eventObservers:s,provide:r,decorations:o}=t||{};return new ne(Tm++,e,n,s,l=>{let a=[];return o&&a.push(gn.of(h=>{let c=h.plugin(l);return c?o(c):D.none})),r&&a.push(r(l)),a})}static fromClass(e,t){return ne.define((n,s)=>new e(n,s),t)}}class xr{constructor(e){this.spec=e,this.mustUpdate=null,this.value=null}get plugin(){return this.spec&&this.spec.plugin}update(e){if(this.value){if(this.mustUpdate){let t=this.mustUpdate;if(this.mustUpdate=null,this.value.update)try{this.value.update(t)}catch(n){if(ve(t.state,n,"CodeMirror plugin crashed"),this.value.destroy)try{this.value.destroy()}catch{}this.deactivate()}}}else if(this.spec)try{this.value=this.spec.plugin.create(e,this.spec.arg)}catch(t){ve(e.state,t,"CodeMirror plugin crashed"),this.deactivate()}return this}destroy(e){var t;if(!((t=this.value)===null||t===void 0)&&t.destroy)try{this.value.destroy()}catch(n){ve(e.state,n,"CodeMirror plugin crashed")}}deactivate(){this.spec=this.value=null}}const vf=B.define(),al=B.define(),gn=B.define(),xf=B.define(),hl=B.define(),Sf=B.define();function Aa(i,e){let t=i.state.facet(Sf);if(!t.length)return t;let n=t.map(r=>r instanceof Function?r(i):r),s=[];return _.spans(n,e.from,e.to,{point(){},span(r,o,l,a){let h=r-e.from,c=o-e.from,f=s;for(let u=l.length-1;u>=0;u--,a--){let d=l[u].spec.bidiIsolate,p;if(d==null&&(d=Im(e.text,h,c)),a>0&&f.length&&(p=f[f.length-1]).to==h&&p.direction==d)p.to=c,f=p.inner;else{let m={from:h,to:c,direction:d,inner:[]};f.push(m),f=m.inner}}}}),s}const Qf=B.define();function cl(i){let e=0,t=0,n=0,s=0;for(let r of i.state.facet(Qf)){let o=r(i);o&&(o.left!=null&&(e=Math.max(e,o.left)),o.right!=null&&(t=Math.max(t,o.right)),o.top!=null&&(n=Math.max(n,o.top)),o.bottom!=null&&(s=Math.max(s,o.bottom)))}return{left:e,right:t,top:n,bottom:s}}const ji=B.define();class He{constructor(e,t,n,s){this.fromA=e,this.toA=t,this.fromB=n,this.toB=s}join(e){return new He(Math.min(this.fromA,e.fromA),Math.max(this.toA,e.toA),Math.min(this.fromB,e.fromB),Math.max(this.toB,e.toB))}addToSet(e){let t=e.length,n=this;for(;t>0;t--){let s=e[t-1];if(!(s.fromA>n.toA)){if(s.toA<n.fromA)break;n=n.join(s),e.splice(t-1,1)}}return e.splice(t,0,n),e}static extendWithRanges(e,t){if(t.length==0)return e;let n=[];for(let s=0,r=0,o=0,l=0;;s++){let a=s==e.length?null:e[s],h=o-l,c=a?a.fromB:1e9;for(;r<t.length&&t[r]<c;){let f=t[r],u=t[r+1],d=Math.max(l,f),p=Math.min(c,u);if(d<=p&&new He(d+h,p+h,d,p).addToSet(n),u>c)break;r+=2}if(!a)return n;new He(a.fromA,a.toA,a.fromB,a.toB).addToSet(n),o=a.toA,l=a.toB}}}class Qs{constructor(e,t,n){this.view=e,this.state=t,this.transactions=n,this.flags=0,this.startState=e.state,this.changes=le.empty(this.startState.doc.length);for(let r of n)this.changes=this.changes.compose(r.changes);let s=[];this.changes.iterChangedRanges((r,o,l,a)=>s.push(new He(r,o,l,a))),this.changedRanges=s}static create(e,t,n){return new Qs(e,t,n)}get viewportChanged(){return(this.flags&4)>0}get viewportMoved(){return(this.flags&8)>0}get heightChanged(){return(this.flags&2)>0}get geometryChanged(){return this.docChanged||(this.flags&18)>0}get focusChanged(){return(this.flags&1)>0}get docChanged(){return!this.changes.empty}get selectionSet(){return this.transactions.some(e=>e.selection)}get empty(){return this.flags==0&&this.transactions.length==0}}class Oa extends Y{get length(){return this.view.state.doc.length}constructor(e){super(),this.view=e,this.decorations=[],this.dynamicDecorationMap=[!1],this.domChanged=null,this.hasComposition=null,this.markedForComposition=new Set,this.editContextFormatting=D.none,this.lastCompositionAfterCursor=!1,this.minWidth=0,this.minWidthFrom=0,this.minWidthTo=0,this.impreciseAnchor=null,this.impreciseHead=null,this.forceSelection=!1,this.lastUpdate=Date.now(),this.setDOM(e.contentDOM),this.children=[new se],this.children[0].setParent(this),this.updateDeco(),this.updateInner([new He(0,0,0,e.state.doc.length)],0,null)}update(e){var t;let n=e.changedRanges;this.minWidth>0&&n.length&&(n.every(({fromA:h,toA:c})=>c<this.minWidthFrom||h>this.minWidthTo)?(this.minWidthFrom=e.changes.mapPos(this.minWidthFrom,1),this.minWidthTo=e.changes.mapPos(this.minWidthTo,1)):this.minWidth=this.minWidthFrom=this.minWidthTo=0),this.updateEditContextFormatting(e);let s=-1;this.view.inputState.composing>=0&&!this.view.observer.editContext&&(!((t=this.domChanged)===null||t===void 0)&&t.newSel?s=this.domChanged.newSel.head:!zm(e.changes,this.hasComposition)&&!e.selectionSet&&(s=e.state.selection.main.head));let r=s>-1?Lm(this.view,e.changes,s):null;if(this.domChanged=null,this.hasComposition){this.markedForComposition.clear();let{from:h,to:c}=this.hasComposition;n=new He(h,c,e.changes.mapPos(h,-1),e.changes.mapPos(c,1)).addToSet(n.slice())}this.hasComposition=r?{from:r.range.fromB,to:r.range.toB}:null,(E.ie||E.chrome)&&!r&&e&&e.state.doc.lines!=e.startState.doc.lines&&(this.forceSelection=!0);let o=this.decorations,l=this.updateDeco(),a=Fm(o,l,e.changes);return n=He.extendWithRanges(n,a),!(this.flags&7)&&n.length==0?!1:(this.updateInner(n,e.startState.doc.length,r),e.transactions.length&&(this.lastUpdate=Date.now()),!0)}updateInner(e,t,n){this.view.viewState.mustMeasureContent=!0,this.updateChildren(e,t,n);let{observer:s}=this.view;s.ignore(()=>{this.dom.style.height=this.view.viewState.contentHeight/this.view.scaleY+"px",this.dom.style.flexBasis=this.minWidth?this.minWidth+"px":"";let o=E.chrome||E.ios?{node:s.selectionRange.focusNode,written:!1}:void 0;this.sync(this.view,o),this.flags&=-8,o&&(o.written||s.selectionRange.focusNode!=o.node)&&(this.forceSelection=!0),this.dom.style.height=""}),this.markedForComposition.forEach(o=>o.flags&=-9);let r=[];if(this.view.viewport.from||this.view.viewport.to<this.view.state.doc.length)for(let o of this.children)o instanceof St&&o.widget instanceof wo&&r.push(o.dom);s.updateGaps(r)}updateChildren(e,t,n){let s=n?n.range.addToSet(e.slice()):e,r=this.childCursor(t);for(let o=s.length-1;;o--){let l=o>=0?s[o]:null;if(!l)break;let{fromA:a,toA:h,fromB:c,toB:f}=l,u,d,p,m;if(n&&n.range.fromB<f&&n.range.toB>c){let v=rn.build(this.view.state.doc,c,n.range.fromB,this.decorations,this.dynamicDecorationMap),y=rn.build(this.view.state.doc,n.range.toB,f,this.decorations,this.dynamicDecorationMap);d=v.breakAtStart,p=v.openStart,m=y.openEnd;let C=this.compositionView(n);y.breakAtStart?C.breakAfter=1:y.content.length&&C.merge(C.length,C.length,y.content[0],!1,y.openStart,0)&&(C.breakAfter=y.content[0].breakAfter,y.content.shift()),v.content.length&&C.merge(0,0,v.content[v.content.length-1],!0,0,v.openEnd)&&v.content.pop(),u=v.content.concat(C).concat(y.content)}else({content:u,breakAtStart:d,openStart:p,openEnd:m}=rn.build(this.view.state.doc,c,f,this.decorations,this.dynamicDecorationMap));let{i:g,off:O}=r.findPos(h,1),{i:w,off:k}=r.findPos(a,-1);ef(this,w,k,g,O,u,d,p,m)}n&&this.fixCompositionDOM(n)}updateEditContextFormatting(e){this.editContextFormatting=this.editContextFormatting.map(e.changes);for(let t of e.transactions)for(let n of t.effects)n.is(Cf)&&(this.editContextFormatting=n.value)}compositionView(e){let t=new it(e.text.nodeValue);t.flags|=8;for(let{deco:s}of e.marks)t=new Et(s,[t],t.length);let n=new se;return n.append(t,0),n}fixCompositionDOM(e){let t=(r,o)=>{o.flags|=8|(o.children.some(a=>a.flags&7)?1:0),this.markedForComposition.add(o);let l=Y.get(r);l&&l!=o&&(l.dom=null),o.setDOM(r)},n=this.childPos(e.range.fromB,1),s=this.children[n.i];t(e.line,s);for(let r=e.marks.length-1;r>=-1;r--)n=s.childPos(n.off,1),s=s.children[n.i],t(r>=0?e.marks[r].node:e.text,s)}updateSelection(e=!1,t=!1){(e||!this.view.observer.selectionRange.focusNode)&&this.view.observer.readSelectionRange();let n=this.view.root.activeElement,s=n==this.dom,r=!s&&!(this.view.state.facet(xt)||this.dom.tabIndex>-1)&&ds(this.dom,this.view.observer.selectionRange)&&!(n&&this.dom.contains(n));if(!(s||t||r))return;let o=this.forceSelection;this.forceSelection=!1;let l=this.view.state.selection.main,a=this.moveToLine(this.domAtPos(l.anchor)),h=l.empty?a:this.moveToLine(this.domAtPos(l.head));if(E.gecko&&l.empty&&!this.hasComposition&&Rm(a)){let f=document.createTextNode("");this.view.observer.ignore(()=>a.node.insertBefore(f,a.node.childNodes[a.offset]||null)),a=h=new be(f,0),o=!0}let c=this.view.observer.selectionRange;(o||!c.focusNode||(!sn(a.node,a.offset,c.anchorNode,c.anchorOffset)||!sn(h.node,h.offset,c.focusNode,c.focusOffset))&&!this.suppressWidgetCursorChange(c,l))&&(this.view.observer.ignore(()=>{E.android&&E.chrome&&this.dom.contains(c.focusNode)&&Km(c.focusNode,this.dom)&&(this.dom.blur(),this.dom.focus({preventScroll:!0}));let f=pn(this.view.root);if(f)if(l.empty){if(E.gecko){let u=Nm(a.node,a.offset);if(u&&u!=3){let d=(u==1?jc:Jc)(a.node,a.offset);d&&(a=new be(d.node,d.offset))}}f.collapse(a.node,a.offset),l.bidiLevel!=null&&f.caretBidiLevel!==void 0&&(f.caretBidiLevel=l.bidiLevel)}else if(f.extend){f.collapse(a.node,a.offset);try{f.extend(h.node,h.offset)}catch{}}else{let u=document.createRange();l.anchor>l.head&&([a,h]=[h,a]),u.setEnd(h.node,h.offset),u.setStart(a.node,a.offset),f.removeAllRanges(),f.addRange(u)}r&&this.view.root.activeElement==this.dom&&(this.dom.blur(),n&&n.focus())}),this.view.observer.setSelectionRange(a,h)),this.impreciseAnchor=a.precise?null:new be(c.anchorNode,c.anchorOffset),this.impreciseHead=h.precise?null:new be(c.focusNode,c.focusOffset)}suppressWidgetCursorChange(e,t){return this.hasComposition&&t.empty&&sn(e.focusNode,e.focusOffset,e.anchorNode,e.anchorOffset)&&this.posFromDOM(e.focusNode,e.focusOffset)==t.head}enforceCursorAssoc(){if(this.hasComposition)return;let{view:e}=this,t=e.state.selection.main,n=pn(e.root),{anchorNode:s,anchorOffset:r}=e.observer.selectionRange;if(!n||!t.empty||!t.assoc||!n.modify)return;let o=se.find(this,t.head);if(!o)return;let l=o.posAtStart;if(t.head==l||t.head==l+o.length)return;let a=this.coordsAt(t.head,-1),h=this.coordsAt(t.head,1);if(!a||!h||a.bottom>h.top)return;let c=this.domAtPos(t.head+t.assoc);n.collapse(c.node,c.offset),n.modify("move",t.assoc<0?"forward":"backward","lineboundary"),e.observer.readSelectionRange();let f=e.observer.selectionRange;e.docView.posFromDOM(f.anchorNode,f.anchorOffset)!=t.from&&n.collapse(s,r)}moveToLine(e){let t=this.dom,n;if(e.node!=t)return e;for(let s=e.offset;!n&&s<t.childNodes.length;s++){let r=Y.get(t.childNodes[s]);r instanceof se&&(n=r.domAtPos(0))}for(let s=e.offset-1;!n&&s>=0;s--){let r=Y.get(t.childNodes[s]);r instanceof se&&(n=r.domAtPos(r.length))}return n?new be(n.node,n.offset,!0):e}nearest(e){for(let t=e;t;){let n=Y.get(t);if(n&&n.rootView==this)return n;t=t.parentNode}return null}posFromDOM(e,t){let n=this.nearest(e);if(!n)throw new RangeError("Trying to find position for a DOM position outside of the document");return n.localPosFromDOM(e,t)+n.posAtStart}domAtPos(e){let{i:t,off:n}=this.childCursor().findPos(e,-1);for(;t<this.children.length-1;){let s=this.children[t];if(n<s.length||s instanceof se)break;t++,n=0}return this.children[t].domAtPos(n)}coordsAt(e,t){let n=null,s=0;for(let r=this.length,o=this.children.length-1;o>=0;o--){let l=this.children[o],a=r-l.breakAfter,h=a-l.length;if(a<e)break;if(h<=e&&(h<e||l.covers(-1))&&(a>e||l.covers(1))&&(!n||l instanceof se&&!(n instanceof se&&t>=0)))n=l,s=h;else if(n&&h==e&&a==e&&l instanceof St&&Math.abs(t)<2){if(l.deco.startSide<0)break;o&&(n=null)}r=h}return n?n.coordsAt(e-s,t):null}coordsForChar(e){let{i:t,off:n}=this.childPos(e,1),s=this.children[t];if(!(s instanceof se))return null;for(;s.children.length;){let{i:l,off:a}=s.childPos(n,1);for(;;l++){if(l==s.children.length)return null;if((s=s.children[l]).length)break}n=a}if(!(s instanceof it))return null;let r=me(s.text,n);if(r==n)return null;let o=hi(s.dom,n,r).getClientRects();for(let l=0;l<o.length;l++){let a=o[l];if(l==o.length-1||a.top<a.bottom&&a.left<a.right)return a}return null}measureVisibleLineHeights(e){let t=[],{from:n,to:s}=e,r=this.view.contentDOM.clientWidth,o=r>Math.max(this.view.scrollDOM.clientWidth,this.minWidth)+1,l=-1,a=this.view.textDirection==Z.LTR;for(let h=0,c=0;c<this.children.length;c++){let f=this.children[c],u=h+f.length;if(u>s)break;if(h>=n){let d=f.dom.getBoundingClientRect();if(t.push(d.height),o){let p=f.dom.lastChild,m=p?mn(p):[];if(m.length){let g=m[m.length-1],O=a?g.right-d.left:d.right-g.left;O>l&&(l=O,this.minWidth=r,this.minWidthFrom=h,this.minWidthTo=u)}}}h=u+f.breakAfter}return t}textDirectionAt(e){let{i:t}=this.childPos(e,1);return getComputedStyle(this.children[t].dom).direction=="rtl"?Z.RTL:Z.LTR}measureTextSize(){for(let r of this.children)if(r instanceof se){let o=r.measureTextSize();if(o)return o}let e=document.createElement("div"),t,n,s;return e.className="cm-line",e.style.width="99999px",e.style.position="absolute",e.textContent="abc def ghi jkl mno pqr stu",this.view.observer.ignore(()=>{this.dom.appendChild(e);let r=mn(e.firstChild)[0];t=e.getBoundingClientRect().height,n=r?r.width/27:7,s=r?r.height:t,e.remove()}),{lineHeight:t,charWidth:n,textHeight:s}}childCursor(e=this.length){let t=this.children.length;return t&&(e-=this.children[--t].length),new Zc(this.children,e,t)}computeBlockGapDeco(){let e=[],t=this.view.viewState;for(let n=0,s=0;;s++){let r=s==t.viewports.length?null:t.viewports[s],o=r?r.from-1:this.length;if(o>n){let l=(t.lineBlockAt(o).bottom-t.lineBlockAt(n).top)/this.view.scaleY;e.push(D.replace({widget:new wo(l),block:!0,inclusive:!0,isBlockGap:!0}).range(n,o))}if(!r)break;n=r.to+1}return D.set(e)}updateDeco(){let e=1,t=this.view.state.facet(gn).map(r=>(this.dynamicDecorationMap[e++]=typeof r=="function")?r(this.view):r),n=!1,s=this.view.state.facet(xf).map((r,o)=>{let l=typeof r=="function";return l&&(n=!0),l?r(this.view):r});for(s.length&&(this.dynamicDecorationMap[e++]=n,t.push(_.join(s))),this.decorations=[this.editContextFormatting,...t,this.computeBlockGapDeco(),this.view.viewState.lineGapDeco];e<this.decorations.length;)this.dynamicDecorationMap[e++]=!1;return this.decorations}scrollIntoView(e){if(e.isSnapshot){let h=this.view.viewState.lineBlockAt(e.range.head);this.view.scrollDOM.scrollTop=h.top-e.yMargin,this.view.scrollDOM.scrollLeft=e.xMargin;return}for(let h of this.view.state.facet(kf))try{if(h(this.view,e.range,e))return!0}catch(c){ve(this.view.state,c,"scroll handler")}let{range:t}=e,n=this.coordsAt(t.head,t.empty?t.assoc:t.head>t.anchor?-1:1),s;if(!n)return;!t.empty&&(s=this.coordsAt(t.anchor,t.anchor>t.head?-1:1))&&(n={left:Math.min(n.left,s.left),top:Math.min(n.top,s.top),right:Math.max(n.right,s.right),bottom:Math.max(n.bottom,s.bottom)});let r=cl(this.view),o={left:n.left-r.left,top:n.top-r.top,right:n.right+r.right,bottom:n.bottom+r.bottom},{offsetWidth:l,offsetHeight:a}=this.view.scrollDOM;dm(this.view.scrollDOM,o,t.head<t.anchor?-1:1,e.x,e.y,Math.max(Math.min(e.xMargin,l),-l),Math.max(Math.min(e.yMargin,a),-a),this.view.textDirection==Z.LTR)}}function Rm(i){return i.node.nodeType==1&&i.node.firstChild&&(i.offset==0||i.node.childNodes[i.offset-1].contentEditable=="false")&&(i.offset==i.node.childNodes.length||i.node.childNodes[i.offset].contentEditable=="false")}function Ef(i,e){let t=i.observer.selectionRange;if(!t.focusNode)return null;let n=jc(t.focusNode,t.focusOffset),s=Jc(t.focusNode,t.focusOffset),r=n||s;if(s&&n&&s.node!=n.node){let l=Y.get(s.node);if(!l||l instanceof it&&l.text!=s.node.nodeValue)r=s;else if(i.docView.lastCompositionAfterCursor){let a=Y.get(n.node);!a||a instanceof it&&a.text!=n.node.nodeValue||(r=s)}}if(i.docView.lastCompositionAfterCursor=r!=n,!r)return null;let o=e-r.offset;return{from:o,to:o+r.node.nodeValue.length,node:r.node}}function Lm(i,e,t){let n=Ef(i,t);if(!n)return null;let{node:s,from:r,to:o}=n,l=s.nodeValue;if(/[\n\r]/.test(l)||i.state.doc.sliceString(n.from,n.to)!=l)return null;let a=e.invertedDesc,h=new He(a.mapPos(r),a.mapPos(o),r,o),c=[];for(let f=s.parentNode;;f=f.parentNode){let u=Y.get(f);if(u instanceof Et)c.push({node:f,deco:u.mark});else{if(u instanceof se||f.nodeName=="DIV"&&f.parentNode==i.contentDOM)return{range:h,text:s,marks:c,line:f};if(f!=i.contentDOM)c.push({node:f,deco:new En({inclusive:!0,attributes:Cm(f),tagName:f.tagName.toLowerCase()})});else return null}}}function Nm(i,e){return i.nodeType!=1?0:(e&&i.childNodes[e-1].contentEditable=="false"?1:0)|(e<i.childNodes.length&&i.childNodes[e].contentEditable=="false"?2:0)}let $m=class{constructor(){this.changes=[]}compareRange(e,t){ps(e,t,this.changes)}comparePoint(e,t){ps(e,t,this.changes)}boundChange(e){ps(e,e,this.changes)}};function Fm(i,e,t){let n=new $m;return _.compare(i,e,t,n),n.changes}function Km(i,e){for(let t=i;t&&t!=e;t=t.assignedSlot||t.parentNode)if(t.nodeType==1&&t.contentEditable=="false")return!0;return!1}function zm(i,e){let t=!1;return e&&i.iterChangedRanges((n,s)=>{n<e.to&&s>e.from&&(t=!0)}),t}function _m(i,e,t=1){let n=i.charCategorizer(e),s=i.doc.lineAt(e),r=e-s.from;if(s.length==0)return b.cursor(e);r==0?t=1:r==s.length&&(t=-1);let o=r,l=r;t<0?o=me(s.text,r,!1):l=me(s.text,r);let a=n(s.text.slice(o,l));for(;o>0;){let h=me(s.text,o,!1);if(n(s.text.slice(h,o))!=a)break;o=h}for(;l<s.length;){let h=me(s.text,l);if(n(s.text.slice(l,h))!=a)break;l=h}return b.range(o+s.from,l+s.from)}function Vm(i,e){return e.left>i?e.left-i:Math.max(0,i-e.right)}function Wm(i,e){return e.top>i?e.top-i:Math.max(0,i-e.bottom)}function Sr(i,e){return i.top<e.bottom-1&&i.bottom>e.top+1}function ba(i,e){return e<i.top?{top:e,left:i.left,right:i.right,bottom:i.bottom}:i}function wa(i,e){return e>i.bottom?{top:i.top,left:i.left,right:i.right,bottom:e}:i}function xo(i,e,t){let n,s,r,o,l=!1,a,h,c,f;for(let p=i.firstChild;p;p=p.nextSibling){let m=mn(p);for(let g=0;g<m.length;g++){let O=m[g];s&&Sr(s,O)&&(O=ba(wa(O,s.bottom),s.top));let w=Vm(e,O),k=Wm(t,O);if(w==0&&k==0)return p.nodeType==3?ya(p,e,t):xo(p,e,t);(!n||o>k||o==k&&r>w)&&(n=p,s=O,r=w,o=k,l=w?e<O.left?g>0:g<m.length-1:!0),w==0?t>O.bottom&&(!c||c.bottom<O.bottom)?(a=p,c=O):t<O.top&&(!f||f.top>O.top)&&(h=p,f=O):c&&Sr(c,O)?c=wa(c,O.bottom):f&&Sr(f,O)&&(f=ba(f,O.top))}}if(c&&c.bottom>=t?(n=a,s=c):f&&f.top<=t&&(n=h,s=f),!n)return{node:i,offset:0};let u=Math.max(s.left,Math.min(s.right,e));if(n.nodeType==3)return ya(n,u,t);if(l&&n.contentEditable!="false")return xo(n,u,t);let d=Array.prototype.indexOf.call(i.childNodes,n)+(e>=(s.left+s.right)/2?1:0);return{node:i,offset:d}}function ya(i,e,t){let n=i.nodeValue.length,s=-1,r=1e9,o=0;for(let l=0;l<n;l++){let a=hi(i,l,l+1).getClientRects();for(let h=0;h<a.length;h++){let c=a[h];if(c.top==c.bottom)continue;o||(o=e-c.left);let f=(c.top>t?c.top-t:t-c.bottom)-1;if(c.left-1<=e&&c.right+1>=e&&f<r){let u=e>=(c.left+c.right)/2,d=u;if((E.chrome||E.gecko)&&hi(i,l).getBoundingClientRect().left==c.right&&(d=!u),f<=0)return{node:i,offset:l+(d?1:0)};s=l+(d?1:0),r=f}}}return{node:i,offset:s>-1?s:o>0?i.nodeValue.length:0}}function Bf(i,e,t,n=-1){var s,r;let o=i.contentDOM.getBoundingClientRect(),l=o.top+i.viewState.paddingTop,a,{docHeight:h}=i.viewState,{x:c,y:f}=e,u=f-l;if(u<0)return 0;if(u>h)return i.state.doc.length;for(let v=i.viewState.heightOracle.textHeight/2,y=!1;a=i.elementAtHeight(u),a.type!=xe.Text;)for(;u=n>0?a.bottom+v:a.top-v,!(u>=0&&u<=h);){if(y)return t?null:0;y=!0,n=-n}f=l+u;let d=a.from;if(d<i.viewport.from)return i.viewport.from==0?0:t?null:ka(i,o,a,c,f);if(d>i.viewport.to)return i.viewport.to==i.state.doc.length?i.state.doc.length:t?null:ka(i,o,a,c,f);let p=i.dom.ownerDocument,m=i.root.elementFromPoint?i.root:p,g=m.elementFromPoint(c,f);g&&!i.contentDOM.contains(g)&&(g=null),g||(c=Math.max(o.left+1,Math.min(o.right-1,c)),g=m.elementFromPoint(c,f),g&&!i.contentDOM.contains(g)&&(g=null));let O,w=-1;if(g&&((s=i.docView.nearest(g))===null||s===void 0?void 0:s.isEditable)!=!1){if(p.caretPositionFromPoint){let v=p.caretPositionFromPoint(c,f);v&&({offsetNode:O,offset:w}=v)}else if(p.caretRangeFromPoint){let v=p.caretRangeFromPoint(c,f);v&&({startContainer:O,startOffset:w}=v,(!i.contentDOM.contains(O)||E.safari&&Hm(O,w,c)||E.chrome&&qm(O,w,c))&&(O=void 0))}O&&(w=Math.min(bt(O),w))}if(!O||!i.docView.dom.contains(O)){let v=se.find(i.docView,d);if(!v)return u>a.top+a.height/2?a.to:a.from;({node:O,offset:w}=xo(v.dom,c,f))}let k=i.docView.nearest(O);if(!k)return null;if(k.isWidget&&((r=k.dom)===null||r===void 0?void 0:r.nodeType)==1){let v=k.dom.getBoundingClientRect();return e.y<v.top||e.y<=v.bottom&&e.x<=(v.left+v.right)/2?k.posAtStart:k.posAtEnd}else return k.localPosFromDOM(O,w)+k.posAtStart}function ka(i,e,t,n,s){let r=Math.round((n-e.left)*i.defaultCharacterWidth);if(i.lineWrapping&&t.height>i.defaultLineHeight*1.5){let l=i.viewState.heightOracle.textHeight,a=Math.floor((s-t.top-(i.defaultLineHeight-l)*.5)/l);r+=a*i.viewState.heightOracle.lineLength}let o=i.state.sliceDoc(t.from,t.to);return t.from+co(o,r,i.state.tabSize)}function Hm(i,e,t){let n,s=i;if(i.nodeType!=3||e!=(n=i.nodeValue.length))return!1;for(;;){let r=s.nextSibling;if(r){if(r.nodeName=="BR")break;return!1}else{let o=s.parentNode;if(!o||o.nodeName=="DIV")break;s=o}}return hi(i,n-1,n).getBoundingClientRect().right>t}function qm(i,e,t){if(e!=0)return!1;for(let s=i;;){let r=s.parentNode;if(!r||r.nodeType!=1||r.firstChild!=s)return!1;if(r.classList.contains("cm-line"))break;s=r}let n=i.nodeType==1?i.getBoundingClientRect():hi(i,0,Math.max(i.nodeValue.length,1)).getBoundingClientRect();return t-n.left>5}function So(i,e,t){let n=i.lineBlockAt(e);if(Array.isArray(n.type)){let s;for(let r of n.type){if(r.from>e)break;if(!(r.to<e)){if(r.from<e&&r.to>e)return r;(!s||r.type==xe.Text&&(s.type!=r.type||(t<0?r.from<e:r.to>e)))&&(s=r)}}return s||n}return n}function Gm(i,e,t,n){let s=So(i,e.head,e.assoc||-1),r=!n||s.type!=xe.Text||!(i.lineWrapping||s.widgetLineBreaks)?null:i.coordsAtPos(e.assoc<0&&e.head>s.from?e.head-1:e.head);if(r){let o=i.dom.getBoundingClientRect(),l=i.textDirectionAt(s.from),a=i.posAtCoords({x:t==(l==Z.LTR)?o.right-1:o.left+1,y:(r.top+r.bottom)/2});if(a!=null)return b.cursor(a,t?-1:1)}return b.cursor(t?s.to:s.from,t?-1:1)}function Ca(i,e,t,n){let s=i.state.doc.lineAt(e.head),r=i.bidiSpans(s),o=i.textDirectionAt(s.from);for(let l=e,a=null;;){let h=Dm(s,r,o,l,t),c=df;if(!h){if(s.number==(t?i.state.doc.lines:1))return l;c=`
8
+ `,s=i.state.doc.line(s.number+(t?1:-1)),r=i.bidiSpans(s),h=i.visualLineSide(s,!t)}if(a){if(!a(c))return l}else{if(!n)return h;a=n(c)}l=h}}function Um(i,e,t){let n=i.state.charCategorizer(e),s=n(t);return r=>{let o=n(r);return s==ee.Space&&(s=o),s==o}}function Ym(i,e,t,n){let s=e.head,r=t?1:-1;if(s==(t?i.state.doc.length:0))return b.cursor(s,e.assoc);let o=e.goalColumn,l,a=i.contentDOM.getBoundingClientRect(),h=i.coordsAtPos(s,e.assoc||-1),c=i.documentTop;if(h)o==null&&(o=h.left-a.left),l=r<0?h.top:h.bottom;else{let d=i.viewState.lineBlockAt(s);o==null&&(o=Math.min(a.right-a.left,i.defaultCharacterWidth*(s-d.from))),l=(r<0?d.top:d.bottom)+c}let f=a.left+o,u=n??i.viewState.heightOracle.textHeight>>1;for(let d=0;;d+=10){let p=l+(u+d)*r,m=Bf(i,{x:f,y:p},!1,r);if(p<a.top||p>a.bottom||(r<0?m<s:m>s)){let g=i.docView.coordsForChar(m),O=!g||p<g.top?-1:1;return b.cursor(m,O,void 0,o)}}}function ms(i,e,t){for(;;){let n=0;for(let s of i)s.between(e-1,e+1,(r,o,l)=>{if(e>r&&e<o){let a=n||t||(e-r<o-e?-1:1);e=a<0?r:o,n=a}});if(!n)return e}}function Qr(i,e,t){let n=ms(i.state.facet(hl).map(s=>s(i)),t.from,e.head>t.from?-1:1);return n==t.from?t:b.cursor(n,n<t.from?1:-1)}const Ji="￿";class Xm{constructor(e,t){this.points=e,this.text="",this.lineSeparator=t.facet(K.lineSeparator)}append(e){this.text+=e}lineBreak(){this.text+=Ji}readRange(e,t){if(!e)return this;let n=e.parentNode;for(let s=e;;){this.findPointBefore(n,s);let r=this.text.length;this.readNode(s);let o=s.nextSibling;if(o==t)break;let l=Y.get(s),a=Y.get(o);(l&&a?l.breakAfter:(l?l.breakAfter:xs(s))||xs(o)&&(s.nodeName!="BR"||s.cmIgnore)&&this.text.length>r)&&this.lineBreak(),s=o}return this.findPointBefore(n,t),this}readTextNode(e){let t=e.nodeValue;for(let n of this.points)n.node==e&&(n.pos=this.text.length+Math.min(n.offset,t.length));for(let n=0,s=this.lineSeparator?null:/\r\n?|\n/g;;){let r=-1,o=1,l;if(this.lineSeparator?(r=t.indexOf(this.lineSeparator,n),o=this.lineSeparator.length):(l=s.exec(t))&&(r=l.index,o=l[0].length),this.append(t.slice(n,r<0?t.length:r)),r<0)break;if(this.lineBreak(),o>1)for(let a of this.points)a.node==e&&a.pos>this.text.length&&(a.pos-=o-1);n=r+o}}readNode(e){if(e.cmIgnore)return;let t=Y.get(e),n=t&&t.overrideDOMText;if(n!=null){this.findPointInside(e,n.length);for(let s=n.iter();!s.next().done;)s.lineBreak?this.lineBreak():this.append(s.value)}else e.nodeType==3?this.readTextNode(e):e.nodeName=="BR"?e.nextSibling&&this.lineBreak():e.nodeType==1&&this.readRange(e.firstChild,null)}findPointBefore(e,t){for(let n of this.points)n.node==e&&e.childNodes[n.offset]==t&&(n.pos=this.text.length)}findPointInside(e,t){for(let n of this.points)(e.nodeType==3?n.node==e:e.contains(n.node))&&(n.pos=this.text.length+(jm(e,n.node,n.offset)?t:0))}}function jm(i,e,t){for(;;){if(!e||t<bt(e))return!1;if(e==i)return!0;t=ai(e)+1,e=e.parentNode}}class va{constructor(e,t){this.node=e,this.offset=t,this.pos=-1}}class Jm{constructor(e,t,n,s){this.typeOver=s,this.bounds=null,this.text="",this.domChanged=t>-1;let{impreciseHead:r,impreciseAnchor:o}=e.docView;if(e.state.readOnly&&t>-1)this.newSel=null;else if(t>-1&&(this.bounds=e.docView.domBoundsAround(t,n,0))){let l=r||o?[]:tg(e),a=new Xm(l,e.state);a.readRange(this.bounds.startDOM,this.bounds.endDOM),this.text=a.text,this.newSel=ig(l,this.bounds.from)}else{let l=e.observer.selectionRange,a=r&&r.node==l.focusNode&&r.offset==l.focusOffset||!po(e.contentDOM,l.focusNode)?e.state.selection.main.head:e.docView.posFromDOM(l.focusNode,l.focusOffset),h=o&&o.node==l.anchorNode&&o.offset==l.anchorOffset||!po(e.contentDOM,l.anchorNode)?e.state.selection.main.anchor:e.docView.posFromDOM(l.anchorNode,l.anchorOffset),c=e.viewport;if((E.ios||E.chrome)&&e.state.selection.main.empty&&a!=h&&(c.from>0||c.to<e.state.doc.length)){let f=Math.min(a,h),u=Math.max(a,h),d=c.from-f,p=c.to-u;(d==0||d==1||f==0)&&(p==0||p==-1||u==e.state.doc.length)&&(a=0,h=e.state.doc.length)}this.newSel=b.single(h,a)}}}function Pf(i,e){let t,{newSel:n}=e,s=i.state.selection.main,r=i.inputState.lastKeyTime>Date.now()-100?i.inputState.lastKeyCode:-1;if(e.bounds){let{from:o,to:l}=e.bounds,a=s.from,h=null;(r===8||E.android&&e.text.length<l-o)&&(a=s.to,h="end");let c=eg(i.state.doc.sliceString(o,l,Ji),e.text,a-o,h);c&&(E.chrome&&r==13&&c.toB==c.from+2&&e.text.slice(c.from,c.toB)==Ji+Ji&&c.toB--,t={from:o+c.from,to:o+c.toA,insert:$.of(e.text.slice(c.from,c.toB).split(Ji))})}else n&&(!i.hasFocus&&i.state.facet(xt)||n.main.eq(s))&&(n=null);if(!t&&!n)return!1;if(!t&&e.typeOver&&!s.empty&&n&&n.main.empty?t={from:s.from,to:s.to,insert:i.state.doc.slice(s.from,s.to)}:(E.mac||E.android)&&t&&t.from==t.to&&t.from==s.head-1&&/^\. ?$/.test(t.insert.toString())&&i.contentDOM.getAttribute("autocorrect")=="off"?(n&&t.insert.length==2&&(n=b.single(n.main.anchor-1,n.main.head-1)),t={from:t.from,to:t.to,insert:$.of([t.insert.toString().replace("."," ")])}):t&&t.from>=s.from&&t.to<=s.to&&(t.from!=s.from||t.to!=s.to)&&s.to-s.from-(t.to-t.from)<=4?t={from:s.from,to:s.to,insert:i.state.doc.slice(s.from,t.from).append(t.insert).append(i.state.doc.slice(t.to,s.to))}:E.chrome&&t&&t.from==t.to&&t.from==s.head&&t.insert.toString()==`
9
+ `&&i.lineWrapping&&(n&&(n=b.single(n.main.anchor-1,n.main.head-1)),t={from:s.from,to:s.to,insert:$.of([" "])}),t)return fl(i,t,n,r);if(n&&!n.main.eq(s)){let o=!1,l="select";return i.inputState.lastSelectionTime>Date.now()-50&&(i.inputState.lastSelectionOrigin=="select"&&(o=!0),l=i.inputState.lastSelectionOrigin),i.dispatch({selection:n,scrollIntoView:o,userEvent:l}),!0}else return!1}function fl(i,e,t,n=-1){if(E.ios&&i.inputState.flushIOSKey(e))return!0;let s=i.state.selection.main;if(E.android&&(e.to==s.to&&(e.from==s.from||e.from==s.from-1&&i.state.sliceDoc(e.from,s.from)==" ")&&e.insert.length==1&&e.insert.lines==2&&xi(i.contentDOM,"Enter",13)||(e.from==s.from-1&&e.to==s.to&&e.insert.length==0||n==8&&e.insert.length<e.to-e.from&&e.to>s.head)&&xi(i.contentDOM,"Backspace",8)||e.from==s.from&&e.to==s.to+1&&e.insert.length==0&&xi(i.contentDOM,"Delete",46)))return!0;let r=e.insert.toString();i.inputState.composing>=0&&i.inputState.composing++;let o,l=()=>o||(o=Zm(i,e,t));return i.state.facet(Of).some(a=>a(i,e.from,e.to,r,l))||i.dispatch(l()),!0}function Zm(i,e,t){let n,s=i.state,r=s.selection.main;if(e.from>=r.from&&e.to<=r.to&&e.to-e.from>=(r.to-r.from)/3&&(!t||t.main.empty&&t.main.from==e.from+e.insert.length)&&i.inputState.composing<0){let l=r.from<e.from?s.sliceDoc(r.from,e.from):"",a=r.to>e.to?s.sliceDoc(e.to,r.to):"";n=s.replaceSelection(i.state.toText(l+e.insert.sliceString(0,void 0,i.state.lineBreak)+a))}else{let l=s.changes(e),a=t&&t.main.to<=l.newLength?t.main:void 0;if(s.selection.ranges.length>1&&i.inputState.composing>=0&&e.to<=r.to&&e.to>=r.to-10){let h=i.state.sliceDoc(e.from,e.to),c,f=t&&Ef(i,t.main.head);if(f){let p=e.insert.length-(e.to-e.from);c={from:f.from,to:f.to-p}}else c=i.state.doc.lineAt(r.head);let u=r.to-e.to,d=r.to-r.from;n=s.changeByRange(p=>{if(p.from==r.from&&p.to==r.to)return{changes:l,range:a||p.map(l)};let m=p.to-u,g=m-h.length;if(p.to-p.from!=d||i.state.sliceDoc(g,m)!=h||p.to>=c.from&&p.from<=c.to)return{range:p};let O=s.changes({from:g,to:m,insert:e.insert}),w=p.to-r.to;return{changes:O,range:a?b.range(Math.max(0,a.anchor+w),Math.max(0,a.head+w)):p.map(O)}})}else n={changes:l,selection:a&&s.selection.replaceRange(a)}}let o="input.type";return(i.composing||i.inputState.compositionPendingChange&&i.inputState.compositionEndedAt>Date.now()-50)&&(i.inputState.compositionPendingChange=!1,o+=".compose",i.inputState.compositionFirstChange&&(o+=".start",i.inputState.compositionFirstChange=!1)),s.update(n,{userEvent:o,scrollIntoView:!0})}function eg(i,e,t,n){let s=Math.min(i.length,e.length),r=0;for(;r<s&&i.charCodeAt(r)==e.charCodeAt(r);)r++;if(r==s&&i.length==e.length)return null;let o=i.length,l=e.length;for(;o>0&&l>0&&i.charCodeAt(o-1)==e.charCodeAt(l-1);)o--,l--;if(n=="end"){let a=Math.max(0,r-Math.min(o,l));t-=o+a-r}if(o<r&&i.length<e.length){let a=t<=r&&t>=o?r-t:0;r-=a,l=r+(l-o),o=r}else if(l<r){let a=t<=r&&t>=l?r-t:0;r-=a,o=r+(o-l),l=r}return{from:r,toA:o,toB:l}}function tg(i){let e=[];if(i.root.activeElement!=i.contentDOM)return e;let{anchorNode:t,anchorOffset:n,focusNode:s,focusOffset:r}=i.observer.selectionRange;return t&&(e.push(new va(t,n)),(s!=t||r!=n)&&e.push(new va(s,r))),e}function ig(i,e){if(i.length==0)return null;let t=i[0].pos,n=i.length==2?i[1].pos:t;return t>-1&&n>-1?b.single(t+e,n+e):null}class ng{setSelectionOrigin(e){this.lastSelectionOrigin=e,this.lastSelectionTime=Date.now()}constructor(e){this.view=e,this.lastKeyCode=0,this.lastKeyTime=0,this.lastTouchTime=0,this.lastFocusTime=0,this.lastScrollTop=0,this.lastScrollLeft=0,this.pendingIOSKey=void 0,this.tabFocusMode=-1,this.lastSelectionOrigin=null,this.lastSelectionTime=0,this.lastContextMenu=0,this.scrollHandlers=[],this.handlers=Object.create(null),this.composing=-1,this.compositionFirstChange=null,this.compositionEndedAt=0,this.compositionPendingKey=!1,this.compositionPendingChange=!1,this.mouseSelection=null,this.draggedContent=null,this.handleEvent=this.handleEvent.bind(this),this.notifiedFocused=e.hasFocus,E.safari&&e.contentDOM.addEventListener("input",()=>null),E.gecko&&bg(e.contentDOM.ownerDocument)}handleEvent(e){!fg(this.view,e)||this.ignoreDuringComposition(e)||e.type=="keydown"&&this.keydown(e)||(this.view.updateState!=0?Promise.resolve().then(()=>this.runHandlers(e.type,e)):this.runHandlers(e.type,e))}runHandlers(e,t){let n=this.handlers[e];if(n){for(let s of n.observers)s(this.view,t);for(let s of n.handlers){if(t.defaultPrevented)break;if(s(this.view,t)){t.preventDefault();break}}}}ensureHandlers(e){let t=sg(e),n=this.handlers,s=this.view.contentDOM;for(let r in t)if(r!="scroll"){let o=!t[r].handlers.length,l=n[r];l&&o!=!l.handlers.length&&(s.removeEventListener(r,this.handleEvent),l=null),l||s.addEventListener(r,this.handleEvent,{passive:o})}for(let r in n)r!="scroll"&&!t[r]&&s.removeEventListener(r,this.handleEvent);this.handlers=t}keydown(e){if(this.lastKeyCode=e.keyCode,this.lastKeyTime=Date.now(),e.keyCode==9&&this.tabFocusMode>-1&&(!this.tabFocusMode||Date.now()<=this.tabFocusMode))return!0;if(this.tabFocusMode>0&&e.keyCode!=27&&Df.indexOf(e.keyCode)<0&&(this.tabFocusMode=-1),E.android&&E.chrome&&!e.synthetic&&(e.keyCode==13||e.keyCode==8))return this.view.observer.delayAndroidKey(e.key,e.keyCode),!0;let t;return E.ios&&!e.synthetic&&!e.altKey&&!e.metaKey&&((t=Mf.find(n=>n.keyCode==e.keyCode))&&!e.ctrlKey||rg.indexOf(e.key)>-1&&e.ctrlKey&&!e.shiftKey)?(this.pendingIOSKey=t||e,setTimeout(()=>this.flushIOSKey(),250),!0):(e.keyCode!=229&&this.view.observer.forceFlush(),!1)}flushIOSKey(e){let t=this.pendingIOSKey;return!t||t.key=="Enter"&&e&&e.from<e.to&&/^\S+$/.test(e.insert.toString())?!1:(this.pendingIOSKey=void 0,xi(this.view.contentDOM,t.key,t.keyCode,t instanceof KeyboardEvent?t:void 0))}ignoreDuringComposition(e){return/^key/.test(e.type)?this.composing>0?!0:E.safari&&!E.ios&&this.compositionPendingKey&&Date.now()-this.compositionEndedAt<100?(this.compositionPendingKey=!1,!0):!1:!1}startMouseSelection(e){this.mouseSelection&&this.mouseSelection.destroy(),this.mouseSelection=e}update(e){this.view.observer.update(e),this.mouseSelection&&this.mouseSelection.update(e),this.draggedContent&&e.docChanged&&(this.draggedContent=this.draggedContent.map(e.changes)),e.transactions.length&&(this.lastKeyCode=this.lastSelectionTime=0)}destroy(){this.mouseSelection&&this.mouseSelection.destroy()}}function xa(i,e){return(t,n)=>{try{return e.call(i,n,t)}catch(s){ve(t.state,s)}}}function sg(i){let e=Object.create(null);function t(n){return e[n]||(e[n]={observers:[],handlers:[]})}for(let n of i){let s=n.spec,r=s&&s.plugin.domEventHandlers,o=s&&s.plugin.domEventObservers;if(r)for(let l in r){let a=r[l];a&&t(l).handlers.push(xa(n.value,a))}if(o)for(let l in o){let a=o[l];a&&t(l).observers.push(xa(n.value,a))}}for(let n in nt)t(n).handlers.push(nt[n]);for(let n in qe)t(n).observers.push(qe[n]);return e}const Mf=[{key:"Backspace",keyCode:8,inputType:"deleteContentBackward"},{key:"Enter",keyCode:13,inputType:"insertParagraph"},{key:"Enter",keyCode:13,inputType:"insertLineBreak"},{key:"Delete",keyCode:46,inputType:"deleteContentForward"}],rg="dthko",Df=[16,17,18,20,91,92,224,225],_n=6;function Vn(i){return Math.max(0,i)*.7+8}function og(i,e){return Math.max(Math.abs(i.clientX-e.clientX),Math.abs(i.clientY-e.clientY))}class lg{constructor(e,t,n,s){this.view=e,this.startEvent=t,this.style=n,this.mustSelect=s,this.scrollSpeed={x:0,y:0},this.scrolling=-1,this.lastEvent=t,this.scrollParents=pm(e.contentDOM),this.atoms=e.state.facet(hl).map(o=>o(e));let r=e.contentDOM.ownerDocument;r.addEventListener("mousemove",this.move=this.move.bind(this)),r.addEventListener("mouseup",this.up=this.up.bind(this)),this.extend=t.shiftKey,this.multiple=e.state.facet(K.allowMultipleSelections)&&ag(e,t),this.dragging=cg(e,t)&&Rf(t)==1?null:!1}start(e){this.dragging===!1&&this.select(e)}move(e){if(e.buttons==0)return this.destroy();if(this.dragging||this.dragging==null&&og(this.startEvent,e)<10)return;this.select(this.lastEvent=e);let t=0,n=0,s=0,r=0,o=this.view.win.innerWidth,l=this.view.win.innerHeight;this.scrollParents.x&&({left:s,right:o}=this.scrollParents.x.getBoundingClientRect()),this.scrollParents.y&&({top:r,bottom:l}=this.scrollParents.y.getBoundingClientRect());let a=cl(this.view);e.clientX-a.left<=s+_n?t=-Vn(s-e.clientX):e.clientX+a.right>=o-_n&&(t=Vn(e.clientX-o)),e.clientY-a.top<=r+_n?n=-Vn(r-e.clientY):e.clientY+a.bottom>=l-_n&&(n=Vn(e.clientY-l)),this.setScrollSpeed(t,n)}up(e){this.dragging==null&&this.select(this.lastEvent),this.dragging||e.preventDefault(),this.destroy()}destroy(){this.setScrollSpeed(0,0);let e=this.view.contentDOM.ownerDocument;e.removeEventListener("mousemove",this.move),e.removeEventListener("mouseup",this.up),this.view.inputState.mouseSelection=this.view.inputState.draggedContent=null}setScrollSpeed(e,t){this.scrollSpeed={x:e,y:t},e||t?this.scrolling<0&&(this.scrolling=setInterval(()=>this.scroll(),50)):this.scrolling>-1&&(clearInterval(this.scrolling),this.scrolling=-1)}scroll(){let{x:e,y:t}=this.scrollSpeed;e&&this.scrollParents.x&&(this.scrollParents.x.scrollLeft+=e,e=0),t&&this.scrollParents.y&&(this.scrollParents.y.scrollTop+=t,t=0),(e||t)&&this.view.win.scrollBy(e,t),this.dragging===!1&&this.select(this.lastEvent)}skipAtoms(e){let t=null;for(let n=0;n<e.ranges.length;n++){let s=e.ranges[n],r=null;if(s.empty){let o=ms(this.atoms,s.from,0);o!=s.from&&(r=b.cursor(o,-1))}else{let o=ms(this.atoms,s.from,-1),l=ms(this.atoms,s.to,1);(o!=s.from||l!=s.to)&&(r=b.range(s.from==s.anchor?o:l,s.from==s.head?o:l))}r&&(t||(t=e.ranges.slice()),t[n]=r)}return t?b.create(t,e.mainIndex):e}select(e){let{view:t}=this,n=this.skipAtoms(this.style.get(e,this.extend,this.multiple));(this.mustSelect||!n.eq(t.state.selection,this.dragging===!1))&&this.view.dispatch({selection:n,userEvent:"select.pointer"}),this.mustSelect=!1}update(e){e.transactions.some(t=>t.isUserEvent("input.type"))?this.destroy():this.style.update(e)&&setTimeout(()=>this.select(this.lastEvent),20)}}function ag(i,e){let t=i.state.facet(pf);return t.length?t[0](e):E.mac?e.metaKey:e.ctrlKey}function hg(i,e){let t=i.state.facet(mf);return t.length?t[0](e):E.mac?!e.altKey:!e.ctrlKey}function cg(i,e){let{main:t}=i.state.selection;if(t.empty)return!1;let n=pn(i.root);if(!n||n.rangeCount==0)return!0;let s=n.getRangeAt(0).getClientRects();for(let r=0;r<s.length;r++){let o=s[r];if(o.left<=e.clientX&&o.right>=e.clientX&&o.top<=e.clientY&&o.bottom>=e.clientY)return!0}return!1}function fg(i,e){if(!e.bubbles)return!0;if(e.defaultPrevented)return!1;for(let t=e.target,n;t!=i.contentDOM;t=t.parentNode)if(!t||t.nodeType==11||(n=Y.get(t))&&n.ignoreEvent(e))return!1;return!0}const nt=Object.create(null),qe=Object.create(null),If=E.ie&&E.ie_version<15||E.ios&&E.webkit_version<604;function ug(i){let e=i.dom.parentNode;if(!e)return;let t=e.appendChild(document.createElement("textarea"));t.style.cssText="position: fixed; left: -10000px; top: 10px",t.focus(),setTimeout(()=>{i.focus(),t.remove(),Tf(i,t.value)},50)}function Zs(i,e,t){for(let n of i.facet(e))t=n(t,i);return t}function Tf(i,e){e=Zs(i.state,ol,e);let{state:t}=i,n,s=1,r=t.toText(e),o=r.lines==t.selection.ranges.length;if(Qo!=null&&t.selection.ranges.every(a=>a.empty)&&Qo==r.toString()){let a=-1;n=t.changeByRange(h=>{let c=t.doc.lineAt(h.from);if(c.from==a)return{range:h};a=c.from;let f=t.toText((o?r.line(s++).text:e)+t.lineBreak);return{changes:{from:c.from,insert:f},range:b.cursor(h.from+f.length)}})}else o?n=t.changeByRange(a=>{let h=r.line(s++);return{changes:{from:a.from,to:a.to,insert:h.text},range:b.cursor(a.from+h.length)}}):n=t.replaceSelection(r);i.dispatch(n,{userEvent:"input.paste",scrollIntoView:!0})}qe.scroll=i=>{i.inputState.lastScrollTop=i.scrollDOM.scrollTop,i.inputState.lastScrollLeft=i.scrollDOM.scrollLeft};nt.keydown=(i,e)=>(i.inputState.setSelectionOrigin("select"),e.keyCode==27&&i.inputState.tabFocusMode!=0&&(i.inputState.tabFocusMode=Date.now()+2e3),!1);qe.touchstart=(i,e)=>{i.inputState.lastTouchTime=Date.now(),i.inputState.setSelectionOrigin("select.pointer")};qe.touchmove=i=>{i.inputState.setSelectionOrigin("select.pointer")};nt.mousedown=(i,e)=>{if(i.observer.flush(),i.inputState.lastTouchTime>Date.now()-2e3)return!1;let t=null;for(let n of i.state.facet(gf))if(t=n(i,e),t)break;if(!t&&e.button==0&&(t=mg(i,e)),t){let n=!i.hasFocus;i.inputState.startMouseSelection(new lg(i,e,t,n)),n&&i.observer.ignore(()=>{Uc(i.contentDOM);let r=i.root.activeElement;r&&!r.contains(i.contentDOM)&&r.blur()});let s=i.inputState.mouseSelection;if(s)return s.start(e),s.dragging===!1}return!1};function Sa(i,e,t,n){if(n==1)return b.cursor(e,t);if(n==2)return _m(i.state,e,t);{let s=se.find(i.docView,e),r=i.state.doc.lineAt(s?s.posAtEnd:e),o=s?s.posAtStart:r.from,l=s?s.posAtEnd:r.to;return l<i.state.doc.length&&l==r.to&&l++,b.range(o,l)}}let Qa=(i,e,t)=>e>=t.top&&e<=t.bottom&&i>=t.left&&i<=t.right;function dg(i,e,t,n){let s=se.find(i.docView,e);if(!s)return 1;let r=e-s.posAtStart;if(r==0)return 1;if(r==s.length)return-1;let o=s.coordsAt(r,-1);if(o&&Qa(t,n,o))return-1;let l=s.coordsAt(r,1);return l&&Qa(t,n,l)?1:o&&o.bottom>=n?-1:1}function Ea(i,e){let t=i.posAtCoords({x:e.clientX,y:e.clientY},!1);return{pos:t,bias:dg(i,t,e.clientX,e.clientY)}}const pg=E.ie&&E.ie_version<=11;let Ba=null,Pa=0,Ma=0;function Rf(i){if(!pg)return i.detail;let e=Ba,t=Ma;return Ba=i,Ma=Date.now(),Pa=!e||t>Date.now()-400&&Math.abs(e.clientX-i.clientX)<2&&Math.abs(e.clientY-i.clientY)<2?(Pa+1)%3:1}function mg(i,e){let t=Ea(i,e),n=Rf(e),s=i.state.selection;return{update(r){r.docChanged&&(t.pos=r.changes.mapPos(t.pos),s=s.map(r.changes))},get(r,o,l){let a=Ea(i,r),h,c=Sa(i,a.pos,a.bias,n);if(t.pos!=a.pos&&!o){let f=Sa(i,t.pos,t.bias,n),u=Math.min(f.from,c.from),d=Math.max(f.to,c.to);c=u<c.from?b.range(u,d):b.range(d,u)}return o?s.replaceRange(s.main.extend(c.from,c.to)):l&&n==1&&s.ranges.length>1&&(h=gg(s,a.pos))?h:l?s.addRange(c):b.create([c])}}}function gg(i,e){for(let t=0;t<i.ranges.length;t++){let{from:n,to:s}=i.ranges[t];if(n<=e&&s>=e)return b.create(i.ranges.slice(0,t).concat(i.ranges.slice(t+1)),i.mainIndex==t?0:i.mainIndex-(i.mainIndex>t?1:0))}return null}nt.dragstart=(i,e)=>{let{selection:{main:t}}=i.state;if(e.target.draggable){let s=i.docView.nearest(e.target);if(s&&s.isWidget){let r=s.posAtStart,o=r+s.length;(r>=t.to||o<=t.from)&&(t=b.range(r,o))}}let{inputState:n}=i;return n.mouseSelection&&(n.mouseSelection.dragging=!0),n.draggedContent=t,e.dataTransfer&&(e.dataTransfer.setData("Text",Zs(i.state,ll,i.state.sliceDoc(t.from,t.to))),e.dataTransfer.effectAllowed="copyMove"),!1};nt.dragend=i=>(i.inputState.draggedContent=null,!1);function Da(i,e,t,n){if(t=Zs(i.state,ol,t),!t)return;let s=i.posAtCoords({x:e.clientX,y:e.clientY},!1),{draggedContent:r}=i.inputState,o=n&&r&&hg(i,e)?{from:r.from,to:r.to}:null,l={from:s,insert:t},a=i.state.changes(o?[o,l]:l);i.focus(),i.dispatch({changes:a,selection:{anchor:a.mapPos(s,-1),head:a.mapPos(s,1)},userEvent:o?"move.drop":"input.drop"}),i.inputState.draggedContent=null}nt.drop=(i,e)=>{if(!e.dataTransfer)return!1;if(i.state.readOnly)return!0;let t=e.dataTransfer.files;if(t&&t.length){let n=Array(t.length),s=0,r=()=>{++s==t.length&&Da(i,e,n.filter(o=>o!=null).join(i.state.lineBreak),!1)};for(let o=0;o<t.length;o++){let l=new FileReader;l.onerror=r,l.onload=()=>{/[\x00-\x08\x0e-\x1f]{2}/.test(l.result)||(n[o]=l.result),r()},l.readAsText(t[o])}return!0}else{let n=e.dataTransfer.getData("Text");if(n)return Da(i,e,n,!0),!0}return!1};nt.paste=(i,e)=>{if(i.state.readOnly)return!0;i.observer.flush();let t=If?null:e.clipboardData;return t?(Tf(i,t.getData("text/plain")||t.getData("text/uri-list")),!0):(ug(i),!1)};function Ag(i,e){let t=i.dom.parentNode;if(!t)return;let n=t.appendChild(document.createElement("textarea"));n.style.cssText="position: fixed; left: -10000px; top: 10px",n.value=e,n.focus(),n.selectionEnd=e.length,n.selectionStart=0,setTimeout(()=>{n.remove(),i.focus()},50)}function Og(i){let e=[],t=[],n=!1;for(let s of i.selection.ranges)s.empty||(e.push(i.sliceDoc(s.from,s.to)),t.push(s));if(!e.length){let s=-1;for(let{from:r}of i.selection.ranges){let o=i.doc.lineAt(r);o.number>s&&(e.push(o.text),t.push({from:o.from,to:Math.min(i.doc.length,o.to+1)})),s=o.number}n=!0}return{text:Zs(i,ll,e.join(i.lineBreak)),ranges:t,linewise:n}}let Qo=null;nt.copy=nt.cut=(i,e)=>{let{text:t,ranges:n,linewise:s}=Og(i.state);if(!t&&!s)return!1;Qo=s?t:null,e.type=="cut"&&!i.state.readOnly&&i.dispatch({changes:n,scrollIntoView:!0,userEvent:"delete.cut"});let r=If?null:e.clipboardData;return r?(r.clearData(),r.setData("text/plain",t),!0):(Ag(i,t),!1)};const Lf=Pt.define();function Nf(i,e){let t=[];for(let n of i.facet(bf)){let s=n(i,e);s&&t.push(s)}return t.length?i.update({effects:t,annotations:Lf.of(!0)}):null}function $f(i){setTimeout(()=>{let e=i.hasFocus;if(e!=i.inputState.notifiedFocused){let t=Nf(i.state,e);t?i.dispatch(t):i.update([])}},10)}qe.focus=i=>{i.inputState.lastFocusTime=Date.now(),!i.scrollDOM.scrollTop&&(i.inputState.lastScrollTop||i.inputState.lastScrollLeft)&&(i.scrollDOM.scrollTop=i.inputState.lastScrollTop,i.scrollDOM.scrollLeft=i.inputState.lastScrollLeft),$f(i)};qe.blur=i=>{i.observer.clearSelectionRange(),$f(i)};qe.compositionstart=qe.compositionupdate=i=>{i.observer.editContext||(i.inputState.compositionFirstChange==null&&(i.inputState.compositionFirstChange=!0),i.inputState.composing<0&&(i.inputState.composing=0))};qe.compositionend=i=>{i.observer.editContext||(i.inputState.composing=-1,i.inputState.compositionEndedAt=Date.now(),i.inputState.compositionPendingKey=!0,i.inputState.compositionPendingChange=i.observer.pendingRecords().length>0,i.inputState.compositionFirstChange=null,E.chrome&&E.android?i.observer.flushSoon():i.inputState.compositionPendingChange?Promise.resolve().then(()=>i.observer.flush()):setTimeout(()=>{i.inputState.composing<0&&i.docView.hasComposition&&i.update([])},50))};qe.contextmenu=i=>{i.inputState.lastContextMenu=Date.now()};nt.beforeinput=(i,e)=>{var t,n;if(e.inputType=="insertReplacementText"&&i.observer.editContext){let r=(t=e.dataTransfer)===null||t===void 0?void 0:t.getData("text/plain"),o=e.getTargetRanges();if(r&&o.length){let l=o[0],a=i.posAtDOM(l.startContainer,l.startOffset),h=i.posAtDOM(l.endContainer,l.endOffset);return fl(i,{from:a,to:h,insert:i.state.toText(r)},null),!0}}let s;if(E.chrome&&E.android&&(s=Mf.find(r=>r.inputType==e.inputType))&&(i.observer.delayAndroidKey(s.key,s.keyCode),s.key=="Backspace"||s.key=="Delete")){let r=((n=window.visualViewport)===null||n===void 0?void 0:n.height)||0;setTimeout(()=>{var o;(((o=window.visualViewport)===null||o===void 0?void 0:o.height)||0)>r+10&&i.hasFocus&&(i.contentDOM.blur(),i.focus())},100)}return E.ios&&e.inputType=="deleteContentForward"&&i.observer.flushSoon(),E.safari&&e.inputType=="insertText"&&i.inputState.composing>=0&&setTimeout(()=>qe.compositionend(i,e),20),!1};const Ia=new Set;function bg(i){Ia.has(i)||(Ia.add(i),i.addEventListener("copy",()=>{}),i.addEventListener("cut",()=>{}))}const Ta=["pre-wrap","normal","pre-line","break-spaces"];let Ti=!1;function Ra(){Ti=!1}class wg{constructor(e){this.lineWrapping=e,this.doc=$.empty,this.heightSamples={},this.lineHeight=14,this.charWidth=7,this.textHeight=14,this.lineLength=30}heightForGap(e,t){let n=this.doc.lineAt(t).number-this.doc.lineAt(e).number+1;return this.lineWrapping&&(n+=Math.max(0,Math.ceil((t-e-n*this.lineLength*.5)/this.lineLength))),this.lineHeight*n}heightForLine(e){return this.lineWrapping?(1+Math.max(0,Math.ceil((e-this.lineLength)/(this.lineLength-5))))*this.lineHeight:this.lineHeight}setDoc(e){return this.doc=e,this}mustRefreshForWrapping(e){return Ta.indexOf(e)>-1!=this.lineWrapping}mustRefreshForHeights(e){let t=!1;for(let n=0;n<e.length;n++){let s=e[n];s<0?n++:this.heightSamples[Math.floor(s*10)]||(t=!0,this.heightSamples[Math.floor(s*10)]=!0)}return t}refresh(e,t,n,s,r,o){let l=Ta.indexOf(e)>-1,a=Math.round(t)!=Math.round(this.lineHeight)||this.lineWrapping!=l;if(this.lineWrapping=l,this.lineHeight=t,this.charWidth=n,this.textHeight=s,this.lineLength=r,a){this.heightSamples={};for(let h=0;h<o.length;h++){let c=o[h];c<0?h++:this.heightSamples[Math.floor(c*10)]=!0}}return a}}class yg{constructor(e,t){this.from=e,this.heights=t,this.index=0}get more(){return this.index<this.heights.length}}class pt{constructor(e,t,n,s,r){this.from=e,this.length=t,this.top=n,this.height=s,this._content=r}get type(){return typeof this._content=="number"?xe.Text:Array.isArray(this._content)?this._content:this._content.type}get to(){return this.from+this.length}get bottom(){return this.top+this.height}get widget(){return this._content instanceof qt?this._content.widget:null}get widgetLineBreaks(){return typeof this._content=="number"?this._content:0}join(e){let t=(Array.isArray(this._content)?this._content:[this]).concat(Array.isArray(e._content)?e._content:[e]);return new pt(this.from,this.length+e.length,this.top,this.height+e.height,t)}}var j=(function(i){return i[i.ByPos=0]="ByPos",i[i.ByHeight=1]="ByHeight",i[i.ByPosNoHeight=2]="ByPosNoHeight",i})(j||(j={}));const gs=.001;class Se{constructor(e,t,n=2){this.length=e,this.height=t,this.flags=n}get outdated(){return(this.flags&2)>0}set outdated(e){this.flags=(e?2:0)|this.flags&-3}setHeight(e){this.height!=e&&(Math.abs(this.height-e)>gs&&(Ti=!0),this.height=e)}replace(e,t,n){return Se.of(n)}decomposeLeft(e,t){t.push(this)}decomposeRight(e,t){t.push(this)}applyChanges(e,t,n,s){let r=this,o=n.doc;for(let l=s.length-1;l>=0;l--){let{fromA:a,toA:h,fromB:c,toB:f}=s[l],u=r.lineAt(a,j.ByPosNoHeight,n.setDoc(t),0,0),d=u.to>=h?u:r.lineAt(h,j.ByPosNoHeight,n,0,0);for(f+=d.to-h,h=d.to;l>0&&u.from<=s[l-1].toA;)a=s[l-1].fromA,c=s[l-1].fromB,l--,a<u.from&&(u=r.lineAt(a,j.ByPosNoHeight,n,0,0));c+=u.from-a,a=u.from;let p=ul.build(n.setDoc(o),e,c,f);r=Es(r,r.replace(a,h,p))}return r.updateHeight(n,0)}static empty(){return new Le(0,0)}static of(e){if(e.length==1)return e[0];let t=0,n=e.length,s=0,r=0;for(;;)if(t==n)if(s>r*2){let l=e[t-1];l.break?e.splice(--t,1,l.left,null,l.right):e.splice(--t,1,l.left,l.right),n+=1+l.break,s-=l.size}else if(r>s*2){let l=e[n];l.break?e.splice(n,1,l.left,null,l.right):e.splice(n,1,l.left,l.right),n+=2+l.break,r-=l.size}else break;else if(s<r){let l=e[t++];l&&(s+=l.size)}else{let l=e[--n];l&&(r+=l.size)}let o=0;return e[t-1]==null?(o=1,t--):e[t]==null&&(o=1,n++),new kg(Se.of(e.slice(0,t)),o,Se.of(e.slice(n)))}}function Es(i,e){return i==e?i:(i.constructor!=e.constructor&&(Ti=!0),e)}Se.prototype.size=1;class Ff extends Se{constructor(e,t,n){super(e,t),this.deco=n}blockAt(e,t,n,s){return new pt(s,this.length,n,this.height,this.deco||0)}lineAt(e,t,n,s,r){return this.blockAt(0,n,s,r)}forEachLine(e,t,n,s,r,o){e<=r+this.length&&t>=r&&o(this.blockAt(0,n,s,r))}updateHeight(e,t=0,n=!1,s){return s&&s.from<=t&&s.more&&this.setHeight(s.heights[s.index++]),this.outdated=!1,this}toString(){return`block(${this.length})`}}class Le extends Ff{constructor(e,t){super(e,t,null),this.collapsed=0,this.widgetHeight=0,this.breaks=0}blockAt(e,t,n,s){return new pt(s,this.length,n,this.height,this.breaks)}replace(e,t,n){let s=n[0];return n.length==1&&(s instanceof Le||s instanceof de&&s.flags&4)&&Math.abs(this.length-s.length)<10?(s instanceof de?s=new Le(s.length,this.height):s.height=this.height,this.outdated||(s.outdated=!1),s):Se.of(n)}updateHeight(e,t=0,n=!1,s){return s&&s.from<=t&&s.more?this.setHeight(s.heights[s.index++]):(n||this.outdated)&&this.setHeight(Math.max(this.widgetHeight,e.heightForLine(this.length-this.collapsed))+this.breaks*e.lineHeight),this.outdated=!1,this}toString(){return`line(${this.length}${this.collapsed?-this.collapsed:""}${this.widgetHeight?":"+this.widgetHeight:""})`}}class de extends Se{constructor(e){super(e,0)}heightMetrics(e,t){let n=e.doc.lineAt(t).number,s=e.doc.lineAt(t+this.length).number,r=s-n+1,o,l=0;if(e.lineWrapping){let a=Math.min(this.height,e.lineHeight*r);o=a/r,this.length>r+1&&(l=(this.height-a)/(this.length-r-1))}else o=this.height/r;return{firstLine:n,lastLine:s,perLine:o,perChar:l}}blockAt(e,t,n,s){let{firstLine:r,lastLine:o,perLine:l,perChar:a}=this.heightMetrics(t,s);if(t.lineWrapping){let h=s+(e<t.lineHeight?0:Math.round(Math.max(0,Math.min(1,(e-n)/this.height))*this.length)),c=t.doc.lineAt(h),f=l+c.length*a,u=Math.max(n,e-f/2);return new pt(c.from,c.length,u,f,0)}else{let h=Math.max(0,Math.min(o-r,Math.floor((e-n)/l))),{from:c,length:f}=t.doc.line(r+h);return new pt(c,f,n+l*h,l,0)}}lineAt(e,t,n,s,r){if(t==j.ByHeight)return this.blockAt(e,n,s,r);if(t==j.ByPosNoHeight){let{from:d,to:p}=n.doc.lineAt(e);return new pt(d,p-d,0,0,0)}let{firstLine:o,perLine:l,perChar:a}=this.heightMetrics(n,r),h=n.doc.lineAt(e),c=l+h.length*a,f=h.number-o,u=s+l*f+a*(h.from-r-f);return new pt(h.from,h.length,Math.max(s,Math.min(u,s+this.height-c)),c,0)}forEachLine(e,t,n,s,r,o){e=Math.max(e,r),t=Math.min(t,r+this.length);let{firstLine:l,perLine:a,perChar:h}=this.heightMetrics(n,r);for(let c=e,f=s;c<=t;){let u=n.doc.lineAt(c);if(c==e){let p=u.number-l;f+=a*p+h*(e-r-p)}let d=a+h*u.length;o(new pt(u.from,u.length,f,d,0)),f+=d,c=u.to+1}}replace(e,t,n){let s=this.length-t;if(s>0){let r=n[n.length-1];r instanceof de?n[n.length-1]=new de(r.length+s):n.push(null,new de(s-1))}if(e>0){let r=n[0];r instanceof de?n[0]=new de(e+r.length):n.unshift(new de(e-1),null)}return Se.of(n)}decomposeLeft(e,t){t.push(new de(e-1),null)}decomposeRight(e,t){t.push(null,new de(this.length-e-1))}updateHeight(e,t=0,n=!1,s){let r=t+this.length;if(s&&s.from<=t+this.length&&s.more){let o=[],l=Math.max(t,s.from),a=-1;for(s.from>t&&o.push(new de(s.from-t-1).updateHeight(e,t));l<=r&&s.more;){let c=e.doc.lineAt(l).length;o.length&&o.push(null);let f=s.heights[s.index++];a==-1?a=f:Math.abs(f-a)>=gs&&(a=-2);let u=new Le(c,f);u.outdated=!1,o.push(u),l+=c+1}l<=r&&o.push(null,new de(r-l).updateHeight(e,l));let h=Se.of(o);return(a<0||Math.abs(h.height-this.height)>=gs||Math.abs(a-this.heightMetrics(e,t).perLine)>=gs)&&(Ti=!0),Es(this,h)}else(n||this.outdated)&&(this.setHeight(e.heightForGap(t,t+this.length)),this.outdated=!1);return this}toString(){return`gap(${this.length})`}}class kg extends Se{constructor(e,t,n){super(e.length+t+n.length,e.height+n.height,t|(e.outdated||n.outdated?2:0)),this.left=e,this.right=n,this.size=e.size+n.size}get break(){return this.flags&1}blockAt(e,t,n,s){let r=n+this.left.height;return e<r?this.left.blockAt(e,t,n,s):this.right.blockAt(e,t,r,s+this.left.length+this.break)}lineAt(e,t,n,s,r){let o=s+this.left.height,l=r+this.left.length+this.break,a=t==j.ByHeight?e<o:e<l,h=a?this.left.lineAt(e,t,n,s,r):this.right.lineAt(e,t,n,o,l);if(this.break||(a?h.to<l:h.from>l))return h;let c=t==j.ByPosNoHeight?j.ByPosNoHeight:j.ByPos;return a?h.join(this.right.lineAt(l,c,n,o,l)):this.left.lineAt(l,c,n,s,r).join(h)}forEachLine(e,t,n,s,r,o){let l=s+this.left.height,a=r+this.left.length+this.break;if(this.break)e<a&&this.left.forEachLine(e,t,n,s,r,o),t>=a&&this.right.forEachLine(e,t,n,l,a,o);else{let h=this.lineAt(a,j.ByPos,n,s,r);e<h.from&&this.left.forEachLine(e,h.from-1,n,s,r,o),h.to>=e&&h.from<=t&&o(h),t>h.to&&this.right.forEachLine(h.to+1,t,n,l,a,o)}}replace(e,t,n){let s=this.left.length+this.break;if(t<s)return this.balanced(this.left.replace(e,t,n),this.right);if(e>this.left.length)return this.balanced(this.left,this.right.replace(e-s,t-s,n));let r=[];e>0&&this.decomposeLeft(e,r);let o=r.length;for(let l of n)r.push(l);if(e>0&&La(r,o-1),t<this.length){let l=r.length;this.decomposeRight(t,r),La(r,l)}return Se.of(r)}decomposeLeft(e,t){let n=this.left.length;if(e<=n)return this.left.decomposeLeft(e,t);t.push(this.left),this.break&&(n++,e>=n&&t.push(null)),e>n&&this.right.decomposeLeft(e-n,t)}decomposeRight(e,t){let n=this.left.length,s=n+this.break;if(e>=s)return this.right.decomposeRight(e-s,t);e<n&&this.left.decomposeRight(e,t),this.break&&e<s&&t.push(null),t.push(this.right)}balanced(e,t){return e.size>2*t.size||t.size>2*e.size?Se.of(this.break?[e,null,t]:[e,t]):(this.left=Es(this.left,e),this.right=Es(this.right,t),this.setHeight(e.height+t.height),this.outdated=e.outdated||t.outdated,this.size=e.size+t.size,this.length=e.length+this.break+t.length,this)}updateHeight(e,t=0,n=!1,s){let{left:r,right:o}=this,l=t+r.length+this.break,a=null;return s&&s.from<=t+r.length&&s.more?a=r=r.updateHeight(e,t,n,s):r.updateHeight(e,t,n),s&&s.from<=l+o.length&&s.more?a=o=o.updateHeight(e,l,n,s):o.updateHeight(e,l,n),a?this.balanced(r,o):(this.height=this.left.height+this.right.height,this.outdated=!1,this)}toString(){return this.left+(this.break?" ":"-")+this.right}}function La(i,e){let t,n;i[e]==null&&(t=i[e-1])instanceof de&&(n=i[e+1])instanceof de&&i.splice(e-1,3,new de(t.length+1+n.length))}const Cg=5;class ul{constructor(e,t){this.pos=e,this.oracle=t,this.nodes=[],this.lineStart=-1,this.lineEnd=-1,this.covering=null,this.writtenTo=e}get isCovered(){return this.covering&&this.nodes[this.nodes.length-1]==this.covering}span(e,t){if(this.lineStart>-1){let n=Math.min(t,this.lineEnd),s=this.nodes[this.nodes.length-1];s instanceof Le?s.length+=n-this.pos:(n>this.pos||!this.isCovered)&&this.nodes.push(new Le(n-this.pos,-1)),this.writtenTo=n,t>n&&(this.nodes.push(null),this.writtenTo++,this.lineStart=-1)}this.pos=t}point(e,t,n){if(e<t||n.heightRelevant){let s=n.widget?n.widget.estimatedHeight:0,r=n.widget?n.widget.lineBreaks:0;s<0&&(s=this.oracle.lineHeight);let o=t-e;n.block?this.addBlock(new Ff(o,s,n)):(o||r||s>=Cg)&&this.addLineDeco(s,r,o)}else t>e&&this.span(e,t);this.lineEnd>-1&&this.lineEnd<this.pos&&(this.lineEnd=this.oracle.doc.lineAt(this.pos).to)}enterLine(){if(this.lineStart>-1)return;let{from:e,to:t}=this.oracle.doc.lineAt(this.pos);this.lineStart=e,this.lineEnd=t,this.writtenTo<e&&((this.writtenTo<e-1||this.nodes[this.nodes.length-1]==null)&&this.nodes.push(this.blankContent(this.writtenTo,e-1)),this.nodes.push(null)),this.pos>e&&this.nodes.push(new Le(this.pos-e,-1)),this.writtenTo=this.pos}blankContent(e,t){let n=new de(t-e);return this.oracle.doc.lineAt(e).to==t&&(n.flags|=4),n}ensureLine(){this.enterLine();let e=this.nodes.length?this.nodes[this.nodes.length-1]:null;if(e instanceof Le)return e;let t=new Le(0,-1);return this.nodes.push(t),t}addBlock(e){this.enterLine();let t=e.deco;t&&t.startSide>0&&!this.isCovered&&this.ensureLine(),this.nodes.push(e),this.writtenTo=this.pos=this.pos+e.length,t&&t.endSide>0&&(this.covering=e)}addLineDeco(e,t,n){let s=this.ensureLine();s.length+=n,s.collapsed+=n,s.widgetHeight=Math.max(s.widgetHeight,e),s.breaks+=t,this.writtenTo=this.pos=this.pos+n}finish(e){let t=this.nodes.length==0?null:this.nodes[this.nodes.length-1];this.lineStart>-1&&!(t instanceof Le)&&!this.isCovered?this.nodes.push(new Le(0,-1)):(this.writtenTo<this.pos||t==null)&&this.nodes.push(this.blankContent(this.writtenTo,this.pos));let n=e;for(let s of this.nodes)s instanceof Le&&s.updateHeight(this.oracle,n),n+=s?s.length:1;return this.nodes}static build(e,t,n,s){let r=new ul(n,e);return _.spans(t,n,s,r,0),r.finish(n)}}function vg(i,e,t){let n=new xg;return _.compare(i,e,t,n,0),n.changes}class xg{constructor(){this.changes=[]}compareRange(){}comparePoint(e,t,n,s){(e<t||n&&n.heightRelevant||s&&s.heightRelevant)&&ps(e,t,this.changes,5)}}function Sg(i,e){let t=i.getBoundingClientRect(),n=i.ownerDocument,s=n.defaultView||window,r=Math.max(0,t.left),o=Math.min(s.innerWidth,t.right),l=Math.max(0,t.top),a=Math.min(s.innerHeight,t.bottom);for(let h=i.parentNode;h&&h!=n.body;)if(h.nodeType==1){let c=h,f=window.getComputedStyle(c);if((c.scrollHeight>c.clientHeight||c.scrollWidth>c.clientWidth)&&f.overflow!="visible"){let u=c.getBoundingClientRect();r=Math.max(r,u.left),o=Math.min(o,u.right),l=Math.max(l,u.top),a=Math.min(h==i.parentNode?s.innerHeight:a,u.bottom)}h=f.position=="absolute"||f.position=="fixed"?c.offsetParent:c.parentNode}else if(h.nodeType==11)h=h.host;else break;return{left:r-t.left,right:Math.max(r,o)-t.left,top:l-(t.top+e),bottom:Math.max(l,a)-(t.top+e)}}function Qg(i){let e=i.getBoundingClientRect(),t=i.ownerDocument.defaultView||window;return e.left<t.innerWidth&&e.right>0&&e.top<t.innerHeight&&e.bottom>0}function Eg(i,e){let t=i.getBoundingClientRect();return{left:0,right:t.right-t.left,top:e,bottom:t.bottom-(t.top+e)}}class Er{constructor(e,t,n,s){this.from=e,this.to=t,this.size=n,this.displaySize=s}static same(e,t){if(e.length!=t.length)return!1;for(let n=0;n<e.length;n++){let s=e[n],r=t[n];if(s.from!=r.from||s.to!=r.to||s.size!=r.size)return!1}return!0}draw(e,t){return D.replace({widget:new Bg(this.displaySize*(t?e.scaleY:e.scaleX),t)}).range(this.from,this.to)}}class Bg extends Ut{constructor(e,t){super(),this.size=e,this.vertical=t}eq(e){return e.size==this.size&&e.vertical==this.vertical}toDOM(){let e=document.createElement("div");return this.vertical?e.style.height=this.size+"px":(e.style.width=this.size+"px",e.style.height="2px",e.style.display="inline-block"),e}get estimatedHeight(){return this.vertical?this.size:-1}}class Na{constructor(e){this.state=e,this.pixelViewport={left:0,right:window.innerWidth,top:0,bottom:0},this.inView=!0,this.paddingTop=0,this.paddingBottom=0,this.contentDOMWidth=0,this.contentDOMHeight=0,this.editorHeight=0,this.editorWidth=0,this.scrollTop=0,this.scrolledToBottom=!1,this.scaleX=1,this.scaleY=1,this.scrollAnchorPos=0,this.scrollAnchorHeight=-1,this.scaler=$a,this.scrollTarget=null,this.printing=!1,this.mustMeasureContent=!0,this.defaultTextDirection=Z.LTR,this.visibleRanges=[],this.mustEnforceCursorAssoc=!1;let t=e.facet(al).some(n=>typeof n!="function"&&n.class=="cm-lineWrapping");this.heightOracle=new wg(t),this.stateDeco=e.facet(gn).filter(n=>typeof n!="function"),this.heightMap=Se.empty().applyChanges(this.stateDeco,$.empty,this.heightOracle.setDoc(e.doc),[new He(0,0,0,e.doc.length)]);for(let n=0;n<2&&(this.viewport=this.getViewport(0,null),!!this.updateForViewport());n++);this.updateViewportLines(),this.lineGaps=this.ensureLineGaps([]),this.lineGapDeco=D.set(this.lineGaps.map(n=>n.draw(this,!1))),this.computeVisibleRanges()}updateForViewport(){let e=[this.viewport],{main:t}=this.state.selection;for(let n=0;n<=1;n++){let s=n?t.head:t.anchor;if(!e.some(({from:r,to:o})=>s>=r&&s<=o)){let{from:r,to:o}=this.lineBlockAt(s);e.push(new Wn(r,o))}}return this.viewports=e.sort((n,s)=>n.from-s.from),this.updateScaler()}updateScaler(){let e=this.scaler;return this.scaler=this.heightMap.height<=7e6?$a:new dl(this.heightOracle,this.heightMap,this.viewports),e.eq(this.scaler)?0:2}updateViewportLines(){this.viewportLines=[],this.heightMap.forEachLine(this.viewport.from,this.viewport.to,this.heightOracle.setDoc(this.state.doc),0,0,e=>{this.viewportLines.push(Zi(e,this.scaler))})}update(e,t=null){this.state=e.state;let n=this.stateDeco;this.stateDeco=this.state.facet(gn).filter(c=>typeof c!="function");let s=e.changedRanges,r=He.extendWithRanges(s,vg(n,this.stateDeco,e?e.changes:le.empty(this.state.doc.length))),o=this.heightMap.height,l=this.scrolledToBottom?null:this.scrollAnchorAt(this.scrollTop);Ra(),this.heightMap=this.heightMap.applyChanges(this.stateDeco,e.startState.doc,this.heightOracle.setDoc(this.state.doc),r),(this.heightMap.height!=o||Ti)&&(e.flags|=2),l?(this.scrollAnchorPos=e.changes.mapPos(l.from,-1),this.scrollAnchorHeight=l.top):(this.scrollAnchorPos=-1,this.scrollAnchorHeight=o);let a=r.length?this.mapViewport(this.viewport,e.changes):this.viewport;(t&&(t.range.head<a.from||t.range.head>a.to)||!this.viewportIsAppropriate(a))&&(a=this.getViewport(0,t));let h=a.from!=this.viewport.from||a.to!=this.viewport.to;this.viewport=a,e.flags|=this.updateForViewport(),(h||!e.changes.empty||e.flags&2)&&this.updateViewportLines(),(this.lineGaps.length||this.viewport.to-this.viewport.from>4e3)&&this.updateLineGaps(this.ensureLineGaps(this.mapLineGaps(this.lineGaps,e.changes))),e.flags|=this.computeVisibleRanges(e.changes),t&&(this.scrollTarget=t),!this.mustEnforceCursorAssoc&&e.selectionSet&&e.view.lineWrapping&&e.state.selection.main.empty&&e.state.selection.main.assoc&&!e.state.facet(yf)&&(this.mustEnforceCursorAssoc=!0)}measure(e){let t=e.contentDOM,n=window.getComputedStyle(t),s=this.heightOracle,r=n.whiteSpace;this.defaultTextDirection=n.direction=="rtl"?Z.RTL:Z.LTR;let o=this.heightOracle.mustRefreshForWrapping(r),l=t.getBoundingClientRect(),a=o||this.mustMeasureContent||this.contentDOMHeight!=l.height;this.contentDOMHeight=l.height,this.mustMeasureContent=!1;let h=0,c=0;if(l.width&&l.height){let{scaleX:v,scaleY:y}=Gc(t,l);(v>.005&&Math.abs(this.scaleX-v)>.005||y>.005&&Math.abs(this.scaleY-y)>.005)&&(this.scaleX=v,this.scaleY=y,h|=16,o=a=!0)}let f=(parseInt(n.paddingTop)||0)*this.scaleY,u=(parseInt(n.paddingBottom)||0)*this.scaleY;(this.paddingTop!=f||this.paddingBottom!=u)&&(this.paddingTop=f,this.paddingBottom=u,h|=18),this.editorWidth!=e.scrollDOM.clientWidth&&(s.lineWrapping&&(a=!0),this.editorWidth=e.scrollDOM.clientWidth,h|=16);let d=e.scrollDOM.scrollTop*this.scaleY;this.scrollTop!=d&&(this.scrollAnchorHeight=-1,this.scrollTop=d),this.scrolledToBottom=Xc(e.scrollDOM);let p=(this.printing?Eg:Sg)(t,this.paddingTop),m=p.top-this.pixelViewport.top,g=p.bottom-this.pixelViewport.bottom;this.pixelViewport=p;let O=this.pixelViewport.bottom>this.pixelViewport.top&&this.pixelViewport.right>this.pixelViewport.left;if(O!=this.inView&&(this.inView=O,O&&(a=!0)),!this.inView&&!this.scrollTarget&&!Qg(e.dom))return 0;let w=l.width;if((this.contentDOMWidth!=w||this.editorHeight!=e.scrollDOM.clientHeight)&&(this.contentDOMWidth=l.width,this.editorHeight=e.scrollDOM.clientHeight,h|=16),a){let v=e.docView.measureVisibleLineHeights(this.viewport);if(s.mustRefreshForHeights(v)&&(o=!0),o||s.lineWrapping&&Math.abs(w-this.contentDOMWidth)>s.charWidth){let{lineHeight:y,charWidth:C,textHeight:x}=e.docView.measureTextSize();o=y>0&&s.refresh(r,y,C,x,w/C,v),o&&(e.docView.minWidth=0,h|=16)}m>0&&g>0?c=Math.max(m,g):m<0&&g<0&&(c=Math.min(m,g)),Ra();for(let y of this.viewports){let C=y.from==this.viewport.from?v:e.docView.measureVisibleLineHeights(y);this.heightMap=(o?Se.empty().applyChanges(this.stateDeco,$.empty,this.heightOracle,[new He(0,0,0,e.state.doc.length)]):this.heightMap).updateHeight(s,0,o,new yg(y.from,C))}Ti&&(h|=2)}let k=!this.viewportIsAppropriate(this.viewport,c)||this.scrollTarget&&(this.scrollTarget.range.head<this.viewport.from||this.scrollTarget.range.head>this.viewport.to);return k&&(h&2&&(h|=this.updateScaler()),this.viewport=this.getViewport(c,this.scrollTarget),h|=this.updateForViewport()),(h&2||k)&&this.updateViewportLines(),(this.lineGaps.length||this.viewport.to-this.viewport.from>4e3)&&this.updateLineGaps(this.ensureLineGaps(o?[]:this.lineGaps,e)),h|=this.computeVisibleRanges(),this.mustEnforceCursorAssoc&&(this.mustEnforceCursorAssoc=!1,e.docView.enforceCursorAssoc()),h}get visibleTop(){return this.scaler.fromDOM(this.pixelViewport.top)}get visibleBottom(){return this.scaler.fromDOM(this.pixelViewport.bottom)}getViewport(e,t){let n=.5-Math.max(-.5,Math.min(.5,e/1e3/2)),s=this.heightMap,r=this.heightOracle,{visibleTop:o,visibleBottom:l}=this,a=new Wn(s.lineAt(o-n*1e3,j.ByHeight,r,0,0).from,s.lineAt(l+(1-n)*1e3,j.ByHeight,r,0,0).to);if(t){let{head:h}=t.range;if(h<a.from||h>a.to){let c=Math.min(this.editorHeight,this.pixelViewport.bottom-this.pixelViewport.top),f=s.lineAt(h,j.ByPos,r,0,0),u;t.y=="center"?u=(f.top+f.bottom)/2-c/2:t.y=="start"||t.y=="nearest"&&h<a.from?u=f.top:u=f.bottom-c,a=new Wn(s.lineAt(u-1e3/2,j.ByHeight,r,0,0).from,s.lineAt(u+c+1e3/2,j.ByHeight,r,0,0).to)}}return a}mapViewport(e,t){let n=t.mapPos(e.from,-1),s=t.mapPos(e.to,1);return new Wn(this.heightMap.lineAt(n,j.ByPos,this.heightOracle,0,0).from,this.heightMap.lineAt(s,j.ByPos,this.heightOracle,0,0).to)}viewportIsAppropriate({from:e,to:t},n=0){if(!this.inView)return!0;let{top:s}=this.heightMap.lineAt(e,j.ByPos,this.heightOracle,0,0),{bottom:r}=this.heightMap.lineAt(t,j.ByPos,this.heightOracle,0,0),{visibleTop:o,visibleBottom:l}=this;return(e==0||s<=o-Math.max(10,Math.min(-n,250)))&&(t==this.state.doc.length||r>=l+Math.max(10,Math.min(n,250)))&&s>o-2*1e3&&r<l+2*1e3}mapLineGaps(e,t){if(!e.length||t.empty)return e;let n=[];for(let s of e)t.touchesRange(s.from,s.to)||n.push(new Er(t.mapPos(s.from),t.mapPos(s.to),s.size,s.displaySize));return n}ensureLineGaps(e,t){let n=this.heightOracle.lineWrapping,s=n?1e4:2e3,r=s>>1,o=s<<1;if(this.defaultTextDirection!=Z.LTR&&!n)return[];let l=[],a=(c,f,u,d)=>{if(f-c<r)return;let p=this.state.selection.main,m=[p.from];p.empty||m.push(p.to);for(let O of m)if(O>c&&O<f){a(c,O-10,u,d),a(O+10,f,u,d);return}let g=Mg(e,O=>O.from>=u.from&&O.to<=u.to&&Math.abs(O.from-c)<r&&Math.abs(O.to-f)<r&&!m.some(w=>O.from<w&&O.to>w));if(!g){if(f<u.to&&t&&n&&t.visibleRanges.some(k=>k.from<=f&&k.to>=f)){let k=t.moveToLineBoundary(b.cursor(f),!1,!0).head;k>c&&(f=k)}let O=this.gapSize(u,c,f,d),w=n||O<2e6?O:2e6;g=new Er(c,f,O,w)}l.push(g)},h=c=>{if(c.length<o||c.type!=xe.Text)return;let f=Pg(c.from,c.to,this.stateDeco);if(f.total<o)return;let u=this.scrollTarget?this.scrollTarget.range.head:null,d,p;if(n){let m=s/this.heightOracle.lineLength*this.heightOracle.lineHeight,g,O;if(u!=null){let w=qn(f,u),k=((this.visibleBottom-this.visibleTop)/2+m)/c.height;g=w-k,O=w+k}else g=(this.visibleTop-c.top-m)/c.height,O=(this.visibleBottom-c.top+m)/c.height;d=Hn(f,g),p=Hn(f,O)}else{let m=f.total*this.heightOracle.charWidth,g=s*this.heightOracle.charWidth,O=0;if(m>2e6)for(let C of e)C.from>=c.from&&C.from<c.to&&C.size!=C.displaySize&&C.from*this.heightOracle.charWidth+O<this.pixelViewport.left&&(O=C.size-C.displaySize);let w=this.pixelViewport.left+O,k=this.pixelViewport.right+O,v,y;if(u!=null){let C=qn(f,u),x=((k-w)/2+g)/m;v=C-x,y=C+x}else v=(w-g)/m,y=(k+g)/m;d=Hn(f,v),p=Hn(f,y)}d>c.from&&a(c.from,d,c,f),p<c.to&&a(p,c.to,c,f)};for(let c of this.viewportLines)Array.isArray(c.type)?c.type.forEach(h):h(c);return l}gapSize(e,t,n,s){let r=qn(s,n)-qn(s,t);return this.heightOracle.lineWrapping?e.height*r:s.total*this.heightOracle.charWidth*r}updateLineGaps(e){Er.same(e,this.lineGaps)||(this.lineGaps=e,this.lineGapDeco=D.set(e.map(t=>t.draw(this,this.heightOracle.lineWrapping))))}computeVisibleRanges(e){let t=this.stateDeco;this.lineGaps.length&&(t=t.concat(this.lineGapDeco));let n=[];_.spans(t,this.viewport.from,this.viewport.to,{span(r,o){n.push({from:r,to:o})},point(){}},20);let s=0;if(n.length!=this.visibleRanges.length)s=12;else for(let r=0;r<n.length&&!(s&8);r++){let o=this.visibleRanges[r],l=n[r];(o.from!=l.from||o.to!=l.to)&&(s|=4,e&&e.mapPos(o.from,-1)==l.from&&e.mapPos(o.to,1)==l.to||(s|=8))}return this.visibleRanges=n,s}lineBlockAt(e){return e>=this.viewport.from&&e<=this.viewport.to&&this.viewportLines.find(t=>t.from<=e&&t.to>=e)||Zi(this.heightMap.lineAt(e,j.ByPos,this.heightOracle,0,0),this.scaler)}lineBlockAtHeight(e){return e>=this.viewportLines[0].top&&e<=this.viewportLines[this.viewportLines.length-1].bottom&&this.viewportLines.find(t=>t.top<=e&&t.bottom>=e)||Zi(this.heightMap.lineAt(this.scaler.fromDOM(e),j.ByHeight,this.heightOracle,0,0),this.scaler)}scrollAnchorAt(e){let t=this.lineBlockAtHeight(e+8);return t.from>=this.viewport.from||this.viewportLines[0].top-e>200?t:this.viewportLines[0]}elementAtHeight(e){return Zi(this.heightMap.blockAt(this.scaler.fromDOM(e),this.heightOracle,0,0),this.scaler)}get docHeight(){return this.scaler.toDOM(this.heightMap.height)}get contentHeight(){return this.docHeight+this.paddingTop+this.paddingBottom}}class Wn{constructor(e,t){this.from=e,this.to=t}}function Pg(i,e,t){let n=[],s=i,r=0;return _.spans(t,i,e,{span(){},point(o,l){o>s&&(n.push({from:s,to:o}),r+=o-s),s=l}},20),s<e&&(n.push({from:s,to:e}),r+=e-s),{total:r,ranges:n}}function Hn({total:i,ranges:e},t){if(t<=0)return e[0].from;if(t>=1)return e[e.length-1].to;let n=Math.floor(i*t);for(let s=0;;s++){let{from:r,to:o}=e[s],l=o-r;if(n<=l)return r+n;n-=l}}function qn(i,e){let t=0;for(let{from:n,to:s}of i.ranges){if(e<=s){t+=e-n;break}t+=s-n}return t/i.total}function Mg(i,e){for(let t of i)if(e(t))return t}const $a={toDOM(i){return i},fromDOM(i){return i},scale:1,eq(i){return i==this}};class dl{constructor(e,t,n){let s=0,r=0,o=0;this.viewports=n.map(({from:l,to:a})=>{let h=t.lineAt(l,j.ByPos,e,0,0).top,c=t.lineAt(a,j.ByPos,e,0,0).bottom;return s+=c-h,{from:l,to:a,top:h,bottom:c,domTop:0,domBottom:0}}),this.scale=(7e6-s)/(t.height-s);for(let l of this.viewports)l.domTop=o+(l.top-r)*this.scale,o=l.domBottom=l.domTop+(l.bottom-l.top),r=l.bottom}toDOM(e){for(let t=0,n=0,s=0;;t++){let r=t<this.viewports.length?this.viewports[t]:null;if(!r||e<r.top)return s+(e-n)*this.scale;if(e<=r.bottom)return r.domTop+(e-r.top);n=r.bottom,s=r.domBottom}}fromDOM(e){for(let t=0,n=0,s=0;;t++){let r=t<this.viewports.length?this.viewports[t]:null;if(!r||e<r.domTop)return n+(e-s)/this.scale;if(e<=r.domBottom)return r.top+(e-r.domTop);n=r.bottom,s=r.domBottom}}eq(e){return e instanceof dl?this.scale==e.scale&&this.viewports.length==e.viewports.length&&this.viewports.every((t,n)=>t.from==e.viewports[n].from&&t.to==e.viewports[n].to):!1}}function Zi(i,e){if(e.scale==1)return i;let t=e.toDOM(i.top),n=e.toDOM(i.bottom);return new pt(i.from,i.length,t,n-t,Array.isArray(i._content)?i._content.map(s=>Zi(s,e)):i._content)}const Gn=B.define({combine:i=>i.join(" ")}),Eo=B.define({combine:i=>i.indexOf(!0)>-1}),Bo=Wt.newName(),Kf=Wt.newName(),zf=Wt.newName(),_f={"&light":"."+Kf,"&dark":"."+zf};function Po(i,e,t){return new Wt(e,{finish(n){return/&/.test(n)?n.replace(/&\w*/,s=>{if(s=="&")return i;if(!t||!t[s])throw new RangeError(`Unsupported selector: ${s}`);return t[s]}):i+" "+n}})}const Dg=Po("."+Bo,{"&":{position:"relative !important",boxSizing:"border-box","&.cm-focused":{outline:"1px dotted #212121"},display:"flex !important",flexDirection:"column"},".cm-scroller":{display:"flex !important",alignItems:"flex-start !important",fontFamily:"monospace",lineHeight:1.4,height:"100%",overflowX:"auto",position:"relative",zIndex:0,overflowAnchor:"none"},".cm-content":{margin:0,flexGrow:2,flexShrink:0,display:"block",whiteSpace:"pre",wordWrap:"normal",boxSizing:"border-box",minHeight:"100%",padding:"4px 0",outline:"none","&[contenteditable=true]":{WebkitUserModify:"read-write-plaintext-only"}},".cm-lineWrapping":{whiteSpace_fallback:"pre-wrap",whiteSpace:"break-spaces",wordBreak:"break-word",overflowWrap:"anywhere",flexShrink:1},"&light .cm-content":{caretColor:"black"},"&dark .cm-content":{caretColor:"white"},".cm-line":{display:"block",padding:"0 2px 0 6px"},".cm-layer":{position:"absolute",left:0,top:0,contain:"size style","& > *":{position:"absolute"}},"&light .cm-selectionBackground":{background:"#d9d9d9"},"&dark .cm-selectionBackground":{background:"#222"},"&light.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground":{background:"#d7d4f0"},"&dark.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground":{background:"#233"},".cm-cursorLayer":{pointerEvents:"none"},"&.cm-focused > .cm-scroller > .cm-cursorLayer":{animation:"steps(1) cm-blink 1.2s infinite"},"@keyframes cm-blink":{"0%":{},"50%":{opacity:0},"100%":{}},"@keyframes cm-blink2":{"0%":{},"50%":{opacity:0},"100%":{}},".cm-cursor, .cm-dropCursor":{borderLeft:"1.2px solid black",marginLeft:"-0.6px",pointerEvents:"none"},".cm-cursor":{display:"none"},"&dark .cm-cursor":{borderLeftColor:"#ddd"},".cm-dropCursor":{position:"absolute"},"&.cm-focused > .cm-scroller > .cm-cursorLayer .cm-cursor":{display:"block"},".cm-iso":{unicodeBidi:"isolate"},".cm-announced":{position:"fixed",top:"-10000px"},"@media print":{".cm-announced":{display:"none"}},"&light .cm-activeLine":{backgroundColor:"#cceeff44"},"&dark .cm-activeLine":{backgroundColor:"#99eeff33"},"&light .cm-specialChar":{color:"red"},"&dark .cm-specialChar":{color:"#f78"},".cm-gutters":{flexShrink:0,display:"flex",height:"100%",boxSizing:"border-box",zIndex:200},".cm-gutters-before":{insetInlineStart:0},".cm-gutters-after":{insetInlineEnd:0},"&light .cm-gutters":{backgroundColor:"#f5f5f5",color:"#6c6c6c",border:"0px solid #ddd","&.cm-gutters-before":{borderRightWidth:"1px"},"&.cm-gutters-after":{borderLeftWidth:"1px"}},"&dark .cm-gutters":{backgroundColor:"#333338",color:"#ccc"},".cm-gutter":{display:"flex !important",flexDirection:"column",flexShrink:0,boxSizing:"border-box",minHeight:"100%",overflow:"hidden"},".cm-gutterElement":{boxSizing:"border-box"},".cm-lineNumbers .cm-gutterElement":{padding:"0 3px 0 5px",minWidth:"20px",textAlign:"right",whiteSpace:"nowrap"},"&light .cm-activeLineGutter":{backgroundColor:"#e2f2ff"},"&dark .cm-activeLineGutter":{backgroundColor:"#222227"},".cm-panels":{boxSizing:"border-box",position:"sticky",left:0,right:0,zIndex:300},"&light .cm-panels":{backgroundColor:"#f5f5f5",color:"black"},"&light .cm-panels-top":{borderBottom:"1px solid #ddd"},"&light .cm-panels-bottom":{borderTop:"1px solid #ddd"},"&dark .cm-panels":{backgroundColor:"#333338",color:"white"},".cm-dialog":{padding:"2px 19px 4px 6px",position:"relative","& label":{fontSize:"80%"}},".cm-dialog-close":{position:"absolute",top:"3px",right:"4px",backgroundColor:"inherit",border:"none",font:"inherit",fontSize:"14px",padding:"0"},".cm-tab":{display:"inline-block",overflow:"hidden",verticalAlign:"bottom"},".cm-widgetBuffer":{verticalAlign:"text-top",height:"1em",width:0,display:"inline"},".cm-placeholder":{color:"#888",display:"inline-block",verticalAlign:"top",userSelect:"none"},".cm-highlightSpace":{backgroundImage:"radial-gradient(circle at 50% 55%, #aaa 20%, transparent 5%)",backgroundPosition:"center"},".cm-highlightTab":{backgroundImage:`url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="200" height="20"><path stroke="%23888" stroke-width="1" fill="none" d="M1 10H196L190 5M190 15L196 10M197 4L197 16"/></svg>')`,backgroundSize:"auto 100%",backgroundPosition:"right 90%",backgroundRepeat:"no-repeat"},".cm-trailingSpace":{backgroundColor:"#ff332255"},".cm-button":{verticalAlign:"middle",color:"inherit",fontSize:"70%",padding:".2em 1em",borderRadius:"1px"},"&light .cm-button":{backgroundImage:"linear-gradient(#eff1f5, #d9d9df)",border:"1px solid #888","&:active":{backgroundImage:"linear-gradient(#b4b4b4, #d0d3d6)"}},"&dark .cm-button":{backgroundImage:"linear-gradient(#393939, #111)",border:"1px solid #888","&:active":{backgroundImage:"linear-gradient(#111, #333)"}},".cm-textfield":{verticalAlign:"middle",color:"inherit",fontSize:"70%",border:"1px solid silver",padding:".2em .5em"},"&light .cm-textfield":{backgroundColor:"white"},"&dark .cm-textfield":{border:"1px solid #555",backgroundColor:"inherit"}},_f),Ig={childList:!0,characterData:!0,subtree:!0,attributes:!0,characterDataOldValue:!0},Br=E.ie&&E.ie_version<=11;class Tg{constructor(e){this.view=e,this.active=!1,this.editContext=null,this.selectionRange=new mm,this.selectionChanged=!1,this.delayedFlush=-1,this.resizeTimeout=-1,this.queue=[],this.delayedAndroidKey=null,this.flushingAndroidKey=-1,this.lastChange=0,this.scrollTargets=[],this.intersection=null,this.resizeScroll=null,this.intersecting=!1,this.gapIntersection=null,this.gaps=[],this.printQuery=null,this.parentCheck=-1,this.dom=e.contentDOM,this.observer=new MutationObserver(t=>{for(let n of t)this.queue.push(n);(E.ie&&E.ie_version<=11||E.ios&&e.composing)&&t.some(n=>n.type=="childList"&&n.removedNodes.length||n.type=="characterData"&&n.oldValue.length>n.target.nodeValue.length)?this.flushSoon():this.flush()}),window.EditContext&&E.android&&e.constructor.EDIT_CONTEXT!==!1&&!(E.chrome&&E.chrome_version<126)&&(this.editContext=new Lg(e),e.state.facet(xt)&&(e.contentDOM.editContext=this.editContext.editContext)),Br&&(this.onCharData=t=>{this.queue.push({target:t.target,type:"characterData",oldValue:t.prevValue}),this.flushSoon()}),this.onSelectionChange=this.onSelectionChange.bind(this),this.onResize=this.onResize.bind(this),this.onPrint=this.onPrint.bind(this),this.onScroll=this.onScroll.bind(this),window.matchMedia&&(this.printQuery=window.matchMedia("print")),typeof ResizeObserver=="function"&&(this.resizeScroll=new ResizeObserver(()=>{var t;((t=this.view.docView)===null||t===void 0?void 0:t.lastUpdate)<Date.now()-75&&this.onResize()}),this.resizeScroll.observe(e.scrollDOM)),this.addWindowListeners(this.win=e.win),this.start(),typeof IntersectionObserver=="function"&&(this.intersection=new IntersectionObserver(t=>{this.parentCheck<0&&(this.parentCheck=setTimeout(this.listenForScroll.bind(this),1e3)),t.length>0&&t[t.length-1].intersectionRatio>0!=this.intersecting&&(this.intersecting=!this.intersecting,this.intersecting!=this.view.inView&&this.onScrollChanged(document.createEvent("Event")))},{threshold:[0,.001]}),this.intersection.observe(this.dom),this.gapIntersection=new IntersectionObserver(t=>{t.length>0&&t[t.length-1].intersectionRatio>0&&this.onScrollChanged(document.createEvent("Event"))},{})),this.listenForScroll(),this.readSelectionRange()}onScrollChanged(e){this.view.inputState.runHandlers("scroll",e),this.intersecting&&this.view.measure()}onScroll(e){this.intersecting&&this.flush(!1),this.editContext&&this.view.requestMeasure(this.editContext.measureReq),this.onScrollChanged(e)}onResize(){this.resizeTimeout<0&&(this.resizeTimeout=setTimeout(()=>{this.resizeTimeout=-1,this.view.requestMeasure()},50))}onPrint(e){(e.type=="change"||!e.type)&&!e.matches||(this.view.viewState.printing=!0,this.view.measure(),setTimeout(()=>{this.view.viewState.printing=!1,this.view.requestMeasure()},500))}updateGaps(e){if(this.gapIntersection&&(e.length!=this.gaps.length||this.gaps.some((t,n)=>t!=e[n]))){this.gapIntersection.disconnect();for(let t of e)this.gapIntersection.observe(t);this.gaps=e}}onSelectionChange(e){let t=this.selectionChanged;if(!this.readSelectionRange()||this.delayedAndroidKey)return;let{view:n}=this,s=this.selectionRange;if(n.state.facet(xt)?n.root.activeElement!=this.dom:!ds(this.dom,s))return;let r=s.anchorNode&&n.docView.nearest(s.anchorNode);if(r&&r.ignoreEvent(e)){t||(this.selectionChanged=!1);return}(E.ie&&E.ie_version<=11||E.android&&E.chrome)&&!n.state.selection.main.empty&&s.focusNode&&sn(s.focusNode,s.focusOffset,s.anchorNode,s.anchorOffset)?this.flushSoon():this.flush(!1)}readSelectionRange(){let{view:e}=this,t=pn(e.root);if(!t)return!1;let n=E.safari&&e.root.nodeType==11&&e.root.activeElement==this.dom&&Rg(this.view,t)||t;if(!n||this.selectionRange.eq(n))return!1;let s=ds(this.dom,n);return s&&!this.selectionChanged&&e.inputState.lastFocusTime>Date.now()-200&&e.inputState.lastTouchTime<Date.now()-300&&Am(this.dom,n)?(this.view.inputState.lastFocusTime=0,e.docView.updateSelection(),!1):(this.selectionRange.setRange(n),s&&(this.selectionChanged=!0),!0)}setSelectionRange(e,t){this.selectionRange.set(e.node,e.offset,t.node,t.offset),this.selectionChanged=!1}clearSelectionRange(){this.selectionRange.set(null,0,null,0)}listenForScroll(){this.parentCheck=-1;let e=0,t=null;for(let n=this.dom;n;)if(n.nodeType==1)!t&&e<this.scrollTargets.length&&this.scrollTargets[e]==n?e++:t||(t=this.scrollTargets.slice(0,e)),t&&t.push(n),n=n.assignedSlot||n.parentNode;else if(n.nodeType==11)n=n.host;else break;if(e<this.scrollTargets.length&&!t&&(t=this.scrollTargets.slice(0,e)),t){for(let n of this.scrollTargets)n.removeEventListener("scroll",this.onScroll);for(let n of this.scrollTargets=t)n.addEventListener("scroll",this.onScroll)}}ignore(e){if(!this.active)return e();try{return this.stop(),e()}finally{this.start(),this.clear()}}start(){this.active||(this.observer.observe(this.dom,Ig),Br&&this.dom.addEventListener("DOMCharacterDataModified",this.onCharData),this.active=!0)}stop(){this.active&&(this.active=!1,this.observer.disconnect(),Br&&this.dom.removeEventListener("DOMCharacterDataModified",this.onCharData))}clear(){this.processRecords(),this.queue.length=0,this.selectionChanged=!1}delayAndroidKey(e,t){var n;if(!this.delayedAndroidKey){let s=()=>{let r=this.delayedAndroidKey;r&&(this.clearDelayedAndroidKey(),this.view.inputState.lastKeyCode=r.keyCode,this.view.inputState.lastKeyTime=Date.now(),!this.flush()&&r.force&&xi(this.dom,r.key,r.keyCode))};this.flushingAndroidKey=this.view.win.requestAnimationFrame(s)}(!this.delayedAndroidKey||e=="Enter")&&(this.delayedAndroidKey={key:e,keyCode:t,force:this.lastChange<Date.now()-50||!!(!((n=this.delayedAndroidKey)===null||n===void 0)&&n.force)})}clearDelayedAndroidKey(){this.win.cancelAnimationFrame(this.flushingAndroidKey),this.delayedAndroidKey=null,this.flushingAndroidKey=-1}flushSoon(){this.delayedFlush<0&&(this.delayedFlush=this.view.win.requestAnimationFrame(()=>{this.delayedFlush=-1,this.flush()}))}forceFlush(){this.delayedFlush>=0&&(this.view.win.cancelAnimationFrame(this.delayedFlush),this.delayedFlush=-1),this.flush()}pendingRecords(){for(let e of this.observer.takeRecords())this.queue.push(e);return this.queue}processRecords(){let e=this.pendingRecords();e.length&&(this.queue=[]);let t=-1,n=-1,s=!1;for(let r of e){let o=this.readMutation(r);o&&(o.typeOver&&(s=!0),t==-1?{from:t,to:n}=o:(t=Math.min(o.from,t),n=Math.max(o.to,n)))}return{from:t,to:n,typeOver:s}}readChange(){let{from:e,to:t,typeOver:n}=this.processRecords(),s=this.selectionChanged&&ds(this.dom,this.selectionRange);if(e<0&&!s)return null;e>-1&&(this.lastChange=Date.now()),this.view.inputState.lastFocusTime=0,this.selectionChanged=!1;let r=new Jm(this.view,e,t,n);return this.view.docView.domChanged={newSel:r.newSel?r.newSel.main:null},r}flush(e=!0){if(this.delayedFlush>=0||this.delayedAndroidKey)return!1;e&&this.readSelectionRange();let t=this.readChange();if(!t)return this.view.requestMeasure(),!1;let n=this.view.state,s=Pf(this.view,t);return this.view.state==n&&(t.domChanged||t.newSel&&!t.newSel.main.eq(this.view.state.selection.main))&&this.view.update([]),s}readMutation(e){let t=this.view.docView.nearest(e.target);if(!t||t.ignoreMutation(e))return null;if(t.markDirty(e.type=="attributes"),e.type=="attributes"&&(t.flags|=4),e.type=="childList"){let n=Fa(t,e.previousSibling||e.target.previousSibling,-1),s=Fa(t,e.nextSibling||e.target.nextSibling,1);return{from:n?t.posAfter(n):t.posAtStart,to:s?t.posBefore(s):t.posAtEnd,typeOver:!1}}else return e.type=="characterData"?{from:t.posAtStart,to:t.posAtEnd,typeOver:e.target.nodeValue==e.oldValue}:null}setWindow(e){e!=this.win&&(this.removeWindowListeners(this.win),this.win=e,this.addWindowListeners(this.win))}addWindowListeners(e){e.addEventListener("resize",this.onResize),this.printQuery?this.printQuery.addEventListener?this.printQuery.addEventListener("change",this.onPrint):this.printQuery.addListener(this.onPrint):e.addEventListener("beforeprint",this.onPrint),e.addEventListener("scroll",this.onScroll),e.document.addEventListener("selectionchange",this.onSelectionChange)}removeWindowListeners(e){e.removeEventListener("scroll",this.onScroll),e.removeEventListener("resize",this.onResize),this.printQuery?this.printQuery.removeEventListener?this.printQuery.removeEventListener("change",this.onPrint):this.printQuery.removeListener(this.onPrint):e.removeEventListener("beforeprint",this.onPrint),e.document.removeEventListener("selectionchange",this.onSelectionChange)}update(e){this.editContext&&(this.editContext.update(e),e.startState.facet(xt)!=e.state.facet(xt)&&(e.view.contentDOM.editContext=e.state.facet(xt)?this.editContext.editContext:null))}destroy(){var e,t,n;this.stop(),(e=this.intersection)===null||e===void 0||e.disconnect(),(t=this.gapIntersection)===null||t===void 0||t.disconnect(),(n=this.resizeScroll)===null||n===void 0||n.disconnect();for(let s of this.scrollTargets)s.removeEventListener("scroll",this.onScroll);this.removeWindowListeners(this.win),clearTimeout(this.parentCheck),clearTimeout(this.resizeTimeout),this.win.cancelAnimationFrame(this.delayedFlush),this.win.cancelAnimationFrame(this.flushingAndroidKey),this.editContext&&(this.view.contentDOM.editContext=null,this.editContext.destroy())}}function Fa(i,e,t){for(;e;){let n=Y.get(e);if(n&&n.parent==i)return n;let s=e.parentNode;e=s!=i.dom?s:t>0?e.nextSibling:e.previousSibling}return null}function Ka(i,e){let t=e.startContainer,n=e.startOffset,s=e.endContainer,r=e.endOffset,o=i.docView.domAtPos(i.state.selection.main.anchor);return sn(o.node,o.offset,s,r)&&([t,n,s,r]=[s,r,t,n]),{anchorNode:t,anchorOffset:n,focusNode:s,focusOffset:r}}function Rg(i,e){if(e.getComposedRanges){let s=e.getComposedRanges(i.root)[0];if(s)return Ka(i,s)}let t=null;function n(s){s.preventDefault(),s.stopImmediatePropagation(),t=s.getTargetRanges()[0]}return i.contentDOM.addEventListener("beforeinput",n,!0),i.dom.ownerDocument.execCommand("indent"),i.contentDOM.removeEventListener("beforeinput",n,!0),t?Ka(i,t):null}class Lg{constructor(e){this.from=0,this.to=0,this.pendingContextChange=null,this.handlers=Object.create(null),this.composing=null,this.resetRange(e.state);let t=this.editContext=new window.EditContext({text:e.state.doc.sliceString(this.from,this.to),selectionStart:this.toContextPos(Math.max(this.from,Math.min(this.to,e.state.selection.main.anchor))),selectionEnd:this.toContextPos(e.state.selection.main.head)});this.handlers.textupdate=n=>{let s=e.state.selection.main,{anchor:r,head:o}=s,l=this.toEditorPos(n.updateRangeStart),a=this.toEditorPos(n.updateRangeEnd);e.inputState.composing>=0&&!this.composing&&(this.composing={contextBase:n.updateRangeStart,editorBase:l,drifted:!1});let h={from:l,to:a,insert:$.of(n.text.split(`
10
+ `))};if(h.from==this.from&&r<this.from?h.from=r:h.to==this.to&&r>this.to&&(h.to=r),h.from==h.to&&!h.insert.length){let c=b.single(this.toEditorPos(n.selectionStart),this.toEditorPos(n.selectionEnd));c.main.eq(s)||e.dispatch({selection:c,userEvent:"select"});return}if((E.mac||E.android)&&h.from==o-1&&/^\. ?$/.test(n.text)&&e.contentDOM.getAttribute("autocorrect")=="off"&&(h={from:l,to:a,insert:$.of([n.text.replace("."," ")])}),this.pendingContextChange=h,!e.state.readOnly){let c=this.to-this.from+(h.to-h.from+h.insert.length);fl(e,h,b.single(this.toEditorPos(n.selectionStart,c),this.toEditorPos(n.selectionEnd,c)))}this.pendingContextChange&&(this.revertPending(e.state),this.setSelection(e.state))},this.handlers.characterboundsupdate=n=>{let s=[],r=null;for(let o=this.toEditorPos(n.rangeStart),l=this.toEditorPos(n.rangeEnd);o<l;o++){let a=e.coordsForChar(o);r=a&&new DOMRect(a.left,a.top,a.right-a.left,a.bottom-a.top)||r||new DOMRect,s.push(r)}t.updateCharacterBounds(n.rangeStart,s)},this.handlers.textformatupdate=n=>{let s=[];for(let r of n.getTextFormats()){let o=r.underlineStyle,l=r.underlineThickness;if(o!="None"&&l!="None"){let a=this.toEditorPos(r.rangeStart),h=this.toEditorPos(r.rangeEnd);if(a<h){let c=`text-decoration: underline ${o=="Dashed"?"dashed ":o=="Squiggle"?"wavy ":""}${l=="Thin"?1:2}px`;s.push(D.mark({attributes:{style:c}}).range(a,h))}}}e.dispatch({effects:Cf.of(D.set(s))})},this.handlers.compositionstart=()=>{e.inputState.composing<0&&(e.inputState.composing=0,e.inputState.compositionFirstChange=!0)},this.handlers.compositionend=()=>{if(e.inputState.composing=-1,e.inputState.compositionFirstChange=null,this.composing){let{drifted:n}=this.composing;this.composing=null,n&&this.reset(e.state)}};for(let n in this.handlers)t.addEventListener(n,this.handlers[n]);this.measureReq={read:n=>{this.editContext.updateControlBounds(n.contentDOM.getBoundingClientRect());let s=pn(n.root);s&&s.rangeCount&&this.editContext.updateSelectionBounds(s.getRangeAt(0).getBoundingClientRect())}}}applyEdits(e){let t=0,n=!1,s=this.pendingContextChange;return e.changes.iterChanges((r,o,l,a,h)=>{if(n)return;let c=h.length-(o-r);if(s&&o>=s.to)if(s.from==r&&s.to==o&&s.insert.eq(h)){s=this.pendingContextChange=null,t+=c,this.to+=c;return}else s=null,this.revertPending(e.state);if(r+=t,o+=t,o<=this.from)this.from+=c,this.to+=c;else if(r<this.to){if(r<this.from||o>this.to||this.to-this.from+h.length>3e4){n=!0;return}this.editContext.updateText(this.toContextPos(r),this.toContextPos(o),h.toString()),this.to+=c}t+=c}),s&&!n&&this.revertPending(e.state),!n}update(e){let t=this.pendingContextChange,n=e.startState.selection.main;this.composing&&(this.composing.drifted||!e.changes.touchesRange(n.from,n.to)&&e.transactions.some(s=>!s.isUserEvent("input.type")&&s.changes.touchesRange(this.from,this.to)))?(this.composing.drifted=!0,this.composing.editorBase=e.changes.mapPos(this.composing.editorBase)):!this.applyEdits(e)||!this.rangeIsValid(e.state)?(this.pendingContextChange=null,this.reset(e.state)):(e.docChanged||e.selectionSet||t)&&this.setSelection(e.state),(e.geometryChanged||e.docChanged||e.selectionSet)&&e.view.requestMeasure(this.measureReq)}resetRange(e){let{head:t}=e.selection.main;this.from=Math.max(0,t-1e4),this.to=Math.min(e.doc.length,t+1e4)}reset(e){this.resetRange(e),this.editContext.updateText(0,this.editContext.text.length,e.doc.sliceString(this.from,this.to)),this.setSelection(e)}revertPending(e){let t=this.pendingContextChange;this.pendingContextChange=null,this.editContext.updateText(this.toContextPos(t.from),this.toContextPos(t.from+t.insert.length),e.doc.sliceString(t.from,t.to))}setSelection(e){let{main:t}=e.selection,n=this.toContextPos(Math.max(this.from,Math.min(this.to,t.anchor))),s=this.toContextPos(t.head);(this.editContext.selectionStart!=n||this.editContext.selectionEnd!=s)&&this.editContext.updateSelection(n,s)}rangeIsValid(e){let{head:t}=e.selection.main;return!(this.from>0&&t-this.from<500||this.to<e.doc.length&&this.to-t<500||this.to-this.from>1e4*3)}toEditorPos(e,t=this.to-this.from){e=Math.min(e,t);let n=this.composing;return n&&n.drifted?n.editorBase+(e-n.contextBase):e+this.from}toContextPos(e){let t=this.composing;return t&&t.drifted?t.contextBase+(e-t.editorBase):e-this.from}destroy(){for(let e in this.handlers)this.editContext.removeEventListener(e,this.handlers[e])}}class Q{get state(){return this.viewState.state}get viewport(){return this.viewState.viewport}get visibleRanges(){return this.viewState.visibleRanges}get inView(){return this.viewState.inView}get composing(){return!!this.inputState&&this.inputState.composing>0}get compositionStarted(){return!!this.inputState&&this.inputState.composing>=0}get root(){return this._root}get win(){return this.dom.ownerDocument.defaultView||window}constructor(e={}){var t;this.plugins=[],this.pluginMap=new Map,this.editorAttrs={},this.contentAttrs={},this.bidiCache=[],this.destroyed=!1,this.updateState=2,this.measureScheduled=-1,this.measureRequests=[],this.contentDOM=document.createElement("div"),this.scrollDOM=document.createElement("div"),this.scrollDOM.tabIndex=-1,this.scrollDOM.className="cm-scroller",this.scrollDOM.appendChild(this.contentDOM),this.announceDOM=document.createElement("div"),this.announceDOM.className="cm-announced",this.announceDOM.setAttribute("aria-live","polite"),this.dom=document.createElement("div"),this.dom.appendChild(this.announceDOM),this.dom.appendChild(this.scrollDOM),e.parent&&e.parent.appendChild(this.dom);let{dispatch:n}=e;this.dispatchTransactions=e.dispatchTransactions||n&&(s=>s.forEach(r=>n(r,this)))||(s=>this.update(s)),this.dispatch=this.dispatch.bind(this),this._root=e.root||gm(e.parent)||document,this.viewState=new Na(e.state||K.create(e)),e.scrollTo&&e.scrollTo.is(zn)&&(this.viewState.scrollTarget=e.scrollTo.value.clip(this.viewState.state)),this.plugins=this.state.facet(bi).map(s=>new xr(s));for(let s of this.plugins)s.update(this);this.observer=new Tg(this),this.inputState=new ng(this),this.inputState.ensureHandlers(this.plugins),this.docView=new Oa(this),this.mountStyles(),this.updateAttrs(),this.updateState=0,this.requestMeasure(),!((t=document.fonts)===null||t===void 0)&&t.ready&&document.fonts.ready.then(()=>this.requestMeasure())}dispatch(...e){let t=e.length==1&&e[0]instanceof ae?e:e.length==1&&Array.isArray(e[0])?e[0]:[this.state.update(...e)];this.dispatchTransactions(t,this)}update(e){if(this.updateState!=0)throw new Error("Calls to EditorView.update are not allowed while an update is in progress");let t=!1,n=!1,s,r=this.state;for(let u of e){if(u.startState!=r)throw new RangeError("Trying to update state with a transaction that doesn't start from the previous state.");r=u.state}if(this.destroyed){this.viewState.state=r;return}let o=this.hasFocus,l=0,a=null;e.some(u=>u.annotation(Lf))?(this.inputState.notifiedFocused=o,l=1):o!=this.inputState.notifiedFocused&&(this.inputState.notifiedFocused=o,a=Nf(r,o),a||(l=1));let h=this.observer.delayedAndroidKey,c=null;if(h?(this.observer.clearDelayedAndroidKey(),c=this.observer.readChange(),(c&&!this.state.doc.eq(r.doc)||!this.state.selection.eq(r.selection))&&(c=null)):this.observer.clear(),r.facet(K.phrases)!=this.state.facet(K.phrases))return this.setState(r);s=Qs.create(this,r,e),s.flags|=l;let f=this.viewState.scrollTarget;try{this.updateState=2;for(let u of e){if(f&&(f=f.map(u.changes)),u.scrollIntoView){let{main:d}=u.state.selection;f=new Si(d.empty?d:b.cursor(d.head,d.head>d.anchor?-1:1))}for(let d of u.effects)d.is(zn)&&(f=d.value.clip(this.state))}this.viewState.update(s,f),this.bidiCache=Bs.update(this.bidiCache,s.changes),s.empty||(this.updatePlugins(s),this.inputState.update(s)),t=this.docView.update(s),this.state.facet(ji)!=this.styleModules&&this.mountStyles(),n=this.updateAttrs(),this.showAnnouncements(e),this.docView.updateSelection(t,e.some(u=>u.isUserEvent("select.pointer")))}finally{this.updateState=0}if(s.startState.facet(Gn)!=s.state.facet(Gn)&&(this.viewState.mustMeasureContent=!0),(t||n||f||this.viewState.mustEnforceCursorAssoc||this.viewState.mustMeasureContent)&&this.requestMeasure(),t&&this.docViewUpdate(),!s.empty)for(let u of this.state.facet(vo))try{u(s)}catch(d){ve(this.state,d,"update listener")}(a||c)&&Promise.resolve().then(()=>{a&&this.state==a.startState&&this.dispatch(a),c&&!Pf(this,c)&&h.force&&xi(this.contentDOM,h.key,h.keyCode)})}setState(e){if(this.updateState!=0)throw new Error("Calls to EditorView.setState are not allowed while an update is in progress");if(this.destroyed){this.viewState.state=e;return}this.updateState=2;let t=this.hasFocus;try{for(let n of this.plugins)n.destroy(this);this.viewState=new Na(e),this.plugins=e.facet(bi).map(n=>new xr(n)),this.pluginMap.clear();for(let n of this.plugins)n.update(this);this.docView.destroy(),this.docView=new Oa(this),this.inputState.ensureHandlers(this.plugins),this.mountStyles(),this.updateAttrs(),this.bidiCache=[]}finally{this.updateState=0}t&&this.focus(),this.requestMeasure()}updatePlugins(e){let t=e.startState.facet(bi),n=e.state.facet(bi);if(t!=n){let s=[];for(let r of n){let o=t.indexOf(r);if(o<0)s.push(new xr(r));else{let l=this.plugins[o];l.mustUpdate=e,s.push(l)}}for(let r of this.plugins)r.mustUpdate!=e&&r.destroy(this);this.plugins=s,this.pluginMap.clear()}else for(let s of this.plugins)s.mustUpdate=e;for(let s=0;s<this.plugins.length;s++)this.plugins[s].update(this);t!=n&&this.inputState.ensureHandlers(this.plugins)}docViewUpdate(){for(let e of this.plugins){let t=e.value;if(t&&t.docViewUpdate)try{t.docViewUpdate(this)}catch(n){ve(this.state,n,"doc view update listener")}}}measure(e=!0){if(this.destroyed)return;if(this.measureScheduled>-1&&this.win.cancelAnimationFrame(this.measureScheduled),this.observer.delayedAndroidKey){this.measureScheduled=-1,this.requestMeasure();return}this.measureScheduled=0,e&&this.observer.forceFlush();let t=null,n=this.scrollDOM,s=n.scrollTop*this.scaleY,{scrollAnchorPos:r,scrollAnchorHeight:o}=this.viewState;Math.abs(s-this.viewState.scrollTop)>1&&(o=-1),this.viewState.scrollAnchorHeight=-1;try{for(let l=0;;l++){if(o<0)if(Xc(n))r=-1,o=this.viewState.heightMap.height;else{let d=this.viewState.scrollAnchorAt(s);r=d.from,o=d.top}this.updateState=1;let a=this.viewState.measure(this);if(!a&&!this.measureRequests.length&&this.viewState.scrollTarget==null)break;if(l>5){console.warn(this.measureRequests.length?"Measure loop restarted more than 5 times":"Viewport failed to stabilize");break}let h=[];a&4||([this.measureRequests,h]=[h,this.measureRequests]);let c=h.map(d=>{try{return d.read(this)}catch(p){return ve(this.state,p),za}}),f=Qs.create(this,this.state,[]),u=!1;f.flags|=a,t?t.flags|=a:t=f,this.updateState=2,f.empty||(this.updatePlugins(f),this.inputState.update(f),this.updateAttrs(),u=this.docView.update(f),u&&this.docViewUpdate());for(let d=0;d<h.length;d++)if(c[d]!=za)try{let p=h[d];p.write&&p.write(c[d],this)}catch(p){ve(this.state,p)}if(u&&this.docView.updateSelection(!0),!f.viewportChanged&&this.measureRequests.length==0){if(this.viewState.editorHeight)if(this.viewState.scrollTarget){this.docView.scrollIntoView(this.viewState.scrollTarget),this.viewState.scrollTarget=null,o=-1;continue}else{let p=(r<0?this.viewState.heightMap.height:this.viewState.lineBlockAt(r).top)-o;if(p>1||p<-1){s=s+p,n.scrollTop=s/this.scaleY,o=-1;continue}}break}}}finally{this.updateState=0,this.measureScheduled=-1}if(t&&!t.empty)for(let l of this.state.facet(vo))l(t)}get themeClasses(){return Bo+" "+(this.state.facet(Eo)?zf:Kf)+" "+this.state.facet(Gn)}updateAttrs(){let e=_a(this,vf,{class:"cm-editor"+(this.hasFocus?" cm-focused ":" ")+this.themeClasses}),t={spellcheck:"false",autocorrect:"off",autocapitalize:"off",writingsuggestions:"false",translate:"no",contenteditable:this.state.facet(xt)?"true":"false",class:"cm-content",style:`${E.tabSize}: ${this.state.tabSize}`,role:"textbox","aria-multiline":"true"};this.state.readOnly&&(t["aria-readonly"]="true"),_a(this,al,t);let n=this.observer.ignore(()=>{let s=bo(this.contentDOM,this.contentAttrs,t),r=bo(this.dom,this.editorAttrs,e);return s||r});return this.editorAttrs=e,this.contentAttrs=t,n}showAnnouncements(e){let t=!0;for(let n of e)for(let s of n.effects)if(s.is(Q.announce)){t&&(this.announceDOM.textContent=""),t=!1;let r=this.announceDOM.appendChild(document.createElement("div"));r.textContent=s.value}}mountStyles(){this.styleModules=this.state.facet(ji);let e=this.state.facet(Q.cspNonce);Wt.mount(this.root,this.styleModules.concat(Dg).reverse(),e?{nonce:e}:void 0)}readMeasured(){if(this.updateState==2)throw new Error("Reading the editor layout isn't allowed during an update");this.updateState==0&&this.measureScheduled>-1&&this.measure(!1)}requestMeasure(e){if(this.measureScheduled<0&&(this.measureScheduled=this.win.requestAnimationFrame(()=>this.measure())),e){if(this.measureRequests.indexOf(e)>-1)return;if(e.key!=null){for(let t=0;t<this.measureRequests.length;t++)if(this.measureRequests[t].key===e.key){this.measureRequests[t]=e;return}}this.measureRequests.push(e)}}plugin(e){let t=this.pluginMap.get(e);return(t===void 0||t&&t.plugin!=e)&&this.pluginMap.set(e,t=this.plugins.find(n=>n.plugin==e)||null),t&&t.update(this).value}get documentTop(){return this.contentDOM.getBoundingClientRect().top+this.viewState.paddingTop}get documentPadding(){return{top:this.viewState.paddingTop,bottom:this.viewState.paddingBottom}}get scaleX(){return this.viewState.scaleX}get scaleY(){return this.viewState.scaleY}elementAtHeight(e){return this.readMeasured(),this.viewState.elementAtHeight(e)}lineBlockAtHeight(e){return this.readMeasured(),this.viewState.lineBlockAtHeight(e)}get viewportLineBlocks(){return this.viewState.viewportLines}lineBlockAt(e){return this.viewState.lineBlockAt(e)}get contentHeight(){return this.viewState.contentHeight}moveByChar(e,t,n){return Qr(this,e,Ca(this,e,t,n))}moveByGroup(e,t){return Qr(this,e,Ca(this,e,t,n=>Um(this,e.head,n)))}visualLineSide(e,t){let n=this.bidiSpans(e),s=this.textDirectionAt(e.from),r=n[t?n.length-1:0];return b.cursor(r.side(t,s)+e.from,r.forward(!t,s)?1:-1)}moveToLineBoundary(e,t,n=!0){return Gm(this,e,t,n)}moveVertically(e,t,n){return Qr(this,e,Ym(this,e,t,n))}domAtPos(e){return this.docView.domAtPos(e)}posAtDOM(e,t=0){return this.docView.posFromDOM(e,t)}posAtCoords(e,t=!0){return this.readMeasured(),Bf(this,e,t)}coordsAtPos(e,t=1){this.readMeasured();let n=this.docView.coordsAt(e,t);if(!n||n.left==n.right)return n;let s=this.state.doc.lineAt(e),r=this.bidiSpans(s),o=r[Kt.find(r,e-s.from,-1,t)];return js(n,o.dir==Z.LTR==t>0)}coordsForChar(e){return this.readMeasured(),this.docView.coordsForChar(e)}get defaultCharacterWidth(){return this.viewState.heightOracle.charWidth}get defaultLineHeight(){return this.viewState.heightOracle.lineHeight}get textDirection(){return this.viewState.defaultTextDirection}textDirectionAt(e){return!this.state.facet(wf)||e<this.viewport.from||e>this.viewport.to?this.textDirection:(this.readMeasured(),this.docView.textDirectionAt(e))}get lineWrapping(){return this.viewState.heightOracle.lineWrapping}bidiSpans(e){if(e.length>Ng)return uf(e.length);let t=this.textDirectionAt(e.from),n;for(let r of this.bidiCache)if(r.from==e.from&&r.dir==t&&(r.fresh||ff(r.isolates,n=Aa(this,e))))return r.order;n||(n=Aa(this,e));let s=Mm(e.text,t,n);return this.bidiCache.push(new Bs(e.from,e.to,t,n,!0,s)),s}get hasFocus(){var e;return(this.dom.ownerDocument.hasFocus()||E.safari&&((e=this.inputState)===null||e===void 0?void 0:e.lastContextMenu)>Date.now()-3e4)&&this.root.activeElement==this.contentDOM}focus(){this.observer.ignore(()=>{Uc(this.contentDOM),this.docView.updateSelection()})}setRoot(e){this._root!=e&&(this._root=e,this.observer.setWindow((e.nodeType==9?e:e.ownerDocument).defaultView||window),this.mountStyles())}destroy(){this.root.activeElement==this.contentDOM&&this.contentDOM.blur();for(let e of this.plugins)e.destroy(this);this.plugins=[],this.inputState.destroy(),this.docView.destroy(),this.dom.remove(),this.observer.destroy(),this.measureScheduled>-1&&this.win.cancelAnimationFrame(this.measureScheduled),this.destroyed=!0}static scrollIntoView(e,t={}){return zn.of(new Si(typeof e=="number"?b.cursor(e):e,t.y,t.x,t.yMargin,t.xMargin))}scrollSnapshot(){let{scrollTop:e,scrollLeft:t}=this.scrollDOM,n=this.viewState.scrollAnchorAt(e);return zn.of(new Si(b.cursor(n.from),"start","start",n.top-e,t,!0))}setTabFocusMode(e){e==null?this.inputState.tabFocusMode=this.inputState.tabFocusMode<0?0:-1:typeof e=="boolean"?this.inputState.tabFocusMode=e?0:-1:this.inputState.tabFocusMode!=0&&(this.inputState.tabFocusMode=Date.now()+e)}static domEventHandlers(e){return ne.define(()=>({}),{eventHandlers:e})}static domEventObservers(e){return ne.define(()=>({}),{eventObservers:e})}static theme(e,t){let n=Wt.newName(),s=[Gn.of(n),ji.of(Po(`.${n}`,e))];return t&&t.dark&&s.push(Eo.of(!0)),s}static baseTheme(e){return di.lowest(ji.of(Po("."+Bo,e,_f)))}static findFromDOM(e){var t;let n=e.querySelector(".cm-content"),s=n&&Y.get(n)||Y.get(e);return((t=s?.rootView)===null||t===void 0?void 0:t.view)||null}}Q.styleModule=ji;Q.inputHandler=Of;Q.clipboardInputFilter=ol;Q.clipboardOutputFilter=ll;Q.scrollHandler=kf;Q.focusChangeEffect=bf;Q.perLineTextDirection=wf;Q.exceptionSink=Af;Q.updateListener=vo;Q.editable=xt;Q.mouseSelectionStyle=gf;Q.dragMovesSelection=mf;Q.clickAddsSelectionRange=pf;Q.decorations=gn;Q.outerDecorations=xf;Q.atomicRanges=hl;Q.bidiIsolatedRanges=Sf;Q.scrollMargins=Qf;Q.darkTheme=Eo;Q.cspNonce=B.define({combine:i=>i.length?i[0]:""});Q.contentAttributes=al;Q.editorAttributes=vf;Q.lineWrapping=Q.contentAttributes.of({class:"cm-lineWrapping"});Q.announce=R.define();const Ng=4096,za={};class Bs{constructor(e,t,n,s,r,o){this.from=e,this.to=t,this.dir=n,this.isolates=s,this.fresh=r,this.order=o}static update(e,t){if(t.empty&&!e.some(r=>r.fresh))return e;let n=[],s=e.length?e[e.length-1].dir:Z.LTR;for(let r=Math.max(0,e.length-10);r<e.length;r++){let o=e[r];o.dir==s&&!t.touchesRange(o.from,o.to)&&n.push(new Bs(t.mapPos(o.from,1),t.mapPos(o.to,-1),o.dir,o.isolates,!1,o.order))}return n}}function _a(i,e,t){for(let n=i.state.facet(e),s=n.length-1;s>=0;s--){let r=n[s],o=typeof r=="function"?r(i):r;o&&Oo(o,t)}return t}const $g=E.mac?"mac":E.windows?"win":E.linux?"linux":"key";function Fg(i,e){const t=i.split(/-(?!$)/);let n=t[t.length-1];n=="Space"&&(n=" ");let s,r,o,l;for(let a=0;a<t.length-1;++a){const h=t[a];if(/^(cmd|meta|m)$/i.test(h))l=!0;else if(/^a(lt)?$/i.test(h))s=!0;else if(/^(c|ctrl|control)$/i.test(h))r=!0;else if(/^s(hift)?$/i.test(h))o=!0;else if(/^mod$/i.test(h))e=="mac"?l=!0:r=!0;else throw new Error("Unrecognized modifier name: "+h)}return s&&(n="Alt-"+n),r&&(n="Ctrl-"+n),l&&(n="Meta-"+n),o&&(n="Shift-"+n),n}function Un(i,e,t){return e.altKey&&(i="Alt-"+i),e.ctrlKey&&(i="Ctrl-"+i),e.metaKey&&(i="Meta-"+i),t!==!1&&e.shiftKey&&(i="Shift-"+i),i}const Kg=di.default(Q.domEventHandlers({keydown(i,e){return Wf(Vf(e.state),i,e,"editor")}})),pl=B.define({enables:Kg}),Va=new WeakMap;function Vf(i){let e=i.facet(pl),t=Va.get(e);return t||Va.set(e,t=Vg(e.reduce((n,s)=>n.concat(s),[]))),t}function zg(i,e,t){return Wf(Vf(i.state),e,i,t)}let Rt=null;const _g=4e3;function Vg(i,e=$g){let t=Object.create(null),n=Object.create(null),s=(o,l)=>{let a=n[o];if(a==null)n[o]=l;else if(a!=l)throw new Error("Key binding "+o+" is used both as a regular binding and as a multi-stroke prefix")},r=(o,l,a,h,c)=>{var f,u;let d=t[o]||(t[o]=Object.create(null)),p=l.split(/ (?!$)/).map(O=>Fg(O,e));for(let O=1;O<p.length;O++){let w=p.slice(0,O).join(" ");s(w,!0),d[w]||(d[w]={preventDefault:!0,stopPropagation:!1,run:[k=>{let v=Rt={view:k,prefix:w,scope:o};return setTimeout(()=>{Rt==v&&(Rt=null)},_g),!0}]})}let m=p.join(" ");s(m,!1);let g=d[m]||(d[m]={preventDefault:!1,stopPropagation:!1,run:((u=(f=d._any)===null||f===void 0?void 0:f.run)===null||u===void 0?void 0:u.slice())||[]});a&&g.run.push(a),h&&(g.preventDefault=!0),c&&(g.stopPropagation=!0)};for(let o of i){let l=o.scope?o.scope.split(" "):["editor"];if(o.any)for(let h of l){let c=t[h]||(t[h]=Object.create(null));c._any||(c._any={preventDefault:!1,stopPropagation:!1,run:[]});let{any:f}=o;for(let u in c)c[u].run.push(d=>f(d,Mo))}let a=o[e]||o.key;if(a)for(let h of l)r(h,a,o.run,o.preventDefault,o.stopPropagation),o.shift&&r(h,"Shift-"+a,o.shift,o.preventDefault,o.stopPropagation)}return t}let Mo=null;function Wf(i,e,t,n){Mo=e;let s=fm(e),r=Ee(s,0),o=dt(r)==s.length&&s!=" ",l="",a=!1,h=!1,c=!1;Rt&&Rt.view==t&&Rt.scope==n&&(l=Rt.prefix+" ",Df.indexOf(e.keyCode)<0&&(h=!0,Rt=null));let f=new Set,u=g=>{if(g){for(let O of g.run)if(!f.has(O)&&(f.add(O),O(t)))return g.stopPropagation&&(c=!0),!0;g.preventDefault&&(g.stopPropagation&&(c=!0),h=!0)}return!1},d=i[n],p,m;return d&&(u(d[l+Un(s,e,!o)])?a=!0:o&&(e.altKey||e.metaKey||e.ctrlKey)&&!(E.windows&&e.ctrlKey&&e.altKey)&&(p=Ht[e.keyCode])&&p!=s?(u(d[l+Un(p,e,!0)])||e.shiftKey&&(m=dn[e.keyCode])!=s&&m!=p&&u(d[l+Un(m,e,!1)]))&&(a=!0):o&&e.shiftKey&&u(d[l+Un(s,e,!0)])&&(a=!0),!a&&u(d._any)&&(a=!0)),h&&(a=!0),a&&c&&e.stopPropagation(),Mo=null,a}class Pn{constructor(e,t,n,s,r){this.className=e,this.left=t,this.top=n,this.width=s,this.height=r}draw(){let e=document.createElement("div");return e.className=this.className,this.adjust(e),e}update(e,t){return t.className!=this.className?!1:(this.adjust(e),!0)}adjust(e){e.style.left=this.left+"px",e.style.top=this.top+"px",this.width!=null&&(e.style.width=this.width+"px"),e.style.height=this.height+"px"}eq(e){return this.left==e.left&&this.top==e.top&&this.width==e.width&&this.height==e.height&&this.className==e.className}static forRange(e,t,n){if(n.empty){let s=e.coordsAtPos(n.head,n.assoc||1);if(!s)return[];let r=Hf(e);return[new Pn(t,s.left-r.left,s.top-r.top,null,s.bottom-s.top)]}else return Wg(e,t,n)}}function Hf(i){let e=i.scrollDOM.getBoundingClientRect();return{left:(i.textDirection==Z.LTR?e.left:e.right-i.scrollDOM.clientWidth*i.scaleX)-i.scrollDOM.scrollLeft*i.scaleX,top:e.top-i.scrollDOM.scrollTop*i.scaleY}}function Wa(i,e,t,n){let s=i.coordsAtPos(e,t*2);if(!s)return n;let r=i.dom.getBoundingClientRect(),o=(s.top+s.bottom)/2,l=i.posAtCoords({x:r.left+1,y:o}),a=i.posAtCoords({x:r.right-1,y:o});return l==null||a==null?n:{from:Math.max(n.from,Math.min(l,a)),to:Math.min(n.to,Math.max(l,a))}}function Wg(i,e,t){if(t.to<=i.viewport.from||t.from>=i.viewport.to)return[];let n=Math.max(t.from,i.viewport.from),s=Math.min(t.to,i.viewport.to),r=i.textDirection==Z.LTR,o=i.contentDOM,l=o.getBoundingClientRect(),a=Hf(i),h=o.querySelector(".cm-line"),c=h&&window.getComputedStyle(h),f=l.left+(c?parseInt(c.paddingLeft)+Math.min(0,parseInt(c.textIndent)):0),u=l.right-(c?parseInt(c.paddingRight):0),d=So(i,n,1),p=So(i,s,-1),m=d.type==xe.Text?d:null,g=p.type==xe.Text?p:null;if(m&&(i.lineWrapping||d.widgetLineBreaks)&&(m=Wa(i,n,1,m)),g&&(i.lineWrapping||p.widgetLineBreaks)&&(g=Wa(i,s,-1,g)),m&&g&&m.from==g.from&&m.to==g.to)return w(k(t.from,t.to,m));{let y=m?k(t.from,null,m):v(d,!1),C=g?k(null,t.to,g):v(p,!0),x=[];return(m||d).to<(g||p).from-(m&&g?1:0)||d.widgetLineBreaks>1&&y.bottom+i.defaultLineHeight/2<C.top?x.push(O(f,y.bottom,u,C.top)):y.bottom<C.top&&i.elementAtHeight((y.bottom+C.top)/2).type==xe.Text&&(y.bottom=C.top=(y.bottom+C.top)/2),w(y).concat(x).concat(w(C))}function O(y,C,x,I){return new Pn(e,y-a.left,C-a.top,x-y,I-C)}function w({top:y,bottom:C,horizontal:x}){let I=[];for(let T=0;T<x.length;T+=2)I.push(O(x[T],y,x[T+1],C));return I}function k(y,C,x){let I=1e9,T=-1e9,V=[];function M(z,H,te,he,Ie){let X=i.coordsAtPos(z,z==x.to?-2:2),Qe=i.coordsAtPos(te,te==x.from?2:-2);!X||!Qe||(I=Math.min(X.top,Qe.top,I),T=Math.max(X.bottom,Qe.bottom,T),Ie==Z.LTR?V.push(r&&H?f:X.left,r&&he?u:Qe.right):V.push(!r&&he?f:Qe.left,!r&&H?u:X.right))}let P=y??x.from,W=C??x.to;for(let z of i.visibleRanges)if(z.to>P&&z.from<W)for(let H=Math.max(z.from,P),te=Math.min(z.to,W);;){let he=i.state.doc.lineAt(H);for(let Ie of i.bidiSpans(he)){let X=Ie.from+he.from,Qe=Ie.to+he.from;if(X>=te)break;Qe>H&&M(Math.max(X,H),y==null&&X<=P,Math.min(Qe,te),C==null&&Qe>=W,Ie.dir)}if(H=he.to+1,H>=te)break}return V.length==0&&M(P,y==null,W,C==null,i.textDirection),{top:I,bottom:T,horizontal:V}}function v(y,C){let x=l.top+(C?y.top:y.bottom);return{top:x,bottom:x,horizontal:[]}}}function Hg(i,e){return i.constructor==e.constructor&&i.eq(e)}class qg{constructor(e,t){this.view=e,this.layer=t,this.drawn=[],this.scaleX=1,this.scaleY=1,this.measureReq={read:this.measure.bind(this),write:this.draw.bind(this)},this.dom=e.scrollDOM.appendChild(document.createElement("div")),this.dom.classList.add("cm-layer"),t.above&&this.dom.classList.add("cm-layer-above"),t.class&&this.dom.classList.add(t.class),this.scale(),this.dom.setAttribute("aria-hidden","true"),this.setOrder(e.state),e.requestMeasure(this.measureReq),t.mount&&t.mount(this.dom,e)}update(e){e.startState.facet(As)!=e.state.facet(As)&&this.setOrder(e.state),(this.layer.update(e,this.dom)||e.geometryChanged)&&(this.scale(),e.view.requestMeasure(this.measureReq))}docViewUpdate(e){this.layer.updateOnDocViewUpdate!==!1&&e.requestMeasure(this.measureReq)}setOrder(e){let t=0,n=e.facet(As);for(;t<n.length&&n[t]!=this.layer;)t++;this.dom.style.zIndex=String((this.layer.above?150:-1)-t)}measure(){return this.layer.markers(this.view)}scale(){let{scaleX:e,scaleY:t}=this.view;(e!=this.scaleX||t!=this.scaleY)&&(this.scaleX=e,this.scaleY=t,this.dom.style.transform=`scale(${1/e}, ${1/t})`)}draw(e){if(e.length!=this.drawn.length||e.some((t,n)=>!Hg(t,this.drawn[n]))){let t=this.dom.firstChild,n=0;for(let s of e)s.update&&t&&s.constructor&&this.drawn[n].constructor&&s.update(t,this.drawn[n])?(t=t.nextSibling,n++):this.dom.insertBefore(s.draw(),t);for(;t;){let s=t.nextSibling;t.remove(),t=s}this.drawn=e}}destroy(){this.layer.destroy&&this.layer.destroy(this.dom,this.view),this.dom.remove()}}const As=B.define();function qf(i){return[ne.define(e=>new qg(e,i)),As.of(i)]}const An=B.define({combine(i){return yt(i,{cursorBlinkRate:1200,drawRangeCursor:!0},{cursorBlinkRate:(e,t)=>Math.min(e,t),drawRangeCursor:(e,t)=>e||t})}});function Gg(i={}){return[An.of(i),Ug,Yg,Xg,yf.of(!0)]}function Gf(i){return i.startState.facet(An)!=i.state.facet(An)}const Ug=qf({above:!0,markers(i){let{state:e}=i,t=e.facet(An),n=[];for(let s of e.selection.ranges){let r=s==e.selection.main;if(s.empty||t.drawRangeCursor){let o=r?"cm-cursor cm-cursor-primary":"cm-cursor cm-cursor-secondary",l=s.empty?s:b.cursor(s.head,s.head>s.anchor?-1:1);for(let a of Pn.forRange(i,o,l))n.push(a)}}return n},update(i,e){i.transactions.some(n=>n.selection)&&(e.style.animationName=e.style.animationName=="cm-blink"?"cm-blink2":"cm-blink");let t=Gf(i);return t&&Ha(i.state,e),i.docChanged||i.selectionSet||t},mount(i,e){Ha(e.state,i)},class:"cm-cursorLayer"});function Ha(i,e){e.style.animationDuration=i.facet(An).cursorBlinkRate+"ms"}const Yg=qf({above:!1,markers(i){return i.state.selection.ranges.map(e=>e.empty?[]:Pn.forRange(i,"cm-selectionBackground",e)).reduce((e,t)=>e.concat(t))},update(i,e){return i.docChanged||i.selectionSet||i.viewportChanged||Gf(i)},class:"cm-selectionLayer"}),Xg=di.highest(Q.theme({".cm-line":{"& ::selection, &::selection":{backgroundColor:"transparent !important"},caretColor:"transparent !important"},".cm-content":{caretColor:"transparent !important","& :focus":{caretColor:"initial !important","&::selection, & ::selection":{backgroundColor:"Highlight !important"}}}})),Uf=R.define({map(i,e){return i==null?null:e.mapPos(i)}}),en=ge.define({create(){return null},update(i,e){return i!=null&&(i=e.changes.mapPos(i)),e.effects.reduce((t,n)=>n.is(Uf)?n.value:t,i)}}),jg=ne.fromClass(class{constructor(i){this.view=i,this.cursor=null,this.measureReq={read:this.readPos.bind(this),write:this.drawCursor.bind(this)}}update(i){var e;let t=i.state.field(en);t==null?this.cursor!=null&&((e=this.cursor)===null||e===void 0||e.remove(),this.cursor=null):(this.cursor||(this.cursor=this.view.scrollDOM.appendChild(document.createElement("div")),this.cursor.className="cm-dropCursor"),(i.startState.field(en)!=t||i.docChanged||i.geometryChanged)&&this.view.requestMeasure(this.measureReq))}readPos(){let{view:i}=this,e=i.state.field(en),t=e!=null&&i.coordsAtPos(e);if(!t)return null;let n=i.scrollDOM.getBoundingClientRect();return{left:t.left-n.left+i.scrollDOM.scrollLeft*i.scaleX,top:t.top-n.top+i.scrollDOM.scrollTop*i.scaleY,height:t.bottom-t.top}}drawCursor(i){if(this.cursor){let{scaleX:e,scaleY:t}=this.view;i?(this.cursor.style.left=i.left/e+"px",this.cursor.style.top=i.top/t+"px",this.cursor.style.height=i.height/t+"px"):this.cursor.style.left="-100000px"}}destroy(){this.cursor&&this.cursor.remove()}setDropPos(i){this.view.state.field(en)!=i&&this.view.dispatch({effects:Uf.of(i)})}},{eventObservers:{dragover(i){this.setDropPos(this.view.posAtCoords({x:i.clientX,y:i.clientY}))},dragleave(i){(i.target==this.view.contentDOM||!this.view.contentDOM.contains(i.relatedTarget))&&this.setDropPos(null)},dragend(){this.setDropPos(null)},drop(){this.setDropPos(null)}}});function Jg(){return[en,jg]}function qa(i,e,t,n,s){e.lastIndex=0;for(let r=i.iterRange(t,n),o=t,l;!r.next().done;o+=r.value.length)if(!r.lineBreak)for(;l=e.exec(r.value);)s(o+l.index,l)}function Zg(i,e){let t=i.visibleRanges;if(t.length==1&&t[0].from==i.viewport.from&&t[0].to==i.viewport.to)return t;let n=[];for(let{from:s,to:r}of t)s=Math.max(i.state.doc.lineAt(s).from,s-e),r=Math.min(i.state.doc.lineAt(r).to,r+e),n.length&&n[n.length-1].to>=s?n[n.length-1].to=r:n.push({from:s,to:r});return n}class eA{constructor(e){const{regexp:t,decoration:n,decorate:s,boundary:r,maxLength:o=1e3}=e;if(!t.global)throw new RangeError("The regular expression given to MatchDecorator should have its 'g' flag set");if(this.regexp=t,s)this.addMatch=(l,a,h,c)=>s(c,h,h+l[0].length,l,a);else if(typeof n=="function")this.addMatch=(l,a,h,c)=>{let f=n(l,a,h);f&&c(h,h+l[0].length,f)};else if(n)this.addMatch=(l,a,h,c)=>c(h,h+l[0].length,n);else throw new RangeError("Either 'decorate' or 'decoration' should be provided to MatchDecorator");this.boundary=r,this.maxLength=o}createDeco(e){let t=new Qt,n=t.add.bind(t);for(let{from:s,to:r}of Zg(e,this.maxLength))qa(e.state.doc,this.regexp,s,r,(o,l)=>this.addMatch(l,e,o,n));return t.finish()}updateDeco(e,t){let n=1e9,s=-1;return e.docChanged&&e.changes.iterChanges((r,o,l,a)=>{a>=e.view.viewport.from&&l<=e.view.viewport.to&&(n=Math.min(l,n),s=Math.max(a,s))}),e.viewportMoved||s-n>1e3?this.createDeco(e.view):s>-1?this.updateRange(e.view,t.map(e.changes),n,s):t}updateRange(e,t,n,s){for(let r of e.visibleRanges){let o=Math.max(r.from,n),l=Math.min(r.to,s);if(l>=o){let a=e.state.doc.lineAt(o),h=a.to<l?e.state.doc.lineAt(l):a,c=Math.max(r.from,a.from),f=Math.min(r.to,h.to);if(this.boundary){for(;o>a.from;o--)if(this.boundary.test(a.text[o-1-a.from])){c=o;break}for(;l<h.to;l++)if(this.boundary.test(h.text[l-h.from])){f=l;break}}let u=[],d,p=(m,g,O)=>u.push(O.range(m,g));if(a==h)for(this.regexp.lastIndex=c-a.from;(d=this.regexp.exec(a.text))&&d.index<f-a.from;)this.addMatch(d,e,d.index+a.from,p);else qa(e.state.doc,this.regexp,c,f,(m,g)=>this.addMatch(g,e,m,p));t=t.update({filterFrom:c,filterTo:f,filter:(m,g)=>m<c||g>f,add:u})}}return t}}const Do=/x/.unicode!=null?"gu":"g",tA=new RegExp(`[\0-\b
11
+ --Ÿ­؜​‎‏\u2028\u2029‭‮⁦⁧⁩\uFEFF-]`,Do),iA={0:"null",7:"bell",8:"backspace",10:"newline",11:"vertical tab",13:"carriage return",27:"escape",8203:"zero width space",8204:"zero width non-joiner",8205:"zero width joiner",8206:"left-to-right mark",8207:"right-to-left mark",8232:"line separator",8237:"left-to-right override",8238:"right-to-left override",8294:"left-to-right isolate",8295:"right-to-left isolate",8297:"pop directional isolate",8233:"paragraph separator",65279:"zero width no-break space",65532:"object replacement"};let Pr=null;function nA(){var i;if(Pr==null&&typeof document<"u"&&document.body){let e=document.body.style;Pr=((i=e.tabSize)!==null&&i!==void 0?i:e.MozTabSize)!=null}return Pr||!1}const Os=B.define({combine(i){let e=yt(i,{render:null,specialChars:tA,addSpecialChars:null});return(e.replaceTabs=!nA())&&(e.specialChars=new RegExp(" |"+e.specialChars.source,Do)),e.addSpecialChars&&(e.specialChars=new RegExp(e.specialChars.source+"|"+e.addSpecialChars.source,Do)),e}});function sA(i={}){return[Os.of(i),rA()]}let Ga=null;function rA(){return Ga||(Ga=ne.fromClass(class{constructor(i){this.view=i,this.decorations=D.none,this.decorationCache=Object.create(null),this.decorator=this.makeDecorator(i.state.facet(Os)),this.decorations=this.decorator.createDeco(i)}makeDecorator(i){return new eA({regexp:i.specialChars,decoration:(e,t,n)=>{let{doc:s}=t.state,r=Ee(e[0],0);if(r==9){let o=s.lineAt(n),l=t.state.tabSize,a=$i(o.text,l,n-o.from);return D.replace({widget:new hA((l-a%l)*this.view.defaultCharacterWidth/this.view.scaleX)})}return this.decorationCache[r]||(this.decorationCache[r]=D.replace({widget:new aA(i,r)}))},boundary:i.replaceTabs?void 0:/[^]/})}update(i){let e=i.state.facet(Os);i.startState.facet(Os)!=e?(this.decorator=this.makeDecorator(e),this.decorations=this.decorator.createDeco(i.view)):this.decorations=this.decorator.updateDeco(i,this.decorations)}},{decorations:i=>i.decorations}))}const oA="•";function lA(i){return i>=32?oA:i==10?"␤":String.fromCharCode(9216+i)}class aA extends Ut{constructor(e,t){super(),this.options=e,this.code=t}eq(e){return e.code==this.code}toDOM(e){let t=lA(this.code),n=e.state.phrase("Control character")+" "+(iA[this.code]||"0x"+this.code.toString(16)),s=this.options.render&&this.options.render(this.code,n,t);if(s)return s;let r=document.createElement("span");return r.textContent=t,r.title=n,r.setAttribute("aria-label",n),r.className="cm-specialChar",r}ignoreEvent(){return!1}}class hA extends Ut{constructor(e){super(),this.width=e}eq(e){return e.width==this.width}toDOM(){let e=document.createElement("span");return e.textContent=" ",e.className="cm-tab",e.style.width=this.width+"px",e}ignoreEvent(){return!1}}function cA(){return uA}const fA=D.line({class:"cm-activeLine"}),uA=ne.fromClass(class{constructor(i){this.decorations=this.getDeco(i)}update(i){(i.docChanged||i.selectionSet)&&(this.decorations=this.getDeco(i.view))}getDeco(i){let e=-1,t=[];for(let n of i.state.selection.ranges){let s=i.lineBlockAt(n.head);s.from>e&&(t.push(fA.range(s.from)),e=s.from)}return D.set(t)}},{decorations:i=>i.decorations}),Io=2e3;function dA(i,e,t){let n=Math.min(e.line,t.line),s=Math.max(e.line,t.line),r=[];if(e.off>Io||t.off>Io||e.col<0||t.col<0){let o=Math.min(e.off,t.off),l=Math.max(e.off,t.off);for(let a=n;a<=s;a++){let h=i.doc.line(a);h.length<=l&&r.push(b.range(h.from+o,h.to+l))}}else{let o=Math.min(e.col,t.col),l=Math.max(e.col,t.col);for(let a=n;a<=s;a++){let h=i.doc.line(a),c=co(h.text,o,i.tabSize,!0);if(c<0)r.push(b.cursor(h.to));else{let f=co(h.text,l,i.tabSize);r.push(b.range(h.from+c,h.from+f))}}}return r}function pA(i,e){let t=i.coordsAtPos(i.viewport.from);return t?Math.round(Math.abs((t.left-e)/i.defaultCharacterWidth)):-1}function Ua(i,e){let t=i.posAtCoords({x:e.clientX,y:e.clientY},!1),n=i.state.doc.lineAt(t),s=t-n.from,r=s>Io?-1:s==n.length?pA(i,e.clientX):$i(n.text,i.state.tabSize,t-n.from);return{line:n.number,col:r,off:s}}function mA(i,e){let t=Ua(i,e),n=i.state.selection;return t?{update(s){if(s.docChanged){let r=s.changes.mapPos(s.startState.doc.line(t.line).from),o=s.state.doc.lineAt(r);t={line:o.number,col:t.col,off:Math.min(t.off,o.length)},n=n.map(s.changes)}},get(s,r,o){let l=Ua(i,s);if(!l)return n;let a=dA(i.state,t,l);return a.length?o?b.create(a.concat(n.ranges)):b.create(a):n}}:null}function gA(i){let e=(t=>t.altKey&&t.button==0);return Q.mouseSelectionStyle.of((t,n)=>e(n)?mA(t,n):null)}const AA={Alt:[18,i=>!!i.altKey],Control:[17,i=>!!i.ctrlKey],Shift:[16,i=>!!i.shiftKey],Meta:[91,i=>!!i.metaKey]},OA={style:"cursor: crosshair"};function bA(i={}){let[e,t]=AA[i.key||"Alt"],n=ne.fromClass(class{constructor(s){this.view=s,this.isDown=!1}set(s){this.isDown!=s&&(this.isDown=s,this.view.update([]))}},{eventObservers:{keydown(s){this.set(s.keyCode==e||t(s))},keyup(s){(s.keyCode==e||!t(s))&&this.set(!1)},mousemove(s){this.set(t(s))}}});return[n,Q.contentAttributes.of(s=>{var r;return!((r=s.plugin(n))===null||r===void 0)&&r.isDown?OA:null})]}const Gi="-10000px";class Yf{constructor(e,t,n,s){this.facet=t,this.createTooltipView=n,this.removeTooltipView=s,this.input=e.state.facet(t),this.tooltips=this.input.filter(o=>o);let r=null;this.tooltipViews=this.tooltips.map(o=>r=n(o,r))}update(e,t){var n;let s=e.state.facet(this.facet),r=s.filter(a=>a);if(s===this.input){for(let a of this.tooltipViews)a.update&&a.update(e);return!1}let o=[],l=t?[]:null;for(let a=0;a<r.length;a++){let h=r[a],c=-1;if(h){for(let f=0;f<this.tooltips.length;f++){let u=this.tooltips[f];u&&u.create==h.create&&(c=f)}if(c<0)o[a]=this.createTooltipView(h,a?o[a-1]:null),l&&(l[a]=!!h.above);else{let f=o[a]=this.tooltipViews[c];l&&(l[a]=t[c]),f.update&&f.update(e)}}}for(let a of this.tooltipViews)o.indexOf(a)<0&&(this.removeTooltipView(a),(n=a.destroy)===null||n===void 0||n.call(a));return t&&(l.forEach((a,h)=>t[h]=a),t.length=l.length),this.input=s,this.tooltips=r,this.tooltipViews=o,!0}}function wA(i){let e=i.dom.ownerDocument.documentElement;return{top:0,left:0,bottom:e.clientHeight,right:e.clientWidth}}const Mr=B.define({combine:i=>{var e,t,n;return{position:E.ios?"absolute":((e=i.find(s=>s.position))===null||e===void 0?void 0:e.position)||"fixed",parent:((t=i.find(s=>s.parent))===null||t===void 0?void 0:t.parent)||null,tooltipSpace:((n=i.find(s=>s.tooltipSpace))===null||n===void 0?void 0:n.tooltipSpace)||wA}}}),Ya=new WeakMap,ml=ne.fromClass(class{constructor(i){this.view=i,this.above=[],this.inView=!0,this.madeAbsolute=!1,this.lastTransaction=0,this.measureTimeout=-1;let e=i.state.facet(Mr);this.position=e.position,this.parent=e.parent,this.classes=i.themeClasses,this.createContainer(),this.measureReq={read:this.readMeasure.bind(this),write:this.writeMeasure.bind(this),key:this},this.resizeObserver=typeof ResizeObserver=="function"?new ResizeObserver(()=>this.measureSoon()):null,this.manager=new Yf(i,gl,(t,n)=>this.createTooltip(t,n),t=>{this.resizeObserver&&this.resizeObserver.unobserve(t.dom),t.dom.remove()}),this.above=this.manager.tooltips.map(t=>!!t.above),this.intersectionObserver=typeof IntersectionObserver=="function"?new IntersectionObserver(t=>{Date.now()>this.lastTransaction-50&&t.length>0&&t[t.length-1].intersectionRatio<1&&this.measureSoon()},{threshold:[1]}):null,this.observeIntersection(),i.win.addEventListener("resize",this.measureSoon=this.measureSoon.bind(this)),this.maybeMeasure()}createContainer(){this.parent?(this.container=document.createElement("div"),this.container.style.position="relative",this.container.className=this.view.themeClasses,this.parent.appendChild(this.container)):this.container=this.view.dom}observeIntersection(){if(this.intersectionObserver){this.intersectionObserver.disconnect();for(let i of this.manager.tooltipViews)this.intersectionObserver.observe(i.dom)}}measureSoon(){this.measureTimeout<0&&(this.measureTimeout=setTimeout(()=>{this.measureTimeout=-1,this.maybeMeasure()},50))}update(i){i.transactions.length&&(this.lastTransaction=Date.now());let e=this.manager.update(i,this.above);e&&this.observeIntersection();let t=e||i.geometryChanged,n=i.state.facet(Mr);if(n.position!=this.position&&!this.madeAbsolute){this.position=n.position;for(let s of this.manager.tooltipViews)s.dom.style.position=this.position;t=!0}if(n.parent!=this.parent){this.parent&&this.container.remove(),this.parent=n.parent,this.createContainer();for(let s of this.manager.tooltipViews)this.container.appendChild(s.dom);t=!0}else this.parent&&this.view.themeClasses!=this.classes&&(this.classes=this.container.className=this.view.themeClasses);t&&this.maybeMeasure()}createTooltip(i,e){let t=i.create(this.view),n=e?e.dom:null;if(t.dom.classList.add("cm-tooltip"),i.arrow&&!t.dom.querySelector(".cm-tooltip > .cm-tooltip-arrow")){let s=document.createElement("div");s.className="cm-tooltip-arrow",t.dom.appendChild(s)}return t.dom.style.position=this.position,t.dom.style.top=Gi,t.dom.style.left="0px",this.container.insertBefore(t.dom,n),t.mount&&t.mount(this.view),this.resizeObserver&&this.resizeObserver.observe(t.dom),t}destroy(){var i,e,t;this.view.win.removeEventListener("resize",this.measureSoon);for(let n of this.manager.tooltipViews)n.dom.remove(),(i=n.destroy)===null||i===void 0||i.call(n);this.parent&&this.container.remove(),(e=this.resizeObserver)===null||e===void 0||e.disconnect(),(t=this.intersectionObserver)===null||t===void 0||t.disconnect(),clearTimeout(this.measureTimeout)}readMeasure(){let i=1,e=1,t=!1;if(this.position=="fixed"&&this.manager.tooltipViews.length){let{dom:r}=this.manager.tooltipViews[0];if(E.gecko)t=r.offsetParent!=this.container.ownerDocument.body;else if(r.style.top==Gi&&r.style.left=="0px"){let o=r.getBoundingClientRect();t=Math.abs(o.top+1e4)>1||Math.abs(o.left)>1}}if(t||this.position=="absolute")if(this.parent){let r=this.parent.getBoundingClientRect();r.width&&r.height&&(i=r.width/this.parent.offsetWidth,e=r.height/this.parent.offsetHeight)}else({scaleX:i,scaleY:e}=this.view.viewState);let n=this.view.scrollDOM.getBoundingClientRect(),s=cl(this.view);return{visible:{left:n.left+s.left,top:n.top+s.top,right:n.right-s.right,bottom:n.bottom-s.bottom},parent:this.parent?this.container.getBoundingClientRect():this.view.dom.getBoundingClientRect(),pos:this.manager.tooltips.map((r,o)=>{let l=this.manager.tooltipViews[o];return l.getCoords?l.getCoords(r.pos):this.view.coordsAtPos(r.pos)}),size:this.manager.tooltipViews.map(({dom:r})=>r.getBoundingClientRect()),space:this.view.state.facet(Mr).tooltipSpace(this.view),scaleX:i,scaleY:e,makeAbsolute:t}}writeMeasure(i){var e;if(i.makeAbsolute){this.madeAbsolute=!0,this.position="absolute";for(let l of this.manager.tooltipViews)l.dom.style.position="absolute"}let{visible:t,space:n,scaleX:s,scaleY:r}=i,o=[];for(let l=0;l<this.manager.tooltips.length;l++){let a=this.manager.tooltips[l],h=this.manager.tooltipViews[l],{dom:c}=h,f=i.pos[l],u=i.size[l];if(!f||a.clip!==!1&&(f.bottom<=Math.max(t.top,n.top)||f.top>=Math.min(t.bottom,n.bottom)||f.right<Math.max(t.left,n.left)-.1||f.left>Math.min(t.right,n.right)+.1)){c.style.top=Gi;continue}let d=a.arrow?h.dom.querySelector(".cm-tooltip-arrow"):null,p=d?7:0,m=u.right-u.left,g=(e=Ya.get(h))!==null&&e!==void 0?e:u.bottom-u.top,O=h.offset||kA,w=this.view.textDirection==Z.LTR,k=u.width>n.right-n.left?w?n.left:n.right-u.width:w?Math.max(n.left,Math.min(f.left-(d?14:0)+O.x,n.right-m)):Math.min(Math.max(n.left,f.left-m+(d?14:0)-O.x),n.right-m),v=this.above[l];!a.strictSide&&(v?f.top-g-p-O.y<n.top:f.bottom+g+p+O.y>n.bottom)&&v==n.bottom-f.bottom>f.top-n.top&&(v=this.above[l]=!v);let y=(v?f.top-n.top:n.bottom-f.bottom)-p;if(y<g&&h.resize!==!1){if(y<this.view.defaultLineHeight){c.style.top=Gi;continue}Ya.set(h,g),c.style.height=(g=y)/r+"px"}else c.style.height&&(c.style.height="");let C=v?f.top-g-p-O.y:f.bottom+p+O.y,x=k+m;if(h.overlap!==!0)for(let I of o)I.left<x&&I.right>k&&I.top<C+g&&I.bottom>C&&(C=v?I.top-g-2-p:I.bottom+p+2);if(this.position=="absolute"?(c.style.top=(C-i.parent.top)/r+"px",Xa(c,(k-i.parent.left)/s)):(c.style.top=C/r+"px",Xa(c,k/s)),d){let I=f.left+(w?O.x:-O.x)-(k+14-7);d.style.left=I/s+"px"}h.overlap!==!0&&o.push({left:k,top:C,right:x,bottom:C+g}),c.classList.toggle("cm-tooltip-above",v),c.classList.toggle("cm-tooltip-below",!v),h.positioned&&h.positioned(i.space)}}maybeMeasure(){if(this.manager.tooltips.length&&(this.view.inView&&this.view.requestMeasure(this.measureReq),this.inView!=this.view.inView&&(this.inView=this.view.inView,!this.inView)))for(let i of this.manager.tooltipViews)i.dom.style.top=Gi}},{eventObservers:{scroll(){this.maybeMeasure()}}});function Xa(i,e){let t=parseInt(i.style.left,10);(isNaN(t)||Math.abs(e-t)>1)&&(i.style.left=e+"px")}const yA=Q.baseTheme({".cm-tooltip":{zIndex:500,boxSizing:"border-box"},"&light .cm-tooltip":{border:"1px solid #bbb",backgroundColor:"#f5f5f5"},"&light .cm-tooltip-section:not(:first-child)":{borderTop:"1px solid #bbb"},"&dark .cm-tooltip":{backgroundColor:"#333338",color:"white"},".cm-tooltip-arrow":{height:"7px",width:"14px",position:"absolute",zIndex:-1,overflow:"hidden","&:before, &:after":{content:"''",position:"absolute",width:0,height:0,borderLeft:"7px solid transparent",borderRight:"7px solid transparent"},".cm-tooltip-above &":{bottom:"-7px","&:before":{borderTop:"7px solid #bbb"},"&:after":{borderTop:"7px solid #f5f5f5",bottom:"1px"}},".cm-tooltip-below &":{top:"-7px","&:before":{borderBottom:"7px solid #bbb"},"&:after":{borderBottom:"7px solid #f5f5f5",top:"1px"}}},"&dark .cm-tooltip .cm-tooltip-arrow":{"&:before":{borderTopColor:"#333338",borderBottomColor:"#333338"},"&:after":{borderTopColor:"transparent",borderBottomColor:"transparent"}}}),kA={x:0,y:0},gl=B.define({enables:[ml,yA]}),Ps=B.define({combine:i=>i.reduce((e,t)=>e.concat(t),[])});class er{static create(e){return new er(e)}constructor(e){this.view=e,this.mounted=!1,this.dom=document.createElement("div"),this.dom.classList.add("cm-tooltip-hover"),this.manager=new Yf(e,Ps,(t,n)=>this.createHostedView(t,n),t=>t.dom.remove())}createHostedView(e,t){let n=e.create(this.view);return n.dom.classList.add("cm-tooltip-section"),this.dom.insertBefore(n.dom,t?t.dom.nextSibling:this.dom.firstChild),this.mounted&&n.mount&&n.mount(this.view),n}mount(e){for(let t of this.manager.tooltipViews)t.mount&&t.mount(e);this.mounted=!0}positioned(e){for(let t of this.manager.tooltipViews)t.positioned&&t.positioned(e)}update(e){this.manager.update(e)}destroy(){var e;for(let t of this.manager.tooltipViews)(e=t.destroy)===null||e===void 0||e.call(t)}passProp(e){let t;for(let n of this.manager.tooltipViews){let s=n[e];if(s!==void 0){if(t===void 0)t=s;else if(t!==s)return}}return t}get offset(){return this.passProp("offset")}get getCoords(){return this.passProp("getCoords")}get overlap(){return this.passProp("overlap")}get resize(){return this.passProp("resize")}}const CA=gl.compute([Ps],i=>{let e=i.facet(Ps);return e.length===0?null:{pos:Math.min(...e.map(t=>t.pos)),end:Math.max(...e.map(t=>{var n;return(n=t.end)!==null&&n!==void 0?n:t.pos})),create:er.create,above:e[0].above,arrow:e.some(t=>t.arrow)}});class vA{constructor(e,t,n,s,r){this.view=e,this.source=t,this.field=n,this.setHover=s,this.hoverTime=r,this.hoverTimeout=-1,this.restartTimeout=-1,this.pending=null,this.lastMove={x:0,y:0,target:e.dom,time:0},this.checkHover=this.checkHover.bind(this),e.dom.addEventListener("mouseleave",this.mouseleave=this.mouseleave.bind(this)),e.dom.addEventListener("mousemove",this.mousemove=this.mousemove.bind(this))}update(){this.pending&&(this.pending=null,clearTimeout(this.restartTimeout),this.restartTimeout=setTimeout(()=>this.startHover(),20))}get active(){return this.view.state.field(this.field)}checkHover(){if(this.hoverTimeout=-1,this.active.length)return;let e=Date.now()-this.lastMove.time;e<this.hoverTime?this.hoverTimeout=setTimeout(this.checkHover,this.hoverTime-e):this.startHover()}startHover(){clearTimeout(this.restartTimeout);let{view:e,lastMove:t}=this,n=e.docView.nearest(t.target);if(!n)return;let s,r=1;if(n instanceof Ft)s=n.posAtStart;else{if(s=e.posAtCoords(t),s==null)return;let l=e.coordsAtPos(s);if(!l||t.y<l.top||t.y>l.bottom||t.x<l.left-e.defaultCharacterWidth||t.x>l.right+e.defaultCharacterWidth)return;let a=e.bidiSpans(e.state.doc.lineAt(s)).find(c=>c.from<=s&&c.to>=s),h=a&&a.dir==Z.RTL?-1:1;r=t.x<l.left?-h:h}let o=this.source(e,s,r);if(o?.then){let l=this.pending={pos:s};o.then(a=>{this.pending==l&&(this.pending=null,a&&!(Array.isArray(a)&&!a.length)&&e.dispatch({effects:this.setHover.of(Array.isArray(a)?a:[a])}))},a=>ve(e.state,a,"hover tooltip"))}else o&&!(Array.isArray(o)&&!o.length)&&e.dispatch({effects:this.setHover.of(Array.isArray(o)?o:[o])})}get tooltip(){let e=this.view.plugin(ml),t=e?e.manager.tooltips.findIndex(n=>n.create==er.create):-1;return t>-1?e.manager.tooltipViews[t]:null}mousemove(e){var t,n;this.lastMove={x:e.clientX,y:e.clientY,target:e.target,time:Date.now()},this.hoverTimeout<0&&(this.hoverTimeout=setTimeout(this.checkHover,this.hoverTime));let{active:s,tooltip:r}=this;if(s.length&&r&&!xA(r.dom,e)||this.pending){let{pos:o}=s[0]||this.pending,l=(n=(t=s[0])===null||t===void 0?void 0:t.end)!==null&&n!==void 0?n:o;(o==l?this.view.posAtCoords(this.lastMove)!=o:!SA(this.view,o,l,e.clientX,e.clientY))&&(this.view.dispatch({effects:this.setHover.of([])}),this.pending=null)}}mouseleave(e){clearTimeout(this.hoverTimeout),this.hoverTimeout=-1;let{active:t}=this;if(t.length){let{tooltip:n}=this;n&&n.dom.contains(e.relatedTarget)?this.watchTooltipLeave(n.dom):this.view.dispatch({effects:this.setHover.of([])})}}watchTooltipLeave(e){let t=n=>{e.removeEventListener("mouseleave",t),this.active.length&&!this.view.dom.contains(n.relatedTarget)&&this.view.dispatch({effects:this.setHover.of([])})};e.addEventListener("mouseleave",t)}destroy(){clearTimeout(this.hoverTimeout),this.view.dom.removeEventListener("mouseleave",this.mouseleave),this.view.dom.removeEventListener("mousemove",this.mousemove)}}const Yn=4;function xA(i,e){let{left:t,right:n,top:s,bottom:r}=i.getBoundingClientRect(),o;if(o=i.querySelector(".cm-tooltip-arrow")){let l=o.getBoundingClientRect();s=Math.min(l.top,s),r=Math.max(l.bottom,r)}return e.clientX>=t-Yn&&e.clientX<=n+Yn&&e.clientY>=s-Yn&&e.clientY<=r+Yn}function SA(i,e,t,n,s,r){let o=i.scrollDOM.getBoundingClientRect(),l=i.documentTop+i.documentPadding.top+i.contentHeight;if(o.left>n||o.right<n||o.top>s||Math.min(o.bottom,l)<s)return!1;let a=i.posAtCoords({x:n,y:s},!1);return a>=e&&a<=t}function QA(i,e={}){let t=R.define(),n=ge.define({create(){return[]},update(s,r){if(s.length&&(e.hideOnChange&&(r.docChanged||r.selection)?s=[]:e.hideOn&&(s=s.filter(o=>!e.hideOn(r,o))),r.docChanged)){let o=[];for(let l of s){let a=r.changes.mapPos(l.pos,-1,Ce.TrackDel);if(a!=null){let h=Object.assign(Object.create(null),l);h.pos=a,h.end!=null&&(h.end=r.changes.mapPos(h.end)),o.push(h)}}s=o}for(let o of r.effects)o.is(t)&&(s=o.value),o.is(EA)&&(s=[]);return s},provide:s=>Ps.from(s)});return{active:n,extension:[n,ne.define(s=>new vA(s,i,n,t,e.hoverTime||300)),CA]}}function Xf(i,e){let t=i.plugin(ml);if(!t)return null;let n=t.manager.tooltips.indexOf(e);return n<0?null:t.manager.tooltipViews[n]}const EA=R.define(),ja=B.define({combine(i){let e,t;for(let n of i)e=e||n.topContainer,t=t||n.bottomContainer;return{topContainer:e,bottomContainer:t}}});function On(i,e){let t=i.plugin(jf),n=t?t.specs.indexOf(e):-1;return n>-1?t.panels[n]:null}const jf=ne.fromClass(class{constructor(i){this.input=i.state.facet(bn),this.specs=this.input.filter(t=>t),this.panels=this.specs.map(t=>t(i));let e=i.state.facet(ja);this.top=new Xn(i,!0,e.topContainer),this.bottom=new Xn(i,!1,e.bottomContainer),this.top.sync(this.panels.filter(t=>t.top)),this.bottom.sync(this.panels.filter(t=>!t.top));for(let t of this.panels)t.dom.classList.add("cm-panel"),t.mount&&t.mount()}update(i){let e=i.state.facet(ja);this.top.container!=e.topContainer&&(this.top.sync([]),this.top=new Xn(i.view,!0,e.topContainer)),this.bottom.container!=e.bottomContainer&&(this.bottom.sync([]),this.bottom=new Xn(i.view,!1,e.bottomContainer)),this.top.syncClasses(),this.bottom.syncClasses();let t=i.state.facet(bn);if(t!=this.input){let n=t.filter(a=>a),s=[],r=[],o=[],l=[];for(let a of n){let h=this.specs.indexOf(a),c;h<0?(c=a(i.view),l.push(c)):(c=this.panels[h],c.update&&c.update(i)),s.push(c),(c.top?r:o).push(c)}this.specs=n,this.panels=s,this.top.sync(r),this.bottom.sync(o);for(let a of l)a.dom.classList.add("cm-panel"),a.mount&&a.mount()}else for(let n of this.panels)n.update&&n.update(i)}destroy(){this.top.sync([]),this.bottom.sync([])}},{provide:i=>Q.scrollMargins.of(e=>{let t=e.plugin(i);return t&&{top:t.top.scrollMargin(),bottom:t.bottom.scrollMargin()}})});class Xn{constructor(e,t,n){this.view=e,this.top=t,this.container=n,this.dom=void 0,this.classes="",this.panels=[],this.syncClasses()}sync(e){for(let t of this.panels)t.destroy&&e.indexOf(t)<0&&t.destroy();this.panels=e,this.syncDOM()}syncDOM(){if(this.panels.length==0){this.dom&&(this.dom.remove(),this.dom=void 0);return}if(!this.dom){this.dom=document.createElement("div"),this.dom.className=this.top?"cm-panels cm-panels-top":"cm-panels cm-panels-bottom",this.dom.style[this.top?"top":"bottom"]="0";let t=this.container||this.view.dom;t.insertBefore(this.dom,this.top?t.firstChild:null)}let e=this.dom.firstChild;for(let t of this.panels)if(t.dom.parentNode==this.dom){for(;e!=t.dom;)e=Ja(e);e=e.nextSibling}else this.dom.insertBefore(t.dom,e);for(;e;)e=Ja(e)}scrollMargin(){return!this.dom||this.container?0:Math.max(0,this.top?this.dom.getBoundingClientRect().bottom-Math.max(0,this.view.scrollDOM.getBoundingClientRect().top):Math.min(innerHeight,this.view.scrollDOM.getBoundingClientRect().bottom)-this.dom.getBoundingClientRect().top)}syncClasses(){if(!(!this.container||this.classes==this.view.themeClasses)){for(let e of this.classes.split(" "))e&&this.container.classList.remove(e);for(let e of(this.classes=this.view.themeClasses).split(" "))e&&this.container.classList.add(e)}}}function Ja(i){let e=i.nextSibling;return i.remove(),e}const bn=B.define({enables:jf});class Bt extends li{compare(e){return this==e||this.constructor==e.constructor&&this.eq(e)}eq(e){return!1}destroy(e){}}Bt.prototype.elementClass="";Bt.prototype.toDOM=void 0;Bt.prototype.mapMode=Ce.TrackBefore;Bt.prototype.startSide=Bt.prototype.endSide=-1;Bt.prototype.point=!0;const bs=B.define(),BA=B.define(),PA={class:"",renderEmptyElements:!1,elementStyle:"",markers:()=>_.empty,lineMarker:()=>null,widgetMarker:()=>null,lineMarkerChange:null,initialSpacer:null,updateSpacer:null,domEventHandlers:{},side:"before"},on=B.define();function MA(i){return[Jf(),on.of({...PA,...i})]}const Za=B.define({combine:i=>i.some(e=>e)});function Jf(i){return[DA]}const DA=ne.fromClass(class{constructor(i){this.view=i,this.domAfter=null,this.prevViewport=i.viewport,this.dom=document.createElement("div"),this.dom.className="cm-gutters cm-gutters-before",this.dom.setAttribute("aria-hidden","true"),this.dom.style.minHeight=this.view.contentHeight/this.view.scaleY+"px",this.gutters=i.state.facet(on).map(e=>new th(i,e)),this.fixed=!i.state.facet(Za);for(let e of this.gutters)e.config.side=="after"?this.getDOMAfter().appendChild(e.dom):this.dom.appendChild(e.dom);this.fixed&&(this.dom.style.position="sticky"),this.syncGutters(!1),i.scrollDOM.insertBefore(this.dom,i.contentDOM)}getDOMAfter(){return this.domAfter||(this.domAfter=document.createElement("div"),this.domAfter.className="cm-gutters cm-gutters-after",this.domAfter.setAttribute("aria-hidden","true"),this.domAfter.style.minHeight=this.view.contentHeight/this.view.scaleY+"px",this.domAfter.style.position=this.fixed?"sticky":"",this.view.scrollDOM.appendChild(this.domAfter)),this.domAfter}update(i){if(this.updateGutters(i)){let e=this.prevViewport,t=i.view.viewport,n=Math.min(e.to,t.to)-Math.max(e.from,t.from);this.syncGutters(n<(t.to-t.from)*.8)}if(i.geometryChanged){let e=this.view.contentHeight/this.view.scaleY+"px";this.dom.style.minHeight=e,this.domAfter&&(this.domAfter.style.minHeight=e)}this.view.state.facet(Za)!=!this.fixed&&(this.fixed=!this.fixed,this.dom.style.position=this.fixed?"sticky":"",this.domAfter&&(this.domAfter.style.position=this.fixed?"sticky":"")),this.prevViewport=i.view.viewport}syncGutters(i){let e=this.dom.nextSibling;i&&(this.dom.remove(),this.domAfter&&this.domAfter.remove());let t=_.iter(this.view.state.facet(bs),this.view.viewport.from),n=[],s=this.gutters.map(r=>new IA(r,this.view.viewport,-this.view.documentPadding.top));for(let r of this.view.viewportLineBlocks)if(n.length&&(n=[]),Array.isArray(r.type)){let o=!0;for(let l of r.type)if(l.type==xe.Text&&o){To(t,n,l.from);for(let a of s)a.line(this.view,l,n);o=!1}else if(l.widget)for(let a of s)a.widget(this.view,l)}else if(r.type==xe.Text){To(t,n,r.from);for(let o of s)o.line(this.view,r,n)}else if(r.widget)for(let o of s)o.widget(this.view,r);for(let r of s)r.finish();i&&(this.view.scrollDOM.insertBefore(this.dom,e),this.domAfter&&this.view.scrollDOM.appendChild(this.domAfter))}updateGutters(i){let e=i.startState.facet(on),t=i.state.facet(on),n=i.docChanged||i.heightChanged||i.viewportChanged||!_.eq(i.startState.facet(bs),i.state.facet(bs),i.view.viewport.from,i.view.viewport.to);if(e==t)for(let s of this.gutters)s.update(i)&&(n=!0);else{n=!0;let s=[];for(let r of t){let o=e.indexOf(r);o<0?s.push(new th(this.view,r)):(this.gutters[o].update(i),s.push(this.gutters[o]))}for(let r of this.gutters)r.dom.remove(),s.indexOf(r)<0&&r.destroy();for(let r of s)r.config.side=="after"?this.getDOMAfter().appendChild(r.dom):this.dom.appendChild(r.dom);this.gutters=s}return n}destroy(){for(let i of this.gutters)i.destroy();this.dom.remove(),this.domAfter&&this.domAfter.remove()}},{provide:i=>Q.scrollMargins.of(e=>{let t=e.plugin(i);if(!t||t.gutters.length==0||!t.fixed)return null;let n=t.dom.offsetWidth*e.scaleX,s=t.domAfter?t.domAfter.offsetWidth*e.scaleX:0;return e.textDirection==Z.LTR?{left:n,right:s}:{right:n,left:s}})});function eh(i){return Array.isArray(i)?i:[i]}function To(i,e,t){for(;i.value&&i.from<=t;)i.from==t&&e.push(i.value),i.next()}class IA{constructor(e,t,n){this.gutter=e,this.height=n,this.i=0,this.cursor=_.iter(e.markers,t.from)}addElement(e,t,n){let{gutter:s}=this,r=(t.top-this.height)/e.scaleY,o=t.height/e.scaleY;if(this.i==s.elements.length){let l=new Zf(e,o,r,n);s.elements.push(l),s.dom.appendChild(l.dom)}else s.elements[this.i].update(e,o,r,n);this.height=t.bottom,this.i++}line(e,t,n){let s=[];To(this.cursor,s,t.from),n.length&&(s=s.concat(n));let r=this.gutter.config.lineMarker(e,t,s);r&&s.unshift(r);let o=this.gutter;s.length==0&&!o.config.renderEmptyElements||this.addElement(e,t,s)}widget(e,t){let n=this.gutter.config.widgetMarker(e,t.widget,t),s=n?[n]:null;for(let r of e.state.facet(BA)){let o=r(e,t.widget,t);o&&(s||(s=[])).push(o)}s&&this.addElement(e,t,s)}finish(){let e=this.gutter;for(;e.elements.length>this.i;){let t=e.elements.pop();e.dom.removeChild(t.dom),t.destroy()}}}class th{constructor(e,t){this.view=e,this.config=t,this.elements=[],this.spacer=null,this.dom=document.createElement("div"),this.dom.className="cm-gutter"+(this.config.class?" "+this.config.class:"");for(let n in t.domEventHandlers)this.dom.addEventListener(n,s=>{let r=s.target,o;if(r!=this.dom&&this.dom.contains(r)){for(;r.parentNode!=this.dom;)r=r.parentNode;let a=r.getBoundingClientRect();o=(a.top+a.bottom)/2}else o=s.clientY;let l=e.lineBlockAtHeight(o-e.documentTop);t.domEventHandlers[n](e,l,s)&&s.preventDefault()});this.markers=eh(t.markers(e)),t.initialSpacer&&(this.spacer=new Zf(e,0,0,[t.initialSpacer(e)]),this.dom.appendChild(this.spacer.dom),this.spacer.dom.style.cssText+="visibility: hidden; pointer-events: none")}update(e){let t=this.markers;if(this.markers=eh(this.config.markers(e.view)),this.spacer&&this.config.updateSpacer){let s=this.config.updateSpacer(this.spacer.markers[0],e);s!=this.spacer.markers[0]&&this.spacer.update(e.view,0,0,[s])}let n=e.view.viewport;return!_.eq(this.markers,t,n.from,n.to)||(this.config.lineMarkerChange?this.config.lineMarkerChange(e):!1)}destroy(){for(let e of this.elements)e.destroy()}}class Zf{constructor(e,t,n,s){this.height=-1,this.above=0,this.markers=[],this.dom=document.createElement("div"),this.dom.className="cm-gutterElement",this.update(e,t,n,s)}update(e,t,n,s){this.height!=t&&(this.height=t,this.dom.style.height=t+"px"),this.above!=n&&(this.dom.style.marginTop=(this.above=n)?n+"px":""),TA(this.markers,s)||this.setMarkers(e,s)}setMarkers(e,t){let n="cm-gutterElement",s=this.dom.firstChild;for(let r=0,o=0;;){let l=o,a=r<t.length?t[r++]:null,h=!1;if(a){let c=a.elementClass;c&&(n+=" "+c);for(let f=o;f<this.markers.length;f++)if(this.markers[f].compare(a)){l=f,h=!0;break}}else l=this.markers.length;for(;o<l;){let c=this.markers[o++];if(c.toDOM){c.destroy(s);let f=s.nextSibling;s.remove(),s=f}}if(!a)break;a.toDOM&&(h?s=s.nextSibling:this.dom.insertBefore(a.toDOM(e),s)),h&&o++}this.dom.className=n,this.markers=t}destroy(){this.setMarkers(null,[])}}function TA(i,e){if(i.length!=e.length)return!1;for(let t=0;t<i.length;t++)if(!i[t].compare(e[t]))return!1;return!0}const RA=B.define(),LA=B.define(),wi=B.define({combine(i){return yt(i,{formatNumber:String,domEventHandlers:{}},{domEventHandlers(e,t){let n=Object.assign({},e);for(let s in t){let r=n[s],o=t[s];n[s]=r?(l,a,h)=>r(l,a,h)||o(l,a,h):o}return n}})}});class Dr extends Bt{constructor(e){super(),this.number=e}eq(e){return this.number==e.number}toDOM(){return document.createTextNode(this.number)}}function Ir(i,e){return i.state.facet(wi).formatNumber(e,i.state)}const NA=on.compute([wi],i=>({class:"cm-lineNumbers",renderEmptyElements:!1,markers(e){return e.state.facet(RA)},lineMarker(e,t,n){return n.some(s=>s.toDOM)?null:new Dr(Ir(e,e.state.doc.lineAt(t.from).number))},widgetMarker:(e,t,n)=>{for(let s of e.state.facet(LA)){let r=s(e,t,n);if(r)return r}return null},lineMarkerChange:e=>e.startState.facet(wi)!=e.state.facet(wi),initialSpacer(e){return new Dr(Ir(e,ih(e.state.doc.lines)))},updateSpacer(e,t){let n=Ir(t.view,ih(t.view.state.doc.lines));return n==e.number?e:new Dr(n)},domEventHandlers:i.facet(wi).domEventHandlers,side:"before"}));function $A(i={}){return[wi.of(i),Jf(),NA]}function ih(i){let e=9;for(;e<i;)e=e*10+9;return e}const FA=new class extends Bt{constructor(){super(...arguments),this.elementClass="cm-activeLineGutter"}},KA=bs.compute(["selection"],i=>{let e=[],t=-1;for(let n of i.selection.ranges){let s=i.doc.lineAt(n.head).from;s>t&&(t=s,e.push(FA.range(s)))}return _.of(e)});function zA(){return KA}let _A=0;class ze{constructor(e,t,n,s){this.name=e,this.set=t,this.base=n,this.modified=s,this.id=_A++}toString(){let{name:e}=this;for(let t of this.modified)t.name&&(e=`${t.name}(${e})`);return e}static define(e,t){let n=typeof e=="string"?e:"?";if(e instanceof ze&&(t=e),t?.base)throw new Error("Can not derive from a modified tag");let s=new ze(n,[],null,[]);if(s.set.push(s),t)for(let r of t.set)s.set.push(r);return s}static defineModifier(e){let t=new Ms(e);return n=>n.modified.indexOf(t)>-1?n:Ms.get(n.base||n,n.modified.concat(t).sort((s,r)=>s.id-r.id))}}let VA=0;class Ms{constructor(e){this.name=e,this.instances=[],this.id=VA++}static get(e,t){if(!t.length)return e;let n=t[0].instances.find(l=>l.base==e&&WA(t,l.modified));if(n)return n;let s=[],r=new ze(e.name,s,e,t);for(let l of t)l.instances.push(r);let o=HA(t);for(let l of e.set)if(!l.modified.length)for(let a of o)s.push(Ms.get(l,a));return r}}function WA(i,e){return i.length==e.length&&i.every((t,n)=>t==e[n])}function HA(i){let e=[[]];for(let t=0;t<i.length;t++)for(let n=0,s=e.length;n<s;n++)e.push(e[n].concat(i[t]));return e.sort((t,n)=>n.length-t.length)}function eu(i){let e=Object.create(null);for(let t in i){let n=i[t];Array.isArray(n)||(n=[n]);for(let s of t.split(" "))if(s){let r=[],o=2,l=s;for(let f=0;;){if(l=="..."&&f>0&&f+3==s.length){o=1;break}let u=/^"(?:[^"\\]|\\.)*?"|[^\/!]+/.exec(l);if(!u)throw new RangeError("Invalid path: "+s);if(r.push(u[0]=="*"?"":u[0][0]=='"'?JSON.parse(u[0]):u[0]),f+=u[0].length,f==s.length)break;let d=s[f++];if(f==s.length&&d=="!"){o=0;break}if(d!="/")throw new RangeError("Invalid path: "+s);l=s.slice(f)}let a=r.length-1,h=r[a];if(!h)throw new RangeError("Invalid path: "+s);let c=new Ds(n,o,a>0?r.slice(0,a):null);e[h]=c.sort(e[h])}}return tu.add(e)}const tu=new N;class Ds{constructor(e,t,n,s){this.tags=e,this.mode=t,this.context=n,this.next=s}get opaque(){return this.mode==0}get inherit(){return this.mode==1}sort(e){return!e||e.depth<this.depth?(this.next=e,this):(e.next=this.sort(e.next),e)}get depth(){return this.context?this.context.length:0}}Ds.empty=new Ds([],2,null);function iu(i,e){let t=Object.create(null);for(let r of i)if(!Array.isArray(r.tag))t[r.tag.id]=r.class;else for(let o of r.tag)t[o.id]=r.class;let{scope:n,all:s=null}=e||{};return{style:r=>{let o=s;for(let l of r)for(let a of l.set){let h=t[a.id];if(h){o=o?o+" "+h:h;break}}return o},scope:n}}function qA(i,e){let t=null;for(let n of i){let s=n.style(e);s&&(t=t?t+" "+s:s)}return t}function GA(i,e,t,n=0,s=i.length){let r=new UA(n,Array.isArray(e)?e:[e],t);r.highlightRange(i.cursor(),n,s,"",r.highlighters),r.flush(s)}class UA{constructor(e,t,n){this.at=e,this.highlighters=t,this.span=n,this.class=""}startSpan(e,t){t!=this.class&&(this.flush(e),e>this.at&&(this.at=e),this.class=t)}flush(e){e>this.at&&this.class&&this.span(this.at,e,this.class)}highlightRange(e,t,n,s,r){let{type:o,from:l,to:a}=e;if(l>=n||a<=t)return;o.isTop&&(r=this.highlighters.filter(d=>!d.scope||d.scope(o)));let h=s,c=YA(e)||Ds.empty,f=qA(r,c.tags);if(f&&(h&&(h+=" "),h+=f,c.mode==1&&(s+=(s?" ":"")+f)),this.startSpan(Math.max(t,l),h),c.opaque)return;let u=e.tree&&e.tree.prop(N.mounted);if(u&&u.overlay){let d=e.node.enter(u.overlay[0].from+l,1),p=this.highlighters.filter(g=>!g.scope||g.scope(u.tree.type)),m=e.firstChild();for(let g=0,O=l;;g++){let w=g<u.overlay.length?u.overlay[g]:null,k=w?w.from+l:a,v=Math.max(t,O),y=Math.min(n,k);if(v<y&&m)for(;e.from<y&&(this.highlightRange(e,v,y,s,r),this.startSpan(Math.min(y,e.to),h),!(e.to>=k||!e.nextSibling())););if(!w||k>n)break;O=w.to+l,O>t&&(this.highlightRange(d.cursor(),Math.max(t,w.from+l),Math.min(n,O),"",p),this.startSpan(Math.min(n,O),h))}m&&e.parent()}else if(e.firstChild()){u&&(s="");do if(!(e.to<=t)){if(e.from>=n)break;this.highlightRange(e,t,n,s,r),this.startSpan(Math.min(n,e.to),h)}while(e.nextSibling());e.parent()}}}function YA(i){let e=i.type.prop(tu);for(;e&&e.context&&!i.matchContext(e.context);)e=e.next;return e||null}const S=ze.define,jn=S(),It=S(),nh=S(It),sh=S(It),Tt=S(),Jn=S(Tt),Tr=S(Tt),ct=S(),jt=S(ct),at=S(),ht=S(),Ro=S(),Ui=S(Ro),Zn=S(),A={comment:jn,lineComment:S(jn),blockComment:S(jn),docComment:S(jn),name:It,variableName:S(It),typeName:nh,tagName:S(nh),propertyName:sh,attributeName:S(sh),className:S(It),labelName:S(It),namespace:S(It),macroName:S(It),literal:Tt,string:Jn,docString:S(Jn),character:S(Jn),attributeValue:S(Jn),number:Tr,integer:S(Tr),float:S(Tr),bool:S(Tt),regexp:S(Tt),escape:S(Tt),color:S(Tt),url:S(Tt),keyword:at,self:S(at),null:S(at),atom:S(at),unit:S(at),modifier:S(at),operatorKeyword:S(at),controlKeyword:S(at),definitionKeyword:S(at),moduleKeyword:S(at),operator:ht,derefOperator:S(ht),arithmeticOperator:S(ht),logicOperator:S(ht),bitwiseOperator:S(ht),compareOperator:S(ht),updateOperator:S(ht),definitionOperator:S(ht),typeOperator:S(ht),controlOperator:S(ht),punctuation:Ro,separator:S(Ro),bracket:Ui,angleBracket:S(Ui),squareBracket:S(Ui),paren:S(Ui),brace:S(Ui),content:ct,heading:jt,heading1:S(jt),heading2:S(jt),heading3:S(jt),heading4:S(jt),heading5:S(jt),heading6:S(jt),contentSeparator:S(ct),list:S(ct),quote:S(ct),emphasis:S(ct),strong:S(ct),link:S(ct),monospace:S(ct),strikethrough:S(ct),inserted:S(),deleted:S(),changed:S(),invalid:S(),meta:Zn,documentMeta:S(Zn),annotation:S(Zn),processingInstruction:S(Zn),definition:ze.defineModifier("definition"),constant:ze.defineModifier("constant"),function:ze.defineModifier("function"),standard:ze.defineModifier("standard"),local:ze.defineModifier("local"),special:ze.defineModifier("special")};for(let i in A){let e=A[i];e instanceof ze&&(e.name=i)}iu([{tag:A.link,class:"tok-link"},{tag:A.heading,class:"tok-heading"},{tag:A.emphasis,class:"tok-emphasis"},{tag:A.strong,class:"tok-strong"},{tag:A.keyword,class:"tok-keyword"},{tag:A.atom,class:"tok-atom"},{tag:A.bool,class:"tok-bool"},{tag:A.url,class:"tok-url"},{tag:A.labelName,class:"tok-labelName"},{tag:A.inserted,class:"tok-inserted"},{tag:A.deleted,class:"tok-deleted"},{tag:A.literal,class:"tok-literal"},{tag:A.string,class:"tok-string"},{tag:A.number,class:"tok-number"},{tag:[A.regexp,A.escape,A.special(A.string)],class:"tok-string2"},{tag:A.variableName,class:"tok-variableName"},{tag:A.local(A.variableName),class:"tok-variableName tok-local"},{tag:A.definition(A.variableName),class:"tok-variableName tok-definition"},{tag:A.special(A.variableName),class:"tok-variableName2"},{tag:A.definition(A.propertyName),class:"tok-propertyName tok-definition"},{tag:A.typeName,class:"tok-typeName"},{tag:A.namespace,class:"tok-namespace"},{tag:A.className,class:"tok-className"},{tag:A.macroName,class:"tok-macroName"},{tag:A.propertyName,class:"tok-propertyName"},{tag:A.operator,class:"tok-operator"},{tag:A.comment,class:"tok-comment"},{tag:A.meta,class:"tok-meta"},{tag:A.invalid,class:"tok-invalid"},{tag:A.punctuation,class:"tok-punctuation"}]);var Rr;const yi=new N;function XA(i){return B.define({combine:i?e=>e.concat(i):void 0})}const jA=new N;class et{constructor(e,t,n=[],s=""){this.data=e,this.name=s,K.prototype.hasOwnProperty("tree")||Object.defineProperty(K.prototype,"tree",{get(){return we(this)}}),this.parser=t,this.extension=[Gt.of(this),K.languageData.of((r,o,l)=>{let a=rh(r,o,l),h=a.type.prop(yi);if(!h)return[];let c=r.facet(h),f=a.type.prop(jA);if(f){let u=a.resolve(o-a.from,l);for(let d of f)if(d.test(u,r)){let p=r.facet(d.facet);return d.type=="replace"?p:p.concat(c)}}return c})].concat(n)}isActiveAt(e,t,n=-1){return rh(e,t,n).type.prop(yi)==this.data}findRegions(e){let t=e.facet(Gt);if(t?.data==this.data)return[{from:0,to:e.doc.length}];if(!t||!t.allowsNesting)return[];let n=[],s=(r,o)=>{if(r.prop(yi)==this.data){n.push({from:o,to:o+r.length});return}let l=r.prop(N.mounted);if(l){if(l.tree.prop(yi)==this.data){if(l.overlay)for(let a of l.overlay)n.push({from:a.from+o,to:a.to+o});else n.push({from:o,to:o+r.length});return}else if(l.overlay){let a=n.length;if(s(l.tree,l.overlay[0].from+o),n.length>a)return}}for(let a=0;a<r.children.length;a++){let h=r.children[a];h instanceof re&&s(h,r.positions[a]+o)}};return s(we(e),0),n}get allowsNesting(){return!0}}et.setState=R.define();function rh(i,e,t){let n=i.facet(Gt),s=we(i).topNode;if(!n||n.allowsNesting)for(let r=s;r;r=r.enter(e,t,ce.ExcludeBuffers))r.type.isTop&&(s=r);return s}class Is extends et{constructor(e,t,n){super(e,t,[],n),this.parser=t}static define(e){let t=XA(e.languageData);return new Is(t,e.parser.configure({props:[yi.add(n=>n.isTop?t:void 0)]}),e.name)}configure(e,t){return new Is(this.data,this.parser.configure(e),t||this.name)}get allowsNesting(){return this.parser.hasWrappers()}}function we(i){let e=i.field(et.state,!1);return e?e.tree:re.empty}class JA{constructor(e){this.doc=e,this.cursorPos=0,this.string="",this.cursor=e.iter()}get length(){return this.doc.length}syncTo(e){return this.string=this.cursor.next(e-this.cursorPos).value,this.cursorPos=e+this.string.length,this.cursorPos-this.string.length}chunk(e){return this.syncTo(e),this.string}get lineChunks(){return!0}read(e,t){let n=this.cursorPos-this.string.length;return e<n||t>=this.cursorPos?this.doc.sliceString(e,t):this.string.slice(e-n,t-n)}}let Yi=null;class Ts{constructor(e,t,n=[],s,r,o,l,a){this.parser=e,this.state=t,this.fragments=n,this.tree=s,this.treeLen=r,this.viewport=o,this.skipped=l,this.scheduleOn=a,this.parse=null,this.tempSkipped=[]}static create(e,t,n){return new Ts(e,t,[],re.empty,0,n,[],null)}startParse(){return this.parser.startParse(new JA(this.state.doc),this.fragments)}work(e,t){return t!=null&&t>=this.state.doc.length&&(t=void 0),this.tree!=re.empty&&this.isDone(t??this.state.doc.length)?(this.takeTree(),!0):this.withContext(()=>{var n;if(typeof e=="number"){let s=Date.now()+e;e=()=>Date.now()>s}for(this.parse||(this.parse=this.startParse()),t!=null&&(this.parse.stoppedAt==null||this.parse.stoppedAt>t)&&t<this.state.doc.length&&this.parse.stopAt(t);;){let s=this.parse.advance();if(s)if(this.fragments=this.withoutTempSkipped(ni.addTree(s,this.fragments,this.parse.stoppedAt!=null)),this.treeLen=(n=this.parse.stoppedAt)!==null&&n!==void 0?n:this.state.doc.length,this.tree=s,this.parse=null,this.treeLen<(t??this.state.doc.length))this.parse=this.startParse();else return!0;if(e())return!1}})}takeTree(){let e,t;this.parse&&(e=this.parse.parsedPos)>=this.treeLen&&((this.parse.stoppedAt==null||this.parse.stoppedAt>e)&&this.parse.stopAt(e),this.withContext(()=>{for(;!(t=this.parse.advance()););}),this.treeLen=e,this.tree=t,this.fragments=this.withoutTempSkipped(ni.addTree(this.tree,this.fragments,!0)),this.parse=null)}withContext(e){let t=Yi;Yi=this;try{return e()}finally{Yi=t}}withoutTempSkipped(e){for(let t;t=this.tempSkipped.pop();)e=oh(e,t.from,t.to);return e}changes(e,t){let{fragments:n,tree:s,treeLen:r,viewport:o,skipped:l}=this;if(this.takeTree(),!e.empty){let a=[];if(e.iterChangedRanges((h,c,f,u)=>a.push({fromA:h,toA:c,fromB:f,toB:u})),n=ni.applyChanges(n,a),s=re.empty,r=0,o={from:e.mapPos(o.from,-1),to:e.mapPos(o.to,1)},this.skipped.length){l=[];for(let h of this.skipped){let c=e.mapPos(h.from,1),f=e.mapPos(h.to,-1);c<f&&l.push({from:c,to:f})}}}return new Ts(this.parser,t,n,s,r,o,l,this.scheduleOn)}updateViewport(e){if(this.viewport.from==e.from&&this.viewport.to==e.to)return!1;this.viewport=e;let t=this.skipped.length;for(let n=0;n<this.skipped.length;n++){let{from:s,to:r}=this.skipped[n];s<e.to&&r>e.from&&(this.fragments=oh(this.fragments,s,r),this.skipped.splice(n--,1))}return this.skipped.length>=t?!1:(this.reset(),!0)}reset(){this.parse&&(this.takeTree(),this.parse=null)}skipUntilInView(e,t){this.skipped.push({from:e,to:t})}static getSkippingParser(e){return new class extends Qc{createParse(t,n,s){let r=s[0].from,o=s[s.length-1].to;return{parsedPos:r,advance(){let a=Yi;if(a){for(let h of s)a.tempSkipped.push(h);e&&(a.scheduleOn=a.scheduleOn?Promise.all([a.scheduleOn,e]):e)}return this.parsedPos=o,new re(De.none,[],[],o-r)},stoppedAt:null,stopAt(){}}}}}isDone(e){e=Math.min(e,this.state.doc.length);let t=this.fragments;return this.treeLen>=e&&t.length&&t[0].from==0&&t[0].to>=e}static get(){return Yi}}function oh(i,e,t){return ni.applyChanges(i,[{fromA:e,toA:t,fromB:e,toB:t}])}class Ri{constructor(e){this.context=e,this.tree=e.tree}apply(e){if(!e.docChanged&&this.tree==this.context.tree)return this;let t=this.context.changes(e.changes,e.state),n=this.context.treeLen==e.startState.doc.length?void 0:Math.max(e.changes.mapPos(this.context.treeLen),t.viewport.to);return t.work(20,n)||t.takeTree(),new Ri(t)}static init(e){let t=Math.min(3e3,e.doc.length),n=Ts.create(e.facet(Gt).parser,e,{from:0,to:t});return n.work(20,t)||n.takeTree(),new Ri(n)}}et.state=ge.define({create:Ri.init,update(i,e){for(let t of e.effects)if(t.is(et.setState))return t.value;return e.startState.facet(Gt)!=e.state.facet(Gt)?Ri.init(e.state):i.apply(e)}});let nu=i=>{let e=setTimeout(()=>i(),500);return()=>clearTimeout(e)};typeof requestIdleCallback<"u"&&(nu=i=>{let e=-1,t=setTimeout(()=>{e=requestIdleCallback(i,{timeout:400})},100);return()=>e<0?clearTimeout(t):cancelIdleCallback(e)});const Lr=typeof navigator<"u"&&(!((Rr=navigator.scheduling)===null||Rr===void 0)&&Rr.isInputPending)?()=>navigator.scheduling.isInputPending():null,ZA=ne.fromClass(class{constructor(e){this.view=e,this.working=null,this.workScheduled=0,this.chunkEnd=-1,this.chunkBudget=-1,this.work=this.work.bind(this),this.scheduleWork()}update(e){let t=this.view.state.field(et.state).context;(t.updateViewport(e.view.viewport)||this.view.viewport.to>t.treeLen)&&this.scheduleWork(),(e.docChanged||e.selectionSet)&&(this.view.hasFocus&&(this.chunkBudget+=50),this.scheduleWork()),this.checkAsyncSchedule(t)}scheduleWork(){if(this.working)return;let{state:e}=this.view,t=e.field(et.state);(t.tree!=t.context.tree||!t.context.isDone(e.doc.length))&&(this.working=nu(this.work))}work(e){this.working=null;let t=Date.now();if(this.chunkEnd<t&&(this.chunkEnd<0||this.view.hasFocus)&&(this.chunkEnd=t+3e4,this.chunkBudget=3e3),this.chunkBudget<=0)return;let{state:n,viewport:{to:s}}=this.view,r=n.field(et.state);if(r.tree==r.context.tree&&r.context.isDone(s+1e5))return;let o=Date.now()+Math.min(this.chunkBudget,100,e&&!Lr?Math.max(25,e.timeRemaining()-5):1e9),l=r.context.treeLen<s&&n.doc.length>s+1e3,a=r.context.work(()=>Lr&&Lr()||Date.now()>o,s+(l?0:1e5));this.chunkBudget-=Date.now()-t,(a||this.chunkBudget<=0)&&(r.context.takeTree(),this.view.dispatch({effects:et.setState.of(new Ri(r.context))})),this.chunkBudget>0&&!(a&&!l)&&this.scheduleWork(),this.checkAsyncSchedule(r.context)}checkAsyncSchedule(e){e.scheduleOn&&(this.workScheduled++,e.scheduleOn.then(()=>this.scheduleWork()).catch(t=>ve(this.view.state,t)).then(()=>this.workScheduled--),e.scheduleOn=null)}destroy(){this.working&&this.working()}isWorking(){return!!(this.working||this.workScheduled>0)}},{eventHandlers:{focus(){this.scheduleWork()}}}),Gt=B.define({combine(i){return i.length?i[0]:null},enables:i=>[et.state,ZA,Q.contentAttributes.compute([i],e=>{let t=e.facet(i);return t&&t.name?{"data-language":t.name}:{}})]});class e0{constructor(e,t=[]){this.language=e,this.support=t,this.extension=[e,t]}}const t0=B.define(),Al=B.define({combine:i=>{if(!i.length)return" ";let e=i[0];if(!e||/\S/.test(e)||Array.from(e).some(t=>t!=e[0]))throw new Error("Invalid indent unit: "+JSON.stringify(i[0]));return e}});function Rs(i){let e=i.facet(Al);return e.charCodeAt(0)==9?i.tabSize*e.length:e.length}function wn(i,e){let t="",n=i.tabSize,s=i.facet(Al)[0];if(s==" "){for(;e>=n;)t+=" ",e-=n;s=" "}for(let r=0;r<e;r++)t+=s;return t}function Ol(i,e){i instanceof K&&(i=new tr(i));for(let n of i.state.facet(t0)){let s=n(i,e);if(s!==void 0)return s}let t=we(i.state);return t.length>=e?n0(i,t,e):null}class tr{constructor(e,t={}){this.state=e,this.options=t,this.unit=Rs(e)}lineAt(e,t=1){let n=this.state.doc.lineAt(e),{simulateBreak:s,simulateDoubleBreak:r}=this.options;return s!=null&&s>=n.from&&s<=n.to?r&&s==e?{text:"",from:e}:(t<0?s<e:s<=e)?{text:n.text.slice(s-n.from),from:s}:{text:n.text.slice(0,s-n.from),from:n.from}:n}textAfterPos(e,t=1){if(this.options.simulateDoubleBreak&&e==this.options.simulateBreak)return"";let{text:n,from:s}=this.lineAt(e,t);return n.slice(e-s,Math.min(n.length,e+100-s))}column(e,t=1){let{text:n,from:s}=this.lineAt(e,t),r=this.countColumn(n,e-s),o=this.options.overrideIndentation?this.options.overrideIndentation(s):-1;return o>-1&&(r+=o-this.countColumn(n,n.search(/\S|$/))),r}countColumn(e,t=e.length){return $i(e,this.state.tabSize,t)}lineIndent(e,t=1){let{text:n,from:s}=this.lineAt(e,t),r=this.options.overrideIndentation;if(r){let o=r(s);if(o>-1)return o}return this.countColumn(n,n.search(/\S|$/))}get simulatedBreak(){return this.options.simulateBreak||null}}const i0=new N;function n0(i,e,t){let n=e.resolveStack(t),s=e.resolveInner(t,-1).resolve(t,0).enterUnfinishedNodesBefore(t);if(s!=n.node){let r=[];for(let o=s;o&&!(o.from<n.node.from||o.to>n.node.to||o.from==n.node.from&&o.type==n.node.type);o=o.parent)r.push(o);for(let o=r.length-1;o>=0;o--)n={node:r[o],next:n}}return su(n,i,t)}function su(i,e,t){for(let n=i;n;n=n.next){let s=r0(n.node);if(s)return s(bl.create(e,t,n))}return 0}function s0(i){return i.pos==i.options.simulateBreak&&i.options.simulateDoubleBreak}function r0(i){let e=i.type.prop(i0);if(e)return e;let t=i.firstChild,n;if(t&&(n=t.type.prop(N.closedBy))){let s=i.lastChild,r=s&&n.indexOf(s.name)>-1;return o=>h0(o,!0,1,void 0,r&&!s0(o)?s.from:void 0)}return i.parent==null?o0:null}function o0(){return 0}class bl extends tr{constructor(e,t,n){super(e.state,e.options),this.base=e,this.pos=t,this.context=n}get node(){return this.context.node}static create(e,t,n){return new bl(e,t,n)}get textAfter(){return this.textAfterPos(this.pos)}get baseIndent(){return this.baseIndentFor(this.node)}baseIndentFor(e){let t=this.state.doc.lineAt(e.from);for(;;){let n=e.resolve(t.from);for(;n.parent&&n.parent.from==n.from;)n=n.parent;if(l0(n,e))break;t=this.state.doc.lineAt(n.from)}return this.lineIndent(t.from)}continue(){return su(this.context.next,this.base,this.pos)}}function l0(i,e){for(let t=e;t;t=t.parent)if(i==t)return!0;return!1}function a0(i){let e=i.node,t=e.childAfter(e.from),n=e.lastChild;if(!t)return null;let s=i.options.simulateBreak,r=i.state.doc.lineAt(t.from),o=s==null||s<=r.from?r.to:Math.min(r.to,s);for(let l=t.to;;){let a=e.childAfter(l);if(!a||a==n)return null;if(!a.type.isSkipped){if(a.from>=o)return null;let h=/^ */.exec(r.text.slice(t.to-r.from))[0].length;return{from:t.from,to:t.to+h}}l=a.to}}function h0(i,e,t,n,s){let r=i.textAfter,o=r.match(/^\s*/)[0].length,l=n&&r.slice(o,o+n.length)==n||s==i.pos+o,a=a0(i);return a?l?i.column(a.from):i.column(a.to):i.baseIndent+(l?0:i.unit*t)}const c0=200;function f0(){return K.transactionFilter.of(i=>{if(!i.docChanged||!i.isUserEvent("input.type")&&!i.isUserEvent("input.complete"))return i;let e=i.startState.languageDataAt("indentOnInput",i.startState.selection.main.head);if(!e.length)return i;let t=i.newDoc,{head:n}=i.newSelection.main,s=t.lineAt(n);if(n>s.from+c0)return i;let r=t.sliceString(s.from,n);if(!e.some(h=>h.test(r)))return i;let{state:o}=i,l=-1,a=[];for(let{head:h}of o.selection.ranges){let c=o.doc.lineAt(h);if(c.from==l)continue;l=c.from;let f=Ol(o,c.from);if(f==null)continue;let u=/^\s*/.exec(c.text)[0],d=wn(o,f);u!=d&&a.push({from:c.from,to:c.from+u.length,insert:d})}return a.length?[i,{changes:a,sequential:!0}]:i})}const u0=B.define(),d0=new N;function p0(i,e,t){let n=we(i);if(n.length<t)return null;let s=n.resolveStack(t,1),r=null;for(let o=s;o;o=o.next){let l=o.node;if(l.to<=t||l.from>t)continue;if(r&&l.from<e)break;let a=l.type.prop(d0);if(a&&(l.to<n.length-50||n.length==i.doc.length||!m0(l))){let h=a(l,i);h&&h.from<=t&&h.from>=e&&h.to>t&&(r=h)}}return r}function m0(i){let e=i.lastChild;return e&&e.to==i.to&&e.type.isError}function Ls(i,e,t){for(let n of i.facet(u0)){let s=n(i,e,t);if(s)return s}return p0(i,e,t)}function ru(i,e){let t=e.mapPos(i.from,1),n=e.mapPos(i.to,-1);return t>=n?void 0:{from:t,to:n}}const ir=R.define({map:ru}),Mn=R.define({map:ru});function ou(i){let e=[];for(let{head:t}of i.state.selection.ranges)e.some(n=>n.from<=t&&n.to>=t)||e.push(i.lineBlockAt(t));return e}const fi=ge.define({create(){return D.none},update(i,e){e.isUserEvent("delete")&&e.changes.iterChangedRanges((t,n)=>i=lh(i,t,n)),i=i.map(e.changes);for(let t of e.effects)if(t.is(ir)&&!g0(i,t.value.from,t.value.to)){let{preparePlaceholder:n}=e.state.facet(hu),s=n?D.replace({widget:new C0(n(e.state,t.value))}):ah;i=i.update({add:[s.range(t.value.from,t.value.to)]})}else t.is(Mn)&&(i=i.update({filter:(n,s)=>t.value.from!=n||t.value.to!=s,filterFrom:t.value.from,filterTo:t.value.to}));return e.selection&&(i=lh(i,e.selection.main.head)),i},provide:i=>Q.decorations.from(i),toJSON(i,e){let t=[];return i.between(0,e.doc.length,(n,s)=>{t.push(n,s)}),t},fromJSON(i){if(!Array.isArray(i)||i.length%2)throw new RangeError("Invalid JSON for fold state");let e=[];for(let t=0;t<i.length;){let n=i[t++],s=i[t++];if(typeof n!="number"||typeof s!="number")throw new RangeError("Invalid JSON for fold state");e.push(ah.range(n,s))}return D.set(e,!0)}});function lh(i,e,t=e){let n=!1;return i.between(e,t,(s,r)=>{s<t&&r>e&&(n=!0)}),n?i.update({filterFrom:e,filterTo:t,filter:(s,r)=>s>=t||r<=e}):i}function Ns(i,e,t){var n;let s=null;return(n=i.field(fi,!1))===null||n===void 0||n.between(e,t,(r,o)=>{(!s||s.from>r)&&(s={from:r,to:o})}),s}function g0(i,e,t){let n=!1;return i.between(e,e,(s,r)=>{s==e&&r==t&&(n=!0)}),n}function lu(i,e){return i.field(fi,!1)?e:e.concat(R.appendConfig.of(cu()))}const A0=i=>{for(let e of ou(i)){let t=Ls(i.state,e.from,e.to);if(t)return i.dispatch({effects:lu(i.state,[ir.of(t),au(i,t)])}),!0}return!1},O0=i=>{if(!i.state.field(fi,!1))return!1;let e=[];for(let t of ou(i)){let n=Ns(i.state,t.from,t.to);n&&e.push(Mn.of(n),au(i,n,!1))}return e.length&&i.dispatch({effects:e}),e.length>0};function au(i,e,t=!0){let n=i.state.doc.lineAt(e.from).number,s=i.state.doc.lineAt(e.to).number;return Q.announce.of(`${i.state.phrase(t?"Folded lines":"Unfolded lines")} ${n} ${i.state.phrase("to")} ${s}.`)}const b0=i=>{let{state:e}=i,t=[];for(let n=0;n<e.doc.length;){let s=i.lineBlockAt(n),r=Ls(e,s.from,s.to);r&&t.push(ir.of(r)),n=(r?i.lineBlockAt(r.to):s).to+1}return t.length&&i.dispatch({effects:lu(i.state,t)}),!!t.length},w0=i=>{let e=i.state.field(fi,!1);if(!e||!e.size)return!1;let t=[];return e.between(0,i.state.doc.length,(n,s)=>{t.push(Mn.of({from:n,to:s}))}),i.dispatch({effects:t}),!0},y0=[{key:"Ctrl-Shift-[",mac:"Cmd-Alt-[",run:A0},{key:"Ctrl-Shift-]",mac:"Cmd-Alt-]",run:O0},{key:"Ctrl-Alt-[",run:b0},{key:"Ctrl-Alt-]",run:w0}],k0={placeholderDOM:null,preparePlaceholder:null,placeholderText:"…"},hu=B.define({combine(i){return yt(i,k0)}});function cu(i){return[fi,S0]}function fu(i,e){let{state:t}=i,n=t.facet(hu),s=o=>{let l=i.lineBlockAt(i.posAtDOM(o.target)),a=Ns(i.state,l.from,l.to);a&&i.dispatch({effects:Mn.of(a)}),o.preventDefault()};if(n.placeholderDOM)return n.placeholderDOM(i,s,e);let r=document.createElement("span");return r.textContent=n.placeholderText,r.setAttribute("aria-label",t.phrase("folded code")),r.title=t.phrase("unfold"),r.className="cm-foldPlaceholder",r.onclick=s,r}const ah=D.replace({widget:new class extends Ut{toDOM(i){return fu(i,null)}}});class C0 extends Ut{constructor(e){super(),this.value=e}eq(e){return this.value==e.value}toDOM(e){return fu(e,this.value)}}const v0={openText:"⌄",closedText:"›",markerDOM:null,domEventHandlers:{},foldingChanged:()=>!1};class Nr extends Bt{constructor(e,t){super(),this.config=e,this.open=t}eq(e){return this.config==e.config&&this.open==e.open}toDOM(e){if(this.config.markerDOM)return this.config.markerDOM(this.open);let t=document.createElement("span");return t.textContent=this.open?this.config.openText:this.config.closedText,t.title=e.state.phrase(this.open?"Fold line":"Unfold line"),t}}function x0(i={}){let e={...v0,...i},t=new Nr(e,!0),n=new Nr(e,!1),s=ne.fromClass(class{constructor(o){this.from=o.viewport.from,this.markers=this.buildMarkers(o)}update(o){(o.docChanged||o.viewportChanged||o.startState.facet(Gt)!=o.state.facet(Gt)||o.startState.field(fi,!1)!=o.state.field(fi,!1)||we(o.startState)!=we(o.state)||e.foldingChanged(o))&&(this.markers=this.buildMarkers(o.view))}buildMarkers(o){let l=new Qt;for(let a of o.viewportLineBlocks){let h=Ns(o.state,a.from,a.to)?n:Ls(o.state,a.from,a.to)?t:null;h&&l.add(a.from,a.from,h)}return l.finish()}}),{domEventHandlers:r}=e;return[s,MA({class:"cm-foldGutter",markers(o){var l;return((l=o.plugin(s))===null||l===void 0?void 0:l.markers)||_.empty},initialSpacer(){return new Nr(e,!1)},domEventHandlers:{...r,click:(o,l,a)=>{if(r.click&&r.click(o,l,a))return!0;let h=Ns(o.state,l.from,l.to);if(h)return o.dispatch({effects:Mn.of(h)}),!0;let c=Ls(o.state,l.from,l.to);return c?(o.dispatch({effects:ir.of(c)}),!0):!1}}}),cu()]}const S0=Q.baseTheme({".cm-foldPlaceholder":{backgroundColor:"#eee",border:"1px solid #ddd",color:"#888",borderRadius:".2em",margin:"0 1px",padding:"0 1px",cursor:"pointer"},".cm-foldGutter span":{padding:"0 1px",cursor:"pointer"}});class Dn{constructor(e,t){this.specs=e;let n;function s(l){let a=Wt.newName();return(n||(n=Object.create(null)))["."+a]=l,a}const r=typeof t.all=="string"?t.all:t.all?s(t.all):void 0,o=t.scope;this.scope=o instanceof et?l=>l.prop(yi)==o.data:o?l=>l==o:void 0,this.style=iu(e.map(l=>({tag:l.tag,class:l.class||s(Object.assign({},l,{tag:null}))})),{all:r}).style,this.module=n?new Wt(n):null,this.themeType=t.themeType}static define(e,t){return new Dn(e,t||{})}}const Lo=B.define(),uu=B.define({combine(i){return i.length?[i[0]]:null}});function $r(i){let e=i.facet(Lo);return e.length?e:i.facet(uu)}function du(i,e){let t=[E0],n;return i instanceof Dn&&(i.module&&t.push(Q.styleModule.of(i.module)),n=i.themeType),e?.fallback?t.push(uu.of(i)):n?t.push(Lo.computeN([Q.darkTheme],s=>s.facet(Q.darkTheme)==(n=="dark")?[i]:[])):t.push(Lo.of(i)),t}class Q0{constructor(e){this.markCache=Object.create(null),this.tree=we(e.state),this.decorations=this.buildDeco(e,$r(e.state)),this.decoratedTo=e.viewport.to}update(e){let t=we(e.state),n=$r(e.state),s=n!=$r(e.startState),{viewport:r}=e.view,o=e.changes.mapPos(this.decoratedTo,1);t.length<r.to&&!s&&t.type==this.tree.type&&o>=r.to?(this.decorations=this.decorations.map(e.changes),this.decoratedTo=o):(t!=this.tree||e.viewportChanged||s)&&(this.tree=t,this.decorations=this.buildDeco(e.view,n),this.decoratedTo=r.to)}buildDeco(e,t){if(!t||!this.tree.length)return D.none;let n=new Qt;for(let{from:s,to:r}of e.visibleRanges)GA(this.tree,t,(o,l,a)=>{n.add(o,l,this.markCache[a]||(this.markCache[a]=D.mark({class:a})))},s,r);return n.finish()}}const E0=di.high(ne.fromClass(Q0,{decorations:i=>i.decorations})),B0=Dn.define([{tag:A.meta,color:"#404740"},{tag:A.link,textDecoration:"underline"},{tag:A.heading,textDecoration:"underline",fontWeight:"bold"},{tag:A.emphasis,fontStyle:"italic"},{tag:A.strong,fontWeight:"bold"},{tag:A.strikethrough,textDecoration:"line-through"},{tag:A.keyword,color:"#708"},{tag:[A.atom,A.bool,A.url,A.contentSeparator,A.labelName],color:"#219"},{tag:[A.literal,A.inserted],color:"#164"},{tag:[A.string,A.deleted],color:"#a11"},{tag:[A.regexp,A.escape,A.special(A.string)],color:"#e40"},{tag:A.definition(A.variableName),color:"#00f"},{tag:A.local(A.variableName),color:"#30a"},{tag:[A.typeName,A.namespace],color:"#085"},{tag:A.className,color:"#167"},{tag:[A.special(A.variableName),A.macroName],color:"#256"},{tag:A.definition(A.propertyName),color:"#00c"},{tag:A.comment,color:"#940"},{tag:A.invalid,color:"#f00"}]),P0=Q.baseTheme({"&.cm-focused .cm-matchingBracket":{backgroundColor:"#328c8252"},"&.cm-focused .cm-nonmatchingBracket":{backgroundColor:"#bb555544"}}),pu=1e4,mu="()[]{}",gu=B.define({combine(i){return yt(i,{afterCursor:!0,brackets:mu,maxScanDistance:pu,renderMatch:I0})}}),M0=D.mark({class:"cm-matchingBracket"}),D0=D.mark({class:"cm-nonmatchingBracket"});function I0(i){let e=[],t=i.matched?M0:D0;return e.push(t.range(i.start.from,i.start.to)),i.end&&e.push(t.range(i.end.from,i.end.to)),e}const T0=ge.define({create(){return D.none},update(i,e){if(!e.docChanged&&!e.selection)return i;let t=[],n=e.state.facet(gu);for(let s of e.state.selection.ranges){if(!s.empty)continue;let r=mt(e.state,s.head,-1,n)||s.head>0&&mt(e.state,s.head-1,1,n)||n.afterCursor&&(mt(e.state,s.head,1,n)||s.head<e.state.doc.length&&mt(e.state,s.head+1,-1,n));r&&(t=t.concat(n.renderMatch(r,e.state)))}return D.set(t,!0)},provide:i=>Q.decorations.from(i)}),R0=[T0,P0];function L0(i={}){return[gu.of(i),R0]}const N0=new N;function No(i,e,t){let n=i.prop(e<0?N.openedBy:N.closedBy);if(n)return n;if(i.name.length==1){let s=t.indexOf(i.name);if(s>-1&&s%2==(e<0?1:0))return[t[s+e]]}return null}function $o(i){let e=i.type.prop(N0);return e?e(i.node):i}function mt(i,e,t,n={}){let s=n.maxScanDistance||pu,r=n.brackets||mu,o=we(i),l=o.resolveInner(e,t);for(let a=l;a;a=a.parent){let h=No(a.type,t,r);if(h&&a.from<a.to){let c=$o(a);if(c&&(t>0?e>=c.from&&e<c.to:e>c.from&&e<=c.to))return $0(i,e,t,a,c,h,r)}}return F0(i,e,t,o,l.type,s,r)}function $0(i,e,t,n,s,r,o){let l=n.parent,a={from:s.from,to:s.to},h=0,c=l?.cursor();if(c&&(t<0?c.childBefore(n.from):c.childAfter(n.to)))do if(t<0?c.to<=n.from:c.from>=n.to){if(h==0&&r.indexOf(c.type.name)>-1&&c.from<c.to){let f=$o(c);return{start:a,end:f?{from:f.from,to:f.to}:void 0,matched:!0}}else if(No(c.type,t,o))h++;else if(No(c.type,-t,o)){if(h==0){let f=$o(c);return{start:a,end:f&&f.from<f.to?{from:f.from,to:f.to}:void 0,matched:!1}}h--}}while(t<0?c.prevSibling():c.nextSibling());return{start:a,matched:!1}}function F0(i,e,t,n,s,r,o){let l=t<0?i.sliceDoc(e-1,e):i.sliceDoc(e,e+1),a=o.indexOf(l);if(a<0||a%2==0!=t>0)return null;let h={from:t<0?e-1:e,to:t>0?e+1:e},c=i.doc.iterRange(e,t>0?i.doc.length:0),f=0;for(let u=0;!c.next().done&&u<=r;){let d=c.value;t<0&&(u+=d.length);let p=e+u*t;for(let m=t>0?0:d.length-1,g=t>0?d.length:-1;m!=g;m+=t){let O=o.indexOf(d[m]);if(!(O<0||n.resolveInner(p+m,1).type!=s))if(O%2==0==t>0)f++;else{if(f==1)return{start:h,end:{from:p+m,to:p+m+1},matched:O>>1==a>>1};f--}}t>0&&(u+=d.length)}return c.done?{start:h,matched:!1}:null}const K0=Object.create(null),hh=[De.none],ch=[],fh=Object.create(null),z0=Object.create(null);for(let[i,e]of[["variable","variableName"],["variable-2","variableName.special"],["string-2","string.special"],["def","variableName.definition"],["tag","tagName"],["attribute","attributeName"],["type","typeName"],["builtin","variableName.standard"],["qualifier","modifier"],["error","invalid"],["header","heading"],["property","propertyName"]])z0[i]=_0(K0,e);function Fr(i,e){ch.indexOf(i)>-1||(ch.push(i),console.warn(e))}function _0(i,e){let t=[];for(let l of e.split(" ")){let a=[];for(let h of l.split(".")){let c=i[h]||A[h];c?typeof c=="function"?a.length?a=a.map(c):Fr(h,`Modifier ${h} used at start of tag`):a.length?Fr(h,`Tag ${h} used as modifier`):a=Array.isArray(c)?c:[c]:Fr(h,`Unknown highlighting tag ${h}`)}for(let h of a)t.push(h)}if(!t.length)return 0;let n=e.replace(/ /g,"_"),s=n+" "+t.map(l=>l.id),r=fh[s];if(r)return r.id;let o=fh[s]=De.define({id:hh.length,name:n,props:[eu({[n]:t})]});return hh.push(o),o.id}Z.RTL,Z.LTR;class uh{constructor(e,t,n){this.from=e,this.to=t,this.diagnostic=n}}class Zt{constructor(e,t,n){this.diagnostics=e,this.panel=t,this.selected=n}static init(e,t,n){let s=n.facet(gt).markerFilter;s&&(e=s(e,n));let r=e.slice().sort((c,f)=>c.from-f.from||c.to-f.to),o=new Qt,l=[],a=0;for(let c=0;;){let f=c==r.length?null:r[c];if(!f&&!l.length)break;let u,d;for(l.length?(u=a,d=l.reduce((m,g)=>Math.min(m,g.to),f&&f.from>u?f.from:1e8)):(u=f.from,d=f.to,l.push(f),c++);c<r.length;){let m=r[c];if(m.from==u&&(m.to>m.from||m.to==u))l.push(m),c++,d=Math.min(m.to,d);else{d=Math.min(m.from,d);break}}let p=nO(l);if(l.some(m=>m.from==m.to||m.from==m.to-1&&n.doc.lineAt(m.from).to==m.from))o.add(u,u,D.widget({widget:new Z0(p),diagnostics:l.slice()}));else{let m=l.reduce((g,O)=>O.markClass?g+" "+O.markClass:g,"");o.add(u,d,D.mark({class:"cm-lintRange cm-lintRange-"+p+m,diagnostics:l.slice(),inclusiveEnd:l.some(g=>g.to>d)}))}a=d;for(let m=0;m<l.length;m++)l[m].to<=a&&l.splice(m--,1)}let h=o.finish();return new Zt(h,t,Li(h))}}function Li(i,e=null,t=0){let n=null;return i.between(t,1e9,(s,r,{spec:o})=>{if(!(e&&o.diagnostics.indexOf(e)<0))if(!n)n=new uh(s,r,e||o.diagnostics[0]);else{if(o.diagnostics.indexOf(n.diagnostic)<0)return!1;n=new uh(n.from,r,n.diagnostic)}}),n}function V0(i,e){let t=e.pos,n=e.end||t,s=i.state.facet(gt).hideOn(i,t,n);if(s!=null)return s;let r=i.startState.doc.lineAt(e.pos);return!!(i.effects.some(o=>o.is(wl))||i.changes.touchesRange(r.from,Math.max(r.to,n)))}function Au(i,e){return i.field($e,!1)?e:e.concat(R.appendConfig.of(ku))}function W0(i,e){return{effects:Au(i,[wl.of(e)])}}const wl=R.define(),yl=R.define(),Ou=R.define(),$e=ge.define({create(){return new Zt(D.none,null,null)},update(i,e){if(e.docChanged&&i.diagnostics.size){let t=i.diagnostics.map(e.changes),n=null,s=i.panel;if(i.selected){let r=e.changes.mapPos(i.selected.from,1);n=Li(t,i.selected.diagnostic,r)||Li(t,null,r)}!t.size&&s&&e.state.facet(gt).autoPanel&&(s=null),i=new Zt(t,s,n)}for(let t of e.effects)if(t.is(wl)){let n=e.state.facet(gt).autoPanel?t.value.length?yn.open:null:i.panel;i=Zt.init(t.value,n,e.state)}else t.is(yl)?i=new Zt(i.diagnostics,t.value?yn.open:null,i.selected):t.is(Ou)&&(i=new Zt(i.diagnostics,i.panel,t.value));return i},provide:i=>[bn.from(i,e=>e.panel),Q.decorations.from(i,e=>e.diagnostics)]}),H0=D.mark({class:"cm-lintRange cm-lintRange-active"});function q0(i,e,t){let{diagnostics:n}=i.state.field($e),s,r=-1,o=-1;n.between(e-(t<0?1:0),e+(t>0?1:0),(a,h,{spec:c})=>{if(e>=a&&e<=h&&(a==h||(e>a||t>0)&&(e<h||t<0)))return s=c.diagnostics,r=a,o=h,!1});let l=i.state.facet(gt).tooltipFilter;return s&&l&&(s=l(s,i.state)),s?{pos:r,end:o,above:i.state.doc.lineAt(r).to<o,create(){return{dom:G0(i,s)}}}:null}function G0(i,e){return G("ul",{class:"cm-tooltip-lint"},e.map(t=>yu(i,t,!1)))}const U0=i=>{let e=i.state.field($e,!1);(!e||!e.panel)&&i.dispatch({effects:Au(i.state,[yl.of(!0)])});let t=On(i,yn.open);return t&&t.dom.querySelector(".cm-panel-lint ul").focus(),!0},dh=i=>{let e=i.state.field($e,!1);return!e||!e.panel?!1:(i.dispatch({effects:yl.of(!1)}),!0)},Y0=i=>{let e=i.state.field($e,!1);if(!e)return!1;let t=i.state.selection.main,n=e.diagnostics.iter(t.to+1);return!n.value&&(n=e.diagnostics.iter(0),!n.value||n.from==t.from&&n.to==t.to)?!1:(i.dispatch({selection:{anchor:n.from,head:n.to},scrollIntoView:!0}),!0)},X0=[{key:"Mod-Shift-m",run:U0,preventDefault:!0},{key:"F8",run:Y0}],bu=ne.fromClass(class{constructor(i){this.view=i,this.timeout=-1,this.set=!0;let{delay:e}=i.state.facet(gt);this.lintTime=Date.now()+e,this.run=this.run.bind(this),this.timeout=setTimeout(this.run,e)}run(){clearTimeout(this.timeout);let i=Date.now();if(i<this.lintTime-10)this.timeout=setTimeout(this.run,this.lintTime-i);else{this.set=!1;let{state:e}=this.view,{sources:t}=e.facet(gt);t.length&&j0(t.map(n=>Promise.resolve(n(this.view))),n=>{this.view.state.doc==e.doc&&this.view.dispatch(W0(this.view.state,n.reduce((s,r)=>s.concat(r))))},n=>{ve(this.view.state,n)})}}update(i){let e=i.state.facet(gt);(i.docChanged||e!=i.startState.facet(gt)||e.needsRefresh&&e.needsRefresh(i))&&(this.lintTime=Date.now()+e.delay,this.set||(this.set=!0,this.timeout=setTimeout(this.run,e.delay)))}force(){this.set&&(this.lintTime=Date.now(),this.run())}destroy(){clearTimeout(this.timeout)}});function j0(i,e,t){let n=[],s=-1;for(let r of i)r.then(o=>{n.push(o),clearTimeout(s),n.length==i.length?e(n):s=setTimeout(()=>e(n),200)},t)}const gt=B.define({combine(i){return Object.assign({sources:i.map(e=>e.source).filter(e=>e!=null)},yt(i.map(e=>e.config),{delay:750,markerFilter:null,tooltipFilter:null,needsRefresh:null,hideOn:()=>null},{needsRefresh:(e,t)=>e?t?n=>e(n)||t(n):e:t}))}});function J0(i,e={}){return[gt.of({source:i,config:e}),bu,ku]}function ph(i){let e=i.plugin(bu);e&&e.force()}function wu(i){let e=[];if(i)e:for(let{name:t}of i){for(let n=0;n<t.length;n++){let s=t[n];if(/[a-zA-Z]/.test(s)&&!e.some(r=>r.toLowerCase()==s.toLowerCase())){e.push(s);continue e}}e.push("")}return e}function yu(i,e,t){var n;let s=t?wu(e.actions):[];return G("li",{class:"cm-diagnostic cm-diagnostic-"+e.severity},G("span",{class:"cm-diagnosticText"},e.renderMessage?e.renderMessage(i):e.message),(n=e.actions)===null||n===void 0?void 0:n.map((r,o)=>{let l=!1,a=u=>{if(u.preventDefault(),l)return;l=!0;let d=Li(i.state.field($e).diagnostics,e);d&&r.apply(i,d.from,d.to)},{name:h}=r,c=s[o]?h.indexOf(s[o]):-1,f=c<0?h:[h.slice(0,c),G("u",h.slice(c,c+1)),h.slice(c+1)];return G("button",{type:"button",class:"cm-diagnosticAction",onclick:a,onmousedown:a,"aria-label":` Action: ${h}${c<0?"":` (access key "${s[o]})"`}.`},f)}),e.source&&G("div",{class:"cm-diagnosticSource"},e.source))}class Z0 extends Ut{constructor(e){super(),this.sev=e}eq(e){return e.sev==this.sev}toDOM(){return G("span",{class:"cm-lintPoint cm-lintPoint-"+this.sev})}}class mh{constructor(e,t){this.diagnostic=t,this.id="item_"+Math.floor(Math.random()*4294967295).toString(16),this.dom=yu(e,t,!0),this.dom.id=this.id,this.dom.setAttribute("role","option")}}class yn{constructor(e){this.view=e,this.items=[];let t=s=>{if(s.keyCode==27)dh(this.view),this.view.focus();else if(s.keyCode==38||s.keyCode==33)this.moveSelection((this.selectedIndex-1+this.items.length)%this.items.length);else if(s.keyCode==40||s.keyCode==34)this.moveSelection((this.selectedIndex+1)%this.items.length);else if(s.keyCode==36)this.moveSelection(0);else if(s.keyCode==35)this.moveSelection(this.items.length-1);else if(s.keyCode==13)this.view.focus();else if(s.keyCode>=65&&s.keyCode<=90&&this.selectedIndex>=0){let{diagnostic:r}=this.items[this.selectedIndex],o=wu(r.actions);for(let l=0;l<o.length;l++)if(o[l].toUpperCase().charCodeAt(0)==s.keyCode){let a=Li(this.view.state.field($e).diagnostics,r);a&&r.actions[l].apply(e,a.from,a.to)}}else return;s.preventDefault()},n=s=>{for(let r=0;r<this.items.length;r++)this.items[r].dom.contains(s.target)&&this.moveSelection(r)};this.list=G("ul",{tabIndex:0,role:"listbox","aria-label":this.view.state.phrase("Diagnostics"),onkeydown:t,onclick:n}),this.dom=G("div",{class:"cm-panel-lint"},this.list,G("button",{type:"button",name:"close","aria-label":this.view.state.phrase("close"),onclick:()=>dh(this.view)},"×")),this.update()}get selectedIndex(){let e=this.view.state.field($e).selected;if(!e)return-1;for(let t=0;t<this.items.length;t++)if(this.items[t].diagnostic==e.diagnostic)return t;return-1}update(){let{diagnostics:e,selected:t}=this.view.state.field($e),n=0,s=!1,r=null,o=new Set;for(e.between(0,this.view.state.doc.length,(l,a,{spec:h})=>{for(let c of h.diagnostics){if(o.has(c))continue;o.add(c);let f=-1,u;for(let d=n;d<this.items.length;d++)if(this.items[d].diagnostic==c){f=d;break}f<0?(u=new mh(this.view,c),this.items.splice(n,0,u),s=!0):(u=this.items[f],f>n&&(this.items.splice(n,f-n),s=!0)),t&&u.diagnostic==t.diagnostic?u.dom.hasAttribute("aria-selected")||(u.dom.setAttribute("aria-selected","true"),r=u):u.dom.hasAttribute("aria-selected")&&u.dom.removeAttribute("aria-selected"),n++}});n<this.items.length&&!(this.items.length==1&&this.items[0].diagnostic.from<0);)s=!0,this.items.pop();this.items.length==0&&(this.items.push(new mh(this.view,{from:-1,to:-1,severity:"info",message:this.view.state.phrase("No diagnostics")})),s=!0),r?(this.list.setAttribute("aria-activedescendant",r.id),this.view.requestMeasure({key:this,read:()=>({sel:r.dom.getBoundingClientRect(),panel:this.list.getBoundingClientRect()}),write:({sel:l,panel:a})=>{let h=a.height/this.list.offsetHeight;l.top<a.top?this.list.scrollTop-=(a.top-l.top)/h:l.bottom>a.bottom&&(this.list.scrollTop+=(l.bottom-a.bottom)/h)}})):this.selectedIndex<0&&this.list.removeAttribute("aria-activedescendant"),s&&this.sync()}sync(){let e=this.list.firstChild;function t(){let n=e;e=n.nextSibling,n.remove()}for(let n of this.items)if(n.dom.parentNode==this.list){for(;e!=n.dom;)t();e=n.dom.nextSibling}else this.list.insertBefore(n.dom,e);for(;e;)t()}moveSelection(e){if(this.selectedIndex<0)return;let t=this.view.state.field($e),n=Li(t.diagnostics,this.items[e].diagnostic);n&&this.view.dispatch({selection:{anchor:n.from,head:n.to},scrollIntoView:!0,effects:Ou.of(n)})}static open(e){return new yn(e)}}function eO(i,e='viewBox="0 0 40 40"'){return`url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" ${e}>${encodeURIComponent(i)}</svg>')`}function es(i){return eO(`<path d="m0 2.5 l2 -1.5 l1 0 l2 1.5 l1 0" stroke="${i}" fill="none" stroke-width=".7"/>`,'width="6" height="3"')}const tO=Q.baseTheme({".cm-diagnostic":{padding:"3px 6px 3px 8px",marginLeft:"-1px",display:"block",whiteSpace:"pre-wrap"},".cm-diagnostic-error":{borderLeft:"5px solid #d11"},".cm-diagnostic-warning":{borderLeft:"5px solid orange"},".cm-diagnostic-info":{borderLeft:"5px solid #999"},".cm-diagnostic-hint":{borderLeft:"5px solid #66d"},".cm-diagnosticAction":{font:"inherit",border:"none",padding:"2px 4px",backgroundColor:"#444",color:"white",borderRadius:"3px",marginLeft:"8px",cursor:"pointer"},".cm-diagnosticSource":{fontSize:"70%",opacity:.7},".cm-lintRange":{backgroundPosition:"left bottom",backgroundRepeat:"repeat-x",paddingBottom:"0.7px"},".cm-lintRange-error":{backgroundImage:es("#d11")},".cm-lintRange-warning":{backgroundImage:es("orange")},".cm-lintRange-info":{backgroundImage:es("#999")},".cm-lintRange-hint":{backgroundImage:es("#66d")},".cm-lintRange-active":{backgroundColor:"#ffdd9980"},".cm-tooltip-lint":{padding:0,margin:0},".cm-lintPoint":{position:"relative","&:after":{content:'""',position:"absolute",bottom:0,left:"-2px",borderLeft:"3px solid transparent",borderRight:"3px solid transparent",borderBottom:"4px solid #d11"}},".cm-lintPoint-warning":{"&:after":{borderBottomColor:"orange"}},".cm-lintPoint-info":{"&:after":{borderBottomColor:"#999"}},".cm-lintPoint-hint":{"&:after":{borderBottomColor:"#66d"}},".cm-panel.cm-panel-lint":{position:"relative","& ul":{maxHeight:"100px",overflowY:"auto","& [aria-selected]":{backgroundColor:"#ddd","& u":{textDecoration:"underline"}},"&:focus [aria-selected]":{background_fallback:"#bdf",backgroundColor:"Highlight",color_fallback:"white",color:"HighlightText"},"& u":{textDecoration:"none"},padding:0,margin:0},"& [name=close]":{position:"absolute",top:"0",right:"2px",background:"inherit",border:"none",font:"inherit",padding:0,margin:0}}});function iO(i){return i=="error"?4:i=="warning"?3:i=="info"?2:1}function nO(i){let e="hint",t=1;for(let n of i){let s=iO(n.severity);s>t&&(t=s,e=n.severity)}return e}const ku=[$e,Q.decorations.compute([$e],i=>{let{selected:e,panel:t}=i.field($e);return!e||!t||e.from==e.to?D.none:D.set([H0.range(e.from,e.to)])}),QA(q0,{hideOn:V0}),tO],sO=eu({Number:A.number,Boolean:A.bool,LineComment:A.lineComment,BlockComment:A.blockComment,Import:A.keyword,"import as":A.keyword,"FunctionDeclaration/Kw":A.controlKeyword,"IfStatement/Kw":A.controlKeyword,"SwitchStatement/Kw":A.controlKeyword,"SwitchClause/Kw":A.controlKeyword,"LoopStatement/Kw":A.controlKeyword,"LoopBlock/Kw":A.controlKeyword,"ForStatement/Kw":A.controlKeyword,"WhileStatement/Kw":A.controlKeyword,"Statement/Kw":A.controlKeyword,"GlobalVariableDeclaration/Kw":A.definitionKeyword,"GlobalValueDeclaration/Kw":A.definitionKeyword,"VarStatement/Kw":A.definitionKeyword,"StructDeclaration/Kw":A.definitionKeyword,"TypeAliasDeclaration/Kw":A.definitionKeyword,"DiagnosticDirective/Kw":A.keyword,"EnableDirective/Kw":A.keyword,"RequiresDirective/Kw":A.keyword,"ConstAssert/Kw":A.keyword,"TypeOrExpr/Kw":A.keyword,BuiltinType:A.keyword,BuiltinFn:A.keyword,Identifier:A.variableName,"Type/Identifier":A.typeName,"TypeOrExpr/Identifier":A.typeName,"FunctionDeclaration/Identifier":A.function(A.definition(A.variableName)),"StructDeclaration/Identifier":A.definition(A.typeName),"Param/Identifier":A.definition(A.variableName),"StructMember/Identifier":A.propertyName,"VarStatement/Identifier":A.definition(A.variableName),"GlobalVariableDeclaration/Identifier":A.definition(A.variableName),"GlobalValueDeclaration/Identifier":A.definition(A.variableName),"FunctionDeclaration/BuiltinFn":A.function(A.definition(A.variableName)),"StructDeclaration/BuiltinFn":A.definition(A.typeName),"Param/BuiltinFn":A.definition(A.variableName),"StructMember/BuiltinFn":A.propertyName,"VarStatement/BuiltinFn":A.definition(A.variableName),"GlobalVariableDeclaration/BuiltinFn":A.definition(A.variableName),"GlobalValueDeclaration/BuiltinFn":A.definition(A.variableName),"ImportPath/Identifier":A.namespace,"ImportItem/Identifier":A.namespace,"ImportPath/Kw":A.keyword,"PathBase/Identifier":A.namespace,"PathExpression/Identifier":A.function(A.variableName),"CallExpression/Identifier":A.typeName,"StandardAttribute/Identifier":A.keyword,'"=" "+=" "-=" "*=" "/=" "%=" "&=" "|=" "^=" "<<=" ">>="':A.definitionOperator,"++ --":A.updateOperator,"( )":A.paren,"[ ]":A.squareBracket,"{ }":A.brace,". , ; : -> ::":A.punctuation,"< >":A.angleBracket});var gh={};class $s{constructor(e,t,n,s,r,o,l,a,h,c=0,f){this.p=e,this.stack=t,this.state=n,this.reducePos=s,this.pos=r,this.score=o,this.buffer=l,this.bufferBase=a,this.curContext=h,this.lookAhead=c,this.parent=f}toString(){return`[${this.stack.filter((e,t)=>t%3==0).concat(this.state)}]@${this.pos}${this.score?"!"+this.score:""}`}static start(e,t,n=0){let s=e.parser.context;return new $s(e,[],t,n,n,0,[],0,s?new Ah(s,s.start):null,0,null)}get context(){return this.curContext?this.curContext.context:null}pushState(e,t){this.stack.push(this.state,t,this.bufferBase+this.buffer.length),this.state=e}reduce(e){var t;let n=e>>19,s=e&65535,{parser:r}=this.p,o=this.reducePos<this.pos-25;o&&this.setLookAhead(this.pos);let l=r.dynamicPrecedence(s);if(l&&(this.score+=l),n==0){this.pushState(r.getGoto(this.state,s,!0),this.reducePos),s<r.minRepeatTerm&&this.storeNode(s,this.reducePos,this.reducePos,o?8:4,!0),this.reduceContext(s,this.reducePos);return}let a=this.stack.length-(n-1)*3-(e&262144?6:0),h=a?this.stack[a-2]:this.p.ranges[0].from,c=this.reducePos-h;c>=2e3&&!(!((t=this.p.parser.nodeSet.types[s])===null||t===void 0)&&t.isAnonymous)&&(h==this.p.lastBigReductionStart?(this.p.bigReductionCount++,this.p.lastBigReductionSize=c):this.p.lastBigReductionSize<c&&(this.p.bigReductionCount=1,this.p.lastBigReductionStart=h,this.p.lastBigReductionSize=c));let f=a?this.stack[a-1]:0,u=this.bufferBase+this.buffer.length-f;if(s<r.minRepeatTerm||e&131072){let d=r.stateFlag(this.state,1)?this.pos:this.reducePos;this.storeNode(s,h,d,u+4,!0)}if(e&262144)this.state=this.stack[a];else{let d=this.stack[a-3];this.state=r.getGoto(d,s,!0)}for(;this.stack.length>a;)this.stack.pop();this.reduceContext(s,h)}storeNode(e,t,n,s=4,r=!1){if(e==0&&(!this.stack.length||this.stack[this.stack.length-1]<this.buffer.length+this.bufferBase)){let o=this,l=this.buffer.length;if(l==0&&o.parent&&(l=o.bufferBase-o.parent.bufferBase,o=o.parent),l>0&&o.buffer[l-4]==0&&o.buffer[l-1]>-1){if(t==n)return;if(o.buffer[l-2]>=t){o.buffer[l-2]=n;return}}}if(!r||this.pos==n)this.buffer.push(e,t,n,s);else{let o=this.buffer.length;if(o>0&&this.buffer[o-4]!=0){let l=!1;for(let a=o;a>0&&this.buffer[a-2]>n;a-=4)if(this.buffer[a-1]>=0){l=!0;break}if(l)for(;o>0&&this.buffer[o-2]>n;)this.buffer[o]=this.buffer[o-4],this.buffer[o+1]=this.buffer[o-3],this.buffer[o+2]=this.buffer[o-2],this.buffer[o+3]=this.buffer[o-1],o-=4,s>4&&(s-=4)}this.buffer[o]=e,this.buffer[o+1]=t,this.buffer[o+2]=n,this.buffer[o+3]=s}}shift(e,t,n,s){if(e&131072)this.pushState(e&65535,this.pos);else if((e&262144)==0){let r=e,{parser:o}=this.p;(s>this.pos||t<=o.maxNode)&&(this.pos=s,o.stateFlag(r,1)||(this.reducePos=s)),this.pushState(r,n),this.shiftContext(t,n),t<=o.maxNode&&this.buffer.push(t,n,s,4)}else this.pos=s,this.shiftContext(t,n),t<=this.p.parser.maxNode&&this.buffer.push(t,n,s,4)}apply(e,t,n,s){e&65536?this.reduce(e):this.shift(e,t,n,s)}useNode(e,t){let n=this.p.reused.length-1;(n<0||this.p.reused[n]!=e)&&(this.p.reused.push(e),n++);let s=this.pos;this.reducePos=this.pos=s+e.length,this.pushState(t,s),this.buffer.push(n,s,this.reducePos,-1),this.curContext&&this.updateContext(this.curContext.tracker.reuse(this.curContext.context,e,this,this.p.stream.reset(this.pos-e.length)))}split(){let e=this,t=e.buffer.length;for(;t>0&&e.buffer[t-2]>e.reducePos;)t-=4;let n=e.buffer.slice(t),s=e.bufferBase+t;for(;e&&s==e.bufferBase;)e=e.parent;return new $s(this.p,this.stack.slice(),this.state,this.reducePos,this.pos,this.score,n,s,this.curContext,this.lookAhead,e)}recoverByDelete(e,t){let n=e<=this.p.parser.maxNode;n&&this.storeNode(e,this.pos,t,4),this.storeNode(0,this.pos,t,n?8:4),this.pos=this.reducePos=t,this.score-=190}canShift(e){for(let t=new rO(this);;){let n=this.p.parser.stateSlot(t.state,4)||this.p.parser.hasAction(t.state,e);if(n==0)return!1;if((n&65536)==0)return!0;t.reduce(n)}}recoverByInsert(e){if(this.stack.length>=300)return[];let t=this.p.parser.nextStates(this.state);if(t.length>8||this.stack.length>=120){let s=[];for(let r=0,o;r<t.length;r+=2)(o=t[r+1])!=this.state&&this.p.parser.hasAction(o,e)&&s.push(t[r],o);if(this.stack.length<120)for(let r=0;s.length<8&&r<t.length;r+=2){let o=t[r+1];s.some((l,a)=>a&1&&l==o)||s.push(t[r],o)}t=s}let n=[];for(let s=0;s<t.length&&n.length<4;s+=2){let r=t[s+1];if(r==this.state)continue;let o=this.split();o.pushState(r,this.pos),o.storeNode(0,o.pos,o.pos,4,!0),o.shiftContext(t[s],this.pos),o.reducePos=this.pos,o.score-=200,n.push(o)}return n}forceReduce(){let{parser:e}=this.p,t=e.stateSlot(this.state,5);if((t&65536)==0)return!1;if(!e.validAction(this.state,t)){let n=t>>19,s=t&65535,r=this.stack.length-n*3;if(r<0||e.getGoto(this.stack[r],s,!1)<0){let o=this.findForcedReduction();if(o==null)return!1;t=o}this.storeNode(0,this.pos,this.pos,4,!0),this.score-=100}return this.reducePos=this.pos,this.reduce(t),!0}findForcedReduction(){let{parser:e}=this.p,t=[],n=(s,r)=>{if(!t.includes(s))return t.push(s),e.allActions(s,o=>{if(!(o&393216))if(o&65536){let l=(o>>19)-r;if(l>1){let a=o&65535,h=this.stack.length-l*3;if(h>=0&&e.getGoto(this.stack[h],a,!1)>=0)return l<<19|65536|a}}else{let l=n(o,r+1);if(l!=null)return l}})};return n(this.state,0)}forceAll(){for(;!this.p.parser.stateFlag(this.state,2);)if(!this.forceReduce()){this.storeNode(0,this.pos,this.pos,4,!0);break}return this}get deadEnd(){if(this.stack.length!=3)return!1;let{parser:e}=this.p;return e.data[e.stateSlot(this.state,1)]==65535&&!e.stateSlot(this.state,4)}restart(){this.storeNode(0,this.pos,this.pos,4,!0),this.state=this.stack[0],this.stack.length=0}sameState(e){if(this.state!=e.state||this.stack.length!=e.stack.length)return!1;for(let t=0;t<this.stack.length;t+=3)if(this.stack[t]!=e.stack[t])return!1;return!0}get parser(){return this.p.parser}dialectEnabled(e){return this.p.parser.dialect.flags[e]}shiftContext(e,t){this.curContext&&this.updateContext(this.curContext.tracker.shift(this.curContext.context,e,this,this.p.stream.reset(t)))}reduceContext(e,t){this.curContext&&this.updateContext(this.curContext.tracker.reduce(this.curContext.context,e,this,this.p.stream.reset(t)))}emitContext(){let e=this.buffer.length-1;(e<0||this.buffer[e]!=-3)&&this.buffer.push(this.curContext.hash,this.pos,this.pos,-3)}emitLookAhead(){let e=this.buffer.length-1;(e<0||this.buffer[e]!=-4)&&this.buffer.push(this.lookAhead,this.pos,this.pos,-4)}updateContext(e){if(e!=this.curContext.context){let t=new Ah(this.curContext.tracker,e);t.hash!=this.curContext.hash&&this.emitContext(),this.curContext=t}}setLookAhead(e){e>this.lookAhead&&(this.emitLookAhead(),this.lookAhead=e)}close(){this.curContext&&this.curContext.tracker.strict&&this.emitContext(),this.lookAhead>0&&this.emitLookAhead()}}class Ah{constructor(e,t){this.tracker=e,this.context=t,this.hash=e.strict?e.hash(t):0}}class rO{constructor(e){this.start=e,this.state=e.state,this.stack=e.stack,this.base=this.stack.length}reduce(e){let t=e&65535,n=e>>19;n==0?(this.stack==this.start.stack&&(this.stack=this.stack.slice()),this.stack.push(this.state,0,0),this.base+=3):this.base-=(n-1)*3;let s=this.start.p.parser.getGoto(this.stack[this.base-3],t,!0);this.state=s}}class Fs{constructor(e,t,n){this.stack=e,this.pos=t,this.index=n,this.buffer=e.buffer,this.index==0&&this.maybeNext()}static create(e,t=e.bufferBase+e.buffer.length){return new Fs(e,t,t-e.bufferBase)}maybeNext(){let e=this.stack.parent;e!=null&&(this.index=this.stack.bufferBase-e.bufferBase,this.stack=e,this.buffer=e.buffer)}get id(){return this.buffer[this.index-4]}get start(){return this.buffer[this.index-3]}get end(){return this.buffer[this.index-2]}get size(){return this.buffer[this.index-1]}next(){this.index-=4,this.pos-=4,this.index==0&&this.maybeNext()}fork(){return new Fs(this.stack,this.pos,this.index)}}function ts(i,e=Uint16Array){if(typeof i!="string")return i;let t=null;for(let n=0,s=0;n<i.length;){let r=0;for(;;){let o=i.charCodeAt(n++),l=!1;if(o==126){r=65535;break}o>=92&&o--,o>=34&&o--;let a=o-32;if(a>=46&&(a-=46,l=!0),r+=a,l)break;r*=46}t?t[s++]=r:t=new e(r)}return t}class ws{constructor(){this.start=-1,this.value=-1,this.end=-1,this.extended=-1,this.lookAhead=0,this.mask=0,this.context=0}}const Oh=new ws;class oO{constructor(e,t){this.input=e,this.ranges=t,this.chunk="",this.chunkOff=0,this.chunk2="",this.chunk2Pos=0,this.next=-1,this.token=Oh,this.rangeIndex=0,this.pos=this.chunkPos=t[0].from,this.range=t[0],this.end=t[t.length-1].to,this.readNext()}resolveOffset(e,t){let n=this.range,s=this.rangeIndex,r=this.pos+e;for(;r<n.from;){if(!s)return null;let o=this.ranges[--s];r-=n.from-o.to,n=o}for(;t<0?r>n.to:r>=n.to;){if(s==this.ranges.length-1)return null;let o=this.ranges[++s];r+=o.from-n.to,n=o}return r}clipPos(e){if(e>=this.range.from&&e<this.range.to)return e;for(let t of this.ranges)if(t.to>e)return Math.max(e,t.from);return this.end}peek(e){let t=this.chunkOff+e,n,s;if(t>=0&&t<this.chunk.length)n=this.pos+e,s=this.chunk.charCodeAt(t);else{let r=this.resolveOffset(e,1);if(r==null)return-1;if(n=r,n>=this.chunk2Pos&&n<this.chunk2Pos+this.chunk2.length)s=this.chunk2.charCodeAt(n-this.chunk2Pos);else{let o=this.rangeIndex,l=this.range;for(;l.to<=n;)l=this.ranges[++o];this.chunk2=this.input.chunk(this.chunk2Pos=n),n+this.chunk2.length>l.to&&(this.chunk2=this.chunk2.slice(0,l.to-n)),s=this.chunk2.charCodeAt(0)}}return n>=this.token.lookAhead&&(this.token.lookAhead=n+1),s}acceptToken(e,t=0){let n=t?this.resolveOffset(t,-1):this.pos;if(n==null||n<this.token.start)throw new RangeError("Token end out of bounds");this.token.value=e,this.token.end=n}acceptTokenTo(e,t){this.token.value=e,this.token.end=t}getChunk(){if(this.pos>=this.chunk2Pos&&this.pos<this.chunk2Pos+this.chunk2.length){let{chunk:e,chunkPos:t}=this;this.chunk=this.chunk2,this.chunkPos=this.chunk2Pos,this.chunk2=e,this.chunk2Pos=t,this.chunkOff=this.pos-this.chunkPos}else{this.chunk2=this.chunk,this.chunk2Pos=this.chunkPos;let e=this.input.chunk(this.pos),t=this.pos+e.length;this.chunk=t>this.range.to?e.slice(0,this.range.to-this.pos):e,this.chunkPos=this.pos,this.chunkOff=0}}readNext(){return this.chunkOff>=this.chunk.length&&(this.getChunk(),this.chunkOff==this.chunk.length)?this.next=-1:this.next=this.chunk.charCodeAt(this.chunkOff)}advance(e=1){for(this.chunkOff+=e;this.pos+e>=this.range.to;){if(this.rangeIndex==this.ranges.length-1)return this.setDone();e-=this.range.to-this.pos,this.range=this.ranges[++this.rangeIndex],this.pos=this.range.from}return this.pos+=e,this.pos>=this.token.lookAhead&&(this.token.lookAhead=this.pos+1),this.readNext()}setDone(){return this.pos=this.chunkPos=this.end,this.range=this.ranges[this.rangeIndex=this.ranges.length-1],this.chunk="",this.next=-1}reset(e,t){if(t?(this.token=t,t.start=e,t.lookAhead=e+1,t.value=t.extended=-1):this.token=Oh,this.pos!=e){if(this.pos=e,e==this.end)return this.setDone(),this;for(;e<this.range.from;)this.range=this.ranges[--this.rangeIndex];for(;e>=this.range.to;)this.range=this.ranges[++this.rangeIndex];e>=this.chunkPos&&e<this.chunkPos+this.chunk.length?this.chunkOff=e-this.chunkPos:(this.chunk="",this.chunkOff=0),this.readNext()}return this}read(e,t){if(e>=this.chunkPos&&t<=this.chunkPos+this.chunk.length)return this.chunk.slice(e-this.chunkPos,t-this.chunkPos);if(e>=this.chunk2Pos&&t<=this.chunk2Pos+this.chunk2.length)return this.chunk2.slice(e-this.chunk2Pos,t-this.chunk2Pos);if(e>=this.range.from&&t<=this.range.to)return this.input.read(e,t);let n="";for(let s of this.ranges){if(s.from>=t)break;s.to>e&&(n+=this.input.read(Math.max(s.from,e),Math.min(s.to,t)))}return n}}class Qi{constructor(e,t){this.data=e,this.id=t}token(e,t){let{parser:n}=t.p;aO(this.data,e,t,this.id,n.data,n.tokenPrecTable)}}Qi.prototype.contextual=Qi.prototype.fallback=Qi.prototype.extend=!1;Qi.prototype.fallback=Qi.prototype.extend=!1;class lO{constructor(e,t={}){this.token=e,this.contextual=!!t.contextual,this.fallback=!!t.fallback,this.extend=!!t.extend}}function aO(i,e,t,n,s,r){let o=0,l=1<<n,{dialect:a}=t.p.parser;e:for(;(l&i[o])!=0;){let h=i[o+1];for(let d=o+3;d<h;d+=2)if((i[d+1]&l)>0){let p=i[d];if(a.allows(p)&&(e.token.value==-1||e.token.value==p||hO(p,e.token.value,s,r))){e.acceptToken(p);break}}let c=e.next,f=0,u=i[o+2];if(e.next<0&&u>f&&i[h+u*3-3]==65535){o=i[h+u*3-1];continue e}for(;f<u;){let d=f+u>>1,p=h+d+(d<<1),m=i[p],g=i[p+1]||65536;if(c<m)u=d;else if(c>=g)f=d+1;else{o=i[p+2],e.advance();continue e}}break}}function bh(i,e,t){for(let n=e,s;(s=i[n])!=65535;n++)if(s==t)return n-e;return-1}function hO(i,e,t,n){let s=bh(t,n,e);return s<0||bh(t,n,i)<s}const Te=typeof process<"u"&&gh&&/\bparse\b/.test(gh.LOG);let Kr=null;function wh(i,e,t){let n=i.cursor(ce.IncludeAnonymous);for(n.moveTo(e);;)if(!(t<0?n.childBefore(e):n.childAfter(e)))for(;;){if((t<0?n.to<e:n.from>e)&&!n.type.isError)return t<0?Math.max(0,Math.min(n.to-1,e-25)):Math.min(i.length,Math.max(n.from+1,e+25));if(t<0?n.prevSibling():n.nextSibling())break;if(!n.parent())return t<0?0:i.length}}class cO{constructor(e,t){this.fragments=e,this.nodeSet=t,this.i=0,this.fragment=null,this.safeFrom=-1,this.safeTo=-1,this.trees=[],this.start=[],this.index=[],this.nextFragment()}nextFragment(){let e=this.fragment=this.i==this.fragments.length?null:this.fragments[this.i++];if(e){for(this.safeFrom=e.openStart?wh(e.tree,e.from+e.offset,1)-e.offset:e.from,this.safeTo=e.openEnd?wh(e.tree,e.to+e.offset,-1)-e.offset:e.to;this.trees.length;)this.trees.pop(),this.start.pop(),this.index.pop();this.trees.push(e.tree),this.start.push(-e.offset),this.index.push(0),this.nextStart=this.safeFrom}else this.nextStart=1e9}nodeAt(e){if(e<this.nextStart)return null;for(;this.fragment&&this.safeTo<=e;)this.nextFragment();if(!this.fragment)return null;for(;;){let t=this.trees.length-1;if(t<0)return this.nextFragment(),null;let n=this.trees[t],s=this.index[t];if(s==n.children.length){this.trees.pop(),this.start.pop(),this.index.pop();continue}let r=n.children[s],o=this.start[t]+n.positions[s];if(o>e)return this.nextStart=o,null;if(r instanceof re){if(o==e){if(o<this.safeFrom)return null;let l=o+r.length;if(l<=this.safeTo){let a=r.prop(N.lookAhead);if(!a||l+a<this.fragment.to)return r}}this.index[t]++,o+r.length>=Math.max(this.safeFrom,e)&&(this.trees.push(r),this.start.push(o),this.index.push(0))}else this.index[t]++,this.nextStart=o+r.length}}}class fO{constructor(e,t){this.stream=t,this.tokens=[],this.mainToken=null,this.actions=[],this.tokens=e.tokenizers.map(n=>new ws)}getActions(e){let t=0,n=null,{parser:s}=e.p,{tokenizers:r}=s,o=s.stateSlot(e.state,3),l=e.curContext?e.curContext.hash:0,a=0;for(let h=0;h<r.length;h++){if((1<<h&o)==0)continue;let c=r[h],f=this.tokens[h];if(!(n&&!c.fallback)&&((c.contextual||f.start!=e.pos||f.mask!=o||f.context!=l)&&(this.updateCachedToken(f,c,e),f.mask=o,f.context=l),f.lookAhead>f.end+25&&(a=Math.max(f.lookAhead,a)),f.value!=0)){let u=t;if(f.extended>-1&&(t=this.addActions(e,f.extended,f.end,t)),t=this.addActions(e,f.value,f.end,t),!c.extend&&(n=f,t>u))break}}for(;this.actions.length>t;)this.actions.pop();return a&&e.setLookAhead(a),!n&&e.pos==this.stream.end&&(n=new ws,n.value=e.p.parser.eofTerm,n.start=n.end=e.pos,t=this.addActions(e,n.value,n.end,t)),this.mainToken=n,this.actions}getMainToken(e){if(this.mainToken)return this.mainToken;let t=new ws,{pos:n,p:s}=e;return t.start=n,t.end=Math.min(n+1,s.stream.end),t.value=n==s.stream.end?s.parser.eofTerm:0,t}updateCachedToken(e,t,n){let s=this.stream.clipPos(n.pos);if(t.token(this.stream.reset(s,e),n),e.value>-1){let{parser:r}=n.p;for(let o=0;o<r.specialized.length;o++)if(r.specialized[o]==e.value){let l=r.specializers[o](this.stream.read(e.start,e.end),n);if(l>=0&&n.p.parser.dialect.allows(l>>1)){(l&1)==0?e.value=l>>1:e.extended=l>>1;break}}}else e.value=0,e.end=this.stream.clipPos(s+1)}putAction(e,t,n,s){for(let r=0;r<s;r+=3)if(this.actions[r]==e)return s;return this.actions[s++]=e,this.actions[s++]=t,this.actions[s++]=n,s}addActions(e,t,n,s){let{state:r}=e,{parser:o}=e.p,{data:l}=o;for(let a=0;a<2;a++)for(let h=o.stateSlot(r,a?2:1);;h+=3){if(l[h]==65535)if(l[h+1]==1)h=vt(l,h+2);else{s==0&&l[h+1]==2&&(s=this.putAction(vt(l,h+2),t,n,s));break}l[h]==t&&(s=this.putAction(vt(l,h+1),t,n,s))}return s}}class uO{constructor(e,t,n,s){this.parser=e,this.input=t,this.ranges=s,this.recovering=0,this.nextStackID=9812,this.minStackPos=0,this.reused=[],this.stoppedAt=null,this.lastBigReductionStart=-1,this.lastBigReductionSize=0,this.bigReductionCount=0,this.stream=new oO(t,s),this.tokens=new fO(e,this.stream),this.topTerm=e.top[1];let{from:r}=s[0];this.stacks=[$s.start(this,e.top[0],r)],this.fragments=n.length&&this.stream.end-r>e.bufferLength*4?new cO(n,e.nodeSet):null}get parsedPos(){return this.minStackPos}advance(){let e=this.stacks,t=this.minStackPos,n=this.stacks=[],s,r;if(this.bigReductionCount>300&&e.length==1){let[o]=e;for(;o.forceReduce()&&o.stack.length&&o.stack[o.stack.length-2]>=this.lastBigReductionStart;);this.bigReductionCount=this.lastBigReductionSize=0}for(let o=0;o<e.length;o++){let l=e[o];for(;;){if(this.tokens.mainToken=null,l.pos>t)n.push(l);else{if(this.advanceStack(l,n,e))continue;{s||(s=[],r=[]),s.push(l);let a=this.tokens.getMainToken(l);r.push(a.value,a.end)}}break}}if(!n.length){let o=s&&pO(s);if(o)return Te&&console.log("Finish with "+this.stackID(o)),this.stackToTree(o);if(this.parser.strict)throw Te&&s&&console.log("Stuck with token "+(this.tokens.mainToken?this.parser.getName(this.tokens.mainToken.value):"none")),new SyntaxError("No parse at "+t);this.recovering||(this.recovering=5)}if(this.recovering&&s){let o=this.stoppedAt!=null&&s[0].pos>this.stoppedAt?s[0]:this.runRecovery(s,r,n);if(o)return Te&&console.log("Force-finish "+this.stackID(o)),this.stackToTree(o.forceAll())}if(this.recovering){let o=this.recovering==1?1:this.recovering*3;if(n.length>o)for(n.sort((l,a)=>a.score-l.score);n.length>o;)n.pop();n.some(l=>l.reducePos>t)&&this.recovering--}else if(n.length>1){e:for(let o=0;o<n.length-1;o++){let l=n[o];for(let a=o+1;a<n.length;a++){let h=n[a];if(l.sameState(h)||l.buffer.length>500&&h.buffer.length>500)if((l.score-h.score||l.buffer.length-h.buffer.length)>0)n.splice(a--,1);else{n.splice(o--,1);continue e}}}n.length>12&&n.splice(12,n.length-12)}this.minStackPos=n[0].pos;for(let o=1;o<n.length;o++)n[o].pos<this.minStackPos&&(this.minStackPos=n[o].pos);return null}stopAt(e){if(this.stoppedAt!=null&&this.stoppedAt<e)throw new RangeError("Can't move stoppedAt forward");this.stoppedAt=e}advanceStack(e,t,n){let s=e.pos,{parser:r}=this,o=Te?this.stackID(e)+" -> ":"";if(this.stoppedAt!=null&&s>this.stoppedAt)return e.forceReduce()?e:null;if(this.fragments){let h=e.curContext&&e.curContext.tracker.strict,c=h?e.curContext.hash:0;for(let f=this.fragments.nodeAt(s);f;){let u=this.parser.nodeSet.types[f.type.id]==f.type?r.getGoto(e.state,f.type.id):-1;if(u>-1&&f.length&&(!h||(f.prop(N.contextHash)||0)==c))return e.useNode(f,u),Te&&console.log(o+this.stackID(e)+` (via reuse of ${r.getName(f.type.id)})`),!0;if(!(f instanceof re)||f.children.length==0||f.positions[0]>0)break;let d=f.children[0];if(d instanceof re&&f.positions[0]==0)f=d;else break}}let l=r.stateSlot(e.state,4);if(l>0)return e.reduce(l),Te&&console.log(o+this.stackID(e)+` (via always-reduce ${r.getName(l&65535)})`),!0;if(e.stack.length>=8400)for(;e.stack.length>6e3&&e.forceReduce(););let a=this.tokens.getActions(e);for(let h=0;h<a.length;){let c=a[h++],f=a[h++],u=a[h++],d=h==a.length||!n,p=d?e:e.split(),m=this.tokens.mainToken;if(p.apply(c,f,m?m.start:p.pos,u),Te&&console.log(o+this.stackID(p)+` (via ${(c&65536)==0?"shift":`reduce of ${r.getName(c&65535)}`} for ${r.getName(f)} @ ${s}${p==e?"":", split"})`),d)return!0;p.pos>s?t.push(p):n.push(p)}return!1}advanceFully(e,t){let n=e.pos;for(;;){if(!this.advanceStack(e,null,null))return!1;if(e.pos>n)return yh(e,t),!0}}runRecovery(e,t,n){let s=null,r=!1;for(let o=0;o<e.length;o++){let l=e[o],a=t[o<<1],h=t[(o<<1)+1],c=Te?this.stackID(l)+" -> ":"";if(l.deadEnd&&(r||(r=!0,l.restart(),Te&&console.log(c+this.stackID(l)+" (restarted)"),this.advanceFully(l,n))))continue;let f=l.split(),u=c;for(let d=0;f.forceReduce()&&d<10&&(Te&&console.log(u+this.stackID(f)+" (via force-reduce)"),!this.advanceFully(f,n));d++)Te&&(u=this.stackID(f)+" -> ");for(let d of l.recoverByInsert(a))Te&&console.log(c+this.stackID(d)+" (via recover-insert)"),this.advanceFully(d,n);this.stream.end>l.pos?(h==l.pos&&(h++,a=0),l.recoverByDelete(a,h),Te&&console.log(c+this.stackID(l)+` (via recover-delete ${this.parser.getName(a)})`),yh(l,n)):(!s||s.score<l.score)&&(s=l)}return s}stackToTree(e){return e.close(),re.build({buffer:Fs.create(e),nodeSet:this.parser.nodeSet,topID:this.topTerm,maxBufferLength:this.parser.bufferLength,reused:this.reused,start:this.ranges[0].from,length:e.pos-this.ranges[0].from,minRepeatType:this.parser.minRepeatTerm})}stackID(e){let t=(Kr||(Kr=new WeakMap)).get(e);return t||Kr.set(e,t=String.fromCodePoint(this.nextStackID++)),t+e}}function yh(i,e){for(let t=0;t<e.length;t++){let n=e[t];if(n.pos==i.pos&&n.sameState(i)){e[t].score<i.score&&(e[t]=i);return}}e.push(i)}class dO{constructor(e,t,n){this.source=e,this.flags=t,this.disabled=n}allows(e){return!this.disabled||this.disabled[e]==0}}class Ks extends Qc{constructor(e){if(super(),this.wrappers=[],e.version!=14)throw new RangeError(`Parser version (${e.version}) doesn't match runtime version (14)`);let t=e.nodeNames.split(" ");this.minRepeatTerm=t.length;for(let l=0;l<e.repeatNodeCount;l++)t.push("");let n=Object.keys(e.topRules).map(l=>e.topRules[l][1]),s=[];for(let l=0;l<t.length;l++)s.push([]);function r(l,a,h){s[l].push([a,a.deserialize(String(h))])}if(e.nodeProps)for(let l of e.nodeProps){let a=l[0];typeof a=="string"&&(a=N[a]);for(let h=1;h<l.length;){let c=l[h++];if(c>=0)r(c,a,l[h++]);else{let f=l[h+-c];for(let u=-c;u>0;u--)r(l[h++],a,f);h++}}}this.nodeSet=new Xo(t.map((l,a)=>De.define({name:a>=this.minRepeatTerm?void 0:l,id:a,props:s[a],top:n.indexOf(a)>-1,error:a==0,skipped:e.skippedNodes&&e.skippedNodes.indexOf(a)>-1}))),e.propSources&&(this.nodeSet=this.nodeSet.extend(...e.propSources)),this.strict=!1,this.bufferLength=Cc;let o=ts(e.tokenData);this.context=e.context,this.specializerSpecs=e.specialized||[],this.specialized=new Uint16Array(this.specializerSpecs.length);for(let l=0;l<this.specializerSpecs.length;l++)this.specialized[l]=this.specializerSpecs[l].term;this.specializers=this.specializerSpecs.map(kh),this.states=ts(e.states,Uint32Array),this.data=ts(e.stateData),this.goto=ts(e.goto),this.maxTerm=e.maxTerm,this.tokenizers=e.tokenizers.map(l=>typeof l=="number"?new Qi(o,l):l),this.topRules=e.topRules,this.dialects=e.dialects||{},this.dynamicPrecedences=e.dynamicPrecedences||null,this.tokenPrecTable=e.tokenPrec,this.termNames=e.termNames||null,this.maxNode=this.nodeSet.types.length-1,this.dialect=this.parseDialect(),this.top=this.topRules[Object.keys(this.topRules)[0]]}createParse(e,t,n){let s=new uO(this,e,t,n);for(let r of this.wrappers)s=r(s,e,t,n);return s}getGoto(e,t,n=!1){let s=this.goto;if(t>=s[0])return-1;for(let r=s[t+1];;){let o=s[r++],l=o&1,a=s[r++];if(l&&n)return a;for(let h=r+(o>>1);r<h;r++)if(s[r]==e)return a;if(l)return-1}}hasAction(e,t){let n=this.data;for(let s=0;s<2;s++)for(let r=this.stateSlot(e,s?2:1),o;;r+=3){if((o=n[r])==65535)if(n[r+1]==1)o=n[r=vt(n,r+2)];else{if(n[r+1]==2)return vt(n,r+2);break}if(o==t||o==0)return vt(n,r+1)}return 0}stateSlot(e,t){return this.states[e*6+t]}stateFlag(e,t){return(this.stateSlot(e,0)&t)>0}validAction(e,t){return!!this.allActions(e,n=>n==t?!0:null)}allActions(e,t){let n=this.stateSlot(e,4),s=n?t(n):void 0;for(let r=this.stateSlot(e,1);s==null;r+=3){if(this.data[r]==65535)if(this.data[r+1]==1)r=vt(this.data,r+2);else break;s=t(vt(this.data,r+1))}return s}nextStates(e){let t=[];for(let n=this.stateSlot(e,1);;n+=3){if(this.data[n]==65535)if(this.data[n+1]==1)n=vt(this.data,n+2);else break;if((this.data[n+2]&1)==0){let s=this.data[n+1];t.some((r,o)=>o&1&&r==s)||t.push(this.data[n],s)}}return t}configure(e){let t=Object.assign(Object.create(Ks.prototype),this);if(e.props&&(t.nodeSet=this.nodeSet.extend(...e.props)),e.top){let n=this.topRules[e.top];if(!n)throw new RangeError(`Invalid top rule name ${e.top}`);t.top=n}return e.tokenizers&&(t.tokenizers=this.tokenizers.map(n=>{let s=e.tokenizers.find(r=>r.from==n);return s?s.to:n})),e.specializers&&(t.specializers=this.specializers.slice(),t.specializerSpecs=this.specializerSpecs.map((n,s)=>{let r=e.specializers.find(l=>l.from==n.external);if(!r)return n;let o=Object.assign(Object.assign({},n),{external:r.to});return t.specializers[s]=kh(o),o})),e.contextTracker&&(t.context=e.contextTracker),e.dialect&&(t.dialect=this.parseDialect(e.dialect)),e.strict!=null&&(t.strict=e.strict),e.wrap&&(t.wrappers=t.wrappers.concat(e.wrap)),e.bufferLength!=null&&(t.bufferLength=e.bufferLength),t}hasWrappers(){return this.wrappers.length>0}getName(e){return this.termNames?this.termNames[e]:String(e<=this.maxNode&&this.nodeSet.types[e].name||e)}get eofTerm(){return this.maxNode+1}get topNode(){return this.nodeSet.types[this.top[1]]}dynamicPrecedence(e){let t=this.dynamicPrecedences;return t==null?0:t[e]||0}parseDialect(e){let t=Object.keys(this.dialects),n=t.map(()=>!1);if(e)for(let r of e.split(" ")){let o=t.indexOf(r);o>=0&&(n[o]=!0)}let s=null;for(let r=0;r<t.length;r++)if(!n[r])for(let o=this.dialects[t[r]],l;(l=this.data[o++])!=65535;)(s||(s=new Uint8Array(this.maxTerm+1)))[l]=1;return new dO(e,n,s)}static deserialize(e){return new Ks(e)}}function vt(i,e){return i[e]|i[e+1]<<16}function pO(i){let e=null;for(let t of i){let n=t.p.stoppedAt;(t.pos==t.p.stream.end||n!=null&&t.pos>n)&&t.p.parser.stateFlag(t.state,2)&&(!e||e.score<t.score)&&(e=t)}return e}function kh(i){if(i.external){let e=i.extend?1:0;return(t,n)=>i.external(t,n)<<1|e}return i.get}let Ch=console.log;function mO(i,e,...t){if(typeof i=="string"){vh(Ch,i,e,...t);return}const{src:n,positions:s}=gO(i,e);vh(Ch,n.text,s,...t)}function gO(i,e){const t=i.mapPositions(...[e].flat()),{src:n}=t[0];let s;return t[1]?.src?.path===n.path&&t[1]?.src?.text===n.text?s=t.map(r=>r.position):s=t[0].position,{src:n,positions:s}}function vh(i,e,t,...n){i(...n);const{line:s,lineNum:r,linePos:o,linePos2:l}=OO(e,t);i(s,` Ln ${r}`);const a=AO(o,l);i(a)}function AO(i,e){const t=" ".repeat(Math.max(0,i)),n=e?e-i:1,s="^".repeat(Math.max(1,n));return t+s}const xh=new Map;function OO(i,e){let t,n;typeof e=="number"?t=e:[t,n]=e;const s=bO(i);let r=0,o=s.length-1;for(t>=s[o]&&(r=o);r+1<o;){const c=r+o>>1;t>=s[c]?r=c:o=c}let l;n!==void 0&&n>=s[r]&&n<s[o]&&(l=n-s[r]);const a=i.slice(s[r],s[r+1]||i.length);return{line:a.slice(-1)===`
12
+ `?a.slice(0,-1):a,linePos:t-s[r],linePos2:l,lineNum:r+1}}function bO(i){const e=xh.get(i);if(e)return e;const t=[...i.matchAll(/\n/g)].map(n=>n.index+1);return t.unshift(0),xh.set(i,t),t}function wO(i,e){if(!i)throw new Error(e)}function si(i,e){wO(i,e)}function Fi(i){throw new yO("Unreachable value",{data:i})}class yO extends Error{data;constructor(e,t){super(e,t),this.data=t?.data}}function kO(i,e){const t=[],n=[];for(const s of i)e(s)?t.push(s):n.push(s);return[t,n]}function CO(i){return i[i.length-1]}function Cu(i,e){const t=[];for(const n of i){const s=e(n);s&&t.push(s)}return t}function kl(i,e){for(const t of i){const n=e(t);if(n)return n}}function vO(i,e){return Object.fromEntries(Object.entries(i).map(([t,n])=>[t,e(n)]))}function Cl(i,e){const t=Math.min(e.length,Math.max(0,i));let n=0,s=1;for(;;){const r=e.indexOf(`
13
+ `,n);if(r===-1||t<=r){const o=1+(t-n);return[s,o]}else n=r+1,s+=1}}function vu(i,e){let t=i.lastIndexOf(`
14
+ `,e[0]);t=t===-1?0:t+1;let n=i.indexOf(`
15
+ `,e[0]);n===-1&&(n=i.length);const s=e[1]-e[0],r=Math.max(1,s),o=Math.max(0,e[0]-t);return[i.slice(t,n)," ".repeat(o)+"^".repeat(r)]}const xu={};"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".split("").forEach((i,e)=>{xu[e]=i});function Sh(i){if(typeof i=="number")return Qh(i);let e="";for(let t=0;t<i.length;t+=1)e+=Qh(i[t]);return e}function Qh(i){let e="",t;i<0?t=-i<<1|1:t=i<<1;do{let n=t&31;t>>>=5,t>0&&(n|=32),e+=xu[n]}while(t>0);return e}const xO="document"in globalThis;function Su(i){const{url:e,text:t,lineNumber:n,lineColumn:s,length:r,error:o}=i,l={file:e,line:n,column:s,length:r};if(o.weslLocation=l,!xO)throw o;const a=Sh([0,0,Math.max(0,n-1),Math.max(0,s-1)])+","+Sh([18,0,Math.max(0,n-1),Math.max(0,s-1)+r]),h={version:3,file:null,sources:[e],sourcesContent:[t??null],names:[],mappings:a};let c=`throw new Error(${JSON.stringify(o.message+"")})`;c+=`
16
+ //# sourceMappingURL=data:application/json;base64,`+btoa(unescape(encodeURIComponent(JSON.stringify(h)))),c+=`
17
+ //# sourceURL=`+h.sources[0];let f=0;"stackTraceLimit"in Error&&(f=Error.stackTraceLimit,Error.stackTraceLimit=1);try{(0,eval)(c)}catch(u){throw"stackTraceLimit"in Error&&(Error.stackTraceLimit=f),o.message="",u.cause=o,u.weslLocation=l,u}}function Qu(i,e){const{refIdentElem:t,originalName:n}=i,s=e??`'${n}'`;if(t)Eu(t,s);else throw new Error(s)}function Eu(i,e=""){const{srcModule:t,start:n,end:s}=i,{debugFilePath:r,src:o}=t,l=`${e} in file: ${r}`;mO(o,[n,s],l);const[a,h]=Cl(n,o),c=s-n;Su({url:r,text:o,lineNumber:a,lineColumn:h,length:c,error:new Error(l)})}function SO(i,e){return ei(i.param.expression,e)}function QO(i,e){return ei(i.param.expression,e)}function ei(i,e){const{kind:t}=i;if(t==="unary-expression")return si(i.operator.value==="!"),!ei(i.expression,e);if(t==="binary-expression"){const n=i.operator.value;si(n==="||"||n==="&&");const s=ei(i.left,e);if(n==="||")return s||ei(i.right,e);if(n==="&&")return s&&ei(i.right,e);Fi(n)}else if(t==="literal"){const{value:n}=i;return si(n==="true"||n==="false"),n==="true"}else{if(t==="parenthesized-expression")return ei(i.expression,e);if(t==="ref")return e[i.ident.originalName]??!1;throw new Error(`unexpected @if expression ${JSON.stringify(i)}`)}}function Yt(i,e){let t=!1;return i.flatMap(n=>{const s=n.attributes,{valid:r,nextElseState:o}=EO(s,t,e);return t=o,r?[n]:[]})}function Bu(i,e,t){if(!i)return{valid:!0,nextElseState:e};if(i.kind==="@if"){const n=SO(i,t);return{valid:n,nextElseState:!n}}else if(i.kind==="@elif"){if(!e)return{valid:!1,nextElseState:!1};const n=QO(i,t);return{valid:n,nextElseState:!n}}else return{valid:e,nextElseState:!1}}function EO(i,e,t){const n=Pu(i);return Bu(n,e,t)}function Pu(i){if(i)for(const e of i){const t=e.attribute.kind;if(t==="@if"||t==="@elif"||t==="@else")return e.attribute}}let BO=0,PO=0;function Eh(){return PO++}function Mu(i,e="scope"){return{id:BO++,kind:e,parent:i,contents:[]}}const MO=new Set(["align","binding","blend_src","compute","const","fragment","group","id","invariant","location","must_use","size","vertex","workgroup_size"]);function vl(i){const{srcBuilder:e,rootElems:t,conditions:n}=i,{extracting:s=!0,skipConditionalFiltering:r=!1}=i,o={conditions:n,srcBuilder:e},l=r?t:Yt(t,n);for(const a of l)Ki(a,o)}function Ki(i,e){switch(i.kind){case"import":return;case"text":LO(i,e);return;case"name":NO(i,e);return;case"synthetic":zO(i,e);return;case"ref":Du(i,e);return;case"decl":Sl(i,e);return;case"literal":case"binary-expression":case"unary-expression":case"call-expression":case"parenthesized-expression":case"component-expression":case"component-member-expression":ft(i,e);return;case"param":case"typeDecl":case"member":case"memberRef":case"expression":case"type":case"switch-clause":nr(i,e);return;case"stuff":DO(i,e);return;case"module":IO(i,e);return;case"var":case"let":case"statement":case"continuing":TO(i,e);return;case"override":case"const":case"assert":case"alias":case"gvar":RO(i,e);return;case"fn":Fo(e),$O(i,e);return;case"struct":Fo(e),FO(i,e);return;case"attribute":Iu(i,e);return;case"directive":VO(i,e);return;default:Fi(i)}}function DO(i,e){xl(i,e)}function IO(i,e){const t=Yt(i.contents,e.conditions);for(const n of t)n.kind==="text"&&n.srcModule.src.slice(n.start,n.end).trim()===""||Ki(n,e)}function TO(i,e){i.contents.length>0&&i.contents[0].kind==="attribute"||Ei(i.attributes,e),nr(i,e)}function RO(i,e){Fo(e),i.contents.length>0&&i.contents[0].kind==="attribute"||Ei(i.attributes,e),xl(i,e)}function Fo(i){i.srcBuilder.addNl(),i.srcBuilder.addNl()}function LO(i,e){e.srcBuilder.addCopy(i.start,i.end)}function NO(i,e){e.srcBuilder.add(i.name,i.start,i.end)}function $O(i,e){const{attributes:t,name:n,params:s,returnAttributes:r,returnType:o,body:l}=i,{conditions:a,srcBuilder:h}=e;Ei(t,e),h.add("fn ",n.start-3,n.start),Sl(n,e),h.appendNext("(");const c=Yt(s,a);c.forEach((f,u)=>{f.contents.length>0&&f.contents[0].kind==="attribute"||Ei(f.attributes,e),Ko(f,e),u<c.length-1&&h.appendNext(", ")}),h.appendNext(") "),o&&(h.appendNext("-> "),Ei(r,e),Ko(o,e),h.appendNext(" ")),nr(l,e)}function Ei(i,e){i?.forEach(t=>{Iu(t,e)&&e.srcBuilder.add(" ",t.start,t.end)})}function FO(i,e){const{attributes:t,name:n,members:s,start:r}=i,{srcBuilder:o,conditions:l}=e,a=Yt(s,l),h=a.length;if(h===0){KO(i);return}Ei(t,e),o.add("struct ",r,n.start),Sl(n,e),h===1?(o.appendNext(" { "),xl(a[0],e),o.appendNext(" }"),o.addNl()):(o.appendNext(" {"),o.addNl(),a.forEach(c=>{o.appendNext(" "),Ko(c,e),o.appendNext(","),o.addNl()}),o.appendNext("}"),o.addNl())}function KO(i){const{name:e,members:t}=i,n=t.length?"(with current conditions)":"",s=`struct '${e.ident.originalName}' has no members ${n}`;Eu(e,s)}function zO(i,e){const{text:t}=i;e.srcBuilder.addSynthetic(t,t,0,t.length)}function nr(i,e){const t=Yt(i.contents,e.conditions);for(const n of t)Ki(n,e)}function xl(i,e){const t=Yt(i.contents,e.conditions),n=t.findIndex(r=>!Bh(r)),s=t.findLastIndex(r=>!Bh(r));t.forEach((r,o)=>{if(r.kind==="text"){let l=r.srcModule.src.slice(r.start,r.end);o===n&&(l=l.trimStart()),o===s&&(l=l.trimEnd()),l&&e.srcBuilder.add(l,r.start,r.end)}else Ki(r,e)})}function Bh(i){if(i.kind!=="attribute")return!1;const{kind:e}=i.attribute;return e==="@if"||e==="@elif"||e==="@else"}function Ko(i,e){Yt(i.contents,e.conditions).forEach(n=>{if(n.kind==="text"){const{srcModule:s,start:r,end:o}=n;if(s.src.slice(r,o).trim()==="")return}Ki(n,e)})}function Du(i,e){if(i.ident.std)e.srcBuilder.add(i.ident.originalName,i.start,i.end);else{const t=WO(i.ident),n=Ru(t);e.srcBuilder.add(n,i.start,i.end)}}function Sl(i,e){const t=Ru(i.ident);e.srcBuilder.add(t,i.start,i.end)}function ft(i,e){const{kind:t}=i;if(t==="literal"){e.srcBuilder.add(i.value,i.start,i.end);return}if(t==="ref"){Du(i,e);return}if(t==="type"){nr(i,e);return}if(t==="binary-expression"){ft(i.left,e),e.srcBuilder.add(` ${i.operator.value} `,i.operator.span[0],i.operator.span[1]),ft(i.right,e);return}if(t==="unary-expression"){e.srcBuilder.add(i.operator.value,i.operator.span[0],i.operator.span[1]),ft(i.expression,e);return}if(t==="parenthesized-expression"){ft(i.expression,e);return}if(t==="call-expression"){if(ft(i.function,e),i.templateArgs)for(const n of i.templateArgs)Ki(n,e);for(const n of i.arguments)ft(n,e);return}if(t==="component-expression"){ft(i.base,e),ft(i.access,e);return}if(t==="component-member-expression"){ft(i.base,e),i.access.kind==="name"&&e.srcBuilder.add(i.access.name,i.access.start,i.access.end);return}Fi(t)}function Iu(i,e){const{kind:t}=i.attribute;if(t==="@if"||t==="@elif"||t==="@else")return!1;if(t==="@attribute")return MO.has(i.attribute.name)?(_O(i,e),!0):!1;if(t==="@builtin")return e.srcBuilder.add("@builtin("+i.attribute.param.name+")",i.start,i.end),!0;if(t==="@diagnostic"){const n="@diagnostic"+Tu(i.attribute.severity,i.attribute.rule);return e.srcBuilder.add(n,i.start,i.end),!0}if(t==="@interpolate"){const n=i.attribute.params.map(s=>s.name).join(", ");return e.srcBuilder.add(`@interpolate(${n})`,i.start,i.end),!0}Fi(t)}function _O(i,e){if(i.attribute.kind!=="@attribute")return;const{params:t}=i.attribute;if(!t||t.length===0){e.srcBuilder.add("@"+i.attribute.name,i.start,i.end);return}e.srcBuilder.add("@"+i.attribute.name+"(",i.start,t[0].start);for(let n=0;n<t.length;n++)e.srcBuilder.addCopy(t[n].start,t[n].end),n<t.length-1&&e.srcBuilder.add(",",t[n].end,t[n+1].start);e.srcBuilder.add(")",t[t.length-1].end,i.end)}function Tu(i,e){const t=e[0].name+(e[1]!==null?"."+e[1].name:"");return`(${i.name}, ${t})`}function VO(i,e){const{directive:t}=i,{kind:n}=t;if(n==="diagnostic"){const s=`diagnostic${Tu(t.severity,t.rule)};`;e.srcBuilder.add(s,i.start,i.end)}else if(n==="enable"){const s=t.extensions.map(r=>r.name).join(", ");e.srcBuilder.add(`enable ${s};`,i.start,i.end)}else if(n==="requires"){const s=t.extensions.map(r=>r.name).join(", ");e.srcBuilder.add(`requires ${s};`,i.start,i.end)}else Fi(n)}function Ru(i){return i.isGlobal?(si(i.mangledName,`ERR: mangled name not found for decl ident ${Ql(i)}`),i.mangledName):i.mangledName||i.originalName}function WO(i){let e=i;do{if(e.kind==="decl")return e;e=e.refersTo}while(e);throw new Error(`unresolved identifer: ${i.originalName}`)}function Ql(i){if(!i)return JSON.stringify(i);const{kind:e,originalName:t}=i,n=i.id?`#${i.id}`:"";if(e==="ref"){const s=Ql(i.refersTo);return`${t} ${n} -> ${s}`}else{const{mangledName:s}=i,r=s?`(${s})`:"";return`%${t}${r} ${n} `}}function El(i=null){return{decls:new Map,parent:i}}function Lu(i,e,t,n){return HO(t,n)}function HO(i,e){let t=i,n=0;for(;e.has(t);)t=i+n++;return t}function Nu(i,e,t){const n=t?Fu(i,t):i,s=n[0];if(s==="package"||s===e)return n.slice(1).join("/")}function $u(i,e,t){const n=t?.split("::"),s=i.split("::");return Nu(s,e,n)}function Fu(i,e){const t=i[0]==="package"?[e[0],...i.slice(1)]:i,n=t.lastIndexOf("super");return n===-1?t:[...e.slice(0,-(n+1)),...t.slice(n+1)]}function Ku(i){return i===void 0?"./":i===""?"":i.endsWith("/")?i:i+"/"}function qO(i){return e([],[],i.segments,i.finalSegment);function e(t,n,s,r){if(s.length>0){const[o,...l]=s,a=[...t,o.name],h=[...n,o.name];return e(a,h,l,r)}else{if(r.kind==="import-collection")return r.subtrees.flatMap(o=>e(t,n,o.segments,o.finalSegment));if(r.kind==="import-item"){const o=[...t,r.as??r.name],l=[...n,r.name];return[{importPath:o,modulePath:l}]}else Fi(r)}}}class zt extends Error{span;constructor(e,t){super(e),this.span=t}}function oe(i,e,t=[]){i.state.context.openElems.push({kind:e,contents:[...t]})}function zi(i,e,t){const n=i.state.context.openElems.pop();if(!n)throw new Error("No open element to close");return GO(i,n.contents,e,t)}function kt(i,e,t,n){const s=t.stream.checkpoint(),r=zi(t,e,s);return{kind:i,start:e,end:s,contents:r,...n}}function Ph(i,e,t){return{kind:"text",start:e,end:t,srcModule:i}}function GO(i,e,t,n){const{srcModule:s}=i.state.stable,r=e.slice().sort((a,h)=>a.start-h.start),o=[];let l=t;for(const a of r)l<a.start&&o.push(Ph(s,l,a.start)),o.push(a),l=a.end;return l<n&&o.push(Ph(s,l,n)),o}function zu(i){const[e,t]=i.span;return{kind:"literal",value:i.text,start:e,end:t}}function UO(i){return{value:i.text,span:i.span}}function YO(i){return{value:i.text,span:i.span}}function XO(i,e){const[t]=i.span;return{kind:"unary-expression",operator:i,expression:e,start:t,end:e.end}}function jO(i,e,t){const{start:n}=i;return{kind:"binary-expression",operator:e,left:i,right:t,start:n,end:t.end}}function JO(i,e,t){return{kind:"component-expression",base:i,access:e,start:i.start,end:t}}function ZO(i,e){return{kind:"component-member-expression",base:i,access:e,start:i.start,end:e.end}}function Mh(i,e,t,n){return{kind:"call-expression",function:i,templateArgs:e??void 0,arguments:t,start:i.start,end:n}}function L(i,e,t){const n=i.matchText(e);if(!n){const s=i.checkpoint(),r=t?`Expected '${e}' after ${t}`:`Expected '${e}'`;throw new zt(r,[s,s])}return n}function Fe(i,e){const t=i.peek();return(!t||t.kind!=="word")&&F(i,e),i.nextToken(),t}function ye(i,e="Expected expression"){const t=st(i);return t||F(i.stream,e),i.options.preserveExpressions&&i.addElem(t),t}function F(i,e){const t=i,n=t.peek(),s=n?n.span:[t.checkpoint(),t.checkpoint()];throw new zt(e,s)}function sr(i,e){const t=[];for(;;){const n=e(i);if(n===null||(t.push(n),!i.stream.matchText(",")))break}return t}function*Bl(i,e){for(let t=e(i);t;t=e(i))yield t}function tt(i){const[e,t]=i.span;return{kind:"name",name:i.text,start:e,end:t}}function rr(i,e,t){const n=i.createDeclIdent(e.text,t),[s,r]=e.span;return{kind:"decl",ident:n,srcModule:i.srcModule,start:s,end:r}}function _u(i,e,t,n){const s={kind:"ref",ident:e,srcModule:i.srcModule,start:t,end:n};return e.refIdentElem=s,s}function Vu(i){const{kind:e}=i;return e==="@if"||e==="@elif"||e==="@else"}function Pl(i){return i.some(e=>Vu(e.attribute))}function Ge(i,e){e?.length&&(i.attributes=e)}function or(i,e){i.ident.declElem=e}function lr(i,e){or(i.decl,e)}const Wu={"||":1,"&&":2,"|":3,"^":4,"&":5,"==":6,"!=":6,"<":7,"<=":7,">":7,">=":7,"<<":8,">>":8,"+":9,"-":9,"*":10,"/":10,"%":10};function eb(i){return i?i.text in Wu:!1}function Dh(i){return Wu[i.text]||0}function Hu(i){switch(i){case"*":case"/":case"%":case"+":case"-":return"arithmetic";case"<<":case">>":return"shift";case"<":case">":case"<=":case">=":case"==":case"!=":return"relational";case"&":return"bitAnd";case"^":return"bitXor";case"|":return"bitOr";case"&&":return"logicalAnd";case"||":return"logicalOr";default:return"arithmetic"}}function tb(i,e,t){const n=Hu(e);return ib(e,t)||F(i,`'${e}' requires parentheses after ${t}`),!nb(n)&&t===n&&F(i,`'${e}' cannot be chained`),n}function ib(i,e){const t=Hu(i);return t==="shift"?e==="unary":t==="bitAnd"?e==="unary"||e==="bitAnd":t==="bitXor"?e==="unary"||e==="bitXor":t==="bitOr"?e==="unary"||e==="bitOr":t==="logicalAnd"?!Ih(e)&&e!=="logicalOr":t==="logicalOr"?!Ih(e)&&e!=="logicalAnd":!0}function nb(i){return i!=="shift"&&i!=="relational"}function Ih(i){return i==="bitAnd"||i==="bitXor"||i==="bitOr"}const qu=new Set(["as","import","package","super","self"]),sb=new Set(["package","super"]);function Gu(i){const e=i.peek();if(!e||!Th(e,!0))return null;const t=e.span[0];i.nextToken();const n=[e.text];for(;i.matchText("::");){const s=i.peek();(!s||!Th(s,!1))&&F(i,"Expected identifier after '::'"),i.nextToken(),n.push(s.text)}return{parts:n,start:t,end:i.checkpoint()}}function rb(i,e){const t=Gu(i.stream);if(!t)return null;const{parts:n,start:s,end:r}=t,o=i.createRefIdent(n.join("::"));e&&(o.conditionRef=!0);const l=_u(i,o,s,r);return e||(i.saveIdent(o),i.addElem(l)),l}function Th(i,e){return i.kind==="word"?!0:i.kind!=="keyword"?!1:qu.has(i.text)?e&&sb.has(i.text):!0}function ar(i){const e=Gu(i.stream);if(!e)return null;const{parts:t,start:n,end:s}=e,r=i.createRefIdent(t.join("::"));oe(i,"type");const o=_u(i,r,n,s);i.saveIdent(r),i.addElem(o);const l=i.stream.nextTemplateStartToken()?Ml(i):void 0;return kt("type",n,i,{name:r,templateParams:l})}function Ml(i){const{stream:e}=i;if(Rh(e))return[];const t=[Lh(i)];for(;e.matchText(",");)t.push(Lh(i));return Rh(e)||F(e,"Expected '>' or ',' after template parameter"),t}function Rh(i){return i.peek()?.text.startsWith(">")?(i.nextTemplateEndToken()||F(i,"Expected '>' to close template parameters"),!0):!1}function Lh(i){const e=st(i,{inTemplate:!0});if(e)return e;F(i.stream,"Expected expression in template parameters")}function ob(i,e,t){if(e.kind!=="ref"&&e.kind!=="type")return null;const{stream:n}=i,s=e.kind==="type"?e.templateParams??null:lb(i);if(!n.matchText("("))return null;const r=[];for(;;){const o=Nh(n);if(o!==null)return Mh(e,s,r,o);const l=t(i);if(l||F(n,"Expected expression"),r.push(l),n.matchText(","))continue;const a=Nh(n);if(a!==null)return Mh(e,s,r,a);F(n,"Expected ',' or ')' in function arguments")}}function lb(i){const{stream:e}=i,t=e.checkpoint();if(!e.nextTemplateStartToken())return null;const n=Ml(i);return e.peek()?.text!=="("?(e.reset(t),null):n}function Nh(i){const e=i.matchText(")");return e?e.span[1]:null}function st(i,e){const{conditionRef:t,inTemplate:n}=e===!0?{conditionRef:!0,inTemplate:!1}:e??{},s=t?!0:void 0,r=Dl(i,s);return r?Uu(i,{prec:1,left:r,group:"unary",condRef:s,inTemplate:n}).expr:null}function Dl(i,e){const{stream:t}=i,n=t.peek();if(!n)return null;if("-!&*~".includes(n.text)){t.nextToken();const r=UO(n),o=Dl(i,e);return o||F(t,"Expected expression after unary operator"),XO(r,o)}return ab(i,e)}function Uu(i,e){const{stream:t}=i,{prec:n,left:s,group:r}=e,{condRef:o,inTemplate:l}=e;let a=s,h=r;for(;;){const c=t.peek();if(!$h(c,l))break;const f=Dh(c);if(f<n)break;t.nextToken(),h=tb(t,c.text,h);let u=Dl(i,o);u||F(t,"Expected expression after binary operator");const d=t.peek();if($h(d,l)){const p=Dh(d);p>f&&(u=Uu(i,{prec:p,left:u,group:"unary",condRef:o,inTemplate:l}).expr)}a=jO(a,YO(c),u)}return{expr:a,group:h}}function ab(i,e){const t=hb(i,e)||cb(i.stream)||fb(i,e);return t?e?t:Yu(i,t):null}function $h(i,e){return!(!eb(i)||e&&i.text.startsWith(">"))}function hb(i,e){const{stream:t}=i,n=t.matchText("(");if(!n)return null;const s=st(i,e);s||F(t,"Expected expression after '('");const r=L(t,")","expression"),o=n.span[0],l=r.span[1];return{kind:"parenthesized-expression",expression:s,start:o,end:l}}function cb(i){const e=i.matchKind("number");return e?zu(e):ub(i)}function fb(i,e){const t=rb(i,e);if(!t)return null;if(!i.stream.nextTemplateStartToken())return t;const n=Ml(i);return{kind:"type",name:t.ident,templateParams:n,start:t.start,end:i.stream.checkpoint(),contents:[]}}function Yu(i,e){const t=db(i,e);return t?Yu(i,t):e}function ub(i){const e=i.matchKind("keyword","true")||i.matchKind("keyword","false");return e?zu(e):null}function db(i,e){return pb(i,e)||mb(i,e)||ob(i,e,st)}function pb(i,e){if(!i.stream.matchText("."))return null;const t=Fe(i.stream,"Expected identifier after '.'");return ZO(e,tt(t))}function mb(i,e){const{stream:t}=i;if(!t.matchText("["))return null;const n=ye(i,"Expected expression in array index"),s=L(t,"]","array index");return JO(e,n,s.span[1])}function wt(i){return[...Bl(i,bb)]}function gb(i){return Xu(i,"if",wb)}function Ab(i){return i.stream.matchSequence("@","else")?yb():null}function Ob(i){return Xu(i,"elif",kb)}function bb(i){const{stream:e}=i,t=e.checkpoint();if(!e.matchText("@"))return null;e.reset(t);const n=ju(i);if(n)return n;const s=Cb(i);return s||null}function Xu(i,e,t){const{stream:n}=i,s=n.checkpoint();if(!n.matchSequence("@",e))return null;L(n,"(",`@${e}`);const r=st(i,!0);if(!r)return null;n.matchText(","),L(n,")",`@${e} expression`);const o=vb({value:r,span:[s,n.checkpoint()]});return t(o)}function wb(i){return{kind:"@if",param:i}}function yb(){return{kind:"@else"}}function kb(i){return{kind:"@elif",param:i}}function ju(i){const{stream:e}=i,t=e.peek();if(t?.text!=="@")return null;const n=t.span[0],s=gb(i);if(s)return ri(s,n,e.checkpoint());const r=Ob(i);if(r)return ri(r,n,e.checkpoint());const o=Ab(i);return o?ri(o,n,e.checkpoint()):null}function Cb(i){const{stream:e}=i,t=e.checkpoint(),n=e.matchText("@");if(!n)return null;const s=n.span[0],r=e.peek();if(!r||r.kind!=="word"&&r.kind!=="keyword")return e.reset(t),null;e.nextToken();const o=r.text;if(o==="builtin")return xb(i,s);if(o==="interpolate")return Sb(i,s);if(o==="diagnostic")return Eb(i,s);let l;if(e.matchText("(")&&(i.parsingAttrParam=o,l=Bb(i),i.parsingAttrParam=void 0,L(e,")","attribute parameters")),o==="must_use"&&l!==void 0)throw new zt("@must_use does not accept parameters",[s,e.checkpoint()]);return ri({kind:"@attribute",name:o,params:l},s,e.checkpoint())}function vb(i){return{kind:"translate-time-expression",expression:i.value,span:i.span}}function ri(i,e,t){return{kind:"attribute",attribute:i,start:e,end:t,contents:[]}}function xb(i,e){const{stream:t}=i;L(t,"(","@builtin");const n=Fe(t,"Expected identifier in @builtin");L(t,")","@builtin parameter");const s={kind:"@builtin",param:tt(n)};return ri(s,e,t.checkpoint())}function Sb(i,e){const{stream:t}=i;L(t,"(","@interpolate");const n=sr(i,Qb);return L(t,")","@interpolate parameters"),ri({kind:"@interpolate",params:n},e,t.checkpoint())}function Qb(i){const e=Fe(i.stream,"Expected identifier");return tt(e)}function Eb(i,e){const{stream:t}=i;L(t,"(","@diagnostic");const n=Fe(t,"Expected severity in @diagnostic"),s=tt(n);L(t,",","@diagnostic severity");const r=Fe(t,"Expected rule in @diagnostic"),o=tt(r);let l;if(t.matchText(".")){const c=Fe(t,"Expected rule after namespace");l=[o,tt(c)]}else l=[o,null];return L(t,")","@diagnostic parameters"),ri({kind:"@diagnostic",severity:s,rule:l},e,t.checkpoint())}function Bb(i){return sr(i,Pb)}function Pb(i){const{stream:e}=i,t=e.checkpoint();oe(i,"expression"),st(i);const n=e.checkpoint(),s=zi(i,t,n);return{kind:"expression",start:t,end:n,contents:s}}function Mb(i){const{stream:e}=i,t=e.checkpoint(),n=wt(i),s=n.length>0?n:void 0,r=Fh(i,"enable",s)||Fh(i,"requires",s)||Ib(i,s);return r||e.reset(t),r}function Fh(i,e,t){const{stream:n}=i,s=n.matchText(e);if(!s)return null;const r=sr(i,Db);return L(n,";",`${e} directive`),Ju({kind:e,extensions:r},s,n,t)}function Db(i){const e=Fe(i.stream,"Expected identifier in name list");return tt(e)}function Ib(i,e){const{stream:t}=i,n=t.matchText("diagnostic");if(!n)return null;L(t,"(","diagnostic");const s=Fe(t,"Expected severity in diagnostic"),r=tt(s);L(t,",","diagnostic severity");const o=Fe(t,"Expected rule name in diagnostic"),l=tt(o);let a=null;if(t.matchText(".")){const c=Fe(t,"Expected subrule name after '.'");a=tt(c)}return t.matchText(","),L(t,")","diagnostic rule"),L(t,";","diagnostic directive"),Ju({kind:"diagnostic",severity:r,rule:[l,a]},n,t,e)}function Ju(i,e,t,n){const s=n?.[0]?.start??e.span[0],r=t.checkpoint(),o={kind:"directive",directive:i,start:s,end:r};return Ge(o,n),o}function Tb(i,e){const t=_i(i,"if",e);if(t===null)return null;ye(i,"Expected condition expression after 'if'");const n=ui(i,"Expected '{' after if condition");return i.addElem(n),Lb(i),Ye(t,i,e)}function Rb(i,e){const t=_i(i,"switch",e);return t===null?null:(ye(i,"Expected expression after 'switch'"),Nb(i),Ye(t,i,e))}function Lb(i){const{stream:e}=i;for(;e.matchText("else");){if(e.matchText("if")){ye(i,"Expected expression after 'else if'");const s=ui(i,"Expected '{' after else if");i.addElem(s);continue}const n=ui(i,"Expected '{' after else");i.addElem(n);break}}function Nb(i){const{stream:e}=i;for(wt(i),L(e,"{","switch expression");!e.matchText("}");){const t=e.checkpoint(),n=wt(i);oe(i,"switch-clause",n.length?n:void 0),e.matchText("case")?($b(i),Kh(i,"Expected '{' after case value")):e.matchText("default")?Kh(i,"Expected '{' after 'default'"):F(e,"Expected 'case', 'default', or '}' in switch");const s=kt("switch-clause",t,i,{});Ge(s,n.length?n:void 0),i.addElem(s)}}function $b(i){const{stream:e}=i;for(ye(i,"Expected expression after 'case'");e.matchText(",");)ye(i,"Expected expression after ',' in case values")}function Kh(i,e){i.stream.matchText(":");const t=wt(i),n=t.length>0?t:void 0,s=cr(i,n);s||F(i.stream,e),i.addElem(s)}function Zu(i,e){return ed(i,"const",!0,Kb(i),e)}function Fb(i,e){return ed(i,"override",!1,!0,e)}function hr(i,e=!0){const t=i.stream.matchKind("word");if(!t)return null;const n=t.span[0];oe(i,"typeDecl");const s=rr(i,t,e);i.addElem(s),i.saveIdent(s.ident);const{typeRef:r,typeScope:o}=zb(i),l=i.stream.checkpoint(),a=zi(i,n,l);return{kind:"typeDecl",decl:s,typeRef:r,typeScope:o,start:n,end:l,contents:a}}function ed(i,e,t,n,s){const{stream:r}=i,o=r.matchText(e);if(!o)return null;const l=Ue(s,o.span[0]);i.pushScope("partial"),oe(i,e,s);const a=hr(i,n);a||F(r,`Expected identifier after '${e}'`),i.addElem(a),t?(L(r,"=",`${e} identifier`),ye(i)):r.matchText("=")&&ye(i),L(r,";",`${e} declaration`);const h=r.checkpoint(),c=zi(i,l,h);a.decl.ident.dependentScope=i.currentScope(),i.popScope();const f={kind:e,name:a,start:l,end:h,contents:c};return Ge(f,s),lr(a,f),f}function Kb(i){let e=i.currentScope();for(;e.kind==="partial"&&e.parent;)e=e.parent;return e.parent===null}function zb(i){if(!i.stream.matchText(":"))return{};i.pushScope();const e=ar(i);e||F(i.stream,"Expected type after ':'"),i.addElem(e);const t=i.currentScope();return i.popScope(),{typeRef:e,typeScope:t}}function _b(i,e){const{stream:t}=i,n=t.matchText("var");if(!n)return null;const s=Ue(e,n.span[0]);i.pushScope("partial"),oe(i,"gvar",e),id(i);const r=hr(i);r||F(t,"Expected identifier after 'var'"),i.addElem(r),t.matchText("=")&&ye(i),L(t,";","var declaration"),r.decl.ident.dependentScope=i.currentScope(),i.popScope();const o=kt("gvar",s,i,{name:r});return Ge(o,e),lr(r,o),o}function Vb(i,e){const{stream:t}=i,n=t.matchText("alias");if(!n)return null;const s=Ue(e,n.span[0]);oe(i,"alias",e);const r=Fe(t,"Expected identifier after 'alias'"),o=rr(i,r,!0);i.addElem(o),i.saveIdent(o.ident),L(t,"=","alias name"),i.pushScope();const l=ar(i);l||F(t,"Expected type after '=' in alias declaration"),i.addElem(l),o.ident.dependentScope=i.currentScope(),i.popScope(),L(t,";","alias declaration");const a=kt("alias",s,i,{name:o,typeRef:l});return Ge(a,e),or(o,a),a}function td(i,e){const t=i.stream.matchText("const_assert");if(!t)return null;const n=Ue(e,t.span[0]);oe(i,"assert",e),ye(i),L(i.stream,";","const_assert expression");const s=kt("assert",n,i,{});return Ge(s,e),s}function id(i){const{stream:e}=i;if(e.nextTemplateStartToken())for(;;){const t=e.peek();if(t||F(e,"Unclosed template in var declaration"),t.text.startsWith(">")){e.nextTemplateEndToken();return}e.nextToken()}}function nd(i,e){return sd(i,"var",!0,!1,e)}function Wb(i,e){return sd(i,"let",!1,!0,e)}function sd(i,e,t,n,s){const{stream:r}=i,o=r.matchText(e);if(!o)return null;const l=Ue(s,o.span[0]);oe(i,e,s),t&&id(i);const a=hr(i,!1);if(a||F(r,`Expected identifier after '${e}'`),i.addElem(a),n){const c=`${e} identifier (${e} requires initialization)`;L(r,"=",c),ye(i)}else r.matchText("=")&&ye(i);L(r,";",`${e} declaration`);const h=kt(e,l,i,{name:a});return Ge(h,s),lr(a,h),h}const Hb=new Set(["=","+=","-=","*=","/=","%=","&=","|=","^=","<<=",">>="]);function qb(i,e){const{stream:t}=i,n=Ue(e,t.checkpoint());return Gb(i,n,e)||Ub(i,n,e)||zh(i,n,e,"continue")||zh(i,n,e,"discard")||Yb(t,n)||Xb(i,n,e)||jb(i,n,e)}function Gb(i,e,t){const{stream:n}=i;if(!n.matchText("return"))return null;oe(i,"statement",t);const s=st(i);return s&&i.options.preserveExpressions&&i.addElem(s),L(n,";","return statement"),Ye(e,i,t)}function Ub(i,e,t){const{stream:n}=i;return n.matchText("break")?(oe(i,"statement",t),n.matchText("if")&&ye(i,"Expected condition after 'break if'"),L(n,";","break statement"),Ye(e,i,t)):null}function zh(i,e,t,n){const{stream:s}=i;return s.matchText(n)?(oe(i,"statement",t),L(s,";",`${n} statement`),Ye(e,i,t)):null}function Yb(i,e){if(!i.matchText(";"))return null;const t=i.checkpoint();return{kind:"statement",start:e,end:t,contents:[]}}function Xb(i,e,t){const{stream:n}=i;return n.matchText("_")?(rd(n)||F(n,"Expected assignment operator after '_'"),oe(i,"statement",t),ye(i,"Expected expression after assignment operator"),L(n,";","assignment"),Ye(e,i,t)):null}function jb(i,e,t){const{stream:n}=i;oe(i,"statement",t);const s=st(i);return s?(i.options.preserveExpressions&&i.addElem(s),ld(n)||od(i),L(n,";","expression"),Ye(e,i,t)):(zi(i,e,e),n.reset(e),null)}function rd(i){return!!i.nextIf(({text:e})=>Hb.has(e))}function od(i){return rd(i.stream)?(ye(i,"Expected expression after assignment operator"),!0):!1}function ld(i){return!!i.nextIf(({text:e})=>e==="++"||e==="--")}function Jb(i,e){const{stream:t}=i,n=_i(i,"for",e);if(n===null)return null;i.pushScope(),L(t,"(","'for'"),iw(i);const s=st(i);s&&i.options.preserveExpressions&&i.addElem(s),L(t,";","for loop condition"),nw(i),L(t,")","for loop header");const r=ui(i,"Expected '{' after for loop header");return i.addElem(r),i.popScope(),Ye(n,i,e)}function Zb(i,e){const t=_i(i,"while",e);if(t===null)return null;ye(i,"Expected condition expression after 'while'");const n=ui(i,"Expected '{' after while condition");return i.addElem(n),Ye(t,i,e)}function ew(i,e){const t=_i(i,"loop",e);if(t===null)return null;const n=ui(i,"Expected '{' after 'loop'",!0);return i.addElem(n),Ye(t,i,e)}function tw(i,e){const t=_i(i,"continuing",e,"continuing");if(t===null)return null;const n=ui(i,"Expected '{' after 'continuing'");return i.addElem(n),Ye(t,i,e,"continuing")}function iw(i){const{stream:e}=i,t=nd(i);if(t)i.addElem(t);else{const n=st(i);n&&i.options.preserveExpressions&&i.addElem(n),L(e,";","for loop init")}}function nw(i){const e=st(i);e&&i.options.preserveExpressions&&i.addElem(e),ld(i.stream)||od(i)}function sw(i){return cr(i,void 0,{noScope:!0})}function cr(i,e,t){const n=i.stream.matchText("{");if(!n)return null;const s=Ue(e,n.span[0]);oe(i,"statement",e);const r=t?.noScope||rw(e);return r||i.pushScope(),ow(i,t?.loopBody),r||i.popScope(),Ye(s,i,e)}function ui(i,e,t){const n=wt(i),s=n.length>0?n:void 0,o=cr(i,s,t?{loopBody:t}:void 0);return o||F(i.stream,e),o}function Ue(i,e){return i?.[0]?.start??e}function _i(i,e,t,n="statement"){const s=i.stream.checkpoint();if(!i.stream.matchText(e))return null;const r=Ue(t,s);return oe(i,n,t),r}function Ye(i,e,t,n="statement"){const s=kt(n,i,e,{});return Ge(s,t),s}function rw(i){return!!i&&Pl(i)}function ow(i,e){const{stream:t}=i;for(;!t.matchText("}");){const n=lw(i);if(n||F(t,"Expected statement or '}'"),i.addElem(n),e&&n.kind==="continuing"){L(t,"}","continuing block");break}}}function lw(i){const{stream:e}=i,t=e.checkpoint(),n=wt(i),s=e.peek();if(!s||s.text==="}")return e.reset(t),null;const r=n.length>0&&Pl(n);r&&i.pushScope("partial");const o=n.length>0?n:void 0,a=kl([nd,Wb,Zu,td,cr,Tb,Rb,Jb,Zb,ew,tw,qb],h=>h(i,o));return a?(aw(i,r,n),a):null}function aw(i,e,t){if(e){const n=i.popScope();n.condAttribute=hw(t)}}function hw(i){return i.find(t=>Vu(t.attribute))?.attribute}function cw(i,e){const{stream:t}=i,n=t.matchText("fn");if(!n)return null;const s=Ue(e,n.span[0]),r=Fe(t,"Expected identifier after 'fn'"),o=rr(i,r,!0);i.saveIdent(o.ident),i.pushScope();const l=i.currentScope();i.pushScope();const a=fw(i),h=i.currentScope();i.state.context.scope=l;const{returnType:c,returnAttributes:f}=uw(i);i.state.context.scope=h;const u=sw(i);u||F(t,"Expected function body"),i.popScope(),o.ident.dependentScope=i.currentScope(),i.popScope();const d={kind:"fn",name:o,params:a,body:u,returnType:c,returnAttributes:f,start:s,end:t.checkpoint(),contents:dw(e,o,a,c,u)};return Ge(d,e),or(o,d),d}function fw(i){const{stream:e}=i,t=[];for(L(e,"(","function name");!e.matchText(")");){const n=pw(i);if(n||F(e,"Expected function parameter or ')'"),t.push(n),!e.matchText(",")){L(e,")","function parameter");break}}return t}function uw(i){const{stream:e}=i;if(!e.matchText("->"))return{};const t=wt(i),n=ar(i);return n||F(e,"Expected type after '->'"),{returnType:n,returnAttributes:t.length>0?t:void 0}}function dw(i,e,t,n,s){const r=n?[e,...t,n,s]:[e,...t,s];return i?.length?[...i,...r]:r}function pw(i){const e=wt(i);if(i.stream.peek()?.kind!=="word")return null;oe(i,"param",e.length?e:void 0);const t=hr(i,!1);if(!t)throw new Error("Unexpected: peek succeeded but parseTypedDecl failed");i.addElem(t);const n=Ue(e,t.start),s=kt("param",n,i,{name:t});return lr(t,s),Ge(s,e.length>0?e:void 0),s}function mw(i){return[...Bl(i,gw)]}function gw(i){const{stream:e}=i,t=ju(i),n=Aw(e);if(!n)return t&&e.reset(t.start),null;const{statement:s,importPos:r}=n,o=t?.start??r,l=e.checkpoint();return{kind:"import",imports:s,start:o,end:l,attributes:t?[t]:void 0}}function Aw(i){const e=i.matchText("import");if(!e)return null;const t=Ow(i)??[],n=ad(i)||zs(i);return n||F(i,"invalid import, expected { or name"),i.matchText(";")||F(i,"invalid import, expected ';'"),{statement:n.kind==="import-statement"?hd(t,n):ys(t,n),importPos:e.span[0]}}function Ow(i){if(i.matchSequence("package","::"))return[zo("package")];const e=[];for(;i.matchSequence("super","::");)e.push(zo("super"));return e.length>0?e:null}function ad(i){if(!i.matchText("{"))return null;const e="invalid import collection, expected name",t=zs(i);t||F(i,e);const n=[t];for(;i.matchText(",")&&i.peek()?.text!=="}";){const s=zs(i);s||F(i,e+" after ','"),n.push(s)}return i.matchText("}")||F(i,"invalid import collection, expected }"),bw(n)}function zs(i){const e=ww(i);if(!e)return null;if(i.matchText("::")){const t=zo(e),n=ad(i);if(n)return ys([t],n);const s=zs(i);if(s)return hd([t],s);F(i,"invalid import, expected '{' or name")}if(i.matchText("as")){const t=i.matchKind("word");return t||F(i,"invalid alias, expected name"),ys([],_h(e,t.text))}return ys([],_h(e))}function hd(i,e){return{...e,segments:i.concat(e.segments)}}function ys(i,e){return{kind:"import-statement",segments:i,finalSegment:e}}function zo(i){return{kind:"import-segment",name:i}}function bw(i){return{kind:"import-collection",subtrees:i}}function ww(i){const e=i.peek();if(!e)return null;const{text:t,kind:n}=e;return n!=="word"&&n!=="keyword"||qu.has(t)?null:(i.nextToken(),t)}function _h(i,e){return{kind:"import-item",name:i,as:e}}function yw(i,e){const{stream:t}=i,n=t.matchText("struct");if(!n)return null;const s=Ue(e,n.span[0]),r=Fe(t,"Expected identifier after 'struct'"),o=rr(i,r,!0);i.saveIdent(o.ident),oe(i,"struct",e),i.addElem(o),L(t,"{","struct name"),i.pushScope();const l=kw(i);o.ident.dependentScope=i.currentScope(),i.popScope(),L(t,"}","struct member");const a=kt("struct",s,i,{name:o,members:l});return Ge(a,e),or(o,a),a}function kw(i){const e=sr(i,Cw);for(const t of e)i.addElem(t);return e}function Cw(i){const{stream:e}=i,t=e.checkpoint(),n=wt(i),s=e.matchKind("word");if(!s)return e.reset(t),null;const r=Ue(n,s.span[0]);oe(i,"member",n.length?n:void 0);const o=tt(s);i.addElem(o),L(e,":","struct member name");const l=ar(i);l||F(e,"Expected type after ':'"),i.addElem(l);const a=kt("member",r,i,{name:o,typeRef:l});return Ge(a,n.length?n:void 0),a}const vw=[Zu,Fb,_b,Vb,yw,cw,td];function xw(i){for(Sw(i),Qw(i);Ew(i););}function Sw(i){const e=mw(i);for(const t of e)i.addElem(t),i.state.stable.imports.push(t.imports)}function Qw(i){const e=Bl(i,Mb);for(const t of e)i.addElem(t)}function Ew(i){const{stream:e}=i;if(e.matchText(";"))return!0;const t=wt(i),n=Pl(t);n&&i.pushScope("partial");const s=Bw(i,t);return n&&s&&Pw(i,t),s?!0:(t.length&&F(e,"Expected declaration after attributes"),!1)}function Bw(i,e){const t=e.length?e:void 0,n=kl(vw,s=>s(i,t));return n?(Mw(i,n,e),!0):!1}function Pw(i,e){const t=i.popScope();t.condAttribute=kl(e,({attribute:n})=>Dw(n)?n:void 0)}function Mw(i,e,t){if(t.length&&e.start>t[0].start&&(e.start=t[0].start),i.addElem(e),e.kind==="assert"){const{stable:n}=i.state;n.moduleAsserts??=[],n.moduleAsserts.push(e)}}function Dw(i){return i.kind==="@if"||i.kind==="@elif"||i.kind==="@else"}class Iw{src;srcModule;stream;state;options;constructor(e,t,n){this.stream=e,this.state=t,this.srcModule=t.stable.srcModule,this.src=this.srcModule.src,this.options=n??{}}position(){return this.stream.checkpoint()}currentScope(){return this.state.context.scope}addElem(e){const{openElems:t}=this.state.context;t.length>0&&t[t.length-1].contents.push(e)}pushScope(e="scope"){const{scope:t}=this.state.context,n=Mu(t,e);t.contents.push(n),this.state.context.scope=n}popScope(){const e=this.state.context,t=e.scope;return t.parent&&(e.scope=t.parent),t}isModuleScope(){let e=this.currentScope();for(;e.kind==="partial"&&e.parent;)e=e.parent;return e.parent===null}parsingAttrParam;createRefIdent(e){const t={kind:"ref",originalName:e,ast:this.state.stable,id:Eh(),refIdentElem:null};return this.parsingAttrParam&&(t.attrParam=this.parsingAttrParam),t}createDeclIdent(e,t=!1){return{kind:"decl",originalName:e,containingScope:this.state.context.scope,isGlobal:t,id:Eh(),srcModule:this.srcModule,declElem:null}}saveIdent(e){this.state.context.scope.contents.push(e)}}const Tw=`alias break case const const_assert continue continuing
18
+ default diagnostic discard else enable false fn for if
19
+ let loop override requires return struct switch true var while`.split(/\s+/),Rw=`NULL Self abstract active alignas alignof as asm asm_fragment async attribute auto await
20
+ become cast catch class co_await co_return co_yield coherent column_major
21
+ common compile compile_fragment concept const_cast consteval constexpr constinit crate
22
+ debugger decltype delete demote demote_to_helper do dynamic_cast
23
+ enum explicit export extends extern external fallthrough filter final finally friend from fxgroup
24
+ get goto groupshared highp impl implements import inline instanceof interface layout lowp
25
+ macro macro_rules match mediump meta mod module move mut mutable
26
+ namespace new nil noexcept noinline nointerpolation non_coherent noncoherent noperspective null nullptr
27
+ of operator package packoffset partition pass patch pixelfragment precise precision premerge
28
+ priv protected pub public readonly ref regardless register reinterpret_cast require resource restrict
29
+ self set shared sizeof smooth snorm static static_assert static_cast std subroutine super
30
+ target template this thread_local throw trait try type typedef typeid typename typeof
31
+ union unless unorm unsafe unsized use using varying virtual volatile wgsl where with writeonly yield`.split(/\s+/);class Lw{cache=new Nw(5);inner;constructor(e){this.inner=e}checkpoint(){return this.inner.checkpoint()}reset(e){this.inner.reset(e)}nextToken(){const e=this.checkpoint(),t=this.cache.get(e);if(t!==void 0)return this.reset(t.checkpoint),t.token;{const n=this.inner.nextToken(),s=this.checkpoint();return this.cache.set(e,{token:n,checkpoint:s}),n}}get src(){return this.inner.src}}class Nw extends Map{max;constructor(e){super(),this.max=e}set(e,t){if(this.size>this.max){const n=this.keys().next().value;n&&this.delete(n)}return super.set(e,t)}}function $w(i){const[e,t]=i;if(typeof t=="string"){const n=`(${cd(t)})`;return Vh(e,new RegExp(n)),n}else return Vh(e,t),`(${t.source})`}function Vh(i,e){if(new RegExp("|"+e.source).exec("").length>1)throw new Error(`match expression groups must be non-capturing: ${i}: /${e.source}/. Use (?:...) instead.`)}const Fw=/[$+*.?|(){}[\]\\/^]/g;function cd(i){return i.replace(Fw,"\\$&")}function fr(i){const t=i.split(/\s+/).sort((n,s)=>s.length-n.length).filter(n=>n).map(cd);return new RegExp(t.join("|"))}class Kw{position=0;text;matchers;constructor(e,t){this.text=e,this.matchers=t}checkpoint(){return this.position}reset(e){this.position=e}nextToken(){const e=this.matchers.execAt(this.text,this.position);return e===null?null:(this.position=e.span[1],e)}get src(){return this.text}}class zw{groups;exp;constructor(e){this.groups=Object.keys(e);const t=Object.entries(e).map($w).join("|");this.exp=new RegExp(t,"dyu")}execAt(e,t){this.exp.lastIndex=t;const n=this.exp.exec(e),s=_w(n?.indices);if(s){const{span:r,groupDex:o}=s;return{kind:this.groups[o],span:r,text:e.slice(r[0],r[1])}}else return null}}function _w(i){if(i!==void 0)for(let e=1;e<i.length;e++){const t=i[e];if(t!==void 0)return{span:t,groupDex:e-1}}}const Vw=/[ \t\n\v\f\r\u{0085}\u{200E}\u{200F}\u{2028}\u{2029}]+/u,Ww="& && -> @ / ! [ ] { } :: : , == = != >>= >> >= > <<= << <= < % - -- . + ++ | || ( ) ; * ~ ^ // /* */ += -= *= /= %= &= |= ^= _",Hw=/(?:(?:[_\p{XID_Start}][\p{XID_Continue}]+)|(?:[\p{XID_Start}]))/u,qw=new Set(Tw.concat(Rw)),Gw=new RegExp(/(?:0[fh])|(?:[1-9][0-9]*[fh])/.source+/|(?:[0-9]*\.[0-9]+(?:[eE][+-]?[0-9]+)?[fh]?)/.source+/|(?:[0-9]+\.[0-9]*(?:[eE][+-]?[0-9]+)?[fh]?)/.source+/|(?:[0-9]+[eE][+-]?[0-9]+[fh]?)/.source+/|(?:0[xX][0-9a-fA-F]*\.[0-9a-fA-F]+(?:[pP][+-]?[0-9]+[fh]?)?)/.source+/|(?:0[xX][0-9a-fA-F]+\.[0-9a-fA-F]*(?:[pP][+-]?[0-9]+[fh]?)?)/.source+/|(?:0[xX][0-9a-fA-F]+[pP][+-]?[0-9]+[fh]?)/.source+/|(?:0[xX][0-9a-fA-F]+[iu]?)/.source+/|(?:0[iu]?)|(?:[1-9][0-9]*[iu]?)/.source),Uw=/\/\/|\/\*/,Yw=new zw({word:Hw,number:Gw,blankspaces:Vw,commentStart:Uw,symbol:fr(Ww),invalid:/[^]/});class fd{stream;eolPattern=/[\n\v\f\u{0085}\u{2028}\u{2029}]|\r\n?/gu;blockCommentPattern=/\/\*|\*\//g;src;constructor(e){this.src=e,this.stream=new Lw(new Kw(e,Yw))}checkpoint(){return this.stream.checkpoint()}reset(e){this.stream.reset(e)}nextToken(){for(;;){const e=this.stream.nextToken();if(e===null)return null;const t=e.kind;if(t!=="blankspaces")if(t==="commentStart")e.text==="//"?this.stream.reset(this.skipToEol(e.span[1])):this.stream.reset(this.skipBlockComment(e.span[1]));else if(t==="word"){const n=e;return qw.has(e.text)&&(n.kind="keyword"),n}else{if(t==="invalid")throw new zt("Invalid token "+e.text,e.span);return e}}}peek(){const e=this.checkpoint(),t=this.nextToken();return this.reset(e),t}matchText(e){const t=this.peek();return t?.text===e?(this.nextToken(),t):null}matchKind(e,t){const n=this.peek();return n?.kind===e&&(!t||n.text===t)?(this.nextToken(),n):null}nextIf(e){const t=this.peek();return t&&e(t)?(this.nextToken(),t):null}matchSequence(...e){const t=this.checkpoint(),n=[];for(const s of e){const r=this.matchText(s);if(!r)return this.reset(t),null;n.push(r)}return n}skipToEol(e){return this.eolPattern.lastIndex=e,this.eolPattern.exec(this.src)===null?this.src.length:this.eolPattern.lastIndex}skipBlockComment(e){let t=e;for(;;){this.blockCommentPattern.lastIndex=t;const n=this.blockCommentPattern.exec(this.src);if(n===null)throw new zt("Unclosed block comment!",[t,t]);if(n[0]==="*/")return this.blockCommentPattern.lastIndex;if(n[0]==="/*")t=this.skipBlockComment(this.blockCommentPattern.lastIndex);else throw new Error("Unreachable, invalid block comment pattern")}}nextTemplateStartToken(){const e=this.stream.checkpoint(),t=this.nextToken();return this.stream.reset(e),t===null||t.kind!=="symbol"?null:t.text==="<"?this.isTemplateStart(t.span[1])?(this.stream.reset(t.span[1]),t):(this.stream.reset(e),null):null}nextTemplateEndToken(){const e=this.stream.checkpoint(),t=this.nextToken();if(this.stream.reset(e),t===null)return null;if(t.kind==="symbol"&&t.text[0]===">"){const n=t.span[0];return this.stream.reset(n+1),{kind:"symbol",span:[n,n+1],text:">"}}else return null}isTemplateStart(e){this.stream.reset(e);let t=1;for(;;){const n=this.stream.nextToken();if(n===null)return!1;if(n.kind==="symbol"){if(n.text==="<")t+=1;else if(n.text[0]===">"){if(n.text===">"||n.text===">=")t-=1;else if(n.text===">>="||n.text===">>")t-=2;else throw new Error("This case should never be reached, looks like we forgot one of the tokens that start with >");if(t<=0)return!0}else if(n.text==="(")this.skipBracketsTo(")");else if(n.text==="[")this.skipBracketsTo("]");else if(n.text==="=="||n.text==="!="||n.text===";"||n.text==="{"||n.text===":"||n.text==="&&"||n.text==="||")return!1}}}skipBracketsTo(e){for(;;){const t=this.stream.nextToken();if(t===null){const n=this.stream.checkpoint();throw new zt("Unclosed bracket!",[n,n])}if(t.kind==="symbol"){if(t.text==="(")this.skipBracketsTo(")");else if(t.text==="[")this.skipBracketsTo("]");else if(t.text===e)return}}}}function Xw(i,e){const{ctx:t,state:n}=jw(i,e);try{oe(t,"module"),xw(t);const s=n.stable.moduleElem;return s.contents=zi(t,0,s.end),n.stable}catch(s){if(s instanceof zt)throw new _s({cause:s,src:i});const r=s instanceof Error?s.message:String(s),o=new zt(r,[0,0]);throw new _s({cause:o,src:i})}}function jw(i,e){const t=new fd(i.src),n=Mu(null),s={kind:"module",contents:[],start:0,end:i.src.length},r={context:{scope:n,openElems:[]},stable:{srcModule:i,moduleElem:s,rootScope:n,imports:[]}};return{ctx:new Iw(t,r,e),state:r}}class _s extends Error{span;src;constructor(e){const t=e.src.src,[n,s]=Cl(e.cause.span[0],t);let r=`${e.src.debugFilePath}:${n}:${s}`;r+=` error: ${e.cause.message}
32
+ `,r+=vu(t,e.cause.span).join(`
33
+ `),super(r,{cause:e.cause}),this.span=e.cause.span,this.src=e.src}}function ur(i,e){return Xw(i,e)}function Jw(i,e){if(i._flatImports&&!e)return i._flatImports;const t=i.moduleElem.contents.filter(o=>o.kind==="import"),r=(e?Yt(t,e):t).map(o=>o.imports).flatMap(qO);return e||(i._flatImports=r),r}const ud=`bitcast all any select arrayLength
34
+ abs acos acosh asin asinh atan atanh atan2 ceil clamp cos cosh
35
+ countLeadingZeros countOneBits countTrailingZeros cross
36
+ degrees determinant distance dot dot4U8Packed dot4I8Packed
37
+ exp exp2 extractBits faceForward firstLeadingBit firstTrailingBit
38
+ floor fma fract frexp insertBits inverseSqrt ldexp length log log2
39
+ max min mix modf normalize pow quantizeToF16 radians reflect refract
40
+ reverseBits round saturate sign sin sinh smoothstep sqrt step tan tanh
41
+ transpose trunc
42
+ dpdx dpdxCoarse dpdxFine dpdy dpdyCoarse dpdyFine fwidth
43
+ fwidthCoarse fwidthFine
44
+ textureDimensions textureGather textureGatherCompare textureLoad
45
+ textureNumLayers textureNumLevels textureNumSamples
46
+ textureSample textureSampleBias textureSampleCompare textureSampleCompareLevel
47
+ textureSampleGrad textureSampleLevel textureSampleBaseClampToEdge
48
+ textureStore
49
+ atomicLoad atomicStore atomicAdd atomicSub atomicMax atomicMin
50
+ atomicAnd atomicOr atomicXor atomicExchange atomicCompareExchangeWeak
51
+ pack4x8snorm pack4x8unorm pack4xI8 pack4xU8 pack4xI8Clamp pack4xU8Clamp
52
+ pack2x16snorm pack2x16unorm pack2x16float
53
+ unpack4x8snorm unpack4x8unorm unpack4xI8 unpack4xU8
54
+ unpack2x16snorm unpack2x16unorm unpack2x16float
55
+ storageBarrier textureBarrier workgroupBarrier workgroupUniformLoad
56
+ subgroupAdd subgroupAll subgroupAnd subgroupAny subgroupBallot
57
+ subgroupBroadcast subgroupBroadcastFirst subgroupElect
58
+ subgroupExclusiveAdd subgroupExclusiveMul subgroupInclusiveAdd
59
+ subgroupInclusiveMul subgroupMax subgroupMin subgroupMul subgroupOr
60
+ subgroupShuffle subgroupShuffleUp subgroupShuffleXor subgroupXor
61
+ quadBroadcast quadSwapDiagonal quadSwapX quadSwapY`.split(/\s+/),dd=`
62
+ texture_1d texture_2d texture_2d_array texture_3d
63
+ texture_cube texture_cube_array
64
+ `,pd=`
65
+ texture_multisampled_2d texture_depth_multisampled_2d
66
+ `,md=`
67
+ texture_storage_1d texture_storage_2d texture_storage_2d_array
68
+ texture_storage_3d
69
+ `,gd=`array atomic bool f16 f32 i32
70
+ mat2x2 mat2x3 mat2x4 mat3x2 mat3x3 mat3x4 mat4x2 mat4x3 mat4x4
71
+ mat2x2f mat2x3f mat2x4f mat3x2f mat3x3f mat3x4f
72
+ mat4x2f mat4x3f mat4x4f
73
+ mat2x2h mat2x3h mat2x4h mat3x2h mat3x3h mat3x4h
74
+ mat4x2h mat4x3h mat4x4h
75
+ u32 vec2 vec3 vec4 ptr
76
+ vec2i vec3i vec4i vec2u vec3u vec4u
77
+ vec2f vec3f vec4f vec2h vec3h vec4h
78
+ ${dd}
79
+ ${pd}
80
+ texture_external
81
+ ${md}
82
+ texture_depth_2d texture_depth_2d_array texture_depth_cube
83
+ texture_depth_cube_array
84
+ sampler sampler_comparison
85
+ rgba8unorm rgba8snorm rgba8uint rgba8sint
86
+ rgba16uint rgba16sint rgba16float
87
+ r32uint r32sint r32float rg32uint rg32sint rg32float
88
+ rgba32uint rgba32sint rgba32float
89
+ bgra8unorm`.split(/\s+/),Zw=`read write read_write
90
+ function private workgroup uniform storage
91
+ rgba8unorm rgba8snorm rgba8uint rgba8sint
92
+ rgba16uint rgba16sint rgba16float
93
+ r32uint r32sint r32float rg32uint rg32sint rg32float
94
+ rgba32uint rgba32sint rgba32float bgra8unorm`.split(/\s+/);function Ad(i){return gd.includes(i)}function ey(i){return ud.includes(i)||Ad(i)}function ty(i){return Zw.includes(i)}const iy=new Set(["align","binding","blend_src","compute","const","fragment","group","id","invariant","location","must_use","size","vertex","workgroup_size"]);function Od(i){const{rootAst:e,resolver:t,virtuals:n,accumulateUnbound:s}=i,{conditions:r={},mangler:o=Lu}=i,l=dr(e.rootScope,r),{globalNames:a,knownDecls:h}=ny(l),c={resolver:t,conditions:r,knownDecls:h,virtuals:n,mangler:o,foundScopes:new Set,globalNames:a,globalStatements:new Map,unbound:s?[]:void 0},u={decls:new Map(l.map(g=>[g.originalName,g])),parent:null},d=l.flatMap(g=>wd(g,c)),p=kn(e.rootScope,c,u),m=[...c.globalStatements.values()];return{decls:[...d,...p],globalNames:a,newStatements:m,unbound:c.unbound}}function ny(i){for(const n of i)n.mangledName=n.originalName;const e=new Set(i);return{globalNames:new Set(i.map(n=>n.originalName)),knownDecls:e}}function sy(i){if(!(i.kind==="decl"&&i.containingScope.kind==="partial")){if(i.kind==="decl")return Pu(i.declElem?.attributes);if(i.kind==="partial"||i.kind==="scope")return i.condAttribute}}function*bd(i,e){let t=!1;for(const n of i.contents){const s=Bu(sy(n),t,e);t=s.nextElseState,s.valid&&(yield n)}}function dr(i,e){const t=[];for(const n of bd(i,e))n.kind==="decl"?t.push(n):n.kind==="partial"&&Cd(n,t);return t}function ry(i,e,t){return py(i,t).find(s=>s.originalName===e)}function kn(i,e,t){const{dontFollowDecls:n,foundScopes:s}=e;if(s.has(i))return[];s.add(i);const r=oy(i,e,t),{newGlobals:o,newFromChildren:l}=r,a=n?[]:ay(o,e);return[o,l,a].flat()}function oy(i,e,t){const n=[],s=[];for(const r of bd(i,e.conditions))if(r.kind==="decl")t.decls.set(r.originalName,r);else if(r.kind==="ref"){const o=ly(r,t,e);o&&n.push(o)}else{const o=r.kind==="scope"?El(t):t;s.push(...kn(r,e,o))}return{newGlobals:n,newFromChildren:s}}function wd(i,e){const{dependentScope:t}=i;if(!t)return[];const n=my(i,e.conditions);return n?kn(t,e,El(n)):[]}function ly(i,e,t){if(i.refersTo||i.std||i.conditionRef||i.attrParam&&!iy.has(i.attrParam))return;const n=yd(i,e)??cy(i,t);if(n)return i.refersTo=n.decl,hy(i,n,t);if(kd(i.originalName)){i.std=!0;return}t.unbound||Qu(i,`unresolved identifier '${i.originalName}'`)}function ay(i,e){return i.flatMap(t=>wd(t,e))}function hy(i,e,t){const{decl:n,moduleAst:s}=e,{knownDecls:r,globalNames:o,mangler:l,globalStatements:a}=t;if(r.has(n))return;r.add(n);const h=i.originalName;if(gy(h,n,o,n.srcModule,l),!!n.isGlobal){for(const c of s.moduleAsserts??[])a.set(c,{srcModule:n.srcModule,elem:c});return n}}function yd(i,e){const t=e.decls.get(i.originalName);if(t)return{decl:t,moduleAst:i.ast};if(e.parent)return yd(i,e.parent)}function cy(i,e){const{conditions:t,unbound:n}=e,s=Jw(i.ast,t),r=i.originalName.split("::"),o=fy(r,s)??Ay(r);if(!o){n&&!kd(i.originalName)&&Wh(n,r,i);return}const l=uy(o,i.ast.srcModule,e);return l||(n?Wh(n,o,i):Qu(i,`module not found for '${o.join("::")}'`)),l}function Wh(i,e,t){const{srcModule:n,start:s,end:r}=t.refIdentElem;i.push({path:e,srcModule:n,start:s,end:r})}function fy(i,e){const t=e.find(n=>n.importPath.at(-1)===i[0]);if(t)return[...t.modulePath,...i.slice(1)]}function uy(i,e,t){const{resolver:n,conditions:s,virtuals:r}=t,o=e.modulePath.split("::"),a=Fu(i,o).slice(0,-1).join("::"),h=n.resolveModule(a)??dy(i[0],s,r);if(!h)return;const c=ry(h.rootScope,CO(i),s);if(c)return{decl:c,moduleAst:h}}function dy(i,e={},t){const n=t?.[i];if(!n)return;if(n.ast)return n.ast;const s=n.fn(e),r=i,o=i;return n.ast=ur({modulePath:r,debugFilePath:o,src:s}),n.ast}function py(i,e){const t=i;return t._validRootDecls||(t._validRootDecls=dr(i,e)),t._validRootDecls}function my(i,e){si(i.isGlobal,Ql(i));let t=i.containingScope;for(;t.parent;)t=t.parent;si(t.kind==="scope");const n=t;if(!n._scopeDecls){const s=dr(t,e);n._scopeDecls={decls:new Map(s.map(r=>[r.originalName,r]))}}return n._scopeDecls}function gy(i,e,t,n,s){if(e.mangledName)return;const r=i.lastIndexOf("::"),o=r===-1?i:i.slice(r+2),l=e.isGlobal?s(e,n,o,t):e.originalName;e.mangledName=l,t.add(l)}function kd(i){return Ad(i)||ey(i)||ty(i)}function Ay(i){if(i.length>1)return i}function Cd(i,e){for(const t of i.contents)t.kind==="decl"?e.push(t):t.kind==="partial"&&Cd(t,e)}function Oy(i){return by(i).map(e=>e.path)}function by(i){const e={resolver:i,conditions:{},knownDecls:new Set,foundScopes:new Set,globalNames:new Set,globalStatements:new Map,mangler:Lu,unbound:[],dontFollowDecls:!0};for(const[,t]of i.allModules()){const n=dr(t.rootScope,{}),s={decls:new Map(n.map(o=>[o.originalName,o])),parent:null};Cu(n,o=>o.dependentScope).forEach(o=>{kn(o,e,El(s))}),kn(t.rootScope,e,s)}return e.unbound}function*wy(i){const[e,t]=yy(i,"/");let n=e,s="";if(e.includes("__")){const[r,...o]=e.split("__");n=o.join("__"),s=`@${r}/`}yield`${s}${n}${t}`,yield`${s}${n.replaceAll("_","-")}${t}`}function yy(i,e){const t=i.indexOf(e);return t===-1?[i,""]:[i.slice(0,t),i.slice(t)]}class ky{sourceMap;constructor(e){this.sourceMap=e}createShaderModule(e,t){if(!("injectError"in e))return e.createShaderModule({...t,code:this.dest});e.pushErrorScope("validation");const n=e.createShaderModule({...t,code:this.dest});e.popErrorScope();const{promise:s,resolve:r}=Promise.withResolvers();return e.injectError("validation",s),n.getCompilationInfo().then(o=>{if(o.messages.length===0){r(null);return}const l=this.mapGPUCompilationInfo(o),a=Cy(l,n);si(a!==null);const h=new GPUValidationError(a);h.cause=new Error("createShaderModule failed"),h.compilationInfo=l,r(h)}),n}get dest(){return this.sourceMap.dest.text}mapGPUCompilationInfo(e){return{__brand:e.__brand,messages:e.messages.map(t=>this.mapGPUCompilationMessage(t))}}mapGPUCompilationMessage(e){const t=this.sourceMap,n=t.destToSrc(e.offset),r=(e.length>0?t.destToSrc(e.offset+e.length):n).position-n.position,[o,l]=Cl(n.position,n.src.text);return{__brand:e.__brand,type:e.type,message:e.message,offset:n.position,length:r,lineNum:o,linePos:l,module:{url:n.src.path??"",text:n.src.text}}}}function Cy(i,e){if(i.messages.length===0)return null;let t=`Compilation log for [Invalid ShaderModule (${e.label||"unlabled"})]:
95
+ `;const n=i.messages.filter(s=>s.type==="error").length;n>0&&(t+=`${n} error(s) generated while compiling the shader:
96
+ `);for(const s of i.messages){const{lineNum:r,linePos:o}=s;t+=`${s.module.url}:${r}:${o}`,t+=` ${s.type}: ${s.message}
97
+ `;const l=s.module.text;l&&(t+=vu(l,[s.offset,s.offset+s.length]).join(`
98
+ `))}return t}function vy(i){const t=i.split("/").filter(s=>s!=="."),n=[];return t.forEach(s=>{s!==""&&(s===".."&&n.length&&n[n.length-1]!==".."?n.pop():n.push(s))}),n.join("/")}function xy(i){const e=i.lastIndexOf("/"),t=e===-1?0:e+1,n=i.indexOf(".",t),s=n===-1?i.length:n;return i.slice(0,s)}const Sy=/^lib\.w[eg]sl$/i;class Cn{astCache=new Map;sources;packageName;debugWeslRoot;constructor(e,t={}){const{packageName:n="package",debugWeslRoot:s}=t;this.sources=e,this.packageName=n,this.debugWeslRoot=Ku(s)}resolveModule(e){const t=this.astCache.get(e);if(t)return t;const n=this.findSource(e);if(n===void 0)return;const s=this.modulePathToDebugPath(e),r=ur({modulePath:e,debugFilePath:s,src:n});return this.astCache.set(e,r),r}findSource(e){if(this.sources[e]!==void 0)return this.sources[e];const t=this.moduleToFilePath(e);if(t!==void 0)return _o(this.sources,t)}moduleToFilePath(e){return $u(e,this.packageName)}modulePathToDebugPath(e){const t=this.moduleToFilePath(e)??e;return this.debugWeslRoot+t+".wesl"}allModules(){for(const e of Object.keys(this.sources)){const t=this.packageName!=="package",n=Tl(e,this.packageName,t);this.resolveModule(n)}return this.astCache.entries()}}class vn{resolvers;constructor(e){this.resolvers=e}resolveModule(e){for(const t of this.resolvers){const n=t.resolveModule(e);if(n)return n}}}class Il{astCache=new Map;sources;packageName;debugWeslRoot;constructor(e,t){this.sources=e.modules,this.packageName=e.name,this.debugWeslRoot=Ku(t)}resolveModule(e){const t=this.packageName+"::";if(e!==this.packageName&&!e.startsWith(t))return;const n=this.astCache.get(e);if(n)return n;const s=this.findSource(e);if(!s)return;const r=this.modulePathToDebugPath(e),o=ur({modulePath:e,debugFilePath:r,src:s});return this.astCache.set(e,o),o}findSource(e){const t=this.moduleToFilePath(e);if(e===this.packageName){const n=_o(this.sources,"lib",["wesl","wgsl"]);if(n)return n}return _o(this.sources,t)}moduleToFilePath(e){return $u(e,this.packageName)??e}modulePathToDebugPath(e){const t=this.moduleToFilePath(e);return this.debugWeslRoot+this.packageName+"/"+t+".wesl"}}function Tl(i,e,t){if(i.includes("::"))return i;if(t&&Sy.test(i))return e;const s=xy(vy(i)).replaceAll("/","::");return e+"::"+s}function _o(i,e,t=["wesl","wgsl"]){const n=["","./"];for(const s of n){const r=s+e;if(i[r]!==void 0)return i[r];for(const o of t){const l=`${r}.${o}`;if(i[l]!==void 0)return i[l]}}}class Rl{entries;dest;constructor(e,t=[]){this.dest=e,this.entries=t}addEntries(e){this.entries.push(...e)}mapPositions(...e){return e.map(t=>this.destToSrc(t))}compact(){if(!this.entries.length)return;let e=this.entries[0];const t=[e];for(let n=1;n<this.entries.length;n++){const s=this.entries[n];s.src.path===e.src.path&&s.src.text===e.src.text&&e.destEnd===s.destStart&&e.srcEnd===s.srcStart&&e.srcEnd-e.srcStart===e.destEnd-e.destStart?(e.destEnd=s.destEnd,e.srcEnd=s.srcEnd):(t.push(s),e=s)}this.entries=t}sort(){this.entries.sort((e,t)=>e.destStart-t.destStart)}merge(e){if(e===this)return this;const t=e.entries.filter(o=>o.src.path===this.dest.path&&o.src.text===this.dest.text);if(t.length===0)return console.log("other source map does not link to this one"),e;Qy(t);const n=t.map(o=>{const{src:l,position:a}=this.destToSrc(o.srcStart),{src:h,position:c}=this.destToSrc(o.srcEnd);if(h!==l)throw new Error("NYI, need to split");return{src:l,srcStart:a,srcEnd:c,destStart:o.destStart,destEnd:o.destEnd}}),s=e.entries.filter(o=>o.src.path!==this.dest.path||o.src.text!==this.dest.text),r=new Rl(e.dest,[...s,...n]);return r.sort(),r}destToSrc(e){const t=this.entries.find(n=>n.destStart<=e&&n.destEnd>=e);return t?{src:t.src,position:t.srcStart+e-t.destStart}:{src:this.dest,position:e}}}function Qy(i){i.sort((e,t)=>e.srcStart-t.srcStart)}class pr{#i=[];#e=0;#t=[];source;constructor(e){this.source=e}add(e,t,n){const s=this.#e;this.#e+=e.length;const r=this.#e;this.#i.push(e),this.#t.push({src:this.source,srcStart:t,srcEnd:n,destStart:s,destEnd:r})}appendNext(e){const t=this.#t.at(-1)?.destEnd??0;this.add(e,t,t+e.length)}addSynthetic(e,t,n,s){const r=this.#e;this.#e+=e.length;const o=this.#e;this.#i.push(e),this.#t.push({src:{text:t},srcStart:n,srcEnd:s,destStart:r,destEnd:o})}addNl(){const e=this.#t.at(-1)??{srcStart:0,srcEnd:0},{srcStart:t,srcEnd:n}=e;this.add(`
99
+ `,t,n)}addCopy(e,t){const n=this.source.text.slice(e,t);this.add(n,e,t)}static build(e){const t=new Rl({text:e.map(n=>n.#i.join("")).join("")},e.flatMap(n=>n.#t));return t.compact(),t}}async function Ey(i){return new ky(By(i))}function By(i){const{weslSrc:e,libs:t=[],packageName:n,debugWeslRoot:s}=i,{resolver:r}=i,o=[];if(r)o.push(r);else if(e)o.push(new Cn(e,{packageName:n,debugWeslRoot:s}));else throw new Error("Either resolver or weslSrc must be provided");if(t.length>0){const a=Py(t,s);o.push(...a)}const l=o.length===1?o[0]:new vn(o);return Dy({...i,resolver:l})}function Py(i,e){return My(i).map(n=>new Il(n,e))}function My(i){const e=[],t=new Set;function n(s){t.has(s)||(t.add(s),e.push(s),s.dependencies?.forEach(n))}return i.forEach(n),e}function Dy(i){const e=Iy(i),{transformedAst:t,newDecls:n,newStatements:s}=e;return pr.build($y(t.moduleElem,t.srcModule,n,s,i.conditions))}function Iy(i){const{resolver:e,mangler:t,constants:n,config:s}=i,{rootModuleName:r="main",conditions:o={}}=i,l=Ty(r),a=Ry(e,l,r),h=Ly(i.virtualLibs,n),f=Od({rootAst:a,resolver:e,conditions:o,virtuals:h,mangler:t}),{globalNames:u,decls:d,newStatements:p}=f;return{transformedAst:Ny(a,u,s),newDecls:d,newStatements:p}}function Ty(i){return i.includes("::")?i:i.includes("/")||i.endsWith(".wesl")||i.endsWith(".wgsl")?"package::"+i.replace(/\.(wesl|wgsl)$/,"").replace(/^\.\//,"").replaceAll("/","::"):"package::"+i}function Ry(i,e,t){const n=i.resolveModule(e);if(!n)throw console.log(`root module not found: ${e} (from ${t})`),new Error(`Root module not found: ${t}`);return n}function Ly(i,e){let t=i;return e&&(t={...t,constants:()=>Object.entries(e).map(([s,r])=>`const ${s} = ${r};`).join(`
100
+ `)}),t&&vO(t,n=>({fn:n}))}function Ny(i,e,t){const{moduleElem:n,srcModule:s}=i,r={moduleElem:n,srcModule:s,globalNames:e,notableElems:{}},o=t?.plugins??[];return Cu(o,h=>h.transform).reduce((h,c)=>c(h),r)}function $y(i,e,t,n,s={}){const r=n.map(a=>Fy(a,s)),o=new pr({text:e.src,path:e.debugFilePath});vl({srcBuilder:o,rootElems:[i],conditions:s,extracting:!1});const l=t.map(a=>Ky(a,s));return[...r,o,...l]}function Fy(i,e){const{elem:t,srcModule:n}=i,{src:s,debugFilePath:r}=n,o=new pr({text:s,path:r});return vl({srcBuilder:o,rootElems:[t],conditions:e}),o.addNl(),o}function Ky(i,e){const{src:t,debugFilePath:n}=i.srcModule,s=new pr({text:t,path:n});return vl({srcBuilder:s,rootElems:[i.declElem],conditions:e,skipConditionalFiltering:!0}),s}fr(md);fr(dd);fr(pd);async function zy(i,e){if(!i)throw new Error("No GPU adapter");return i.requestDevice(e).then(_y)}function _y(i){const e=[];i.injectError=(n,s)=>{const r=e.findLast(o=>o.filter===n);r!==void 0?r.errors.push(s):s.then(o=>{o!==null&&t(o)})};function t(n){i.addEventListener("uncapturederror",s=>{if(!s.defaultPrevented)if("compilationInfo"in s.error){const r=s.error;if(r.compilationInfo)for(const o of r.compilationInfo.messages)Su({url:o.module.url,text:o.module.text??null,lineNumber:o.lineNum,lineColumn:o.linePos,length:o.length,error:new Error(o.type+": "+o.message)});else console.error(s.error.message)}else console.error(s.error.message)},{once:!0}),i.dispatchEvent(new GPUUncapturedErrorEvent("uncapturederror",{error:n}))}return i.pushErrorScope=(n=>function(s){return e.push({filter:s,errors:[]}),n.call(this,s)})(i.pushErrorScope),i.popErrorScope=(n=>function(){const s=e.pop();if(s===void 0)throw new DOMException("popErrorScope called on empty error scope stack","OperationError");return s.errors.push(n.call(this)),Promise.all(s.errors).then(o=>o.find(l=>l!==null)??null)})(i.popErrorScope),i}const Vy=1,Wy=2,Hy=3,qy=4,Gy=new lO(i=>{i.next===62&&i.peek(1)===62&&i.acceptToken(Vy,1)},{extend:!0}),Uy=new Set(gd),Yy=new Set(ud);function Hh(i,e){if(i!=="<")return-1;const t=e.p.input.string.slice(e.pos);return new fd(t).nextTemplateStartToken()!==null?Wy:-1}function qh(i){return Uy.has(i)?Hy:Yy.has(i)?qy:-1}const Xy={__proto__:null,true:326,false:326,uniform:332,storage:334,private:336,workgroup:338,function:340,read:342,write:344,read_write:346,if:348,elif:352,else:354,import:356,package:358,super:360,diagnostic:370,enable:372,requires:376,fn:380,return:384,switch:386,case:388,default:392,loop:394,continuing:396,for:398,var:400,let:402,const:404,while:406,break:408,continue:410,discard:412,struct:414,override:418,alias:420,const_assert:422},jy=Ks.deserialize({version:14,states:"!.lQ]QPOOO!WQPO'#CeOOQO'#Cd'#CdOOQO'#Fc'#FcO!fQPO'#G[OOQO'#Dt'#DtO#^QPO'#FqOOQO'#D}'#D}O#iQPO'#D|OOQO'#EP'#EPO#nQPO'#EOOOQO'#ER'#ERO#nQPO'#EQOOQO'#G['#G[OOQO'#ET'#ETOOQO'#Em'#EmOOQO'#Eo'#EoO#sQPO'#ESOOQO'#FW'#FWO#{QPO'#FVO$TQPO'#FZOOQO'#F]'#F]O$`QPO'#F[OOQO'#F_'#F_O$hQPO'#F^OOQO'#Fa'#FaO$pQPO'#F`OOQO'#Ga'#GaOOQO'#Fb'#FbQ]QPOOOOQS'#Cg'#CgO%eQPO,59PO'zQPO,5:XO(PQPO,5:^OOQO,5:_,5:_OOQO-E9a-E9aO#^QPO,5<]OOQO,5<v,5<vO(UQPO,5:nO(^QPO,5;qO(fQPO,5;uO(qQPO,5;vO(yQPO,5;xO$pQPO,5;zOOQO'#Dv'#DvOOQO'#Dw'#DwO)RQQO'#DuO)^QQO,5<]O#nQPO,5:hO)fQPO'#G_O)nQPO,5:jO)sQPO,5:lO)xQPO,5:nO)}QPO,5;qO*SQTO'#CzO+TQPO,5;uO+`QPO,5;uO+hQPO,5;vO+sQPO,5;xOOQS'#Cn'#CnOOQO'#Cl'#ClO+xQQO'#FtO.nQQO'#DQO.uQPO'#DPOOQO'#Ft'#FtO$pQPO'#FtO$pQPO'#DSO0_QQO,5;zOOQO'#Ck'#CkOOQO-E9`-E9`O0fQPO'#CjOOQO1G.k1G.kO0mQPO1G/sO0mQPO1G/xO0{QQO1G1wO)xQPO1G0YO)}QPO1G1]O1TQPO1G1aO1`QPO1G1aO1hQPO1G1bO1sQPO1G1dO1xQQO1G1fO2PQPO'#FfO2[QQO,5:aOOQO1G1w1G1wO#nQPO1G1wO2gQPO1G0SO2lQPO,5<yO2tQPO,5<yOOQO1G0U1G0UOOQO1G0W1G0WO2|QPO'#EUO3[QPO1G0YO3dQPO'#FXOOQO1G1]1G1]OOQS'#Cr'#CrOOQS'#Cs'#CsOOQS'#Ct'#CtOOQS'#Cu'#CuOOQS'#Cv'#CvOOQS'#Cw'#CwOOQS'#Cx'#CxOOQS'#Cy'#CyOOQS'#Fw'#FwO3oQTO,59fOOQS'#Cq'#CqO3wQTO'#CqO4VQTO'#FvOOQO1G1a1G1aO$pQPO1G1aO4bQPO1G1aOOQO1G1b1G1bO$pQPO1G1bO4bQPO1G1bO4bQPO1G1dO*SQTO'#CpO4mQPO,59ZO4rQPO,59lO4zQQO,5<`O5RQQO,59nO0fQPO'#DOO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tO$pQPO,59tOOQO,5:T,5:TO$pQPO,5:TO7tQPO,5:TOOQO1G1f1G1fO7|QQO'#FsO8WQPO,59UOOQO'#GR'#GRO0mQPO'#GRO0mQPO'#DoO8]QPO7+%_OOQO'#Dn'#DnO8hQPO7+%dOOQO7+'c7+'cO#nQPO7+'cO8sQPO7+%tOOQO7+&w7+&wOOQO7+&{7+&{O$pQPO7+&{O4bQPO7+&{O8{QPO7+&{OOQO7+&|7+&|O$pQPO7+&|O4bQPO7+&|O4bQPO7+'OOOQO7+'Q7+'QO9WQPO'#GXOOQO,5<Q,5<QOOQO-E9d-E9dO9`QPO7+'cO#nQPO7+%nOOQO,5<T,5<TO9eQPO1G2eOOQO-E9g-E9gO9mQPO'#EVO9xQPO'#EVO:TQPO'#GcO:]QPO,5:pO:bQPO'#EZOOQO7+%t7+%tO;hQPO7+%tO;vQPO'#FYO<RQPO'#FYO<WQPO'#GtO<`QPO,5;sOOQS1G/Q1G/QOOQS,59],59]O=`QTO,5<bO=jQTO,5<bO=uQQO7+&{O>eQPO'#DQO>lQPO'#EXO=|QPO'#EXO>qQPO7+&{O>yQQO7+&|O?QQPO7+&|O?YQPO7+'OO?_QTO,59[OOQO1G.u1G.uO?gQQO1G/WOOQO1G1z1G1zOB]QPO,59jOEQQQO1G/`OEXQQO1G/`OHOQQO1G/`OHVQQO1G/`OJyQQO1G/`OKTQQO1G/`OMzQQO1G/`ONUQQO1G/`O!!xQQO1G/`O!#VQQO1G/`O!#dQQO1G/oOOQO1G/o1G/oO!#kQPO,5<_O!#rQPO,5<_OOQO1G.p1G.pO!#zQPO,5<mOOQO,5:Z,5:ZO0mQPO,5:[O0mQPO,5:]OOQO<<Hy<<HyOOQO<<IO<<IOO!$VQPO<<J}OOQO<<I`<<I`O;hQPO<<I`O!$[QQO<<JgO!$cQPO<<JgOOQO<<Jg<<JgO$pQPO<<JgO4bQPO<<JgO!$kQQO<<JhO!$rQPO<<JhO!$zQPO<<JjO!%PQQO'#DyO!%_QPO'#GYO!%gQPO,5<sOOQO<<J}<<J}O!%lQPO<<IYP#nQPO'#FiO!%tQPO,5:qO4bQPO,5:qO!&PQPO,5<}O!&_QPO,5<}OOQO1G0[1G0[O!&gQQO'#FUO!'gQPO'#E[OOQO'#E]'#E]OOQO'#E_'#E_O$pQPO'#E^OOQO'#Eb'#EbO$pQPO'#EaOOQO'#Eg'#EgO!(jQPO'#EfOOQO'#Ek'#EkOOQO'#En'#EnO!(rQPO'#ElO!(}QPO'#ElO!)VQPO'#EjOOQO'#FQ'#FQO$pQPO'#FPOOQO'#FR'#FROOQO'#FS'#FSOOQO'#FT'#FTOOQO'#E['#E[O!)[QPO'#E[O!)cQPO'#E[OOQO'#Fk'#FkO!)hQPO,5:uOOQO,5:u,5:uO;hQPO<<I`O!*nQPO<<I`O!*sQPO,5;tO4bQPO,5;tO!*xQPO,5=`O!+WQPO,5=`OOQO1G1_1G1_OOQS,5<O,5<OO!+`QTO1G1|OOQS-E9b-E9bOOQO,5:s,5:sO!+jQPO,59lOOQO<<Jh<<JhO$pQPO<<JhOOQO<<Jj<<JjOOQO1G.v1G.vOOQO1G/U1G/UOOQO7+%Z7+%ZO!+rQQO,5<PO!,SQPO1G1yOOQO-E9c-E9cOOQO1G2X1G2XOOQO1G/v1G/vO!,ZQPO1G/wOOQOAN@iAN@iO;hQPOAN>zO!*nQPOAN>zOOQOAN@RAN@RO$pQPOAN@RO!,fQQOAN@RO!,mQPOAN@ROOQOAN@SAN@SO$pQPOAN@SOOQOAN@UAN@UO!,uQPO'#FgO!,}QQO,5:eO#nQPO,5:eO!-]QPO,5<tO!-eQPO,5<tOOQO1G2_1G2_O!-mQPOAN>tO#nQPOAN>tO4bQPO1G0]OOQO1G0]1G0]OOQO,5<U,5<UO!-rQPO1G2iOOQO-E9h-E9hOOQO'#Er'#ErOOQO,5;p,5;pO$pQPO,5;pO!.QQPO,5;pOOQO,5:v,5:vO!.VQPO,5:vO!.^QPO,5:vO!.cQQO,5:xO!.jQQO,5:{O!(jQPO,5;QO!.tQPO'#EhOOQO,5;Q,5;QO!/}QPO,5;WO!0YQPO,5;WO!0bQPO,5;UO!.cQQO,5;kO!0rQQO,5:vOOQO-E9i-E9iOOQO1G0a1G0aOOQOAN>zAN>zO4bQPO1G1`OOQO1G1`1G1`OOQO,5<X,5<XO!0yQPO1G2zOOQO-E9k-E9kP<eQPO'#FdO!1XQPO1G/WO!1sQQOAN@SP$pQPO'#FeO!*nQPOG24fOOQOG24fG24fO!1zQQOG25mOOQOG25mG25mO$pQPOG25mO!2RQQOG25nOOQO,5<R,5<ROOQO-E9e-E9eO#nQPO1G0POOQO1G0P1G0POOQO,5<S,5<SO!2YQPO1G2`OOQO-E9f-E9fOOQOG24`G24`O!2bQPOG24`OOQO7+%w7+%wP!2gQPO'#FjO!2rQQO1G1[OOQO1G1[1G1[O!2yQQO1G0bOOQO1G0b1G0bO!3QQPO1G0dO!4}QPO1G0gO!5VQPO1G0gOOQO1G0l1G0lOOQO'#Ei'#EiOOQO,5;S,5;SO!5bQPO,5;SO!5jQPO,5;SO$pQPO1G0rO4bQPO1G0rO!6sQPO1G0rO!7OQQO1G0pO!7VQPO1G0pO!7^QPO1G0pOOQO1G1V1G1VOOQO7+&z7+&zP3dQPO'#FmOOQO7+%y7+%yOOQOG25nG25nOOQOLD*QLD*QOOQOLD+XLD+XO!7cQQOLD+XOOQOLD+YLD+YOOQO7+%k7+%kP#nQPO'#FhO!7jQPOLD)zOOQO7+&v7+&vOOQO7+%|7+%|OOQO'#E`'#E`O!7oQPO7+&OO!5VQPO7+&RO!5VQPO'#EcOOQO'#Ed'#EdOOQO'#Ee'#EeO$pQPO'#EcO!7wQPO'#EcOOQO'#Fl'#FlO!8PQPO7+&RO!5bQPO1G0nO!8_QPO1G0nOOQO1G0n1G0nO!5bQPO1G0nO!8dQQO7+&^O!8kQPO7+&^O$pQPO7+&^O4bQPO7+&^O!8sQPO7+&[O!8zQQO7+&[O!9RQPO7+&[OOQO!$'Ns!$'NsOOQO!$'Mf!$'MfOOQO<<Ij<<IjO!9YQPO<<ImO$pQPO,5:}O!9hQPO,5:}O!9pQQO'#GgOOQO,5:},5:}O!*nQPO,5:}OOQO-E9j-E9jOOQO<<Im<<ImO!9}QPO7+&YOOQO7+&Y7+&YO!5bQPO7+&YO$pQPO<<IxO!:SQQO<<IxO!:ZQPO<<IxO!:cQQO<<IvO!:jQPO<<IvO!:qQQO'#EqO!*nQPO<<IvO!;qQPO<<IvOOQOAN?XAN?XO!;vQPO1G0iOOQO1G0i1G0iO!*nQPO1G0iO!<OQPO,5=RO!<YQPO,5=ROOQO<<It<<ItO!<eQPO<<ItO!<jQQOAN?dO$pQPOAN?dO!<qQPOAN?bO!*nQPOAN?bO!<xQPOAN?bO$pQPO,5;]OOQO,5;],5;]OOQOAN?bAN?bOOQO7+&T7+&TO!*nQPO7+&TO!<}QPO1G2mOOQOAN?`AN?`O!=XQQOG25OO!*nQPOG24|O!=`QPOG24|OOQOG24|G24|O!=eQQO1G0wOOQO<<Io<<IoOOQOLD*hLD*hO!*nQPOLD*hOOQO!$'NS!$'NS",stateData:"!>g~O$dOSTOSUOS~OYPO!okO$xTO%PVO%QXO%SZO%U^O%`_O%b`O%gbO%ieO%jgO%kiO~O$fnO$tpO$vqO$wrO~OYPO$xTO%PVO%QXO%SZO%U^O%`_O%b`O%gbO%ieO%jgO%kiO~O$fnO$y|O$z}O~O]!QO~O$fnO~OS!UO$fnO~OS!VO$fnO~OS!XOo!WO$fnO~OS!ZO$fnO~OS![O$fnO~OR!_OS!`O]!cOa!^Ow!dOx!dOy!dOz!dO{!dO$fnO$i!]O~O]!hOYXa$xXa%PXa%QXa%SXa%UXa%`Xa%bXa%gXa%iXa%jXa%kXaSXa$fXaRXaaXawXaxXayXazXa{Xa!lXa!oXa$iXa$tXa%WXa%XXa%]Xa%_Xa%aXa%cXa%dXa%eXa%fXa%YXa%[Xa~O]!jO~O]!kO~OS!mO$fnO~OS!nO$fnO~OS!oOo!WO$fnO~OS!qO$fnO~OS!rO$fnO~Ou!tO!o!iX$}!iX~O!o!vO$}!wO~Oq!yO!o%RX~O!o!{O~O!o!|O~O]!}O~O!l#PO~OR#^OS#^Oa#]O$fnO$i!]O$l#RO$m#SO$n#TO$o#UO$p#VO$q#WO$r#XO$s#YOP$jPp$jP~O!o#`O!z#bO#d#aO~OS!oO$fnO~O!o#cO!z#eO#d#dO~O#d#fO~OQ#gO]$hXo$hXw$hXz$hX{$hX}$hX!O$hX!P$hX!Q$hX!R$hX!S$hX!T$hX!U$hX!V$hX!W$hX!X$hX!Y$hX!Z$hX![$hX!^$hX!`$hX!o$hX[$hXq$hX!_$hX#d$hX#g$hX#h$hX#i$hX#j$hX#k$hX#l$hX#m$hX#n$hX#o$hX#p$hX#q$hX#r$hX!l$hXY$hX!z$hX~OutX~P+xOu#iO~O]#lOo#sOw#uOz#qO{#vO}#mO!O#nO!P#oO!Q#pO!R#rO!S#rO!T#sO!U#sO!V#sO!W#tO!X#tO!Y#uO!Z#vO![#vO!^#xO!`#yO~O!o#zO~P.zO[$gP~P$pO]$OOx$PO$fnO$i!]O~O!o$TO$}$UO~O!o$XO!z$ZO#d$YO~OS$[O$fnO~O!o$]O!z$_O#d$^O~O#d$`O~O!o$aO~P.zO!l$bO$fnO$z}O~Ou!tO!o!ia$}!ia~Oq$fO~O$fnO!o%Ra~Oq$hO!o%Ra~OS$kOYPO$fnO[%VP~O!l$nO!|$pO~OS$rOYPO$fnO~OP$uOp$uO~Oo!WOPeXpeXqeX~Oq$wOP$jXp$jX~OR$|OS$zO$fnO~O]#lO~OS%TO$fnO~O[%UO~P.zO]#lO!^#xO!`#yOovawvazva{va}va!Ova!Pva!Qva!Rva!Sva!Tva!Uva!Vva!Wva!Xva!Yva!Zva![va!ova[vaqva!_va#dva#gva#hva#iva#jva#kva#lva#mva#nva#ova#pva#qva#rva!lvaYva!zva~OS%cO$fnO~Oq%dO[$gX~P.zO[%fO~O[%kO}%jO!O%iO~O[%lO}%jO!O%iO~O!l$nO!|%oO~O!o%rO!z%tO#d%sO~O$fnO!n$|P~O!o%{O~O$fnO!o%Ri~OS&OOYPO$fnO~O!z&PO[!yXq!yX~Oq&QO[%VX~O[&SO~OYPO!l$nO!n&mO!o&hO$t&WO%W&VO%X&YO%]&[O%_&^O%`_O%a&_O%b`O%c&cO%d&eO%e&fO%f&gO~P$pOR$|OS$zOYPO$fnO~OS&pOYPO$fnO~O!z&qO~Oq&rO!n%hX~O!n&tO~OR#^OS#^Oa#]O$fnO$i!]O$l#RO$m#SO$n#TO$o#UO$p#VO$q#WO$r#XO$s#YO~OP$jap$ja~P<eOq&vOP$jap$ja~O!o%rO~P.zOo!WO!o!{X#d!{X!l!{X[!{Xq!{X!n!{X~OutX~P=|Ou&yO~O!o%rO#d%sO~O!o&zO~P.zO!o&zO#d&{O~O!o&|O~OP&}Op&}O~O]siosiutiwsizsi{si}si!Osi!Psi!Qsi!Rsi!Ssi!Tsi!Usi!Vsi!Wsi!Xsi!Ysi!Zsi![si!^si!`si!osi[siqsi!_si#dsi#gsi#hsi#isi#jsi#ksi#lsi#msi#nsi#osi#psi#qsi#rsi!lsiYsi!zsi~O['OO~O]#lOo#sOw#uOz#qO{#vO!P#oO!Q#pO!R#rO!S#rO!T#sO!U#sO!V#sO!W#tO!X#tO!Y#uO!Z#vO![#vO!^#xO!`#yO}|i!o|i[|iq|i!_|i#d|i#g|i#h|i#i|i#j|i#k|i#l|i#m|i#n|i#o|i#p|i#q|i#r|i!l|iY|i!z|i~O!O#nO~PBbO!O|i~PBbO]#lOo#sOw#uOz#qO{#vO!R#rO!S#rO!T#sO!U#sO!V#sO!W#tO!X#tO!Y#uO!Z#vO![#vO!^#xO!`#yO}|i!O|i!P|i!o|i[|iq|i!_|i#d|i#g|i#h|i#i|i#j|i#k|i#l|i#m|i#n|i#o|i#p|i#q|i#r|i!l|iY|i!z|i~O!Q#pO~PE`O!Q|i~PE`O]#lOo#sOw#uO{#vO!T#sO!U#sO!V#sO!W#tO!X#tO!Y#uO!Z#vO![#vO!^#xO!`#yOz|i}|i!O|i!P|i!Q|i!o|i[|iq|i!_|i#d|i#g|i#h|i#i|i#j|i#k|i#l|i#m|i#n|i#o|i#p|i#q|i#r|i!l|iY|i!z|i~O!R#rO!S#rO~PH^O!R|i!S|i~PH^O]#lOw#uO{#vO!Y#uO!Z#vO![#vO!^#xO!`#yOo|iz|i}|i!O|i!P|i!Q|i!R|i!S|i!T|i!U|i!V|i!o|i[|iq|i!_|i#d|i#g|i#h|i#i|i#j|i#k|i#l|i#m|i#n|i#o|i#p|i#q|i#r|i!l|iY|i!z|i~O!W#tO!X#tO~PK_O!W|i!X|i~PK_O]#lO!^#xO!`#yOo|iw|iz|i}|i!O|i!P|i!Q|i!R|i!S|i!T|i!U|i!V|i!W|i!X|i!Y|i!o|i[|iq|i!_|i#d|i#g|i#h|i#i|i#j|i#k|i#l|i#m|i#n|i#o|i#p|i#q|i#r|i!l|iY|i!z|i~O{#vO!Z#vO![#vO~PN`O{|i!Z|i![|i~PN`O!_'PO~P.zO[$ga~P$pOq'RO[$ga~O['TO}%jO!O%iO~O!o'WO~O!o'ZO~P.zO!o'ZO#d'[O~O!o'_O~P.zO!o'_O#d'`O~O!o'aO~Ou'bO$}'dOq!mX!n!mX~Oq'eO!n$|X~O!n'gO~O['hO!`'iO~O!z'jO[!yaq!ya~OS$kOYPO$fnO[%Va~Oq'mO[%Va~O!o'pO#d'oO#g'oO#h'oO#i'oO#j'oO#k'oO#l'oO#m'oO#n'oO#o'oO#p'oO#q'rO#r'rO~P.zOYPO!l$nO!o'sO$t&WO%W&VO%X&YO%]&[O%_&^O%`_O%a&_O%b`O%c&cO%d&eO%e&fO%f&gO~P$pOYPO!l'yO~OS'{Oo!WO$fnO~OS'{O$fnO~O]'}O~O!o'sO~P$pO!o'sO~OYPO!l$nO!n(RO!o&hO$t&WO%W&VO%X&YO%]&[O%_&^O%`_O%a&_O%b`O%c&cO%d&eO%e&fO%f&gO~P$pO!l$nO~O!z(TO~OS$rOYPO$fnO!n%ha~Oq(WO!n%ha~OP$jip$ji~P<eOS(ZO$fnO~O[$Xaq$Xa!l$Xa!z$Xa~P.zO[$gi~P$pO!O%iO[!ei}!ei~O!o(aO~P.zO!o(aO#d(bO~O!l$bO$fnO~Ou'bO$}(fOq!ma!n!ma~O$fnO!n$|a~Oq(iO!n$|a~O!o(kO~OS$kOYPO$fnO[%Vi~O!o(pO~O!o(rO~P$pO!o(rO~O!l$nO~P.zOYPO!l(uO~P.zOYPO!l$nO!n(xO!o&hO$t&WO%W&VO%X&YO%]&[O%^(wO%_&^O%`_O%a&_O%b`O%c&cO%d&eO%e&fO%f&gO~P$pO!z(|O#d({O!o#`a~OS(}O$fnO~O!o)PO%`_O%a&_O%b`O~P$pO!o(rO~P.zOS$rOYPO$fnO!n%hi~Oo!WOuti!o!{i#d!{i!l!{i[!{iq!{i!n!{i~O!o)VO~P.zO!o)XO~P.zO!o)ZO~P.zO$fnO!n$|i~O[)^O~OS$kOYPO$fnO~O!o)_O~P.zO!o)`O~P.zO$w)aOR#QiS#QiY#Qi]#Qia#Qiw#Qix#Qiy#Qiz#Qi{#Qi!l#Qi!n#Qi!o#Qi$f#Qi$i#Qi$t#Qi%W#Qi%X#Qi%]#Qi%_#Qi%`#Qi%a#Qi%b#Qi%c#Qi%d#Qi%e#Qi%f#Qi%^#Qi~OYPO!l)cO~OYPO%Y)eO%[)fO~OYPO!l$nO~OYPO!l$nO!n)mO!o&hO$t&WO%W&VO%X&YO%]&[O%^(wO%_&^O%`_O%a&_O%b`O%c&cO%d&eO%e&fO%f&gO~P$pO!z)rO#d)qO!o#`i~O!o)sO~P.zO!o)uO~P$pO!o)sO~O!o)vO~P.zO!o)wO~O!l$nO$t&WO~O!l$nO!z*OO~OYPO!n*QO%Y)eO%[)fO~O!n*SO~O!o#`q~P.zO#d*UO!o#`q~O!o*YO~P$pO!o*YO~P.zO[*[O~P$pOYPO!n*^O%Y)eO%[)fO~O!l$nO!z*aO~Oq*bO!l%ZX!z%ZX~P.zO!n*dO~O!o#`y~P.zO#d*gO!o#`y~O!o*hO~P.zO[*iO~P$pO#d'oO#g'oO#h'oO#i'oO#j'oO#k'oO#l'oO#m'oO#n'oO#o'oO#p'oO#q*lO#r*lO[#eX~P.zO[*iO~O!l$nO!z*oO~O!l%Za!z%Za~P$pOq*pO!l%Za!z%Za~O!n*qO~O!o#`!R~P.zO[*sO~P$pO[*sO~O!l%Zi!z%Zi~P$pO!o#`!Z~P.zO[*yO~O[#ei~P.zOTUu!z#n!Q#k![#j#i{!Z#q#g!S!Y!R#dx}#m!P!O#lza#p!X!V!U#o!W!To!|#r#h$f!`w~",goto:"D[%iPPPPPPPP%j&aP'WPP+p+s.vP0R.v1m1q1z1z1z1z1z1z1z1z2RPPP2f.v3hP5WPPPPP5WPPPPPPPPPPPPPP5WPPP&a6c6u6u6u&a&a6}7U7[7`P7gPP7o7v7o7{7o8Q8V8Z8b8hP8pP9s;[;b;k;w<P<S<]<d<j<s<S<|=T=Z<S=a=h=t>T>]P>l>uPPPPPPPPPPPP<S>{?S?S?S<S8V?]?d?j8V8V?r8V?y8V@Q@X@_AlArA|BSBYB`BfBlBvCQPPPCWPC[5WPCbChPPPPPPPPP6uPPPPPCoCuPCWPPCxPCWPDOPPPDRPPPPPPPPPPPPDX!iROSm!}#P$j$n$p$q%o&Q&U&]&l&n&r'X'm'w'x'y(W(n(t(u(y(z)T)c)d)j)k)n)y*T!iQOSm!}#P$j$n$p$q%o&Q&U&]&l&n&r'X'm'w'x'y(W(n(t(u(y(z)T)c)d)j)k)n)y*TQoPS!OUtS!RY[Q!UaQ!VcQ!XdQ!ZfQ![h#b!`j{!c!d!h#a#d#l#m#n#o#p#q#r#s#t#u#v#x$Y$^$n%d%s&U&X&Z&d&i&l&{'R'['`'q't'y'}(](b(z({)P)g)q)s)u)z*U*Y*b*g*h*k*pQ!mvQ!nwS!ox!YQ!qyQ!rzQ!x!QY#^!W#g$w&v(Y[#}!j!k$O$P%i%jQ$[!pQ$c!tQ$e!wU$g!y$h%}W$k!}&Q'm(nW$r#P&r(W)Tr$z#b#e#f$Z$_$`$p%o%t&P&n&q'X'j(T(|)rQ%T#iQ%c#yQ%m$UW%x$b'e(i)]Q%|$fQ&O$jQ&p$qS'{&`&aQ(Z&yQ(d'bQ(g'dQ(l'iQ(}'|R)[(fR!ioQ!ejQ!s{Q#j!cQ#k!dS#{!h#lQ$y#aQ%O#dQ%W#mQ%X#nQ%Y#oQ%Z#pQ%[#qQ%]#rQ%^#sQ%_#tQ%`#uQ%a#vQ%b#xQ%p$YQ%u$^Y&T$n&U&l'y(zY'Q%d'R(]*b*pQ']%sQ'v&XQ'w&ZQ(O&dQ(P&iQ([&{Q(`'[Q(c'`Q(o'qQ(q'tQ)O'}Q)Y(bQ)o({Q)t)PS)|)g)zQ*V)qQ*X)sU*Z)u*Y*hQ*f*UQ*r*gR*v*k#c!bj{!c!d!h#a#d#l#m#n#o#p#q#r#s#t#u#v#x$Y$^$n%d%s&U&X&Z&d&i&l&{'R'['`'q't'y'}(](b(z({)P)g)q)s)u)z*U*Y*b*g*h*k*p#b!^j{!c!d!h#a#d#l#m#n#o#p#q#r#s#t#u#v#x$Y$^$n%d%s&U&X&Z&d&i&l&{'R'['`'q't'y'}(](b(z({)P)g)q)s)u)z*U*Y*b*g*h*k*pY#]!W#g$w&v(Y]#}!j!k$O$P%i%jT#h!_!`S#_!W#gV&u$w&v(YZ#Z!W#g$w&v(YQ!YdQ!pxQ$v#^S&x$z$|Q'|&`R)U(Z!x#w!e!s#j#k#{$y%O%W%X%Y%Z%[%]%^%_%`%a%b%p%u&T'Q']'v'w(O(P([(`(c(o(q)O)Y)o)t)|*V*X*Z*f*r*vR%S#h#b!aj{!c!d!h#a#d#l#m#n#o#p#q#r#s#t#u#v#x$Y$^$n%d%s&U&X&Z&d&i&l&{'R'['`'q't'y'}(](b(z({)P)g)q)s)u)z*U*Y*b*g*h*k*ps${#b#e#f$Z$_$`$p%o%t&P&n&q'X'j(T(|)r#c!fj{!c!d!h#a#d#l#m#n#o#p#q#r#s#t#u#v#x$Y$^$n%d%s&U&X&Z&d&i&l&{'R'['`'q't'y'}(](b(z({)P)g)q)s)u)z*U*Y*b*g*h*k*pQ$Q!jQ$S!kQ%g$OQ%h$PQ'U%iR'V%j]$R!j!k$O$P%i%jSUOmRtSQ!PUR!ltT!OUtS!OUtR$c!tQ%y$bV(h'e(i)]S]OmRuSVWOSmVYOSmV[OSmTkOmSaOmRvSQ#O!UR$V!mQ$l!}V'l&Q'm(nQ$}#bQ%P#eQ%Q#fQ%q$ZQ%v$_Q%w$`Q&o$pS'Y%o&nQ'^%tQ'k&PQ(U&qQ(^'XQ(m'jQ)S(TQ)p(|R*W)rQ$o#OQ%n$VW&h$n&l'y(zQ's&UQ(S&oQ(_'YQ(s'vQ)R(OQ)W(^Q)l(yQ)x)bQ)})hS*R)k)nS*`){*OQ*e*TQ*m*[S*n*_*aQ*u*iQ*w*oQ*x*sR*z*yX&k$n&l'y(zW&i$n&l'y(zR't&UW&h$n&l'y(zQ's&UR)x)b]&X$n&U&l'y(z)bR)b(sW&h$n&l'y(zR's&UZ&Z$n&U&l'y(zX)i(u)c)j)yW)g(u)c)j)yR)z)dW)h(u)c)j)yR){)dZ&]$n&U&l'y(zQ'z&]R(v'xQ(y'yR)n(zZ&b$n&U&l'y(zW&j$n&l'y(zQ'u&UR)Q'}SdOmQxS]&`$n&U&l'y'}(z]&a$n&U&l'y'}(zSfOmQyS]&a$n&U&l'y'}(zQ*])uQ*j*YR*t*hQ'q&TR*k*ZZ&d$n&U&l'y(zW&j$n&l'y(zR'u&UScOmRwSQ#Q!VR$W!nQ$s#PV(V&r(W)TSfOmRySShOmRzSSjOmR{SQmOR!gmSSOmfsS$j$q&U&n'X'x(t)d)k*TW$j!}&Q'm(nW$q#P&r(W)TW&U$n&l'y(zQ&n$pQ'X%oQ'x&]Q(t'wW)d(u)c)j)yQ)k(yR*T)nQ$x#_R&w$xQ%e#{S'S%e*cR*c)|Q!u!OR$d!uQ'c%xR(e'cQ'f%yR(j'fQ!z!RR$i!zQ&R$lR'n&RQ&l$nS(Q&l(zR(z'yQ)j(uQ)y)cT*P)j)yQ&s$sR(X&sTlOmQ#|!hR%V#lQ#[!WR%R#gZ#]!W#g$w&v(YQ$c!tR(d'bR%z$bQ!SYR!T[R$m!}Q){)gR*_)zR$t#P",nodeNames:"⚠ > < BuiltinType BuiltinFn LineComment BlockComment Module Attribute StandardAttribute @ Identifier ) ( AttrArgs Expression Literal Number Boolean CallExpression CallTemplateArgs TypeOrExpr Kw Kw Kw Kw Kw Kw Kw Kw TemplateArgs < > , ArgList PathExpression PathBase :: UnaryExpression - ! ~ & * BinaryExpression || && | ^ == != <= > >= << >> + / % PostfixExpression [ ] . IfAttribute ConditionExpr ConditionNot ConditionAnd ConditionOr ElifAttribute ElseAttribute Import ImportPath Kw Kw { ImportItem } ; DiagnosticDirective Kw EnableDirective Kw RequiresDirective Kw FunctionDeclaration Kw ParamList Param : Type -> Block Statement Kw IfStatement Kw Kw SwitchStatement Kw SwitchClause Kw Kw LoopStatement Kw LoopBlock Kw ForStatement Kw VarStatement Kw Kw Kw = UpdatingExpr AssignOp += -= *= /= %= &= |= ^= <<= >>= ++ -- WhileStatement Kw Kw Kw Kw ExpressionStatement StructDeclaration Kw StructBody StructMember GlobalVariableDeclaration GlobalValueDeclaration Kw TypeAliasDeclaration Kw ConstAssert Kw",maxTerm:211,nodeProps:[["openedBy",12,"(",76,"{"],["closedBy",13,")",74,"}"]],skippedNodes:[0,5,6],repeatNodeCount:12,tokenData:"1a~RxX^#opq#oqr$duv$qvw%Oxy%eyz%jz{%o{|%||}&c}!O&h!O!P'V!P!Q(j!Q!R*g!R![+[![!],q!]!^-O!^!_-T!_!`-r!`!a.P!b!c.p!c!}.u!}#O/W#P#Q/]#Q#R/b#R#S.u#T#U/o#U#o.u#o#p0k#p#q0p#q#r1V#r#s1[#y#z#o$f$g#o#BY#BZ#o$IS$I_#o$I|$JO#o$JT$JU#o$KV$KW#o&FU&FV#o~#tY$d~X^#opq#o#y#z#o$f$g#o#BY#BZ#o$IS$I_#o$I|$JO#o$JT$JU#o$KV$KW#o&FU&FV#o~$iPx~!_!`$l~$qO!S~~$vP![~!_!`$y~%OO#k~~%TQz~vw%Z!_!`%`~%`O!O~~%eO#l~~%jO]~~%oO[~~%tP{~!_!`%w~%|O#i~~&RQ!Y~{|&X!_!`&^~&^O#q~~&cO#g~~&hOq~~&mRw~}!O&v!_!`&{!`!a'Q~&{O#r~~'QO#h~~'VO!|~~'[P!`~!Q!['_~'dTa~!Q!['_!g!h's#X#Y's#Y#Z(e#[#](e~'vR{|(P}!O(P!Q![(V~(SP!Q![(V~([Ra~!Q![(V#Y#Z(e#[#](e~(jOa~~(oR!Z~z{(x!P!Q)y!_!`*b~({TOz(xz{)[{;'S(x;'S;=`)s<%lO(x~)_TO!P(x!P!Q)n!Q;'S(x;'S;=`)s<%lO(x~)sOU~~)vP;=`<%l(x~*OST~OY)yZ;'S)y;'S;=`*[<%lO)y~*_P;=`<%l)y~*gO#j~~*lYa~!O!P'_!Q![+[!g!h's!z!{+y#X#Y's#Y#Z(e#[#](e#]#^(e#i#j(e#l#m+y~+aWa~!O!P'_!Q![+[!g!h's#X#Y's#Y#Z(e#[#](e#]#^(e#i#j(e~+|R!Q![,V!c!i,V#T#Z,V~,[Va~!Q![,V!c!i,V#T#Y,V#Y#Z,V#[#](e#]#^(e#i#j(e~,vP!z~![!],y~-OOu~~-TO!o~~-YQo~!^!_-`!_!`-m~-eP!W~!_!`-h~-mO#o~~-rO!T~~-wP#d~!_!`-z~.PO!R~R.WQpP!UQ!_!`.^!`!a.cQ.cO!VQQ.hP!XQ!_!`.kQ.pO#pQ~.uOY~P.zS$fP!Q![.u!c!}.u#R#S.u#T#o.u~/]O!^~~/bO!_~~/gP!Q~!_!`/j~/oO#n~R/tU$fP!Q![.u!c!}.u#R#S.u#T#g.u#g#h0W#h#o.uR0_S$}Q$fP!Q![.u!c!}.u#R#S.u#T#o.u~0pO!l~~0uQ!P~!_!`0{#p#q1Q~1QO#m~~1VO}~~1[O!n~~1aOy~",tokenizers:[0,1,Gy],topRules:{Module:[0,7]},specialized:[{term:31,get:(i,e)=>Hh(i,e)<<1|1,external:Hh,extend:!0},{term:160,get:(i,e)=>qh(i)<<1,external:qh},{term:160,get:i=>Xy[i]||-1}],tokenPrec:3432}),Jy=Is.define({name:"wesl",parser:jy.configure({props:[sO]}),languageData:{commentTokens:{line:"//",block:{open:"/*",close:"*/"}}}});function Zy(){return new e0(Jy)}function ek(i){return J0(async()=>tk(i),{delay:300})}async function tk(i){const e=i.getLibs?.()??[],t=new Set(i.ignorePackages?.()??[]),{diagnostics:n,externals:s}=Gh(i,e,t);if(!i.fetchLibs||!s.length)return n;const r=await i.fetchLibs(s);return r.length?Gh(i,[...e,...r],t).diagnostics:n}function Gh(i,e,t){const n=i.getSources(),s=i.rootModule(),r=[];let o=[];try{const l=ik(n,e,i.packageName?.()),a=l.resolveModule(s);if(a){const h=nk(i,l,a);r.push(...sk(h,s,t)),o=ok(a,h,l,t,e)}}catch(l){const a=rk(l);a&&r.push(a)}return r.push(...i.getExternalDiagnostics?.()??[]),{diagnostics:r,externals:o}}function ik(i,e,t){const n=new Cn(i,{packageName:t});if(e.length===0)return n;const s=[n,...e.map(r=>new Il(r))];return new vn(s)}function nk(i,e,t){return Od({resolver:e,rootAst:t,conditions:i.conditions?.(),accumulateUnbound:!0})}function sk(i,e,t){const n=[];for(const s of i.unbound??[])s.srcModule.modulePath===e&&(s.path.length>1&&t.has(s.path[0])||n.push(lk(s)));return n}function rk(i){if(i instanceof _s){const[e,t]=i.span;return{from:e,to:t,severity:"error",message:i.cause?.message??i.message}}}function ok(i,e,t,n,s){const r=new Set(s.map(l=>l.name)),o=[];for(const l of i.imports){const a=l.segments[0]?.name;if(!a||!Uh(a)||n.has(a))continue;const h=l.segments.map(c=>c.name).join("::");t.resolveModule(h)||o.push(a)}for(const l of e.unbound??[]){const a=l.path[0];l.path.length>1&&Uh(a)&&!n.has(a)&&!r.has(a)&&o.push(a)}return[...new Set(o)]}function Uh(i){return i!=="package"&&i!=="super"}function lk(i){return{from:i.start,to:i.end,severity:"error",message:`unresolved identifier '${i.path.join("::")}'`}}const ak=i=>{let{state:e}=i,t=e.doc.lineAt(e.selection.main.from),n=Nl(i.state,t.from);return n.line?hk(i):n.block?fk(i):!1};function Ll(i,e){return({state:t,dispatch:n})=>{if(t.readOnly)return!1;let s=i(e,t);return s?(n(t.update(s)),!0):!1}}const hk=Ll(pk,0),ck=Ll(vd,0),fk=Ll((i,e)=>vd(i,e,dk(e)),0);function Nl(i,e){let t=i.languageDataAt("commentTokens",e,1);return t.length?t[0]:{}}const Xi=50;function uk(i,{open:e,close:t},n,s){let r=i.sliceDoc(n-Xi,n),o=i.sliceDoc(s,s+Xi),l=/\s*$/.exec(r)[0].length,a=/^\s*/.exec(o)[0].length,h=r.length-l;if(r.slice(h-e.length,h)==e&&o.slice(a,a+t.length)==t)return{open:{pos:n-l,margin:l&&1},close:{pos:s+a,margin:a&&1}};let c,f;s-n<=2*Xi?c=f=i.sliceDoc(n,s):(c=i.sliceDoc(n,n+Xi),f=i.sliceDoc(s-Xi,s));let u=/^\s*/.exec(c)[0].length,d=/\s*$/.exec(f)[0].length,p=f.length-d-t.length;return c.slice(u,u+e.length)==e&&f.slice(p,p+t.length)==t?{open:{pos:n+u+e.length,margin:/\s/.test(c.charAt(u+e.length))?1:0},close:{pos:s-d-t.length,margin:/\s/.test(f.charAt(p-1))?1:0}}:null}function dk(i){let e=[];for(let t of i.selection.ranges){let n=i.doc.lineAt(t.from),s=t.to<=n.to?n:i.doc.lineAt(t.to);s.from>n.from&&s.from==t.to&&(s=t.to==n.to+1?n:i.doc.lineAt(t.to-1));let r=e.length-1;r>=0&&e[r].to>n.from?e[r].to=s.to:e.push({from:n.from+/^\s*/.exec(n.text)[0].length,to:s.to})}return e}function vd(i,e,t=e.selection.ranges){let n=t.map(r=>Nl(e,r.from).block);if(!n.every(r=>r))return null;let s=t.map((r,o)=>uk(e,n[o],r.from,r.to));if(i!=2&&!s.every(r=>r))return{changes:e.changes(t.map((r,o)=>s[o]?[]:[{from:r.from,insert:n[o].open+" "},{from:r.to,insert:" "+n[o].close}]))};if(i!=1&&s.some(r=>r)){let r=[];for(let o=0,l;o<s.length;o++)if(l=s[o]){let a=n[o],{open:h,close:c}=l;r.push({from:h.pos-a.open.length,to:h.pos+h.margin},{from:c.pos-c.margin,to:c.pos+a.close.length})}return{changes:r}}return null}function pk(i,e,t=e.selection.ranges){let n=[],s=-1;for(let{from:r,to:o}of t){let l=n.length,a=1e9,h=Nl(e,r).line;if(h){for(let c=r;c<=o;){let f=e.doc.lineAt(c);if(f.from>s&&(r==o||o>f.from)){s=f.from;let u=/^\s*/.exec(f.text)[0].length,d=u==f.length,p=f.text.slice(u,u+h.length)==h?u:-1;u<f.text.length&&u<a&&(a=u),n.push({line:f,comment:p,token:h,indent:u,empty:d,single:!1})}c=f.to+1}if(a<1e9)for(let c=l;c<n.length;c++)n[c].indent<n[c].line.text.length&&(n[c].indent=a);n.length==l+1&&(n[l].single=!0)}}if(i!=2&&n.some(r=>r.comment<0&&(!r.empty||r.single))){let r=[];for(let{line:l,token:a,indent:h,empty:c,single:f}of n)(f||!c)&&r.push({from:l.from+h,insert:a+" "});let o=e.changes(r);return{changes:o,selection:e.selection.map(o,1)}}else if(i!=1&&n.some(r=>r.comment>=0)){let r=[];for(let{line:o,comment:l,token:a}of n)if(l>=0){let h=o.from+l,c=h+a.length;o.text[c-o.from]==" "&&c++,r.push({from:h,to:c})}return{changes:r}}return null}const Vo=Pt.define(),mk=Pt.define(),gk=B.define(),xd=B.define({combine(i){return yt(i,{minDepth:100,newGroupDelay:500,joinToEvent:(e,t)=>t},{minDepth:Math.max,newGroupDelay:Math.min,joinToEvent:(e,t)=>(n,s)=>e(n,s)||t(n,s)})}}),Sd=ge.define({create(){return At.empty},update(i,e){let t=e.state.facet(xd),n=e.annotation(Vo);if(n){let a=Me.fromTransaction(e,n.selection),h=n.side,c=h==0?i.undone:i.done;return a?c=Vs(c,c.length,t.minDepth,a):c=Bd(c,e.startState.selection),new At(h==0?n.rest:c,h==0?c:n.rest)}let s=e.annotation(mk);if((s=="full"||s=="before")&&(i=i.isolate()),e.annotation(ae.addToHistory)===!1)return e.changes.empty?i:i.addMapping(e.changes.desc);let r=Me.fromTransaction(e),o=e.annotation(ae.time),l=e.annotation(ae.userEvent);return r?i=i.addChanges(r,o,l,t,e):e.selection&&(i=i.addSelection(e.startState.selection,o,l,t.newGroupDelay)),(s=="full"||s=="after")&&(i=i.isolate()),i},toJSON(i){return{done:i.done.map(e=>e.toJSON()),undone:i.undone.map(e=>e.toJSON())}},fromJSON(i){return new At(i.done.map(Me.fromJSON),i.undone.map(Me.fromJSON))}});function Ak(i={}){return[Sd,xd.of(i),Q.domEventHandlers({beforeinput(e,t){let n=e.inputType=="historyUndo"?Qd:e.inputType=="historyRedo"?Wo:null;return n?(e.preventDefault(),n(t)):!1}})]}function mr(i,e){return function({state:t,dispatch:n}){if(!e&&t.readOnly)return!1;let s=t.field(Sd,!1);if(!s)return!1;let r=s.pop(i,t,e);return r?(n(r),!0):!1}}const Qd=mr(0,!1),Wo=mr(1,!1),Ok=mr(0,!0),bk=mr(1,!0);class Me{constructor(e,t,n,s,r){this.changes=e,this.effects=t,this.mapped=n,this.startSelection=s,this.selectionsAfter=r}setSelAfter(e){return new Me(this.changes,this.effects,this.mapped,this.startSelection,e)}toJSON(){var e,t,n;return{changes:(e=this.changes)===null||e===void 0?void 0:e.toJSON(),mapped:(t=this.mapped)===null||t===void 0?void 0:t.toJSON(),startSelection:(n=this.startSelection)===null||n===void 0?void 0:n.toJSON(),selectionsAfter:this.selectionsAfter.map(s=>s.toJSON())}}static fromJSON(e){return new Me(e.changes&&le.fromJSON(e.changes),[],e.mapped&&Ot.fromJSON(e.mapped),e.startSelection&&b.fromJSON(e.startSelection),e.selectionsAfter.map(b.fromJSON))}static fromTransaction(e,t){let n=_e;for(let s of e.startState.facet(gk)){let r=s(e);r.length&&(n=n.concat(r))}return!n.length&&e.changes.empty?null:new Me(e.changes.invert(e.startState.doc),n,void 0,t||e.startState.selection,_e)}static selection(e){return new Me(void 0,_e,void 0,void 0,e)}}function Vs(i,e,t,n){let s=e+1>t+20?e-t-1:0,r=i.slice(s,e);return r.push(n),r}function wk(i,e){let t=[],n=!1;return i.iterChangedRanges((s,r)=>t.push(s,r)),e.iterChangedRanges((s,r,o,l)=>{for(let a=0;a<t.length;){let h=t[a++],c=t[a++];l>=h&&o<=c&&(n=!0)}}),n}function yk(i,e){return i.ranges.length==e.ranges.length&&i.ranges.filter((t,n)=>t.empty!=e.ranges[n].empty).length===0}function Ed(i,e){return i.length?e.length?i.concat(e):i:e}const _e=[],kk=200;function Bd(i,e){if(i.length){let t=i[i.length-1],n=t.selectionsAfter.slice(Math.max(0,t.selectionsAfter.length-kk));return n.length&&n[n.length-1].eq(e)?i:(n.push(e),Vs(i,i.length-1,1e9,t.setSelAfter(n)))}else return[Me.selection([e])]}function Ck(i){let e=i[i.length-1],t=i.slice();return t[i.length-1]=e.setSelAfter(e.selectionsAfter.slice(0,e.selectionsAfter.length-1)),t}function zr(i,e){if(!i.length)return i;let t=i.length,n=_e;for(;t;){let s=vk(i[t-1],e,n);if(s.changes&&!s.changes.empty||s.effects.length){let r=i.slice(0,t);return r[t-1]=s,r}else e=s.mapped,t--,n=s.selectionsAfter}return n.length?[Me.selection(n)]:_e}function vk(i,e,t){let n=Ed(i.selectionsAfter.length?i.selectionsAfter.map(l=>l.map(e)):_e,t);if(!i.changes)return Me.selection(n);let s=i.changes.map(e),r=e.mapDesc(i.changes,!0),o=i.mapped?i.mapped.composeDesc(r):r;return new Me(s,R.mapEffects(i.effects,e),o,i.startSelection.map(r),n)}const xk=/^(input\.type|delete)($|\.)/;class At{constructor(e,t,n=0,s=void 0){this.done=e,this.undone=t,this.prevTime=n,this.prevUserEvent=s}isolate(){return this.prevTime?new At(this.done,this.undone):this}addChanges(e,t,n,s,r){let o=this.done,l=o[o.length-1];return l&&l.changes&&!l.changes.empty&&e.changes&&(!n||xk.test(n))&&(!l.selectionsAfter.length&&t-this.prevTime<s.newGroupDelay&&s.joinToEvent(r,wk(l.changes,e.changes))||n=="input.type.compose")?o=Vs(o,o.length-1,s.minDepth,new Me(e.changes.compose(l.changes),Ed(R.mapEffects(e.effects,l.changes),l.effects),l.mapped,l.startSelection,_e)):o=Vs(o,o.length,s.minDepth,e),new At(o,_e,t,n)}addSelection(e,t,n,s){let r=this.done.length?this.done[this.done.length-1].selectionsAfter:_e;return r.length>0&&t-this.prevTime<s&&n==this.prevUserEvent&&n&&/^select($|\.)/.test(n)&&yk(r[r.length-1],e)?this:new At(Bd(this.done,e),this.undone,t,n)}addMapping(e){return new At(zr(this.done,e),zr(this.undone,e),this.prevTime,this.prevUserEvent)}pop(e,t,n){let s=e==0?this.done:this.undone;if(s.length==0)return null;let r=s[s.length-1],o=r.selectionsAfter[0]||t.selection;if(n&&r.selectionsAfter.length)return t.update({selection:r.selectionsAfter[r.selectionsAfter.length-1],annotations:Vo.of({side:e,rest:Ck(s),selection:o}),userEvent:e==0?"select.undo":"select.redo",scrollIntoView:!0});if(r.changes){let l=s.length==1?_e:s.slice(0,s.length-1);return r.mapped&&(l=zr(l,r.mapped)),t.update({changes:r.changes,selection:r.startSelection,effects:r.effects,annotations:Vo.of({side:e,rest:l,selection:o}),filter:!1,userEvent:e==0?"undo":"redo",scrollIntoView:!0})}else return null}}At.empty=new At(_e,_e);const Sk=[{key:"Mod-z",run:Qd,preventDefault:!0},{key:"Mod-y",mac:"Mod-Shift-z",run:Wo,preventDefault:!0},{linux:"Ctrl-Shift-z",run:Wo,preventDefault:!0},{key:"Mod-u",run:Ok,preventDefault:!0},{key:"Alt-u",mac:"Mod-Shift-u",run:bk,preventDefault:!0}];function Vi(i,e){return b.create(i.ranges.map(e),i.mainIndex)}function Ct(i,e){return i.update({selection:e,scrollIntoView:!0,userEvent:"select"})}function rt({state:i,dispatch:e},t){let n=Vi(i.selection,t);return n.eq(i.selection,!0)?!1:(e(Ct(i,n)),!0)}function gr(i,e){return b.cursor(e?i.to:i.from)}function Pd(i,e){return rt(i,t=>t.empty?i.moveByChar(t,e):gr(t,e))}function ke(i){return i.textDirectionAt(i.state.selection.main.head)==Z.LTR}const Md=i=>Pd(i,!ke(i)),Dd=i=>Pd(i,ke(i));function Id(i,e){return rt(i,t=>t.empty?i.moveByGroup(t,e):gr(t,e))}const Qk=i=>Id(i,!ke(i)),Ek=i=>Id(i,ke(i));function Bk(i,e,t){if(e.type.prop(t))return!0;let n=e.to-e.from;return n&&(n>2||/[^\s,.;:]/.test(i.sliceDoc(e.from,e.to)))||e.firstChild}function Ar(i,e,t){let n=we(i).resolveInner(e.head),s=t?N.closedBy:N.openedBy;for(let a=e.head;;){let h=t?n.childAfter(a):n.childBefore(a);if(!h)break;Bk(i,h,s)?n=h:a=t?h.to:h.from}let r=n.type.prop(s),o,l;return r&&(o=t?mt(i,n.from,1):mt(i,n.to,-1))&&o.matched?l=t?o.end.to:o.end.from:l=t?n.to:n.from,b.cursor(l,t?-1:1)}const Pk=i=>rt(i,e=>Ar(i.state,e,!ke(i))),Mk=i=>rt(i,e=>Ar(i.state,e,ke(i)));function Td(i,e){return rt(i,t=>{if(!t.empty)return gr(t,e);let n=i.moveVertically(t,e);return n.head!=t.head?n:i.moveToLineBoundary(t,e)})}const Rd=i=>Td(i,!1),Ld=i=>Td(i,!0);function Nd(i){let e=i.scrollDOM.clientHeight<i.scrollDOM.scrollHeight-2,t=0,n=0,s;if(e){for(let r of i.state.facet(Q.scrollMargins)){let o=r(i);o?.top&&(t=Math.max(o?.top,t)),o?.bottom&&(n=Math.max(o?.bottom,n))}s=i.scrollDOM.clientHeight-t-n}else s=(i.dom.ownerDocument.defaultView||window).innerHeight;return{marginTop:t,marginBottom:n,selfScroll:e,height:Math.max(i.defaultLineHeight,s-5)}}function $d(i,e){let t=Nd(i),{state:n}=i,s=Vi(n.selection,o=>o.empty?i.moveVertically(o,e,t.height):gr(o,e));if(s.eq(n.selection))return!1;let r;if(t.selfScroll){let o=i.coordsAtPos(n.selection.main.head),l=i.scrollDOM.getBoundingClientRect(),a=l.top+t.marginTop,h=l.bottom-t.marginBottom;o&&o.top>a&&o.bottom<h&&(r=Q.scrollIntoView(s.main.head,{y:"start",yMargin:o.top-a}))}return i.dispatch(Ct(n,s),{effects:r}),!0}const Yh=i=>$d(i,!1),Ho=i=>$d(i,!0);function Xt(i,e,t){let n=i.lineBlockAt(e.head),s=i.moveToLineBoundary(e,t);if(s.head==e.head&&s.head!=(t?n.to:n.from)&&(s=i.moveToLineBoundary(e,t,!1)),!t&&s.head==n.from&&n.length){let r=/^\s*/.exec(i.state.sliceDoc(n.from,Math.min(n.from+100,n.to)))[0].length;r&&e.head!=n.from+r&&(s=b.cursor(n.from+r))}return s}const Dk=i=>rt(i,e=>Xt(i,e,!0)),Ik=i=>rt(i,e=>Xt(i,e,!1)),Tk=i=>rt(i,e=>Xt(i,e,!ke(i))),Rk=i=>rt(i,e=>Xt(i,e,ke(i))),Lk=i=>rt(i,e=>b.cursor(i.lineBlockAt(e.head).from,1)),Nk=i=>rt(i,e=>b.cursor(i.lineBlockAt(e.head).to,-1));function $k(i,e,t){let n=!1,s=Vi(i.selection,r=>{let o=mt(i,r.head,-1)||mt(i,r.head,1)||r.head>0&&mt(i,r.head-1,1)||r.head<i.doc.length&&mt(i,r.head+1,-1);if(!o||!o.end)return r;n=!0;let l=o.start.from==r.head?o.end.to:o.end.from;return b.cursor(l)});return n?(e(Ct(i,s)),!0):!1}const Fk=({state:i,dispatch:e})=>$k(i,e);function Xe(i,e){let t=Vi(i.state.selection,n=>{let s=e(n);return b.range(n.anchor,s.head,s.goalColumn,s.bidiLevel||void 0)});return t.eq(i.state.selection)?!1:(i.dispatch(Ct(i.state,t)),!0)}function Fd(i,e){return Xe(i,t=>i.moveByChar(t,e))}const Kd=i=>Fd(i,!ke(i)),zd=i=>Fd(i,ke(i));function _d(i,e){return Xe(i,t=>i.moveByGroup(t,e))}const Kk=i=>_d(i,!ke(i)),zk=i=>_d(i,ke(i)),_k=i=>Xe(i,e=>Ar(i.state,e,!ke(i))),Vk=i=>Xe(i,e=>Ar(i.state,e,ke(i)));function Vd(i,e){return Xe(i,t=>i.moveVertically(t,e))}const Wd=i=>Vd(i,!1),Hd=i=>Vd(i,!0);function qd(i,e){return Xe(i,t=>i.moveVertically(t,e,Nd(i).height))}const Xh=i=>qd(i,!1),jh=i=>qd(i,!0),Wk=i=>Xe(i,e=>Xt(i,e,!0)),Hk=i=>Xe(i,e=>Xt(i,e,!1)),qk=i=>Xe(i,e=>Xt(i,e,!ke(i))),Gk=i=>Xe(i,e=>Xt(i,e,ke(i))),Uk=i=>Xe(i,e=>b.cursor(i.lineBlockAt(e.head).from)),Yk=i=>Xe(i,e=>b.cursor(i.lineBlockAt(e.head).to)),Jh=({state:i,dispatch:e})=>(e(Ct(i,{anchor:0})),!0),Zh=({state:i,dispatch:e})=>(e(Ct(i,{anchor:i.doc.length})),!0),ec=({state:i,dispatch:e})=>(e(Ct(i,{anchor:i.selection.main.anchor,head:0})),!0),tc=({state:i,dispatch:e})=>(e(Ct(i,{anchor:i.selection.main.anchor,head:i.doc.length})),!0),Xk=({state:i,dispatch:e})=>(e(i.update({selection:{anchor:0,head:i.doc.length},userEvent:"select"})),!0),jk=({state:i,dispatch:e})=>{let t=Or(i).map(({from:n,to:s})=>b.range(n,Math.min(s+1,i.doc.length)));return e(i.update({selection:b.create(t),userEvent:"select"})),!0},Jk=({state:i,dispatch:e})=>{let t=Vi(i.selection,n=>{let s=we(i),r=s.resolveStack(n.from,1);if(n.empty){let o=s.resolveStack(n.from,-1);o.node.from>=r.node.from&&o.node.to<=r.node.to&&(r=o)}for(let o=r;o;o=o.next){let{node:l}=o;if((l.from<n.from&&l.to>=n.to||l.to>n.to&&l.from<=n.from)&&o.next)return b.range(l.to,l.from)}return n});return t.eq(i.selection)?!1:(e(Ct(i,t)),!0)},Zk=({state:i,dispatch:e})=>{let t=i.selection,n=null;return t.ranges.length>1?n=b.create([t.main]):t.main.empty||(n=b.create([b.cursor(t.main.head)])),n?(e(Ct(i,n)),!0):!1};function In(i,e){if(i.state.readOnly)return!1;let t="delete.selection",{state:n}=i,s=n.changeByRange(r=>{let{from:o,to:l}=r;if(o==l){let a=e(r);a<o?(t="delete.backward",a=is(i,a,!1)):a>o&&(t="delete.forward",a=is(i,a,!0)),o=Math.min(o,a),l=Math.max(l,a)}else o=is(i,o,!1),l=is(i,l,!0);return o==l?{range:r}:{changes:{from:o,to:l},range:b.cursor(o,o<r.head?-1:1)}});return s.changes.empty?!1:(i.dispatch(n.update(s,{scrollIntoView:!0,userEvent:t,effects:t=="delete.selection"?Q.announce.of(n.phrase("Selection deleted")):void 0})),!0)}function is(i,e,t){if(i instanceof Q)for(let n of i.state.facet(Q.atomicRanges).map(s=>s(i)))n.between(e,e,(s,r)=>{s<e&&r>e&&(e=t?r:s)});return e}const Gd=(i,e,t)=>In(i,n=>{let s=n.from,{state:r}=i,o=r.doc.lineAt(s),l,a;if(t&&!e&&s>o.from&&s<o.from+200&&!/[^ \t]/.test(l=o.text.slice(0,s-o.from))){if(l[l.length-1]==" ")return s-1;let h=$i(l,r.tabSize),c=h%Rs(r)||Rs(r);for(let f=0;f<c&&l[l.length-1-f]==" ";f++)s--;a=s}else a=me(o.text,s-o.from,e,e)+o.from,a==s&&o.number!=(e?r.doc.lines:1)?a+=e?1:-1:!e&&/[\ufe00-\ufe0f]/.test(o.text.slice(a-o.from,s-o.from))&&(a=me(o.text,a-o.from,!1,!1)+o.from);return a}),qo=i=>Gd(i,!1,!0),Ud=i=>Gd(i,!0,!1),Yd=(i,e)=>In(i,t=>{let n=t.head,{state:s}=i,r=s.doc.lineAt(n),o=s.charCategorizer(n);for(let l=null;;){if(n==(e?r.to:r.from)){n==t.head&&r.number!=(e?s.doc.lines:1)&&(n+=e?1:-1);break}let a=me(r.text,n-r.from,e)+r.from,h=r.text.slice(Math.min(n,a)-r.from,Math.max(n,a)-r.from),c=o(h);if(l!=null&&c!=l)break;(h!=" "||n!=t.head)&&(l=c),n=a}return n}),Xd=i=>Yd(i,!1),e1=i=>Yd(i,!0),t1=i=>In(i,e=>{let t=i.lineBlockAt(e.head).to;return e.head<t?t:Math.min(i.state.doc.length,e.head+1)}),i1=i=>In(i,e=>{let t=i.moveToLineBoundary(e,!1).head;return e.head>t?t:Math.max(0,e.head-1)}),n1=i=>In(i,e=>{let t=i.moveToLineBoundary(e,!0).head;return e.head<t?t:Math.min(i.state.doc.length,e.head+1)}),s1=({state:i,dispatch:e})=>{if(i.readOnly)return!1;let t=i.changeByRange(n=>({changes:{from:n.from,to:n.to,insert:$.of(["",""])},range:b.cursor(n.from)}));return e(i.update(t,{scrollIntoView:!0,userEvent:"input"})),!0},r1=({state:i,dispatch:e})=>{if(i.readOnly)return!1;let t=i.changeByRange(n=>{if(!n.empty||n.from==0||n.from==i.doc.length)return{range:n};let s=n.from,r=i.doc.lineAt(s),o=s==r.from?s-1:me(r.text,s-r.from,!1)+r.from,l=s==r.to?s+1:me(r.text,s-r.from,!0)+r.from;return{changes:{from:o,to:l,insert:i.doc.slice(s,l).append(i.doc.slice(o,s))},range:b.cursor(l)}});return t.changes.empty?!1:(e(i.update(t,{scrollIntoView:!0,userEvent:"move.character"})),!0)};function Or(i){let e=[],t=-1;for(let n of i.selection.ranges){let s=i.doc.lineAt(n.from),r=i.doc.lineAt(n.to);if(!n.empty&&n.to==r.from&&(r=i.doc.lineAt(n.to-1)),t>=s.number){let o=e[e.length-1];o.to=r.to,o.ranges.push(n)}else e.push({from:s.from,to:r.to,ranges:[n]});t=r.number+1}return e}function jd(i,e,t){if(i.readOnly)return!1;let n=[],s=[];for(let r of Or(i)){if(t?r.to==i.doc.length:r.from==0)continue;let o=i.doc.lineAt(t?r.to+1:r.from-1),l=o.length+1;if(t){n.push({from:r.to,to:o.to},{from:r.from,insert:o.text+i.lineBreak});for(let a of r.ranges)s.push(b.range(Math.min(i.doc.length,a.anchor+l),Math.min(i.doc.length,a.head+l)))}else{n.push({from:o.from,to:r.from},{from:r.to,insert:i.lineBreak+o.text});for(let a of r.ranges)s.push(b.range(a.anchor-l,a.head-l))}}return n.length?(e(i.update({changes:n,scrollIntoView:!0,selection:b.create(s,i.selection.mainIndex),userEvent:"move.line"})),!0):!1}const o1=({state:i,dispatch:e})=>jd(i,e,!1),l1=({state:i,dispatch:e})=>jd(i,e,!0);function Jd(i,e,t){if(i.readOnly)return!1;let n=[];for(let s of Or(i))t?n.push({from:s.from,insert:i.doc.slice(s.from,s.to)+i.lineBreak}):n.push({from:s.to,insert:i.lineBreak+i.doc.slice(s.from,s.to)});return e(i.update({changes:n,scrollIntoView:!0,userEvent:"input.copyline"})),!0}const a1=({state:i,dispatch:e})=>Jd(i,e,!1),h1=({state:i,dispatch:e})=>Jd(i,e,!0),c1=i=>{if(i.state.readOnly)return!1;let{state:e}=i,t=e.changes(Or(e).map(({from:s,to:r})=>(s>0?s--:r<e.doc.length&&r++,{from:s,to:r}))),n=Vi(e.selection,s=>{let r;if(i.lineWrapping){let o=i.lineBlockAt(s.head),l=i.coordsAtPos(s.head,s.assoc||1);l&&(r=o.bottom+i.documentTop-l.bottom+i.defaultLineHeight/2)}return i.moveVertically(s,!0,r)}).map(t);return i.dispatch({changes:t,selection:n,scrollIntoView:!0,userEvent:"delete.line"}),!0};function f1(i,e){if(/\(\)|\[\]|\{\}/.test(i.sliceDoc(e-1,e+1)))return{from:e,to:e};let t=we(i).resolveInner(e),n=t.childBefore(e),s=t.childAfter(e),r;return n&&s&&n.to<=e&&s.from>=e&&(r=n.type.prop(N.closedBy))&&r.indexOf(s.name)>-1&&i.doc.lineAt(n.to).from==i.doc.lineAt(s.from).from&&!/\S/.test(i.sliceDoc(n.to,s.from))?{from:n.to,to:s.from}:null}const ic=Zd(!1),u1=Zd(!0);function Zd(i){return({state:e,dispatch:t})=>{if(e.readOnly)return!1;let n=e.changeByRange(s=>{let{from:r,to:o}=s,l=e.doc.lineAt(r),a=!i&&r==o&&f1(e,r);i&&(r=o=(o<=l.to?l:e.doc.lineAt(o)).to);let h=new tr(e,{simulateBreak:r,simulateDoubleBreak:!!a}),c=Ol(h,r);for(c==null&&(c=$i(/^\s*/.exec(e.doc.lineAt(r).text)[0],e.tabSize));o<l.to&&/\s/.test(l.text[o-l.from]);)o++;a?{from:r,to:o}=a:r>l.from&&r<l.from+100&&!/\S/.test(l.text.slice(0,r))&&(r=l.from);let f=["",wn(e,c)];return a&&f.push(wn(e,h.lineIndent(l.from,-1))),{changes:{from:r,to:o,insert:$.of(f)},range:b.cursor(r+1+f[1].length)}});return t(e.update(n,{scrollIntoView:!0,userEvent:"input"})),!0}}function $l(i,e){let t=-1;return i.changeByRange(n=>{let s=[];for(let o=n.from;o<=n.to;){let l=i.doc.lineAt(o);l.number>t&&(n.empty||n.to>l.from)&&(e(l,s,n),t=l.number),o=l.to+1}let r=i.changes(s);return{changes:s,range:b.range(r.mapPos(n.anchor,1),r.mapPos(n.head,1))}})}const d1=({state:i,dispatch:e})=>{if(i.readOnly)return!1;let t=Object.create(null),n=new tr(i,{overrideIndentation:r=>{let o=t[r];return o??-1}}),s=$l(i,(r,o,l)=>{let a=Ol(n,r.from);if(a==null)return;/\S/.test(r.text)||(a=0);let h=/^\s*/.exec(r.text)[0],c=wn(i,a);(h!=c||l.from<r.from+h.length)&&(t[r.from]=a,o.push({from:r.from,to:r.from+h.length,insert:c}))});return s.changes.empty||e(i.update(s,{userEvent:"indent"})),!0},p1=({state:i,dispatch:e})=>i.readOnly?!1:(e(i.update($l(i,(t,n)=>{n.push({from:t.from,insert:i.facet(Al)})}),{userEvent:"input.indent"})),!0),m1=({state:i,dispatch:e})=>i.readOnly?!1:(e(i.update($l(i,(t,n)=>{let s=/^\s*/.exec(t.text)[0];if(!s)return;let r=$i(s,i.tabSize),o=0,l=wn(i,Math.max(0,r-Rs(i)));for(;o<s.length&&o<l.length&&s.charCodeAt(o)==l.charCodeAt(o);)o++;n.push({from:t.from+o,to:t.from+s.length,insert:l.slice(o)})}),{userEvent:"delete.dedent"})),!0),g1=i=>(i.setTabFocusMode(),!0),A1=[{key:"Ctrl-b",run:Md,shift:Kd,preventDefault:!0},{key:"Ctrl-f",run:Dd,shift:zd},{key:"Ctrl-p",run:Rd,shift:Wd},{key:"Ctrl-n",run:Ld,shift:Hd},{key:"Ctrl-a",run:Lk,shift:Uk},{key:"Ctrl-e",run:Nk,shift:Yk},{key:"Ctrl-d",run:Ud},{key:"Ctrl-h",run:qo},{key:"Ctrl-k",run:t1},{key:"Ctrl-Alt-h",run:Xd},{key:"Ctrl-o",run:s1},{key:"Ctrl-t",run:r1},{key:"Ctrl-v",run:Ho}],O1=[{key:"ArrowLeft",run:Md,shift:Kd,preventDefault:!0},{key:"Mod-ArrowLeft",mac:"Alt-ArrowLeft",run:Qk,shift:Kk,preventDefault:!0},{mac:"Cmd-ArrowLeft",run:Tk,shift:qk,preventDefault:!0},{key:"ArrowRight",run:Dd,shift:zd,preventDefault:!0},{key:"Mod-ArrowRight",mac:"Alt-ArrowRight",run:Ek,shift:zk,preventDefault:!0},{mac:"Cmd-ArrowRight",run:Rk,shift:Gk,preventDefault:!0},{key:"ArrowUp",run:Rd,shift:Wd,preventDefault:!0},{mac:"Cmd-ArrowUp",run:Jh,shift:ec},{mac:"Ctrl-ArrowUp",run:Yh,shift:Xh},{key:"ArrowDown",run:Ld,shift:Hd,preventDefault:!0},{mac:"Cmd-ArrowDown",run:Zh,shift:tc},{mac:"Ctrl-ArrowDown",run:Ho,shift:jh},{key:"PageUp",run:Yh,shift:Xh},{key:"PageDown",run:Ho,shift:jh},{key:"Home",run:Ik,shift:Hk,preventDefault:!0},{key:"Mod-Home",run:Jh,shift:ec},{key:"End",run:Dk,shift:Wk,preventDefault:!0},{key:"Mod-End",run:Zh,shift:tc},{key:"Enter",run:ic,shift:ic},{key:"Mod-a",run:Xk},{key:"Backspace",run:qo,shift:qo},{key:"Delete",run:Ud},{key:"Mod-Backspace",mac:"Alt-Backspace",run:Xd},{key:"Mod-Delete",mac:"Alt-Delete",run:e1},{mac:"Mod-Backspace",run:i1},{mac:"Mod-Delete",run:n1}].concat(A1.map(i=>({mac:i.key,run:i.run,shift:i.shift}))),b1=[{key:"Alt-ArrowLeft",mac:"Ctrl-ArrowLeft",run:Pk,shift:_k},{key:"Alt-ArrowRight",mac:"Ctrl-ArrowRight",run:Mk,shift:Vk},{key:"Alt-ArrowUp",run:o1},{key:"Shift-Alt-ArrowUp",run:a1},{key:"Alt-ArrowDown",run:l1},{key:"Shift-Alt-ArrowDown",run:h1},{key:"Escape",run:Zk},{key:"Mod-Enter",run:u1},{key:"Alt-l",mac:"Ctrl-l",run:jk},{key:"Mod-i",run:Jk,preventDefault:!0},{key:"Mod-[",run:m1},{key:"Mod-]",run:p1},{key:"Mod-Alt-\\",run:d1},{key:"Shift-Mod-k",run:c1},{key:"Shift-Mod-\\",run:Fk},{key:"Mod-/",run:ak},{key:"Alt-A",run:ck},{key:"Ctrl-m",mac:"Shift-Alt-m",run:g1}].concat(O1),nc=typeof String.prototype.normalize=="function"?i=>i.normalize("NFKD"):i=>i;class Ni{constructor(e,t,n=0,s=e.length,r,o){this.test=o,this.value={from:0,to:0},this.done=!1,this.matches=[],this.buffer="",this.bufferPos=0,this.iter=e.iterRange(n,s),this.bufferStart=n,this.normalize=r?l=>r(nc(l)):nc,this.query=this.normalize(t)}peek(){if(this.bufferPos==this.buffer.length){if(this.bufferStart+=this.buffer.length,this.iter.next(),this.iter.done)return-1;this.bufferPos=0,this.buffer=this.iter.value}return Ee(this.buffer,this.bufferPos)}next(){for(;this.matches.length;)this.matches.pop();return this.nextOverlapping()}nextOverlapping(){for(;;){let e=this.peek();if(e<0)return this.done=!0,this;let t=el(e),n=this.bufferStart+this.bufferPos;this.bufferPos+=dt(e);let s=this.normalize(t);if(s.length)for(let r=0,o=n;;r++){let l=s.charCodeAt(r),a=this.match(l,o,this.bufferPos+this.bufferStart);if(r==s.length-1){if(a)return this.value=a,this;break}o==n&&r<t.length&&t.charCodeAt(r)==l&&o++}}}match(e,t,n){let s=null;for(let r=0;r<this.matches.length;r+=2){let o=this.matches[r],l=!1;this.query.charCodeAt(o)==e&&(o==this.query.length-1?s={from:this.matches[r+1],to:n}:(this.matches[r]++,l=!0)),l||(this.matches.splice(r,2),r-=2)}return this.query.charCodeAt(0)==e&&(this.query.length==1?s={from:t,to:n}:this.matches.push(1,t)),s&&this.test&&!this.test(s.from,s.to,this.buffer,this.bufferStart)&&(s=null),s}}typeof Symbol<"u"&&(Ni.prototype[Symbol.iterator]=function(){return this});const ep={from:-1,to:-1,match:/.*/.exec("")},Fl="gm"+(/x/.unicode==null?"":"u");class tp{constructor(e,t,n,s=0,r=e.length){if(this.text=e,this.to=r,this.curLine="",this.done=!1,this.value=ep,/\\[sWDnr]|\n|\r|\[\^/.test(t))return new ip(e,t,n,s,r);this.re=new RegExp(t,Fl+(n?.ignoreCase?"i":"")),this.test=n?.test,this.iter=e.iter();let o=e.lineAt(s);this.curLineStart=o.from,this.matchPos=Ws(e,s),this.getLine(this.curLineStart)}getLine(e){this.iter.next(e),this.iter.lineBreak?this.curLine="":(this.curLine=this.iter.value,this.curLineStart+this.curLine.length>this.to&&(this.curLine=this.curLine.slice(0,this.to-this.curLineStart)),this.iter.next())}nextLine(){this.curLineStart=this.curLineStart+this.curLine.length+1,this.curLineStart>this.to?this.curLine="":this.getLine(0)}next(){for(let e=this.matchPos-this.curLineStart;;){this.re.lastIndex=e;let t=this.matchPos<=this.to&&this.re.exec(this.curLine);if(t){let n=this.curLineStart+t.index,s=n+t[0].length;if(this.matchPos=Ws(this.text,s+(n==s?1:0)),n==this.curLineStart+this.curLine.length&&this.nextLine(),(n<s||n>this.value.to)&&(!this.test||this.test(n,s,t)))return this.value={from:n,to:s,match:t},this;e=this.matchPos-this.curLineStart}else if(this.curLineStart+this.curLine.length<this.to)this.nextLine(),e=0;else return this.done=!0,this}}}const _r=new WeakMap;class Bi{constructor(e,t){this.from=e,this.text=t}get to(){return this.from+this.text.length}static get(e,t,n){let s=_r.get(e);if(!s||s.from>=n||s.to<=t){let l=new Bi(t,e.sliceString(t,n));return _r.set(e,l),l}if(s.from==t&&s.to==n)return s;let{text:r,from:o}=s;return o>t&&(r=e.sliceString(t,o)+r,o=t),s.to<n&&(r+=e.sliceString(s.to,n)),_r.set(e,new Bi(o,r)),new Bi(t,r.slice(t-o,n-o))}}class ip{constructor(e,t,n,s,r){this.text=e,this.to=r,this.done=!1,this.value=ep,this.matchPos=Ws(e,s),this.re=new RegExp(t,Fl+(n?.ignoreCase?"i":"")),this.test=n?.test,this.flat=Bi.get(e,s,this.chunkEnd(s+5e3))}chunkEnd(e){return e>=this.to?this.to:this.text.lineAt(e).to}next(){for(;;){let e=this.re.lastIndex=this.matchPos-this.flat.from,t=this.re.exec(this.flat.text);if(t&&!t[0]&&t.index==e&&(this.re.lastIndex=e+1,t=this.re.exec(this.flat.text)),t){let n=this.flat.from+t.index,s=n+t[0].length;if((this.flat.to>=this.to||t.index+t[0].length<=this.flat.text.length-10)&&(!this.test||this.test(n,s,t)))return this.value={from:n,to:s,match:t},this.matchPos=Ws(this.text,s+(n==s?1:0)),this}if(this.flat.to==this.to)return this.done=!0,this;this.flat=Bi.get(this.text,this.flat.from,this.chunkEnd(this.flat.from+this.flat.text.length*2))}}}typeof Symbol<"u"&&(tp.prototype[Symbol.iterator]=ip.prototype[Symbol.iterator]=function(){return this});function w1(i){try{return new RegExp(i,Fl),!0}catch{return!1}}function Ws(i,e){if(e>=i.length)return e;let t=i.lineAt(e),n;for(;e<t.to&&(n=t.text.charCodeAt(e-t.from))>=56320&&n<57344;)e++;return e}function Go(i){let e=String(i.state.doc.lineAt(i.state.selection.main.head).number),t=G("input",{class:"cm-textfield",name:"line",value:e}),n=G("form",{class:"cm-gotoLine",onkeydown:r=>{r.keyCode==27?(r.preventDefault(),i.dispatch({effects:ln.of(!1)}),i.focus()):r.keyCode==13&&(r.preventDefault(),s())},onsubmit:r=>{r.preventDefault(),s()}},G("label",i.state.phrase("Go to line"),": ",t)," ",G("button",{class:"cm-button",type:"submit"},i.state.phrase("go")),G("button",{name:"close",onclick:()=>{i.dispatch({effects:ln.of(!1)}),i.focus()},"aria-label":i.state.phrase("close"),type:"button"},["×"]));function s(){let r=/^([+-])?(\d+)?(:\d+)?(%)?$/.exec(t.value);if(!r)return;let{state:o}=i,l=o.doc.lineAt(o.selection.main.head),[,a,h,c,f]=r,u=c?+c.slice(1):0,d=h?+h:l.number;if(h&&f){let g=d/100;a&&(g=g*(a=="-"?-1:1)+l.number/o.doc.lines),d=Math.round(o.doc.lines*g)}else h&&a&&(d=d*(a=="-"?-1:1)+l.number);let p=o.doc.line(Math.max(1,Math.min(o.doc.lines,d))),m=b.cursor(p.from+Math.max(0,Math.min(u,p.length)));i.dispatch({effects:[ln.of(!1),Q.scrollIntoView(m.from,{y:"center"})],selection:m}),i.focus()}return{dom:n}}const ln=R.define(),sc=ge.define({create(){return!0},update(i,e){for(let t of e.effects)t.is(ln)&&(i=t.value);return i},provide:i=>bn.from(i,e=>e?Go:null)}),y1=i=>{let e=On(i,Go);if(!e){let t=[ln.of(!0)];i.state.field(sc,!1)==null&&t.push(R.appendConfig.of([sc,k1])),i.dispatch({effects:t}),e=On(i,Go)}return e&&e.dom.querySelector("input").select(),!0},k1=Q.baseTheme({".cm-panel.cm-gotoLine":{padding:"2px 6px 4px",position:"relative","& label":{fontSize:"80%"},"& [name=close]":{position:"absolute",top:"0",bottom:"0",right:"4px",backgroundColor:"inherit",border:"none",font:"inherit",padding:"0"}}}),C1={highlightWordAroundCursor:!1,minSelectionLength:1,maxMatches:100,wholeWords:!1},v1=B.define({combine(i){return yt(i,C1,{highlightWordAroundCursor:(e,t)=>e||t,minSelectionLength:Math.min,maxMatches:Math.min})}});function x1(i){return[P1,B1]}const S1=D.mark({class:"cm-selectionMatch"}),Q1=D.mark({class:"cm-selectionMatch cm-selectionMatch-main"});function rc(i,e,t,n){return(t==0||i(e.sliceDoc(t-1,t))!=ee.Word)&&(n==e.doc.length||i(e.sliceDoc(n,n+1))!=ee.Word)}function E1(i,e,t,n){return i(e.sliceDoc(t,t+1))==ee.Word&&i(e.sliceDoc(n-1,n))==ee.Word}const B1=ne.fromClass(class{constructor(i){this.decorations=this.getDeco(i)}update(i){(i.selectionSet||i.docChanged||i.viewportChanged)&&(this.decorations=this.getDeco(i.view))}getDeco(i){let e=i.state.facet(v1),{state:t}=i,n=t.selection;if(n.ranges.length>1)return D.none;let s=n.main,r,o=null;if(s.empty){if(!e.highlightWordAroundCursor)return D.none;let a=t.wordAt(s.head);if(!a)return D.none;o=t.charCategorizer(s.head),r=t.sliceDoc(a.from,a.to)}else{let a=s.to-s.from;if(a<e.minSelectionLength||a>200)return D.none;if(e.wholeWords){if(r=t.sliceDoc(s.from,s.to),o=t.charCategorizer(s.head),!(rc(o,t,s.from,s.to)&&E1(o,t,s.from,s.to)))return D.none}else if(r=t.sliceDoc(s.from,s.to),!r)return D.none}let l=[];for(let a of i.visibleRanges){let h=new Ni(t.doc,r,a.from,a.to);for(;!h.next().done;){let{from:c,to:f}=h.value;if((!o||rc(o,t,c,f))&&(s.empty&&c<=s.from&&f>=s.to?l.push(Q1.range(c,f)):(c>=s.to||f<=s.from)&&l.push(S1.range(c,f)),l.length>e.maxMatches))return D.none}}return D.set(l)}},{decorations:i=>i.decorations}),P1=Q.baseTheme({".cm-selectionMatch":{backgroundColor:"#99ff7780"},".cm-searchMatch .cm-selectionMatch":{backgroundColor:"transparent"}}),M1=({state:i,dispatch:e})=>{let{selection:t}=i,n=b.create(t.ranges.map(s=>i.wordAt(s.head)||b.cursor(s.head)),t.mainIndex);return n.eq(t)?!1:(e(i.update({selection:n})),!0)};function D1(i,e){let{main:t,ranges:n}=i.selection,s=i.wordAt(t.head),r=s&&s.from==t.from&&s.to==t.to;for(let o=!1,l=new Ni(i.doc,e,n[n.length-1].to);;)if(l.next(),l.done){if(o)return null;l=new Ni(i.doc,e,0,Math.max(0,n[n.length-1].from-1)),o=!0}else{if(o&&n.some(a=>a.from==l.value.from))continue;if(r){let a=i.wordAt(l.value.from);if(!a||a.from!=l.value.from||a.to!=l.value.to)continue}return l.value}}const I1=({state:i,dispatch:e})=>{let{ranges:t}=i.selection;if(t.some(r=>r.from===r.to))return M1({state:i,dispatch:e});let n=i.sliceDoc(t[0].from,t[0].to);if(i.selection.ranges.some(r=>i.sliceDoc(r.from,r.to)!=n))return!1;let s=D1(i,n);return s?(e(i.update({selection:i.selection.addRange(b.range(s.from,s.to),!1),effects:Q.scrollIntoView(s.to)})),!0):!1},Wi=B.define({combine(i){return yt(i,{top:!1,caseSensitive:!1,literal:!1,regexp:!1,wholeWord:!1,createPanel:e=>new H1(e),scrollToMatch:e=>Q.scrollIntoView(e)})}});class np{constructor(e){this.search=e.search,this.caseSensitive=!!e.caseSensitive,this.literal=!!e.literal,this.regexp=!!e.regexp,this.replace=e.replace||"",this.valid=!!this.search&&(!this.regexp||w1(this.search)),this.unquoted=this.unquote(this.search),this.wholeWord=!!e.wholeWord}unquote(e){return this.literal?e:e.replace(/\\([nrt\\])/g,(t,n)=>n=="n"?`
101
+ `:n=="r"?"\r":n=="t"?" ":"\\")}eq(e){return this.search==e.search&&this.replace==e.replace&&this.caseSensitive==e.caseSensitive&&this.regexp==e.regexp&&this.wholeWord==e.wholeWord}create(){return this.regexp?new N1(this):new R1(this)}getCursor(e,t=0,n){let s=e.doc?e:K.create({doc:e});return n==null&&(n=s.doc.length),this.regexp?Oi(this,s,t,n):Ai(this,s,t,n)}}class sp{constructor(e){this.spec=e}}function Ai(i,e,t,n){return new Ni(e.doc,i.unquoted,t,n,i.caseSensitive?void 0:s=>s.toLowerCase(),i.wholeWord?T1(e.doc,e.charCategorizer(e.selection.main.head)):void 0)}function T1(i,e){return(t,n,s,r)=>((r>t||r+s.length<n)&&(r=Math.max(0,t-2),s=i.sliceString(r,Math.min(i.length,n+2))),(e(Hs(s,t-r))!=ee.Word||e(qs(s,t-r))!=ee.Word)&&(e(qs(s,n-r))!=ee.Word||e(Hs(s,n-r))!=ee.Word))}class R1 extends sp{constructor(e){super(e)}nextMatch(e,t,n){let s=Ai(this.spec,e,n,e.doc.length).nextOverlapping();if(s.done){let r=Math.min(e.doc.length,t+this.spec.unquoted.length);s=Ai(this.spec,e,0,r).nextOverlapping()}return s.done||s.value.from==t&&s.value.to==n?null:s.value}prevMatchInRange(e,t,n){for(let s=n;;){let r=Math.max(t,s-1e4-this.spec.unquoted.length),o=Ai(this.spec,e,r,s),l=null;for(;!o.nextOverlapping().done;)l=o.value;if(l)return l;if(r==t)return null;s-=1e4}}prevMatch(e,t,n){let s=this.prevMatchInRange(e,0,t);return s||(s=this.prevMatchInRange(e,Math.max(0,n-this.spec.unquoted.length),e.doc.length)),s&&(s.from!=t||s.to!=n)?s:null}getReplacement(e){return this.spec.unquote(this.spec.replace)}matchAll(e,t){let n=Ai(this.spec,e,0,e.doc.length),s=[];for(;!n.next().done;){if(s.length>=t)return null;s.push(n.value)}return s}highlight(e,t,n,s){let r=Ai(this.spec,e,Math.max(0,t-this.spec.unquoted.length),Math.min(n+this.spec.unquoted.length,e.doc.length));for(;!r.next().done;)s(r.value.from,r.value.to)}}function Oi(i,e,t,n){return new tp(e.doc,i.search,{ignoreCase:!i.caseSensitive,test:i.wholeWord?L1(e.charCategorizer(e.selection.main.head)):void 0},t,n)}function Hs(i,e){return i.slice(me(i,e,!1),e)}function qs(i,e){return i.slice(e,me(i,e))}function L1(i){return(e,t,n)=>!n[0].length||(i(Hs(n.input,n.index))!=ee.Word||i(qs(n.input,n.index))!=ee.Word)&&(i(qs(n.input,n.index+n[0].length))!=ee.Word||i(Hs(n.input,n.index+n[0].length))!=ee.Word)}class N1 extends sp{nextMatch(e,t,n){let s=Oi(this.spec,e,n,e.doc.length).next();return s.done&&(s=Oi(this.spec,e,0,t).next()),s.done?null:s.value}prevMatchInRange(e,t,n){for(let s=1;;s++){let r=Math.max(t,n-s*1e4),o=Oi(this.spec,e,r,n),l=null;for(;!o.next().done;)l=o.value;if(l&&(r==t||l.from>r+10))return l;if(r==t)return null}}prevMatch(e,t,n){return this.prevMatchInRange(e,0,t)||this.prevMatchInRange(e,n,e.doc.length)}getReplacement(e){return this.spec.unquote(this.spec.replace).replace(/\$([$&]|\d+)/g,(t,n)=>{if(n=="&")return e.match[0];if(n=="$")return"$";for(let s=n.length;s>0;s--){let r=+n.slice(0,s);if(r>0&&r<e.match.length)return e.match[r]+n.slice(s)}return t})}matchAll(e,t){let n=Oi(this.spec,e,0,e.doc.length),s=[];for(;!n.next().done;){if(s.length>=t)return null;s.push(n.value)}return s}highlight(e,t,n,s){let r=Oi(this.spec,e,Math.max(0,t-250),Math.min(n+250,e.doc.length));for(;!r.next().done;)s(r.value.from,r.value.to)}}const xn=R.define(),Kl=R.define(),_t=ge.define({create(i){return new Vr(Uo(i).create(),null)},update(i,e){for(let t of e.effects)t.is(xn)?i=new Vr(t.value.create(),i.panel):t.is(Kl)&&(i=new Vr(i.query,t.value?zl:null));return i},provide:i=>bn.from(i,e=>e.panel)});class Vr{constructor(e,t){this.query=e,this.panel=t}}const $1=D.mark({class:"cm-searchMatch"}),F1=D.mark({class:"cm-searchMatch cm-searchMatch-selected"}),K1=ne.fromClass(class{constructor(i){this.view=i,this.decorations=this.highlight(i.state.field(_t))}update(i){let e=i.state.field(_t);(e!=i.startState.field(_t)||i.docChanged||i.selectionSet||i.viewportChanged)&&(this.decorations=this.highlight(e))}highlight({query:i,panel:e}){if(!e||!i.spec.valid)return D.none;let{view:t}=this,n=new Qt;for(let s=0,r=t.visibleRanges,o=r.length;s<o;s++){let{from:l,to:a}=r[s];for(;s<o-1&&a>r[s+1].from-500;)a=r[++s].to;i.highlight(t.state,l,a,(h,c)=>{let f=t.state.selection.ranges.some(u=>u.from==h&&u.to==c);n.add(h,c,f?F1:$1)})}return n.finish()}},{decorations:i=>i.decorations});function Tn(i){return e=>{let t=e.state.field(_t,!1);return t&&t.query.spec.valid?i(e,t):lp(e)}}const Gs=Tn((i,{query:e})=>{let{to:t}=i.state.selection.main,n=e.nextMatch(i.state,t,t);if(!n)return!1;let s=b.single(n.from,n.to),r=i.state.facet(Wi);return i.dispatch({selection:s,effects:[_l(i,n),r.scrollToMatch(s.main,i)],userEvent:"select.search"}),op(i),!0}),Us=Tn((i,{query:e})=>{let{state:t}=i,{from:n}=t.selection.main,s=e.prevMatch(t,n,n);if(!s)return!1;let r=b.single(s.from,s.to),o=i.state.facet(Wi);return i.dispatch({selection:r,effects:[_l(i,s),o.scrollToMatch(r.main,i)],userEvent:"select.search"}),op(i),!0}),z1=Tn((i,{query:e})=>{let t=e.matchAll(i.state,1e3);return!t||!t.length?!1:(i.dispatch({selection:b.create(t.map(n=>b.range(n.from,n.to))),userEvent:"select.search.matches"}),!0)}),_1=({state:i,dispatch:e})=>{let t=i.selection;if(t.ranges.length>1||t.main.empty)return!1;let{from:n,to:s}=t.main,r=[],o=0;for(let l=new Ni(i.doc,i.sliceDoc(n,s));!l.next().done;){if(r.length>1e3)return!1;l.value.from==n&&(o=r.length),r.push(b.range(l.value.from,l.value.to))}return e(i.update({selection:b.create(r,o),userEvent:"select.search.matches"})),!0},oc=Tn((i,{query:e})=>{let{state:t}=i,{from:n,to:s}=t.selection.main;if(t.readOnly)return!1;let r=e.nextMatch(t,n,n);if(!r)return!1;let o=r,l=[],a,h,c=[];o.from==n&&o.to==s&&(h=t.toText(e.getReplacement(o)),l.push({from:o.from,to:o.to,insert:h}),o=e.nextMatch(t,o.from,o.to),c.push(Q.announce.of(t.phrase("replaced match on line $",t.doc.lineAt(n).number)+".")));let f=i.state.changes(l);return o&&(a=b.single(o.from,o.to).map(f),c.push(_l(i,o)),c.push(t.facet(Wi).scrollToMatch(a.main,i))),i.dispatch({changes:f,selection:a,effects:c,userEvent:"input.replace"}),!0}),V1=Tn((i,{query:e})=>{if(i.state.readOnly)return!1;let t=e.matchAll(i.state,1e9).map(s=>{let{from:r,to:o}=s;return{from:r,to:o,insert:e.getReplacement(s)}});if(!t.length)return!1;let n=i.state.phrase("replaced $ matches",t.length)+".";return i.dispatch({changes:t,effects:Q.announce.of(n),userEvent:"input.replace.all"}),!0});function zl(i){return i.state.facet(Wi).createPanel(i)}function Uo(i,e){var t,n,s,r,o;let l=i.selection.main,a=l.empty||l.to>l.from+100?"":i.sliceDoc(l.from,l.to);if(e&&!a)return e;let h=i.facet(Wi);return new np({search:((t=e?.literal)!==null&&t!==void 0?t:h.literal)?a:a.replace(/\n/g,"\\n"),caseSensitive:(n=e?.caseSensitive)!==null&&n!==void 0?n:h.caseSensitive,literal:(s=e?.literal)!==null&&s!==void 0?s:h.literal,regexp:(r=e?.regexp)!==null&&r!==void 0?r:h.regexp,wholeWord:(o=e?.wholeWord)!==null&&o!==void 0?o:h.wholeWord})}function rp(i){let e=On(i,zl);return e&&e.dom.querySelector("[main-field]")}function op(i){let e=rp(i);e&&e==i.root.activeElement&&e.select()}const lp=i=>{let e=i.state.field(_t,!1);if(e&&e.panel){let t=rp(i);if(t&&t!=i.root.activeElement){let n=Uo(i.state,e.query.spec);n.valid&&i.dispatch({effects:xn.of(n)}),t.focus(),t.select()}}else i.dispatch({effects:[Kl.of(!0),e?xn.of(Uo(i.state,e.query.spec)):R.appendConfig.of(G1)]});return!0},ap=i=>{let e=i.state.field(_t,!1);if(!e||!e.panel)return!1;let t=On(i,zl);return t&&t.dom.contains(i.root.activeElement)&&i.focus(),i.dispatch({effects:Kl.of(!1)}),!0},W1=[{key:"Mod-f",run:lp,scope:"editor search-panel"},{key:"F3",run:Gs,shift:Us,scope:"editor search-panel",preventDefault:!0},{key:"Mod-g",run:Gs,shift:Us,scope:"editor search-panel",preventDefault:!0},{key:"Escape",run:ap,scope:"editor search-panel"},{key:"Mod-Shift-l",run:_1},{key:"Mod-Alt-g",run:y1},{key:"Mod-d",run:I1,preventDefault:!0}];class H1{constructor(e){this.view=e;let t=this.query=e.state.field(_t).query.spec;this.commit=this.commit.bind(this),this.searchField=G("input",{value:t.search,placeholder:Re(e,"Find"),"aria-label":Re(e,"Find"),class:"cm-textfield",name:"search",form:"","main-field":"true",onchange:this.commit,onkeyup:this.commit}),this.replaceField=G("input",{value:t.replace,placeholder:Re(e,"Replace"),"aria-label":Re(e,"Replace"),class:"cm-textfield",name:"replace",form:"",onchange:this.commit,onkeyup:this.commit}),this.caseField=G("input",{type:"checkbox",name:"case",form:"",checked:t.caseSensitive,onchange:this.commit}),this.reField=G("input",{type:"checkbox",name:"re",form:"",checked:t.regexp,onchange:this.commit}),this.wordField=G("input",{type:"checkbox",name:"word",form:"",checked:t.wholeWord,onchange:this.commit});function n(s,r,o){return G("button",{class:"cm-button",name:s,onclick:r,type:"button"},o)}this.dom=G("div",{onkeydown:s=>this.keydown(s),class:"cm-search"},[this.searchField,n("next",()=>Gs(e),[Re(e,"next")]),n("prev",()=>Us(e),[Re(e,"previous")]),n("select",()=>z1(e),[Re(e,"all")]),G("label",null,[this.caseField,Re(e,"match case")]),G("label",null,[this.reField,Re(e,"regexp")]),G("label",null,[this.wordField,Re(e,"by word")]),...e.state.readOnly?[]:[G("br"),this.replaceField,n("replace",()=>oc(e),[Re(e,"replace")]),n("replaceAll",()=>V1(e),[Re(e,"replace all")])],G("button",{name:"close",onclick:()=>ap(e),"aria-label":Re(e,"close"),type:"button"},["×"])])}commit(){let e=new np({search:this.searchField.value,caseSensitive:this.caseField.checked,regexp:this.reField.checked,wholeWord:this.wordField.checked,replace:this.replaceField.value});e.eq(this.query)||(this.query=e,this.view.dispatch({effects:xn.of(e)}))}keydown(e){zg(this.view,e,"search-panel")?e.preventDefault():e.keyCode==13&&e.target==this.searchField?(e.preventDefault(),(e.shiftKey?Us:Gs)(this.view)):e.keyCode==13&&e.target==this.replaceField&&(e.preventDefault(),oc(this.view))}update(e){for(let t of e.transactions)for(let n of t.effects)n.is(xn)&&!n.value.eq(this.query)&&this.setQuery(n.value)}setQuery(e){this.query=e,this.searchField.value=e.search,this.replaceField.value=e.replace,this.caseField.checked=e.caseSensitive,this.reField.checked=e.regexp,this.wordField.checked=e.wholeWord}mount(){this.searchField.select()}get pos(){return 80}get top(){return this.view.state.facet(Wi).top}}function Re(i,e){return i.state.phrase(e)}const ns=30,ss=/[\s\.,:;?!]/;function _l(i,{from:e,to:t}){let n=i.state.doc.lineAt(e),s=i.state.doc.lineAt(t).to,r=Math.max(n.from,e-ns),o=Math.min(s,t+ns),l=i.state.sliceDoc(r,o);if(r!=n.from){for(let a=0;a<ns;a++)if(!ss.test(l[a+1])&&ss.test(l[a])){l=l.slice(a);break}}if(o!=s){for(let a=l.length-1;a>l.length-ns;a--)if(!ss.test(l[a-1])&&ss.test(l[a])){l=l.slice(0,a);break}}return Q.announce.of(`${i.state.phrase("current match")}. ${l} ${i.state.phrase("on line")} ${n.number}.`)}const q1=Q.baseTheme({".cm-panel.cm-search":{padding:"2px 6px 4px",position:"relative","& [name=close]":{position:"absolute",top:"0",right:"4px",backgroundColor:"inherit",border:"none",font:"inherit",padding:0,margin:0},"& input, & button, & label":{margin:".2em .6em .2em 0"},"& input[type=checkbox]":{marginRight:".2em"},"& label":{fontSize:"80%",whiteSpace:"pre"}},"&light .cm-searchMatch":{backgroundColor:"#ffff0054"},"&dark .cm-searchMatch":{backgroundColor:"#00ffff8a"},"&light .cm-searchMatch-selected":{backgroundColor:"#ff6a0054"},"&dark .cm-searchMatch-selected":{backgroundColor:"#ff00ff8a"}}),G1=[_t,di.low(K1),q1];class hp{constructor(e,t,n,s){this.state=e,this.pos=t,this.explicit=n,this.view=s,this.abortListeners=[],this.abortOnDocChange=!1}tokenBefore(e){let t=we(this.state).resolveInner(this.pos,-1);for(;t&&e.indexOf(t.name)<0;)t=t.parent;return t?{from:t.from,to:this.pos,text:this.state.sliceDoc(t.from,this.pos),type:t.type}:null}matchBefore(e){let t=this.state.doc.lineAt(this.pos),n=Math.max(t.from,this.pos-250),s=t.text.slice(n-t.from,this.pos-t.from),r=s.search(cp(e,!1));return r<0?null:{from:n+r,to:this.pos,text:s.slice(r)}}get aborted(){return this.abortListeners==null}addEventListener(e,t,n){e=="abort"&&this.abortListeners&&(this.abortListeners.push(t),n&&n.onDocChange&&(this.abortOnDocChange=!0))}}function lc(i){let e=Object.keys(i).join(""),t=/\w/.test(e);return t&&(e=e.replace(/\w/g,"")),`[${t?"\\w":""}${e.replace(/[^\w\s]/g,"\\$&")}]`}function U1(i){let e=Object.create(null),t=Object.create(null);for(let{label:s}of i){e[s[0]]=!0;for(let r=1;r<s.length;r++)t[s[r]]=!0}let n=lc(e)+lc(t)+"*$";return[new RegExp("^"+n),new RegExp(n)]}function Y1(i){let e=i.map(s=>typeof s=="string"?{label:s}:s),[t,n]=e.every(s=>/^\w+$/.test(s.label))?[/\w*$/,/\w+$/]:U1(e);return s=>{let r=s.matchBefore(n);return r||s.explicit?{from:r?r.from:s.pos,options:e,validFor:t}:null}}class ac{constructor(e,t,n,s){this.completion=e,this.source=t,this.match=n,this.score=s}}function oi(i){return i.selection.main.from}function cp(i,e){var t;let{source:n}=i,s=e&&n[0]!="^",r=n[n.length-1]!="$";return!s&&!r?i:new RegExp(`${s?"^":""}(?:${n})${r?"$":""}`,(t=i.flags)!==null&&t!==void 0?t:i.ignoreCase?"i":"")}const fp=Pt.define();function X1(i,e,t,n){let{main:s}=i.selection,r=t-s.from,o=n-s.from;return Object.assign(Object.assign({},i.changeByRange(l=>{if(l!=s&&t!=n&&i.sliceDoc(l.from+r,l.from+o)!=i.sliceDoc(t,n))return{range:l};let a=i.toText(e);return{changes:{from:l.from+r,to:n==s.from?l.to:l.from+o,insert:a},range:b.cursor(l.from+r+a.length)}})),{scrollIntoView:!0,userEvent:"input.complete"})}const hc=new WeakMap;function j1(i){if(!Array.isArray(i))return i;let e=hc.get(i);return e||hc.set(i,e=Y1(i)),e}const Ys=R.define(),Sn=R.define();class J1{constructor(e){this.pattern=e,this.chars=[],this.folded=[],this.any=[],this.precise=[],this.byWord=[],this.score=0,this.matched=[];for(let t=0;t<e.length;){let n=Ee(e,t),s=dt(n);this.chars.push(n);let r=e.slice(t,t+s),o=r.toUpperCase();this.folded.push(Ee(o==r?r.toLowerCase():o,0)),t+=s}this.astral=e.length!=this.chars.length}ret(e,t){return this.score=e,this.matched=t,this}match(e){if(this.pattern.length==0)return this.ret(-100,[]);if(e.length<this.pattern.length)return null;let{chars:t,folded:n,any:s,precise:r,byWord:o}=this;if(t.length==1){let w=Ee(e,0),k=dt(w),v=k==e.length?0:-100;if(w!=t[0])if(w==n[0])v+=-200;else return null;return this.ret(v,[0,k])}let l=e.indexOf(this.pattern);if(l==0)return this.ret(e.length==this.pattern.length?0:-100,[0,this.pattern.length]);let a=t.length,h=0;if(l<0){for(let w=0,k=Math.min(e.length,200);w<k&&h<a;){let v=Ee(e,w);(v==t[h]||v==n[h])&&(s[h++]=w),w+=dt(v)}if(h<a)return null}let c=0,f=0,u=!1,d=0,p=-1,m=-1,g=/[a-z]/.test(e),O=!0;for(let w=0,k=Math.min(e.length,200),v=0;w<k&&f<a;){let y=Ee(e,w);l<0&&(c<a&&y==t[c]&&(r[c++]=w),d<a&&(y==t[d]||y==n[d]?(d==0&&(p=w),m=w+1,d++):d=0));let C,x=y<255?y>=48&&y<=57||y>=97&&y<=122?2:y>=65&&y<=90?1:0:(C=el(y))!=C.toLowerCase()?1:C!=C.toUpperCase()?2:0;(!w||x==1&&g||v==0&&x!=0)&&(t[f]==y||n[f]==y&&(u=!0)?o[f++]=w:o.length&&(O=!1)),v=x,w+=dt(y)}return f==a&&o[0]==0&&O?this.result(-100+(u?-200:0),o,e):d==a&&p==0?this.ret(-200-e.length+(m==e.length?0:-100),[0,m]):l>-1?this.ret(-700-e.length,[l,l+this.pattern.length]):d==a?this.ret(-900-e.length,[p,m]):f==a?this.result(-100+(u?-200:0)+-700+(O?0:-1100),o,e):t.length==2?null:this.result((s[0]?-700:0)+-200+-1100,s,e)}result(e,t,n){let s=[],r=0;for(let o of t){let l=o+(this.astral?dt(Ee(n,o)):1);r&&s[r-1]==o?s[r-1]=l:(s[r++]=o,s[r++]=l)}return this.ret(e-n.length,s)}}class Z1{constructor(e){this.pattern=e,this.matched=[],this.score=0,this.folded=e.toLowerCase()}match(e){if(e.length<this.pattern.length)return null;let t=e.slice(0,this.pattern.length),n=t==this.pattern?0:t.toLowerCase()==this.folded?-200:null;return n==null?null:(this.matched=[0,t.length],this.score=n+(e.length==this.pattern.length?0:-100),this)}}const fe=B.define({combine(i){return yt(i,{activateOnTyping:!0,activateOnCompletion:()=>!1,activateOnTypingDelay:100,selectOnOpen:!0,override:null,closeOnBlur:!0,maxRenderedOptions:100,defaultKeymap:!0,tooltipClass:()=>"",optionClass:()=>"",aboveCursor:!1,icons:!0,addToOptions:[],positionInfo:eC,filterStrict:!1,compareCompletions:(e,t)=>e.label.localeCompare(t.label),interactionDelay:75,updateSyncTime:100},{defaultKeymap:(e,t)=>e&&t,closeOnBlur:(e,t)=>e&&t,icons:(e,t)=>e&&t,tooltipClass:(e,t)=>n=>cc(e(n),t(n)),optionClass:(e,t)=>n=>cc(e(n),t(n)),addToOptions:(e,t)=>e.concat(t),filterStrict:(e,t)=>e||t})}});function cc(i,e){return i?e?i+" "+e:i:e}function eC(i,e,t,n,s,r){let o=i.textDirection==Z.RTL,l=o,a=!1,h="top",c,f,u=e.left-s.left,d=s.right-e.right,p=n.right-n.left,m=n.bottom-n.top;if(l&&u<Math.min(p,d)?l=!1:!l&&d<Math.min(p,u)&&(l=!0),p<=(l?u:d))c=Math.max(s.top,Math.min(t.top,s.bottom-m))-e.top,f=Math.min(400,l?u:d);else{a=!0,f=Math.min(400,(o?e.right:s.right-e.left)-30);let w=s.bottom-e.bottom;w>=m||w>e.top?c=t.bottom-e.top:(h="bottom",c=e.bottom-t.top)}let g=(e.bottom-e.top)/r.offsetHeight,O=(e.right-e.left)/r.offsetWidth;return{style:`${h}: ${c/g}px; max-width: ${f/O}px`,class:"cm-completionInfo-"+(a?o?"left-narrow":"right-narrow":l?"left":"right")}}function tC(i){let e=i.addToOptions.slice();return i.icons&&e.push({render(t){let n=document.createElement("div");return n.classList.add("cm-completionIcon"),t.type&&n.classList.add(...t.type.split(/\s+/g).map(s=>"cm-completionIcon-"+s)),n.setAttribute("aria-hidden","true"),n},position:20}),e.push({render(t,n,s,r){let o=document.createElement("span");o.className="cm-completionLabel";let l=t.displayLabel||t.label,a=0;for(let h=0;h<r.length;){let c=r[h++],f=r[h++];c>a&&o.appendChild(document.createTextNode(l.slice(a,c)));let u=o.appendChild(document.createElement("span"));u.appendChild(document.createTextNode(l.slice(c,f))),u.className="cm-completionMatchedText",a=f}return a<l.length&&o.appendChild(document.createTextNode(l.slice(a))),o},position:50},{render(t){if(!t.detail)return null;let n=document.createElement("span");return n.className="cm-completionDetail",n.textContent=t.detail,n},position:80}),e.sort((t,n)=>t.position-n.position).map(t=>t.render)}function Wr(i,e,t){if(i<=t)return{from:0,to:i};if(e<0&&(e=0),e<=i>>1){let s=Math.floor(e/t);return{from:s*t,to:(s+1)*t}}let n=Math.floor((i-e)/t);return{from:i-(n+1)*t,to:i-n*t}}class iC{constructor(e,t,n){this.view=e,this.stateField=t,this.applyCompletion=n,this.info=null,this.infoDestroy=null,this.placeInfoReq={read:()=>this.measureInfo(),write:a=>this.placeInfo(a),key:this},this.space=null,this.currentClass="";let s=e.state.field(t),{options:r,selected:o}=s.open,l=e.state.facet(fe);this.optionContent=tC(l),this.optionClass=l.optionClass,this.tooltipClass=l.tooltipClass,this.range=Wr(r.length,o,l.maxRenderedOptions),this.dom=document.createElement("div"),this.dom.className="cm-tooltip-autocomplete",this.updateTooltipClass(e.state),this.dom.addEventListener("mousedown",a=>{let{options:h}=e.state.field(t).open;for(let c=a.target,f;c&&c!=this.dom;c=c.parentNode)if(c.nodeName=="LI"&&(f=/-(\d+)$/.exec(c.id))&&+f[1]<h.length){this.applyCompletion(e,h[+f[1]]),a.preventDefault();return}}),this.dom.addEventListener("focusout",a=>{let h=e.state.field(this.stateField,!1);h&&h.tooltip&&e.state.facet(fe).closeOnBlur&&a.relatedTarget!=e.contentDOM&&e.dispatch({effects:Sn.of(null)})}),this.showOptions(r,s.id)}mount(){this.updateSel()}showOptions(e,t){this.list&&this.list.remove(),this.list=this.dom.appendChild(this.createListBox(e,t,this.range)),this.list.addEventListener("scroll",()=>{this.info&&this.view.requestMeasure(this.placeInfoReq)})}update(e){var t;let n=e.state.field(this.stateField),s=e.startState.field(this.stateField);if(this.updateTooltipClass(e.state),n!=s){let{options:r,selected:o,disabled:l}=n.open;(!s.open||s.open.options!=r)&&(this.range=Wr(r.length,o,e.state.facet(fe).maxRenderedOptions),this.showOptions(r,n.id)),this.updateSel(),l!=((t=s.open)===null||t===void 0?void 0:t.disabled)&&this.dom.classList.toggle("cm-tooltip-autocomplete-disabled",!!l)}}updateTooltipClass(e){let t=this.tooltipClass(e);if(t!=this.currentClass){for(let n of this.currentClass.split(" "))n&&this.dom.classList.remove(n);for(let n of t.split(" "))n&&this.dom.classList.add(n);this.currentClass=t}}positioned(e){this.space=e,this.info&&this.view.requestMeasure(this.placeInfoReq)}updateSel(){let e=this.view.state.field(this.stateField),t=e.open;if((t.selected>-1&&t.selected<this.range.from||t.selected>=this.range.to)&&(this.range=Wr(t.options.length,t.selected,this.view.state.facet(fe).maxRenderedOptions),this.showOptions(t.options,e.id)),this.updateSelectedOption(t.selected)){this.destroyInfo();let{completion:n}=t.options[t.selected],{info:s}=n;if(!s)return;let r=typeof s=="string"?document.createTextNode(s):s(n);if(!r)return;"then"in r?r.then(o=>{o&&this.view.state.field(this.stateField,!1)==e&&this.addInfoPane(o,n)}).catch(o=>ve(this.view.state,o,"completion info")):this.addInfoPane(r,n)}}addInfoPane(e,t){this.destroyInfo();let n=this.info=document.createElement("div");if(n.className="cm-tooltip cm-completionInfo",e.nodeType!=null)n.appendChild(e),this.infoDestroy=null;else{let{dom:s,destroy:r}=e;n.appendChild(s),this.infoDestroy=r||null}this.dom.appendChild(n),this.view.requestMeasure(this.placeInfoReq)}updateSelectedOption(e){let t=null;for(let n=this.list.firstChild,s=this.range.from;n;n=n.nextSibling,s++)n.nodeName!="LI"||!n.id?s--:s==e?n.hasAttribute("aria-selected")||(n.setAttribute("aria-selected","true"),t=n):n.hasAttribute("aria-selected")&&n.removeAttribute("aria-selected");return t&&sC(this.list,t),t}measureInfo(){let e=this.dom.querySelector("[aria-selected]");if(!e||!this.info)return null;let t=this.dom.getBoundingClientRect(),n=this.info.getBoundingClientRect(),s=e.getBoundingClientRect(),r=this.space;if(!r){let o=this.dom.ownerDocument.documentElement;r={left:0,top:0,right:o.clientWidth,bottom:o.clientHeight}}return s.top>Math.min(r.bottom,t.bottom)-10||s.bottom<Math.max(r.top,t.top)+10?null:this.view.state.facet(fe).positionInfo(this.view,t,s,n,r,this.dom)}placeInfo(e){this.info&&(e?(e.style&&(this.info.style.cssText=e.style),this.info.className="cm-tooltip cm-completionInfo "+(e.class||"")):this.info.style.cssText="top: -1e6px")}createListBox(e,t,n){const s=document.createElement("ul");s.id=t,s.setAttribute("role","listbox"),s.setAttribute("aria-expanded","true"),s.setAttribute("aria-label",this.view.state.phrase("Completions")),s.addEventListener("mousedown",o=>{o.target==s&&o.preventDefault()});let r=null;for(let o=n.from;o<n.to;o++){let{completion:l,match:a}=e[o],{section:h}=l;if(h){let u=typeof h=="string"?h:h.name;if(u!=r&&(o>n.from||n.from==0))if(r=u,typeof h!="string"&&h.header)s.appendChild(h.header(h));else{let d=s.appendChild(document.createElement("completion-section"));d.textContent=u}}const c=s.appendChild(document.createElement("li"));c.id=t+"-"+o,c.setAttribute("role","option");let f=this.optionClass(l);f&&(c.className=f);for(let u of this.optionContent){let d=u(l,this.view.state,this.view,a);d&&c.appendChild(d)}}return n.from&&s.classList.add("cm-completionListIncompleteTop"),n.to<e.length&&s.classList.add("cm-completionListIncompleteBottom"),s}destroyInfo(){this.info&&(this.infoDestroy&&this.infoDestroy(),this.info.remove(),this.info=null)}destroy(){this.destroyInfo()}}function nC(i,e){return t=>new iC(t,i,e)}function sC(i,e){let t=i.getBoundingClientRect(),n=e.getBoundingClientRect(),s=t.height/i.offsetHeight;n.top<t.top?i.scrollTop-=(t.top-n.top)/s:n.bottom>t.bottom&&(i.scrollTop+=(n.bottom-t.bottom)/s)}function fc(i){return(i.boost||0)*100+(i.apply?10:0)+(i.info?5:0)+(i.type?1:0)}function rC(i,e){let t=[],n=null,s=h=>{t.push(h);let{section:c}=h.completion;if(c){n||(n=[]);let f=typeof c=="string"?c:c.name;n.some(u=>u.name==f)||n.push(typeof c=="string"?{name:f}:c)}},r=e.facet(fe);for(let h of i)if(h.hasResult()){let c=h.result.getMatch;if(h.result.filter===!1)for(let f of h.result.options)s(new ac(f,h.source,c?c(f):[],1e9-t.length));else{let f=e.sliceDoc(h.from,h.to),u,d=r.filterStrict?new Z1(f):new J1(f);for(let p of h.result.options)if(u=d.match(p.label)){let m=p.displayLabel?c?c(p,u.matched):[]:u.matched;s(new ac(p,h.source,m,u.score+(p.boost||0)))}}}if(n){let h=Object.create(null),c=0,f=(u,d)=>{var p,m;return((p=u.rank)!==null&&p!==void 0?p:1e9)-((m=d.rank)!==null&&m!==void 0?m:1e9)||(u.name<d.name?-1:1)};for(let u of n.sort(f))c-=1e5,h[u.name]=c;for(let u of t){let{section:d}=u.completion;d&&(u.score+=h[typeof d=="string"?d:d.name])}}let o=[],l=null,a=r.compareCompletions;for(let h of t.sort((c,f)=>f.score-c.score||a(c.completion,f.completion))){let c=h.completion;!l||l.label!=c.label||l.detail!=c.detail||l.type!=null&&c.type!=null&&l.type!=c.type||l.apply!=c.apply||l.boost!=c.boost?o.push(h):fc(h.completion)>fc(l)&&(o[o.length-1]=h),l=h.completion}return o}class ki{constructor(e,t,n,s,r,o){this.options=e,this.attrs=t,this.tooltip=n,this.timestamp=s,this.selected=r,this.disabled=o}setSelected(e,t){return e==this.selected||e>=this.options.length?this:new ki(this.options,uc(t,e),this.tooltip,this.timestamp,e,this.disabled)}static build(e,t,n,s,r,o){if(s&&!o&&e.some(h=>h.isPending))return s.setDisabled();let l=rC(e,t);if(!l.length)return s&&e.some(h=>h.isPending)?s.setDisabled():null;let a=t.facet(fe).selectOnOpen?0:-1;if(s&&s.selected!=a&&s.selected!=-1){let h=s.options[s.selected].completion;for(let c=0;c<l.length;c++)if(l[c].completion==h){a=c;break}}return new ki(l,uc(n,a),{pos:e.reduce((h,c)=>c.hasResult()?Math.min(h,c.from):h,1e8),create:fC,above:r.aboveCursor},s?s.timestamp:Date.now(),a,!1)}map(e){return new ki(this.options,this.attrs,Object.assign(Object.assign({},this.tooltip),{pos:e.mapPos(this.tooltip.pos)}),this.timestamp,this.selected,this.disabled)}setDisabled(){return new ki(this.options,this.attrs,this.tooltip,this.timestamp,this.selected,!0)}}class Xs{constructor(e,t,n){this.active=e,this.id=t,this.open=n}static start(){return new Xs(hC,"cm-ac-"+Math.floor(Math.random()*2e6).toString(36),null)}update(e){let{state:t}=e,n=t.facet(fe),r=(n.override||t.languageDataAt("autocomplete",oi(t)).map(j1)).map(a=>(this.active.find(c=>c.source==a)||new Ve(a,this.active.some(c=>c.state!=0)?1:0)).update(e,n));r.length==this.active.length&&r.every((a,h)=>a==this.active[h])&&(r=this.active);let o=this.open,l=e.effects.some(a=>a.is(Vl));o&&e.docChanged&&(o=o.map(e.changes)),e.selection||r.some(a=>a.hasResult()&&e.changes.touchesRange(a.from,a.to))||!oC(r,this.active)||l?o=ki.build(r,t,this.id,o,n,l):o&&o.disabled&&!r.some(a=>a.isPending)&&(o=null),!o&&r.every(a=>!a.isPending)&&r.some(a=>a.hasResult())&&(r=r.map(a=>a.hasResult()?new Ve(a.source,0):a));for(let a of e.effects)a.is(dp)&&(o=o&&o.setSelected(a.value,this.id));return r==this.active&&o==this.open?this:new Xs(r,this.id,o)}get tooltip(){return this.open?this.open.tooltip:null}get attrs(){return this.open?this.open.attrs:this.active.length?lC:aC}}function oC(i,e){if(i==e)return!0;for(let t=0,n=0;;){for(;t<i.length&&!i[t].hasResult();)t++;for(;n<e.length&&!e[n].hasResult();)n++;let s=t==i.length,r=n==e.length;if(s||r)return s==r;if(i[t++].result!=e[n++].result)return!1}}const lC={"aria-autocomplete":"list"},aC={};function uc(i,e){let t={"aria-autocomplete":"list","aria-haspopup":"listbox","aria-controls":i};return e>-1&&(t["aria-activedescendant"]=i+"-"+e),t}const hC=[];function up(i,e){if(i.isUserEvent("input.complete")){let n=i.annotation(fp);if(n&&e.activateOnCompletion(n))return 12}let t=i.isUserEvent("input.type");return t&&e.activateOnTyping?5:t?1:i.isUserEvent("delete.backward")?2:i.selection?8:i.docChanged?16:0}class Ve{constructor(e,t,n=!1){this.source=e,this.state=t,this.explicit=n}hasResult(){return!1}get isPending(){return this.state==1}update(e,t){let n=up(e,t),s=this;(n&8||n&16&&this.touches(e))&&(s=new Ve(s.source,0)),n&4&&s.state==0&&(s=new Ve(this.source,1)),s=s.updateFor(e,n);for(let r of e.effects)if(r.is(Ys))s=new Ve(s.source,1,r.value);else if(r.is(Sn))s=new Ve(s.source,0);else if(r.is(Vl))for(let o of r.value)o.source==s.source&&(s=o);return s}updateFor(e,t){return this.map(e.changes)}map(e){return this}touches(e){return e.changes.touchesRange(oi(e.state))}}class Pi extends Ve{constructor(e,t,n,s,r,o){super(e,3,t),this.limit=n,this.result=s,this.from=r,this.to=o}hasResult(){return!0}updateFor(e,t){var n;if(!(t&3))return this.map(e.changes);let s=this.result;s.map&&!e.changes.empty&&(s=s.map(s,e.changes));let r=e.changes.mapPos(this.from),o=e.changes.mapPos(this.to,1),l=oi(e.state);if(l>o||!s||t&2&&(oi(e.startState)==this.from||l<this.limit))return new Ve(this.source,t&4?1:0);let a=e.changes.mapPos(this.limit);return cC(s.validFor,e.state,r,o)?new Pi(this.source,this.explicit,a,s,r,o):s.update&&(s=s.update(s,r,o,new hp(e.state,l,!1)))?new Pi(this.source,this.explicit,a,s,s.from,(n=s.to)!==null&&n!==void 0?n:oi(e.state)):new Ve(this.source,1,this.explicit)}map(e){return e.empty?this:(this.result.map?this.result.map(this.result,e):this.result)?new Pi(this.source,this.explicit,e.mapPos(this.limit),this.result,e.mapPos(this.from),e.mapPos(this.to,1)):new Ve(this.source,0)}touches(e){return e.changes.touchesRange(this.from,this.to)}}function cC(i,e,t,n){if(!i)return!1;let s=e.sliceDoc(t,n);return typeof i=="function"?i(s,t,n,e):cp(i,!0).test(s)}const Vl=R.define({map(i,e){return i.map(t=>t.map(e))}}),dp=R.define(),Pe=ge.define({create(){return Xs.start()},update(i,e){return i.update(e)},provide:i=>[gl.from(i,e=>e.tooltip),Q.contentAttributes.from(i,e=>e.attrs)]});function Wl(i,e){const t=e.completion.apply||e.completion.label;let n=i.state.field(Pe).active.find(s=>s.source==e.source);return n instanceof Pi?(typeof t=="string"?i.dispatch(Object.assign(Object.assign({},X1(i.state,t,n.from,n.to)),{annotations:fp.of(e.completion)})):t(i,e.completion,n.from,n.to),!0):!1}const fC=nC(Pe,Wl);function rs(i,e="option"){return t=>{let n=t.state.field(Pe,!1);if(!n||!n.open||n.open.disabled||Date.now()-n.open.timestamp<t.state.facet(fe).interactionDelay)return!1;let s=1,r;e=="page"&&(r=Xf(t,n.open.tooltip))&&(s=Math.max(2,Math.floor(r.dom.offsetHeight/r.dom.querySelector("li").offsetHeight)-1));let{length:o}=n.open.options,l=n.open.selected>-1?n.open.selected+s*(i?1:-1):i?0:o-1;return l<0?l=e=="page"?0:o-1:l>=o&&(l=e=="page"?o-1:0),t.dispatch({effects:dp.of(l)}),!0}}const uC=i=>{let e=i.state.field(Pe,!1);return i.state.readOnly||!e||!e.open||e.open.selected<0||e.open.disabled||Date.now()-e.open.timestamp<i.state.facet(fe).interactionDelay?!1:Wl(i,e.open.options[e.open.selected])},dc=i=>i.state.field(Pe,!1)?(i.dispatch({effects:Ys.of(!0)}),!0):!1,dC=i=>{let e=i.state.field(Pe,!1);return!e||!e.active.some(t=>t.state!=0)?!1:(i.dispatch({effects:Sn.of(null)}),!0)};class pC{constructor(e,t){this.active=e,this.context=t,this.time=Date.now(),this.updates=[],this.done=void 0}}const mC=50,gC=1e3,AC=ne.fromClass(class{constructor(i){this.view=i,this.debounceUpdate=-1,this.running=[],this.debounceAccept=-1,this.pendingStart=!1,this.composing=0;for(let e of i.state.field(Pe).active)e.isPending&&this.startQuery(e)}update(i){let e=i.state.field(Pe),t=i.state.facet(fe);if(!i.selectionSet&&!i.docChanged&&i.startState.field(Pe)==e)return;let n=i.transactions.some(r=>{let o=up(r,t);return o&8||(r.selection||r.docChanged)&&!(o&3)});for(let r=0;r<this.running.length;r++){let o=this.running[r];if(n||o.context.abortOnDocChange&&i.docChanged||o.updates.length+i.transactions.length>mC&&Date.now()-o.time>gC){for(let l of o.context.abortListeners)try{l()}catch(a){ve(this.view.state,a)}o.context.abortListeners=null,this.running.splice(r--,1)}else o.updates.push(...i.transactions)}this.debounceUpdate>-1&&clearTimeout(this.debounceUpdate),i.transactions.some(r=>r.effects.some(o=>o.is(Ys)))&&(this.pendingStart=!0);let s=this.pendingStart?50:t.activateOnTypingDelay;if(this.debounceUpdate=e.active.some(r=>r.isPending&&!this.running.some(o=>o.active.source==r.source))?setTimeout(()=>this.startUpdate(),s):-1,this.composing!=0)for(let r of i.transactions)r.isUserEvent("input.type")?this.composing=2:this.composing==2&&r.selection&&(this.composing=3)}startUpdate(){this.debounceUpdate=-1,this.pendingStart=!1;let{state:i}=this.view,e=i.field(Pe);for(let t of e.active)t.isPending&&!this.running.some(n=>n.active.source==t.source)&&this.startQuery(t);this.running.length&&e.open&&e.open.disabled&&(this.debounceAccept=setTimeout(()=>this.accept(),this.view.state.facet(fe).updateSyncTime))}startQuery(i){let{state:e}=this.view,t=oi(e),n=new hp(e,t,i.explicit,this.view),s=new pC(i,n);this.running.push(s),Promise.resolve(i.source(n)).then(r=>{s.context.aborted||(s.done=r||null,this.scheduleAccept())},r=>{this.view.dispatch({effects:Sn.of(null)}),ve(this.view.state,r)})}scheduleAccept(){this.running.every(i=>i.done!==void 0)?this.accept():this.debounceAccept<0&&(this.debounceAccept=setTimeout(()=>this.accept(),this.view.state.facet(fe).updateSyncTime))}accept(){var i;this.debounceAccept>-1&&clearTimeout(this.debounceAccept),this.debounceAccept=-1;let e=[],t=this.view.state.facet(fe),n=this.view.state.field(Pe);for(let s=0;s<this.running.length;s++){let r=this.running[s];if(r.done===void 0)continue;if(this.running.splice(s--,1),r.done){let l=oi(r.updates.length?r.updates[0].startState:this.view.state),a=Math.min(l,r.done.from+(r.active.explicit?0:1)),h=new Pi(r.active.source,r.active.explicit,a,r.done,r.done.from,(i=r.done.to)!==null&&i!==void 0?i:l);for(let c of r.updates)h=h.update(c,t);if(h.hasResult()){e.push(h);continue}}let o=n.active.find(l=>l.source==r.active.source);if(o&&o.isPending)if(r.done==null){let l=new Ve(r.active.source,0);for(let a of r.updates)l=l.update(a,t);l.isPending||e.push(l)}else this.startQuery(o)}(e.length||n.open&&n.open.disabled)&&this.view.dispatch({effects:Vl.of(e)})}},{eventHandlers:{blur(i){let e=this.view.state.field(Pe,!1);if(e&&e.tooltip&&this.view.state.facet(fe).closeOnBlur){let t=e.open&&Xf(this.view,e.open.tooltip);(!t||!t.dom.contains(i.relatedTarget))&&setTimeout(()=>this.view.dispatch({effects:Sn.of(null)}),10)}},compositionstart(){this.composing=1},compositionend(){this.composing==3&&setTimeout(()=>this.view.dispatch({effects:Ys.of(!1)}),20),this.composing=0}}}),OC=typeof navigator=="object"&&/Win/.test(navigator.platform),bC=di.highest(Q.domEventHandlers({keydown(i,e){let t=e.state.field(Pe,!1);if(!t||!t.open||t.open.disabled||t.open.selected<0||i.key.length>1||i.ctrlKey&&!(OC&&i.altKey)||i.metaKey)return!1;let n=t.open.options[t.open.selected],s=t.active.find(o=>o.source==n.source),r=n.completion.commitCharacters||s.result.commitCharacters;return r&&r.indexOf(i.key)>-1&&Wl(e,n),!1}})),wC=Q.baseTheme({".cm-tooltip.cm-tooltip-autocomplete":{"& > ul":{fontFamily:"monospace",whiteSpace:"nowrap",overflow:"hidden auto",maxWidth_fallback:"700px",maxWidth:"min(700px, 95vw)",minWidth:"250px",maxHeight:"10em",height:"100%",listStyle:"none",margin:0,padding:0,"& > li, & > completion-section":{padding:"1px 3px",lineHeight:1.2},"& > li":{overflowX:"hidden",textOverflow:"ellipsis",cursor:"pointer"},"& > completion-section":{display:"list-item",borderBottom:"1px solid silver",paddingLeft:"0.5em",opacity:.7}}},"&light .cm-tooltip-autocomplete ul li[aria-selected]":{background:"#17c",color:"white"},"&light .cm-tooltip-autocomplete-disabled ul li[aria-selected]":{background:"#777"},"&dark .cm-tooltip-autocomplete ul li[aria-selected]":{background:"#347",color:"white"},"&dark .cm-tooltip-autocomplete-disabled ul li[aria-selected]":{background:"#444"},".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after":{content:'"···"',opacity:.5,display:"block",textAlign:"center"},".cm-tooltip.cm-completionInfo":{position:"absolute",padding:"3px 9px",width:"max-content",maxWidth:"400px",boxSizing:"border-box",whiteSpace:"pre-line"},".cm-completionInfo.cm-completionInfo-left":{right:"100%"},".cm-completionInfo.cm-completionInfo-right":{left:"100%"},".cm-completionInfo.cm-completionInfo-left-narrow":{right:"30px"},".cm-completionInfo.cm-completionInfo-right-narrow":{left:"30px"},"&light .cm-snippetField":{backgroundColor:"#00000022"},"&dark .cm-snippetField":{backgroundColor:"#ffffff22"},".cm-snippetFieldPosition":{verticalAlign:"text-top",width:0,height:"1.15em",display:"inline-block",margin:"0 -0.7px -.7em",borderLeft:"1.4px dotted #888"},".cm-completionMatchedText":{textDecoration:"underline"},".cm-completionDetail":{marginLeft:"0.5em",fontStyle:"italic"},".cm-completionIcon":{fontSize:"90%",width:".8em",display:"inline-block",textAlign:"center",paddingRight:".6em",opacity:"0.6",boxSizing:"content-box"},".cm-completionIcon-function, .cm-completionIcon-method":{"&:after":{content:"'ƒ'"}},".cm-completionIcon-class":{"&:after":{content:"'○'"}},".cm-completionIcon-interface":{"&:after":{content:"'◌'"}},".cm-completionIcon-variable":{"&:after":{content:"'𝑥'"}},".cm-completionIcon-constant":{"&:after":{content:"'𝐶'"}},".cm-completionIcon-type":{"&:after":{content:"'𝑡'"}},".cm-completionIcon-enum":{"&:after":{content:"'∪'"}},".cm-completionIcon-property":{"&:after":{content:"'□'"}},".cm-completionIcon-keyword":{"&:after":{content:"'🔑︎'"}},".cm-completionIcon-namespace":{"&:after":{content:"'▢'"}},".cm-completionIcon-text":{"&:after":{content:"'abc'",fontSize:"50%",verticalAlign:"middle"}}}),Qn={brackets:["(","[","{","'",'"'],before:")]}:;>",stringPrefixes:[]},ii=R.define({map(i,e){let t=e.mapPos(i,-1,Ce.TrackAfter);return t??void 0}}),Hl=new class extends li{};Hl.startSide=1;Hl.endSide=-1;const pp=ge.define({create(){return _.empty},update(i,e){if(i=i.map(e.changes),e.selection){let t=e.state.doc.lineAt(e.selection.main.head);i=i.update({filter:n=>n>=t.from&&n<=t.to})}for(let t of e.effects)t.is(ii)&&(i=i.update({add:[Hl.range(t.value,t.value+1)]}));return i}});function yC(){return[CC,pp]}const Hr="()[]{}<>«»»«[]{}";function mp(i){for(let e=0;e<Hr.length;e+=2)if(Hr.charCodeAt(e)==i)return Hr.charAt(e+1);return el(i<128?i:i+1)}function gp(i,e){return i.languageDataAt("closeBrackets",e)[0]||Qn}const kC=typeof navigator=="object"&&/Android\b/.test(navigator.userAgent),CC=Q.inputHandler.of((i,e,t,n)=>{if((kC?i.composing:i.compositionStarted)||i.state.readOnly)return!1;let s=i.state.selection.main;if(n.length>2||n.length==2&&dt(Ee(n,0))==1||e!=s.from||t!=s.to)return!1;let r=SC(i.state,n);return r?(i.dispatch(r),!0):!1}),vC=({state:i,dispatch:e})=>{if(i.readOnly)return!1;let n=gp(i,i.selection.main.head).brackets||Qn.brackets,s=null,r=i.changeByRange(o=>{if(o.empty){let l=QC(i.doc,o.head);for(let a of n)if(a==l&&br(i.doc,o.head)==mp(Ee(a,0)))return{changes:{from:o.head-a.length,to:o.head+a.length},range:b.cursor(o.head-a.length)}}return{range:s=o}});return s||e(i.update(r,{scrollIntoView:!0,userEvent:"delete.backward"})),!s},xC=[{key:"Backspace",run:vC}];function SC(i,e){let t=gp(i,i.selection.main.head),n=t.brackets||Qn.brackets;for(let s of n){let r=mp(Ee(s,0));if(e==s)return r==s?PC(i,s,n.indexOf(s+s+s)>-1,t):EC(i,s,r,t.before||Qn.before);if(e==r&&Ap(i,i.selection.main.from))return BC(i,s,r)}return null}function Ap(i,e){let t=!1;return i.field(pp).between(0,i.doc.length,n=>{n==e&&(t=!0)}),t}function br(i,e){let t=i.sliceString(e,e+2);return t.slice(0,dt(Ee(t,0)))}function QC(i,e){let t=i.sliceString(e-2,e);return dt(Ee(t,0))==t.length?t:t.slice(1)}function EC(i,e,t,n){let s=null,r=i.changeByRange(o=>{if(!o.empty)return{changes:[{insert:e,from:o.from},{insert:t,from:o.to}],effects:ii.of(o.to+e.length),range:b.range(o.anchor+e.length,o.head+e.length)};let l=br(i.doc,o.head);return!l||/\s/.test(l)||n.indexOf(l)>-1?{changes:{insert:e+t,from:o.head},effects:ii.of(o.head+e.length),range:b.cursor(o.head+e.length)}:{range:s=o}});return s?null:i.update(r,{scrollIntoView:!0,userEvent:"input.type"})}function BC(i,e,t){let n=null,s=i.changeByRange(r=>r.empty&&br(i.doc,r.head)==t?{changes:{from:r.head,to:r.head+t.length,insert:t},range:b.cursor(r.head+t.length)}:n={range:r});return n?null:i.update(s,{scrollIntoView:!0,userEvent:"input.type"})}function PC(i,e,t,n){let s=n.stringPrefixes||Qn.stringPrefixes,r=null,o=i.changeByRange(l=>{if(!l.empty)return{changes:[{insert:e,from:l.from},{insert:e,from:l.to}],effects:ii.of(l.to+e.length),range:b.range(l.anchor+e.length,l.head+e.length)};let a=l.head,h=br(i.doc,a),c;if(h==e){if(pc(i,a))return{changes:{insert:e+e,from:a},effects:ii.of(a+e.length),range:b.cursor(a+e.length)};if(Ap(i,a)){let u=t&&i.sliceDoc(a,a+e.length*3)==e+e+e?e+e+e:e;return{changes:{from:a,to:a+u.length,insert:u},range:b.cursor(a+u.length)}}}else{if(t&&i.sliceDoc(a-2*e.length,a)==e+e&&(c=mc(i,a-2*e.length,s))>-1&&pc(i,c))return{changes:{insert:e+e+e+e,from:a},effects:ii.of(a+e.length),range:b.cursor(a+e.length)};if(i.charCategorizer(a)(h)!=ee.Word&&mc(i,a,s)>-1&&!MC(i,a,e,s))return{changes:{insert:e+e,from:a},effects:ii.of(a+e.length),range:b.cursor(a+e.length)}}return{range:r=l}});return r?null:i.update(o,{scrollIntoView:!0,userEvent:"input.type"})}function pc(i,e){let t=we(i).resolveInner(e+1);return t.parent&&t.from==e}function MC(i,e,t,n){let s=we(i).resolveInner(e,-1),r=n.reduce((o,l)=>Math.max(o,l.length),0);for(let o=0;o<5;o++){let l=i.sliceDoc(s.from,Math.min(s.to,s.from+t.length+r)),a=l.indexOf(t);if(!a||a>-1&&n.indexOf(l.slice(0,a))>-1){let c=s.firstChild;for(;c&&c.from==s.from&&c.to-c.from>t.length+a;){if(i.sliceDoc(c.to-t.length,c.to)==t)return!1;c=c.firstChild}return!0}let h=s.to==e&&s.parent;if(!h)break;s=h}return!1}function mc(i,e,t){let n=i.charCategorizer(e);if(n(i.sliceDoc(e-1,e))!=ee.Word)return e;for(let s of t){let r=e-s.length;if(i.sliceDoc(r,e)==s&&n(i.sliceDoc(r-1,r))!=ee.Word)return r}return-1}function DC(i={}){return[bC,Pe,fe.of(i),AC,IC,wC]}const Op=[{key:"Ctrl-Space",run:dc},{mac:"Alt-`",run:dc},{key:"Escape",run:dC},{key:"ArrowDown",run:rs(!0)},{key:"ArrowUp",run:rs(!1)},{key:"PageDown",run:rs(!0,"page")},{key:"PageUp",run:rs(!1,"page")},{key:"Enter",run:uC}],IC=di.highest(pl.computeN([fe],i=>i.facet(fe).defaultKeymap?[Op]:[])),TC=[$A(),zA(),sA(),Ak(),x0(),Gg(),Jg(),K.allowMultipleSelections.of(!0),f0(),du(B0,{fallback:!0}),L0(),yC(),DC(),gA(),bA(),cA(),x1(),pl.of([...xC,...b1,...W1,...Sk,...y0,...Op,...X0])];var gc;(function(i){i[i.Static=1]="Static",i[i.Dynamic=2]="Dynamic",i[i.ImportMeta=3]="ImportMeta",i[i.StaticSourcePhase=4]="StaticSourcePhase",i[i.DynamicSourcePhase=5]="DynamicSourcePhase",i[i.StaticDeferPhase=6]="StaticDeferPhase",i[i.DynamicDeferPhase=7]="DynamicDeferPhase"})(gc||(gc={}));const RC=new Uint8Array(new Uint16Array([1]).buffer)[0]===1;function bp(i,e="@"){if(!q)return wp.then((()=>bp(i)));const t=i.length+1,n=(q.__heap_base.value||q.__heap_base)+4*t-q.memory.buffer.byteLength;n>0&&q.memory.grow(Math.ceil(n/65536));const s=q.sa(t-1);if((RC?NC:LC)(i,new Uint16Array(q.memory.buffer,s,t)),!q.parse())throw Object.assign(new Error(`Parse error ${e}:${i.slice(0,q.e()).split(`
102
+ `).length}:${q.e()-i.lastIndexOf(`
103
+ `,q.e()-1)}`),{idx:q.e()});const r=[],o=[];for(;q.ri();){const a=q.is(),h=q.ie(),c=q.it(),f=q.ai(),u=q.id(),d=q.ss(),p=q.se();let m;q.ip()&&(m=l(i.slice(u===-1?a-1:a,u===-1?h+1:h))),r.push({n:m,t:c,s:a,e:h,ss:d,se:p,d:u,a:f})}for(;q.re();){const a=q.es(),h=q.ee(),c=q.els(),f=q.ele(),u=i.slice(a,h),d=u[0],p=c<0?void 0:i.slice(c,f),m=p?p[0]:"";o.push({s:a,e:h,ls:c,le:f,n:d==='"'||d==="'"?l(u):u,ln:m==='"'||m==="'"?l(p):p})}function l(a){try{return(0,eval)(a)}catch{}}return[r,o,!!q.f(),!!q.ms()]}function LC(i,e){const t=i.length;let n=0;for(;n<t;){const s=i.charCodeAt(n);e[n++]=(255&s)<<8|s>>>8}}function NC(i,e){const t=i.length;let n=0;for(;n<t;)e[n]=i.charCodeAt(n++)}let q;const $C=()=>{return i="AGFzbQEAAAABKwhgAX8Bf2AEf39/fwBgAAF/YAAAYAF/AGADf39/AX9gAn9/AX9gA39/fwADMTAAAQECAgICAgICAgICAgICAgICAgIAAwMDBAQAAAUAAAAAAAMDAwAGAAAABwAGAgUEBQFwAQEBBQMBAAEGDwJ/AUHA8gALfwBBwPIACwd6FQZtZW1vcnkCAAJzYQAAAWUAAwJpcwAEAmllAAUCc3MABgJzZQAHAml0AAgCYWkACQJpZAAKAmlwAAsCZXMADAJlZQANA2VscwAOA2VsZQAPAnJpABACcmUAEQFmABICbXMAEwVwYXJzZQAUC19faGVhcF9iYXNlAwEKzkQwaAEBf0EAIAA2AoAKQQAoAtwJIgEgAEEBdGoiAEEAOwEAQQAgAEECaiIANgKECkEAIAA2AogKQQBBADYC4AlBAEEANgLwCUEAQQA2AugJQQBBADYC5AlBAEEANgL4CUEAQQA2AuwJIAEL0wEBA39BACgC8AkhBEEAQQAoAogKIgU2AvAJQQAgBDYC9AlBACAFQSRqNgKICiAEQSBqQeAJIAQbIAU2AgBBACgC1AkhBEEAKALQCSEGIAUgATYCACAFIAA2AgggBSACIAJBAmpBACAGIANGIgAbIAQgA0YiBBs2AgwgBSADNgIUIAVBADYCECAFIAI2AgQgBUEANgIgIAVBA0EBQQIgABsgBBs2AhwgBUEAKALQCSADRiICOgAYAkACQCACDQBBACgC1AkgA0cNAQtBAEEBOgCMCgsLXgEBf0EAKAL4CSIEQRBqQeQJIAQbQQAoAogKIgQ2AgBBACAENgL4CUEAIARBFGo2AogKQQBBAToAjAogBEEANgIQIAQgAzYCDCAEIAI2AgggBCABNgIEIAQgADYCAAsIAEEAKAKQCgsVAEEAKALoCSgCAEEAKALcCWtBAXULHgEBf0EAKALoCSgCBCIAQQAoAtwJa0EBdUF/IAAbCxUAQQAoAugJKAIIQQAoAtwJa0EBdQseAQF/QQAoAugJKAIMIgBBACgC3AlrQQF1QX8gABsLCwBBACgC6AkoAhwLHgEBf0EAKALoCSgCECIAQQAoAtwJa0EBdUF/IAAbCzsBAX8CQEEAKALoCSgCFCIAQQAoAtAJRw0AQX8PCwJAIABBACgC1AlHDQBBfg8LIABBACgC3AlrQQF1CwsAQQAoAugJLQAYCxUAQQAoAuwJKAIAQQAoAtwJa0EBdQsVAEEAKALsCSgCBEEAKALcCWtBAXULHgEBf0EAKALsCSgCCCIAQQAoAtwJa0EBdUF/IAAbCx4BAX9BACgC7AkoAgwiAEEAKALcCWtBAXVBfyAAGwslAQF/QQBBACgC6AkiAEEgakHgCSAAGygCACIANgLoCSAAQQBHCyUBAX9BAEEAKALsCSIAQRBqQeQJIAAbKAIAIgA2AuwJIABBAEcLCABBAC0AlAoLCABBAC0AjAoL3Q0BBX8jAEGA0ABrIgAkAEEAQQE6AJQKQQBBACgC2Ak2ApwKQQBBACgC3AlBfmoiATYCsApBACABQQAoAoAKQQF0aiICNgK0CkEAQQA6AIwKQQBBADsBlgpBAEEAOwGYCkEAQQA6AKAKQQBBADYCkApBAEEAOgD8CUEAIABBgBBqNgKkCkEAIAA2AqgKQQBBADoArAoCQAJAAkACQANAQQAgAUECaiIDNgKwCiABIAJPDQECQCADLwEAIgJBd2pBBUkNAAJAAkACQAJAAkAgAkGbf2oOBQEICAgCAAsgAkEgRg0EIAJBL0YNAyACQTtGDQIMBwtBAC8BmAoNASADEBVFDQEgAUEEakGCCEEKEC8NARAWQQAtAJQKDQFBAEEAKAKwCiIBNgKcCgwHCyADEBVFDQAgAUEEakGMCEEKEC8NABAXC0EAQQAoArAKNgKcCgwBCwJAIAEvAQQiA0EqRg0AIANBL0cNBBAYDAELQQEQGQtBACgCtAohAkEAKAKwCiEBDAALC0EAIQIgAyEBQQAtAPwJDQIMAQtBACABNgKwCkEAQQA6AJQKCwNAQQAgAUECaiIDNgKwCgJAAkACQAJAAkACQAJAIAFBACgCtApPDQAgAy8BACICQXdqQQVJDQYCQAJAAkACQAJAAkACQAJAAkACQCACQWBqDgoQDwYPDw8PBQECAAsCQAJAAkACQCACQaB/ag4KCxISAxIBEhISAgALIAJBhX9qDgMFEQYJC0EALwGYCg0QIAMQFUUNECABQQRqQYIIQQoQLw0QEBYMEAsgAxAVRQ0PIAFBBGpBjAhBChAvDQ8QFwwPCyADEBVFDQ4gASkABELsgISDsI7AOVINDiABLwEMIgNBd2oiAUEXSw0MQQEgAXRBn4CABHFFDQwMDQtBAEEALwGYCiIBQQFqOwGYCkEAKAKkCiABQQN0aiIBQQE2AgAgAUEAKAKcCjYCBAwNC0EALwGYCiIDRQ0JQQAgA0F/aiIDOwGYCkEALwGWCiICRQ0MQQAoAqQKIANB//8DcUEDdGooAgBBBUcNDAJAIAJBAnRBACgCqApqQXxqKAIAIgMoAgQNACADQQAoApwKQQJqNgIEC0EAIAJBf2o7AZYKIAMgAUEEajYCDAwMCwJAQQAoApwKIgEvAQBBKUcNAEEAKALwCSIDRQ0AIAMoAgQgAUcNAEEAQQAoAvQJIgM2AvAJAkAgA0UNACADQQA2AiAMAQtBAEEANgLgCQtBAEEALwGYCiIDQQFqOwGYCkEAKAKkCiADQQN0aiIDQQZBAkEALQCsChs2AgAgAyABNgIEQQBBADoArAoMCwtBAC8BmAoiAUUNB0EAIAFBf2oiATsBmApBACgCpAogAUH//wNxQQN0aigCAEEERg0EDAoLQScQGgwJC0EiEBoMCAsgAkEvRw0HAkACQCABLwEEIgFBKkYNACABQS9HDQEQGAwKC0EBEBkMCQsCQAJAAkACQEEAKAKcCiIBLwEAIgMQG0UNAAJAAkAgA0FVag4EAAkBAwkLIAFBfmovAQBBK0YNAwwICyABQX5qLwEAQS1GDQIMBwsgA0EpRw0BQQAoAqQKQQAvAZgKIgJBA3RqKAIEEBxFDQIMBgsgAUF+ai8BAEFQakH//wNxQQpPDQULQQAvAZgKIQILAkACQCACQf//A3EiAkUNACADQeYARw0AQQAoAqQKIAJBf2pBA3RqIgQoAgBBAUcNACABQX5qLwEAQe8ARw0BIAQoAgRBlghBAxAdRQ0BDAULIANB/QBHDQBBACgCpAogAkEDdGoiAigCBBAeDQQgAigCAEEGRg0ECyABEB8NAyADRQ0DIANBL0ZBAC0AoApBAEdxDQMCQEEAKAL4CSICRQ0AIAEgAigCAEkNACABIAIoAgRNDQQLIAFBfmohAUEAKALcCSECAkADQCABQQJqIgQgAk0NAUEAIAE2ApwKIAEvAQAhAyABQX5qIgQhASADECBFDQALIARBAmohBAsCQCADQf//A3EQIUUNACAEQX5qIQECQANAIAFBAmoiAyACTQ0BQQAgATYCnAogAS8BACEDIAFBfmoiBCEBIAMQIQ0ACyAEQQJqIQMLIAMQIg0EC0EAQQE6AKAKDAcLQQAoAqQKQQAvAZgKIgFBA3QiA2pBACgCnAo2AgRBACABQQFqOwGYCkEAKAKkCiADakEDNgIACxAjDAULQQAtAPwJQQAvAZYKQQAvAZgKcnJFIQIMBwsQJEEAQQA6AKAKDAMLECVBACECDAULIANBoAFHDQELQQBBAToArAoLQQBBACgCsAo2ApwKC0EAKAKwCiEBDAALCyAAQYDQAGokACACCxoAAkBBACgC3AkgAEcNAEEBDwsgAEF+ahAmC/4KAQZ/QQBBACgCsAoiAEEMaiIBNgKwCkEAKAL4CSECQQEQKSEDAkACQAJAAkACQAJAAkACQAJAQQAoArAKIgQgAUcNACADEChFDQELAkACQAJAAkACQAJAAkAgA0EqRg0AIANB+wBHDQFBACAEQQJqNgKwCkEBECkhA0EAKAKwCiEEA0ACQAJAIANB//8DcSIDQSJGDQAgA0EnRg0AIAMQLBpBACgCsAohAwwBCyADEBpBAEEAKAKwCkECaiIDNgKwCgtBARApGgJAIAQgAxAtIgNBLEcNAEEAQQAoArAKQQJqNgKwCkEBECkhAwsgA0H9AEYNA0EAKAKwCiIFIARGDQ8gBSEEIAVBACgCtApNDQAMDwsLQQAgBEECajYCsApBARApGkEAKAKwCiIDIAMQLRoMAgtBAEEAOgCUCgJAAkACQAJAAkACQCADQZ9/ag4MAgsEAQsDCwsLCwsFAAsgA0H2AEYNBAwKC0EAIARBDmoiAzYCsAoCQAJAAkBBARApQZ9/ag4GABICEhIBEgtBACgCsAoiBSkAAkLzgOSD4I3AMVINESAFLwEKECFFDRFBACAFQQpqNgKwCkEAECkaC0EAKAKwCiIFQQJqQbIIQQ4QLw0QIAUvARAiAkF3aiIBQRdLDQ1BASABdEGfgIAEcUUNDQwOC0EAKAKwCiIFKQACQuyAhIOwjsA5Ug0PIAUvAQoiAkF3aiIBQRdNDQYMCgtBACAEQQpqNgKwCkEAECkaQQAoArAKIQQLQQAgBEEQajYCsAoCQEEBECkiBEEqRw0AQQBBACgCsApBAmo2ArAKQQEQKSEEC0EAKAKwCiEDIAQQLBogA0EAKAKwCiIEIAMgBBACQQBBACgCsApBfmo2ArAKDwsCQCAEKQACQuyAhIOwjsA5Ug0AIAQvAQoQIEUNAEEAIARBCmo2ArAKQQEQKSEEQQAoArAKIQMgBBAsGiADQQAoArAKIgQgAyAEEAJBAEEAKAKwCkF+ajYCsAoPC0EAIARBBGoiBDYCsAoLQQAgBEEGajYCsApBAEEAOgCUCkEBECkhBEEAKAKwCiEDIAQQLCEEQQAoArAKIQIgBEHf/wNxIgFB2wBHDQNBACACQQJqNgKwCkEBECkhBUEAKAKwCiEDQQAhBAwEC0EAQQE6AIwKQQBBACgCsApBAmo2ArAKC0EBECkhBEEAKAKwCiEDAkAgBEHmAEcNACADQQJqQawIQQYQLw0AQQAgA0EIajYCsAogAEEBEClBABArIAJBEGpB5AkgAhshAwNAIAMoAgAiA0UNBSADQgA3AgggA0EQaiEDDAALC0EAIANBfmo2ArAKDAMLQQEgAXRBn4CABHFFDQMMBAtBASEECwNAAkACQCAEDgIAAQELIAVB//8DcRAsGkEBIQQMAQsCQAJAQQAoArAKIgQgA0YNACADIAQgAyAEEAJBARApIQQCQCABQdsARw0AIARBIHJB/QBGDQQLQQAoArAKIQMCQCAEQSxHDQBBACADQQJqNgKwCkEBECkhBUEAKAKwCiEDIAVBIHJB+wBHDQILQQAgA0F+ajYCsAoLIAFB2wBHDQJBACACQX5qNgKwCg8LQQAhBAwACwsPCyACQaABRg0AIAJB+wBHDQQLQQAgBUEKajYCsApBARApIgVB+wBGDQMMAgsCQCACQVhqDgMBAwEACyACQaABRw0CC0EAIAVBEGo2ArAKAkBBARApIgVBKkcNAEEAQQAoArAKQQJqNgKwCkEBECkhBQsgBUEoRg0BC0EAKAKwCiEBIAUQLBpBACgCsAoiBSABTQ0AIAQgAyABIAUQAkEAQQAoArAKQX5qNgKwCg8LIAQgA0EAQQAQAkEAIARBDGo2ArAKDwsQJQuFDAEKf0EAQQAoArAKIgBBDGoiATYCsApBARApIQJBACgCsAohAwJAAkACQAJAAkACQAJAAkAgAkEuRw0AQQAgA0ECajYCsAoCQEEBECkiAkHkAEYNAAJAIAJB8wBGDQAgAkHtAEcNB0EAKAKwCiICQQJqQZwIQQYQLw0HAkBBACgCnAoiAxAqDQAgAy8BAEEuRg0ICyAAIAAgAkEIakEAKALUCRABDwtBACgCsAoiAkECakGiCEEKEC8NBgJAQQAoApwKIgMQKg0AIAMvAQBBLkYNBwtBACEEQQAgAkEMajYCsApBASEFQQUhBkEBECkhAkEAIQdBASEIDAILQQAoArAKIgIpAAJC5YCYg9CMgDlSDQUCQEEAKAKcCiIDECoNACADLwEAQS5GDQYLQQAhBEEAIAJBCmo2ArAKQQIhCEEHIQZBASEHQQEQKSECQQEhBQwBCwJAAkACQAJAIAJB8wBHDQAgAyABTQ0AIANBAmpBoghBChAvDQACQCADLwEMIgRBd2oiB0EXSw0AQQEgB3RBn4CABHENAgsgBEGgAUYNAQtBACEHQQchBkEBIQQgAkHkAEYNAQwCC0EAIQRBACADQQxqIgI2ArAKQQEhBUEBECkhCQJAQQAoArAKIgYgAkYNAEHmACECAkAgCUHmAEYNAEEFIQZBACEHQQEhCCAJIQIMBAtBACEHQQEhCCAGQQJqQawIQQYQLw0EIAYvAQgQIEUNBAtBACEHQQAgAzYCsApBByEGQQEhBEEAIQVBACEIIAkhAgwCCyADIABBCmpNDQBBACEIQeQAIQICQCADKQACQuWAmIPQjIA5Ug0AAkACQCADLwEKIgRBd2oiB0EXSw0AQQEgB3RBn4CABHENAQtBACEIIARBoAFHDQELQQAhBUEAIANBCmo2ArAKQSohAkEBIQdBAiEIQQEQKSIJQSpGDQRBACADNgKwCkEBIQRBACEHQQAhCCAJIQIMAgsgAyEGQQAhBwwCC0EAIQVBACEICwJAIAJBKEcNAEEAKAKkCkEALwGYCiICQQN0aiIDQQAoArAKNgIEQQAgAkEBajsBmAogA0EFNgIAQQAoApwKLwEAQS5GDQRBAEEAKAKwCiIDQQJqNgKwCkEBECkhAiAAQQAoArAKQQAgAxABAkACQCAFDQBBACgC8AkhAQwBC0EAKALwCSIBIAY2AhwLQQBBAC8BlgoiA0EBajsBlgpBACgCqAogA0ECdGogATYCAAJAIAJBIkYNACACQSdGDQBBAEEAKAKwCkF+ajYCsAoPCyACEBpBAEEAKAKwCkECaiICNgKwCgJAAkACQEEBEClBV2oOBAECAgACC0EAQQAoArAKQQJqNgKwCkEBECkaQQAoAvAJIgMgAjYCBCADQQE6ABggA0EAKAKwCiICNgIQQQAgAkF+ajYCsAoPC0EAKALwCSIDIAI2AgQgA0EBOgAYQQBBAC8BmApBf2o7AZgKIANBACgCsApBAmo2AgxBAEEALwGWCkF/ajsBlgoPC0EAQQAoArAKQX5qNgKwCg8LAkAgBEEBcyACQfsAR3INAEEAKAKwCiECQQAvAZgKDQUDQAJAAkACQCACQQAoArQKTw0AQQEQKSICQSJGDQEgAkEnRg0BIAJB/QBHDQJBAEEAKAKwCkECajYCsAoLQQEQKSEDQQAoArAKIQICQCADQeYARw0AIAJBAmpBrAhBBhAvDQcLQQAgAkEIajYCsAoCQEEBECkiAkEiRg0AIAJBJ0cNBwsgACACQQAQKw8LIAIQGgtBAEEAKAKwCkECaiICNgKwCgwACwsCQAJAIAJBWWoOBAMBAQMACyACQSJGDQILQQAoArAKIQYLIAYgAUcNAEEAIABBCmo2ArAKDwsgAkEqRyAHcQ0DQQAvAZgKQf//A3ENA0EAKAKwCiECQQAoArQKIQEDQCACIAFPDQECQAJAIAIvAQAiA0EnRg0AIANBIkcNAQsgACADIAgQKw8LQQAgAkECaiICNgKwCgwACwsQJQsPC0EAIAJBfmo2ArAKDwtBAEEAKAKwCkF+ajYCsAoLRwEDf0EAKAKwCkECaiEAQQAoArQKIQECQANAIAAiAkF+aiABTw0BIAJBAmohACACLwEAQXZqDgQBAAABAAsLQQAgAjYCsAoLmAEBA39BAEEAKAKwCiIBQQJqNgKwCiABQQZqIQFBACgCtAohAgNAAkACQAJAIAFBfGogAk8NACABQX5qLwEAIQMCQAJAIAANACADQSpGDQEgA0F2ag4EAgQEAgQLIANBKkcNAwsgAS8BAEEvRw0CQQAgAUF+ajYCsAoMAQsgAUF+aiEBC0EAIAE2ArAKDwsgAUECaiEBDAALC4gBAQR/QQAoArAKIQFBACgCtAohAgJAAkADQCABIgNBAmohASADIAJPDQEgAS8BACIEIABGDQICQCAEQdwARg0AIARBdmoOBAIBAQIBCyADQQRqIQEgAy8BBEENRw0AIANBBmogASADLwEGQQpGGyEBDAALC0EAIAE2ArAKECUPC0EAIAE2ArAKC2wBAX8CQAJAIABBX2oiAUEFSw0AQQEgAXRBMXENAQsgAEFGakH//wNxQQZJDQAgAEEpRyAAQVhqQf//A3FBB0lxDQACQCAAQaV/ag4EAQAAAQALIABB/QBHIABBhX9qQf//A3FBBElxDwtBAQsuAQF/QQEhAQJAIABBpglBBRAdDQAgAEGWCEEDEB0NACAAQbAJQQIQHSEBCyABC0YBA39BACEDAkAgACACQQF0IgJrIgRBAmoiAEEAKALcCSIFSQ0AIAAgASACEC8NAAJAIAAgBUcNAEEBDwsgBBAmIQMLIAMLgwEBAn9BASEBAkACQAJAAkACQAJAIAAvAQAiAkFFag4EBQQEAQALAkAgAkGbf2oOBAMEBAIACyACQSlGDQQgAkH5AEcNAyAAQX5qQbwJQQYQHQ8LIABBfmovAQBBPUYPCyAAQX5qQbQJQQQQHQ8LIABBfmpByAlBAxAdDwtBACEBCyABC7QDAQJ/QQAhAQJAAkACQAJAAkACQAJAAkACQAJAIAAvAQBBnH9qDhQAAQIJCQkJAwkJBAUJCQYJBwkJCAkLAkACQCAAQX5qLwEAQZd/ag4EAAoKAQoLIABBfGpByghBAhAdDwsgAEF8akHOCEEDEB0PCwJAAkACQCAAQX5qLwEAQY1/ag4DAAECCgsCQCAAQXxqLwEAIgJB4QBGDQAgAkHsAEcNCiAAQXpqQeUAECcPCyAAQXpqQeMAECcPCyAAQXxqQdQIQQQQHQ8LIABBfGpB3AhBBhAdDwsgAEF+ai8BAEHvAEcNBiAAQXxqLwEAQeUARw0GAkAgAEF6ai8BACICQfAARg0AIAJB4wBHDQcgAEF4akHoCEEGEB0PCyAAQXhqQfQIQQIQHQ8LIABBfmpB+AhBBBAdDwtBASEBIABBfmoiAEHpABAnDQQgAEGACUEFEB0PCyAAQX5qQeQAECcPCyAAQX5qQYoJQQcQHQ8LIABBfmpBmAlBBBAdDwsCQCAAQX5qLwEAIgJB7wBGDQAgAkHlAEcNASAAQXxqQe4AECcPCyAAQXxqQaAJQQMQHSEBCyABCzQBAX9BASEBAkAgAEF3akH//wNxQQVJDQAgAEGAAXJBoAFGDQAgAEEuRyAAEChxIQELIAELMAEBfwJAAkAgAEF3aiIBQRdLDQBBASABdEGNgIAEcQ0BCyAAQaABRg0AQQAPC0EBC04BAn9BACEBAkACQCAALwEAIgJB5QBGDQAgAkHrAEcNASAAQX5qQfgIQQQQHQ8LIABBfmovAQBB9QBHDQAgAEF8akHcCEEGEB0hAQsgAQveAQEEf0EAKAKwCiEAQQAoArQKIQECQAJAAkADQCAAIgJBAmohACACIAFPDQECQAJAAkAgAC8BACIDQaR/ag4FAgMDAwEACyADQSRHDQIgAi8BBEH7AEcNAkEAIAJBBGoiADYCsApBAEEALwGYCiICQQFqOwGYCkEAKAKkCiACQQN0aiICQQQ2AgAgAiAANgIEDwtBACAANgKwCkEAQQAvAZgKQX9qIgA7AZgKQQAoAqQKIABB//8DcUEDdGooAgBBA0cNAwwECyACQQRqIQAMAAsLQQAgADYCsAoLECULC3ABAn8CQAJAA0BBAEEAKAKwCiIAQQJqIgE2ArAKIABBACgCtApPDQECQAJAAkAgAS8BACIBQaV/ag4CAQIACwJAIAFBdmoOBAQDAwQACyABQS9HDQIMBAsQLhoMAQtBACAAQQRqNgKwCgwACwsQJQsLNQEBf0EAQQE6APwJQQAoArAKIQBBAEEAKAK0CkECajYCsApBACAAQQAoAtwJa0EBdTYCkAoLQwECf0EBIQECQCAALwEAIgJBd2pB//8DcUEFSQ0AIAJBgAFyQaABRg0AQQAhASACEChFDQAgAkEuRyAAECpyDwsgAQs9AQJ/QQAhAgJAQQAoAtwJIgMgAEsNACAALwEAIAFHDQACQCADIABHDQBBAQ8LIABBfmovAQAQICECCyACC2gBAn9BASEBAkACQCAAQV9qIgJBBUsNAEEBIAJ0QTFxDQELIABB+P8DcUEoRg0AIABBRmpB//8DcUEGSQ0AAkAgAEGlf2oiAkEDSw0AIAJBAUcNAQsgAEGFf2pB//8DcUEESSEBCyABC5wBAQN/QQAoArAKIQECQANAAkACQCABLwEAIgJBL0cNAAJAIAEvAQIiAUEqRg0AIAFBL0cNBBAYDAILIAAQGQwBCwJAAkAgAEUNACACQXdqIgFBF0sNAUEBIAF0QZ+AgARxRQ0BDAILIAIQIUUNAwwBCyACQaABRw0CC0EAQQAoArAKIgNBAmoiATYCsAogA0EAKAK0CkkNAAsLIAILMQEBf0EAIQECQCAALwEAQS5HDQAgAEF+ai8BAEEuRw0AIABBfGovAQBBLkYhAQsgAQumBAEBfwJAIAFBIkYNACABQSdGDQAQJQ8LQQAoArAKIQMgARAaIAAgA0ECakEAKAKwCkEAKALQCRABAkAgAkEBSA0AQQAoAvAJQQRBBiACQQFGGzYCHAtBAEEAKAKwCkECajYCsAoCQAJAAkACQEEAECkiAUHhAEYNACABQfcARg0BQQAoArAKIQEMAgtBACgCsAoiAUECakHACEEKEC8NAUEGIQIMAgtBACgCsAoiAS8BAkHpAEcNACABLwEEQfQARw0AQQQhAiABLwEGQegARg0BC0EAIAFBfmo2ArAKDwtBACABIAJBAXRqNgKwCgJAQQEQKUH7AEYNAEEAIAE2ArAKDwtBACgCsAoiACECA0BBACACQQJqNgKwCgJAAkACQEEBECkiAkEiRg0AIAJBJ0cNAUEnEBpBAEEAKAKwCkECajYCsApBARApIQIMAgtBIhAaQQBBACgCsApBAmo2ArAKQQEQKSECDAELIAIQLCECCwJAIAJBOkYNAEEAIAE2ArAKDwtBAEEAKAKwCkECajYCsAoCQEEBECkiAkEiRg0AIAJBJ0YNAEEAIAE2ArAKDwsgAhAaQQBBACgCsApBAmo2ArAKAkACQEEBECkiAkEsRg0AIAJB/QBGDQFBACABNgKwCg8LQQBBACgCsApBAmo2ArAKQQEQKUH9AEYNAEEAKAKwCiECDAELC0EAKALwCSIBIAA2AhAgAUEAKAKwCkECajYCDAttAQJ/AkACQANAAkAgAEH//wNxIgFBd2oiAkEXSw0AQQEgAnRBn4CABHENAgsgAUGgAUYNASAAIQIgARAoDQJBACECQQBBACgCsAoiAEECajYCsAogAC8BAiIADQAMAgsLIAAhAgsgAkH//wNxC6sBAQR/AkACQEEAKAKwCiICLwEAIgNB4QBGDQAgASEEIAAhBQwBC0EAIAJBBGo2ArAKQQEQKSECQQAoArAKIQUCQAJAIAJBIkYNACACQSdGDQAgAhAsGkEAKAKwCiEEDAELIAIQGkEAQQAoArAKQQJqIgQ2ArAKC0EBECkhA0EAKAKwCiECCwJAIAIgBUYNACAFIARBACAAIAAgAUYiAhtBACABIAIbEAILIAMLcgEEf0EAKAKwCiEAQQAoArQKIQECQAJAA0AgAEECaiECIAAgAU8NAQJAAkAgAi8BACIDQaR/ag4CAQQACyACIQAgA0F2ag4EAgEBAgELIABBBGohAAwACwtBACACNgKwChAlQQAPC0EAIAI2ArAKQd0AC0kBA39BACEDAkAgAkUNAAJAA0AgAC0AACIEIAEtAAAiBUcNASABQQFqIQEgAEEBaiEAIAJBf2oiAg0ADAILCyAEIAVrIQMLIAMLC+wBAgBBgAgLzgEAAHgAcABvAHIAdABtAHAAbwByAHQAZgBvAHIAZQB0AGEAbwB1AHIAYwBlAHIAbwBtAHUAbgBjAHQAaQBvAG4AcwBzAGUAcgB0AHYAbwB5AGkAZQBkAGUAbABlAGMAbwBuAHQAaQBuAGkAbgBzAHQAYQBuAHQAeQBiAHIAZQBhAHIAZQB0AHUAcgBkAGUAYgB1AGcAZwBlAGEAdwBhAGkAdABoAHIAdwBoAGkAbABlAGkAZgBjAGEAdABjAGYAaQBuAGEAbABsAGUAbABzAABB0AkLEAEAAAACAAAAAAQAAEA5AAA=",typeof Buffer<"u"?Buffer.from(i,"base64"):Uint8Array.from(atob(i),(e=>e.charCodeAt(0)));var i},wp=WebAssembly.compile($C()).then(WebAssembly.instantiate).then((({exports:i})=>{q=i})),FC=wp,KC=/package\/dist\/(.+)\/weslBundle\.js$/,zC=/package\/dist\/weslBundle\.js$/,_C=/export\s+const\s+weslBundle\s*=\s*({[\s\S]+});?\s*$/m,VC=/import\s+(\w+)\s+from/;async function yp(i,e=new Map){await FC;for(const t of i){const{content:n,packagePath:s,packageName:r}=t,o=HC(n),l=qC(s,r);e.set(l,o)}return e}async function WC(i,e){const t=new Map,n=[];for(const s of i.keys())n.push(await kp(s,i,t,e));return n}function HC(i){const e=i.match(_C);if(!e)throw new Error("Could not find weslBundle export in bundle");const[t]=bp(i),n=t.map(s=>{const r=i.slice(s.ss,s.se),o=r.match(VC);if(!o)throw new Error(`Could not parse import variable name from: ${r}`);return{varName:o[1],path:s.n.replace(/\//g,"::")}});return{bundleLiteral:e[1],imports:n}}function qC(i,e){const t=i.match(KC);if(t){const s=t[1].replace(/\//g,"::");return`${e}::${s}`}if(i.match(zC))return e;throw new Error(`Invalid bundle file path: ${i}`)}async function kp(i,e,t,n){const s=t.get(i);if(s)return s;let r=e.get(i);if(!r){if(!n)throw new Error(`Bundle not found in registry: ${i}`);const f=i.split("::")[0],u=await n(f);if(await yp(u,e),r=e.get(i),!r)throw new Error(`Bundle not found after fetch: ${i}`)}const o={};t.set(i,o);const l=r.imports.map(f=>f.varName),a=await Promise.all(r.imports.map(f=>kp(f.path,e,t,n))),c=new Function(...l,`'use strict'; return ${r.bundleLiteral}`)(...a);return Object.assign(o,c),o}var Ne=Uint8Array,Ci=Uint16Array,GC=Int32Array,Cp=new Ne([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),vp=new Ne([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),UC=new Ne([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),xp=function(i,e){for(var t=new Ci(31),n=0;n<31;++n)t[n]=e+=1<<i[n-1];for(var s=new GC(t[30]),n=1;n<30;++n)for(var r=t[n];r<t[n+1];++r)s[r]=r-t[n]<<5|n;return{b:t,r:s}},Sp=xp(Cp,2),Qp=Sp.b,YC=Sp.r;Qp[28]=258,YC[258]=28;var XC=xp(vp,0),jC=XC.b,Yo=new Ci(32768);for(var J=0;J<32768;++J){var Dt=(J&43690)>>1|(J&21845)<<1;Dt=(Dt&52428)>>2|(Dt&13107)<<2,Dt=(Dt&61680)>>4|(Dt&3855)<<4,Yo[J]=((Dt&65280)>>8|(Dt&255)<<8)>>1}var an=(function(i,e,t){for(var n=i.length,s=0,r=new Ci(e);s<n;++s)i[s]&&++r[i[s]-1];var o=new Ci(e);for(s=1;s<e;++s)o[s]=o[s-1]+r[s-1]<<1;var l;if(t){l=new Ci(1<<e);var a=15-e;for(s=0;s<n;++s)if(i[s])for(var h=s<<4|i[s],c=e-i[s],f=o[i[s]-1]++<<c,u=f|(1<<c)-1;f<=u;++f)l[Yo[f]>>a]=h}else for(l=new Ci(n),s=0;s<n;++s)i[s]&&(l[s]=Yo[o[i[s]-1]++]>>15-i[s]);return l}),Rn=new Ne(288);for(var J=0;J<144;++J)Rn[J]=8;for(var J=144;J<256;++J)Rn[J]=9;for(var J=256;J<280;++J)Rn[J]=7;for(var J=280;J<288;++J)Rn[J]=8;var Ep=new Ne(32);for(var J=0;J<32;++J)Ep[J]=5;var JC=an(Rn,9,1),ZC=an(Ep,5,1),qr=function(i){for(var e=i[0],t=1;t<i.length;++t)i[t]>e&&(e=i[t]);return e},Je=function(i,e,t){var n=e/8|0;return(i[n]|i[n+1]<<8)>>(e&7)&t},Gr=function(i,e){var t=e/8|0;return(i[t]|i[t+1]<<8|i[t+2]<<16)>>(e&7)},ev=function(i){return(i+7)/8|0},tv=function(i,e,t){return(t==null||t>i.length)&&(t=i.length),new Ne(i.subarray(e,t))},iv=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],Ze=function(i,e,t){var n=new Error(e||iv[i]);if(n.code=i,Error.captureStackTrace&&Error.captureStackTrace(n,Ze),!t)throw n;return n},nv=function(i,e,t,n){var s=i.length,r=0;if(!s||e.f&&!e.l)return t||new Ne(0);var o=!t,l=o||e.i!=2,a=e.i;o&&(t=new Ne(s*3));var h=function(Ul){var Yl=t.length;if(Ul>Yl){var Xl=new Ne(Math.max(Yl*2,Ul));Xl.set(t),t=Xl}},c=e.f||0,f=e.p||0,u=e.b||0,d=e.l,p=e.d,m=e.m,g=e.n,O=s*8;do{if(!d){c=Je(i,f,1);var w=Je(i,f+1,3);if(f+=3,w)if(w==1)d=JC,p=ZC,m=9,g=5;else if(w==2){var C=Je(i,f,31)+257,x=Je(i,f+10,15)+4,I=C+Je(i,f+5,31)+1;f+=14;for(var T=new Ne(I),V=new Ne(19),M=0;M<x;++M)V[UC[M]]=Je(i,f+M*3,7);f+=x*3;for(var P=qr(V),W=(1<<P)-1,z=an(V,P,1),M=0;M<I;){var H=z[Je(i,f,W)];f+=H&15;var k=H>>4;if(k<16)T[M++]=k;else{var te=0,he=0;for(k==16?(he=3+Je(i,f,3),f+=2,te=T[M-1]):k==17?(he=3+Je(i,f,7),f+=3):k==18&&(he=11+Je(i,f,127),f+=7);he--;)T[M++]=te}}var Ie=T.subarray(0,C),X=T.subarray(C);m=qr(Ie),g=qr(X),d=an(Ie,m,1),p=an(X,g,1)}else Ze(1);else{var k=ev(f)+4,v=i[k-4]|i[k-3]<<8,y=k+v;if(y>s){a&&Ze(0);break}l&&h(u+v),t.set(i.subarray(k,y),u),e.b=u+=v,e.p=f=y*8,e.f=c;continue}if(f>O){a&&Ze(0);break}}l&&h(u+131072);for(var Qe=(1<<m)-1,je=(1<<g)-1,Ae=f;;Ae=f){var te=d[Gr(i,f)&Qe],ue=te>>4;if(f+=te&15,f>O){a&&Ze(0);break}if(te||Ze(2),ue<256)t[u++]=ue;else if(ue==256){Ae=f,d=null;break}else{var ot=ue-254;if(ue>264){var M=ue-257,Ke=Cp[M];ot=Je(i,f,(1<<Ke)-1)+Qp[M],f+=Ke}var Mt=p[Gr(i,f)&je],pi=Mt>>4;Mt||Ze(3),f+=Mt&15;var X=jC[pi];if(pi>3){var Ke=vp[pi];X+=Gr(i,f)&(1<<Ke)-1,f+=Ke}if(f>O){a&&Ze(0);break}l&&h(u+131072);var ql=u+ot;if(u<X){var Gl=r-X,Rp=Math.min(X,ql);for(Gl+u<0&&Ze(3);u<Rp;++u)t[u]=n[Gl+u]}for(;u<ql;++u)t[u]=t[u-X]}}e.l=d,e.p=Ae,e.b=u,e.f=c,d&&(c=1,e.m=m,e.d=p,e.n=g)}while(!c);return u!=t.length&&o?tv(t,0,u):t.subarray(0,u)},sv=new Ne(0),rv=function(i){(i[0]!=31||i[1]!=139||i[2]!=8)&&Ze(6,"invalid gzip data");var e=i[3],t=10;e&4&&(t+=(i[10]|i[11]<<8)+2);for(var n=(e>>3&1)+(e>>4&1);n>0;n-=!i[t++]);return t+(e&2)},ov=function(i){var e=i.length;return(i[e-4]|i[e-3]<<8|i[e-2]<<16|i[e-1]<<24)>>>0};function lv(i,e){var t=rv(i);return t+8>i.length&&Ze(6,"invalid gzip data"),nv(i.subarray(t,-8),{i:2},new Ne(ov(i)),e)}var av=typeof TextDecoder<"u"&&new TextDecoder,hv=0;try{av.decode(sv,{stream:!0}),hv=1}catch{}const cv=0,Ac=5;function fv(i,e){const t=i.buffer||i,n=[];let s=0;for(;s<t.byteLength-512;){const r=gi(t,s,100);if(r.length===0)break;const o=gi(t,s+100,8).trim(),l=Number.parseInt(gi(t,s+108,8)),a=Number.parseInt(gi(t,s+116,8)),h=Ur(t,s+124,12),c=512+512*Math.trunc(h/512)+(h%512?512:0),f=Ur(t,s+136,12),u=Ur(t,s+156,1),d=u===cv?"file":u===Ac?"directory":u,p=gi(t,s+265,32),m=gi(t,s+297,32),g={name:r,type:d,size:h,attrs:{mode:o,uid:l,gid:a,mtime:f,user:p,group:m}},O=u===Ac?void 0:new Uint8Array(t,s+512,h);n.push({...g,data:O,get text(){return new TextDecoder().decode(this.data)}}),s+=c}return n}function gi(i,e,t){const n=new Uint8Array(i,e,t),s=n.indexOf(0);return new TextDecoder().decode(s===-1?n:n.slice(0,s))}function Ur(i,e,t){const n=new Uint8Array(i,e,t);let s="";for(let r=0;r<t;r++)s+=String.fromCodePoint(n[r]);return Number.parseInt(s,8)}const uv=Bp(mv),dv=Bp(gv);async function pv(i){const e=await dv(i);return Av(e)}function Bp(i){const e=new Map;return t=>{let n=e.get(t);return n||(n=i(t),e.set(t,n)),n}}async function mv(i){const e=await fetch(i);if(!e.ok)throw new Error(`Failed to fetch package: HTTP ${e.status}`);const t=new Uint8Array(await e.arrayBuffer()),n=lv(t);return fv(n)}async function gv(i){const e=`https://registry.npmjs.org/${i}`,t=await fetch(e);if(!t.ok)throw new Error(`Package not found in npm registry: ${i}`);const n=await t.json(),s=n["dist-tags"]?.latest;if(!s)throw new Error(`No latest version found for package: ${i}`);const r=n.versions?.[s]?.dist?.tarball;if(!r)throw new Error(`No tarball URL found for ${i}@${s}`);return r}async function Av(i){const t=(await uv(i)).filter(Ov).map(s=>({packagePath:s.name,content:s.text}));if(t.length===0)return[];const n=bv(t[0].content);return t.map(s=>({...s,packageName:n}))}function Ov(i){return i.name.endsWith("weslBundle.js")&&i.name.includes("/dist/")}function bv(i){const e=i.match(/name:\s*"([^"]+)"/);if(!e)throw new Error("Could not extract package name from bundle");return e[1]}class wv{astCache=new Map;sources;requested=new Set;shaderRoot;srcModuleParts;constructor(e,t){this.sources={...e};const{shaderRoot:n,srcModulePath:s}=t;this.shaderRoot=n.replace(/\/$/,""),this.srcModuleParts=s?this.urlToModuleParts(s):void 0}resolveModule(e){const t=this.astCache.get(e);if(t)return t;const n=this.sources[e];if(!n){this.requested.add(e);return}return this.parseAndCache(e,n)}getUnresolved(){return[...this.requested].filter(e=>!this.astCache.has(e))}allModules(){for(const e of Object.keys(this.sources))this.astCache.has(e)||this.resolveModule(e);return this.astCache.entries()}async resolveModuleAsync(e){const t=this.astCache.get(e);if(t)return t;if(this.sources[e])return this.resolveModule(e);const n=await this.fetchInternal(e);if(n)return this.sources[e]=n,this.requested.delete(e),this.parseAndCache(e,n)}async fetchInternal(e){const t=this.modulePathToUrl(e);if(t)return yv(t)}modulePathToUrl(e){const t=e.split("::"),n=Nu(t,"package",this.srcModuleParts);if(!n){if(t[0]==="super"&&!this.srcModuleParts){const s=`Cannot resolve super:: without file context: ${e}`;throw new Error(s)}return}return`${this.shaderRoot}/${n}`}parseAndCache(e,t){const s=ur({modulePath:e,debugFilePath:e,src:t});return this.astCache.set(e,s),s}urlToModuleParts(e){return["package",...e.replace(this.shaderRoot,"").replace(/^\//,"").replace(/\.w[eg]sl$/,"").split("/").filter(Boolean)]}}async function yv(i){for(const e of[".wesl",".wgsl"])try{const t=await fetch(i+e);if(t.ok)return t.text()}catch{}}const kv=["constants","test"];async function Pp(i,e){const t=e?.shaderRoot??"/shaders",n=e?.currentPath,s=e?.existingSources,r=n?Mp(n,t):"package::main",o={...s,[r]:i},l={shaderRoot:t,srcModulePath:n},a=new wv(o,l),h=[],c=new Set;for(;;){Oy(a);const u=xv(a,c);if(u.length===0)break;const[d,p]=kO(u,Sv);await Promise.all(d.map(g=>a.resolveModuleAsync(g)));const m=await Dp(p,c);h.push(...m)}const f=Qv(a);return{libs:h,weslSrc:f}}async function Cv(i,e="/shaders"){const t=await Ev(i),n=new URL(i,window.location.href).pathname,s=Mp(n,e),{weslSrc:r,libs:o}=await Pp(t,{shaderRoot:e,currentPath:n});return{weslSrc:r,libs:o,rootModuleName:s}}async function vv(i){const e=new Set;return Dp(i.map(t=>`${t}::_`),e)}function Mp(i,e){const t=e.replace(/\/$/,""),n=i.replace(t,"").replace(/^\//,"");return Tl(n,"package",!1)}function xv(i,e){return i.getUnresolved().filter(t=>{const n=t.split("::")[0];return!kv.includes(n)&&!e.has(n)})}function Sv(i){return i.startsWith("package::")||i.startsWith("super::")}async function Dp(i,e){const n=[...new Set(i.map(s=>s.split("::")[0]))].filter(s=>!e.has(s));if(n.length===0)return[];for(const s of n)e.add(s);return Bv(n)}function Qv(i){const e={};for(const[t]of i.allModules())i.sources[t]&&(e[t]=i.sources[t]);return e}async function Ev(i){const e=await fetch(i);if(!e.ok)throw new Error(`HTTP ${e.status}: ${e.statusText}`);return e.text()}async function Bv(i){const e=new Set,t=i.map(r=>Oc(r,e)),n=await Promise.all(t),s=await yp(n.flat());return WC(s,r=>Oc(r,e))}async function Oc(i,e){if(e.has(i))return[];e.add(i);for(const t of wy(i))try{return await pv(t)}catch{}throw new Error(`Package not found: ${i}`)}const Pv=':host{--tab-bar-bg: transparent;--tab-border: #ccc;--tab-color: #999;--tab-active-bg: #fff;--tab-active-color: #222;--tab-accent: #5f61d8;display:flex;flex-direction:column;position:relative;min-height:100px}:host(.dark){--tab-bar-bg: transparent;--tab-border: #555;--tab-color: #999;--tab-active-bg: #1e1e1e;--tab-active-color: #fff}.tab-bar{--bar-v: 6px;--bar-h: 8px;display:flex;align-items:center;gap:14px;padding:var(--bar-v) var(--bar-h);background:var(--tab-bar-bg);flex-shrink:0;position:relative}.tab-bar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--tab-border)}.tab{--tab-v: 5px;--tab-h: 12px;display:flex;align-items:center;gap:16px;padding:var(--tab-v) var(--tab-h);background:transparent;border:none;border-radius:0;color:var(--tab-color);cursor:pointer;position:relative;font-size:15px;font-family:system-ui,sans-serif}.tab.active{color:var(--tab-accent);font-weight:600;padding-bottom:calc(var(--tab-v) + var(--bar-v) + .5px);margin-bottom:calc(-1 * (var(--bar-v) + .5px));position:relative;z-index:1;border-bottom:2px solid var(--tab-accent)}.tab.active:first-child{margin-left:calc(-1 * var(--bar-h));padding-left:calc(var(--tab-h) + var(--bar-h))}.tab-close{position:absolute;right:-8px;width:16px;height:16px;padding:0;border:none;background:transparent;color:inherit;cursor:pointer;opacity:0;font-size:18px;line-height:1}.tab:hover .tab-close{opacity:.6}.tab-close:hover{opacity:1}.tab-rename{background:var(--tab-active-bg);border:1px solid var(--tab-border);border-radius:4px;color:var(--tab-active-color);font-size:15px;font-family:system-ui,sans-serif;padding:0 4px;outline:none}.tab-add{padding:0 10px;background:transparent;border:none;color:var(--tab-color);cursor:pointer;font-size:25px;line-height:1}.tab-add:hover{color:var(--tab-active-color)}.editor-container{flex:1;min-height:0;width:100%;padding:var(--editor-padding, 16px 0 0)}.cm-editor{height:100%;font-size:var(--editor-font-size, 14px)}.cm-scroller{overflow:auto}.snackbar{position:absolute;bottom:16px;left:16px;background:#e8e8e8;color:#333;padding:10px 20px;border-radius:8px;font-size:14px;font-family:system-ui,sans-serif;line-height:1.4;box-shadow:0 2px 8px #00000026;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10}:host(.dark) .snackbar{background:#3a3a3a;color:#e0e0e0;box-shadow:0 2px 8px #0006}.snackbar.visible{opacity:1}',Mv={variable:"#000f80",keyword:"#0000ff",control:"#af00db",type:"#891a1a",fn:"#795e26",number:"#098658",comment:"#008000",modulePath:"#0070c1"},Dv={variable:"#9cdcfe",keyword:"#569cd6",control:"#c586c0",type:"#4ec9b0",fn:"#dcdcaa",number:"#b5cea8",comment:"#6a9955",modulePath:"#4fc1ff"},Iv=Ip(Mv),Tv=Ip(Dv);let os;class Rv extends HTMLElement{static observedAttributes=["src","readonly","theme","shader-root","tabs","lint","lint-from","line-numbers"];editorView=null;editorContainer;tabBar;snackbar;readonlyCompartment=new $t;themeCompartment=new $t;lintCompartment=new $t;lineNumbersCompartment=new $t;_pendingSource=null;_theme="auto";_mediaQuery=null;_lineNumbers=!1;_files=new Map;_activeFile="";_tabs=!0;_lint="on";_conditions={};_packageName;_libs=[];_ignorePackages=["constants","test"];_fetchingPkgs=new Set;_snackTimer;_externalDiagnostics=[];_lintFromEl=null;_boundCompileError=this.onCompileError.bind(this);_boundCompileSuccess=this.onCompileSuccess.bind(this);constructor(){super();const e=this.attachShadow({mode:"open"});e.adoptedStyleSheets=[Lv()],this.tabBar=document.createElement("div"),this.tabBar.className="tab-bar",e.appendChild(this.tabBar),this.editorContainer=document.createElement("div"),this.editorContainer.className="editor-container",e.appendChild(this.editorContainer),this.snackbar=document.createElement("div"),this.snackbar.className="snackbar",this.snackbar.textContent="Loading…",e.appendChild(this.snackbar)}connectedCallback(){this.initEditor(),this.loadInitialContent()}disconnectedCallback(){this.connectLintSource(null),this.editorView?.destroy(),this.editorView=null}attributeChangedCallback(e,t,n){e==="src"&&n&&this.editorView?this.loadFromUrl(n):e==="readonly"?this.updateReadonly():e==="theme"?this.theme=n||"auto":e==="tabs"?(this._tabs=n!=="false",this.renderTabs()):e==="lint"?(this._lint=n||"on",this.updateLint()):e==="lint-from"?this.connectLintSource(n):e==="line-numbers"&&(this._lineNumbers=n==="true",this.updateLineNumbers())}get source(){return this.editorView?.state.doc.toString()??this._pendingSource??""}set source(e){if(this.editorView){const t=this.editorView.state.doc.length;this.editorView.dispatch({changes:{from:0,to:t,insert:e}})}else this._pendingSource=e}get sources(){this.saveCurrentFileState();const e={};for(const[t,n]of this._files)e[ls(t)]=n.doc.toString();return e}set sources(e){this._files.clear();for(const[n,s]of Object.entries(e)){const r=Yr(n);this._files.set(r,{doc:$.of(s.split(`
104
+ `))})}const t=Object.keys(e)[0];t&&this.switchToFile(Yr(t)),this.renderTabs()}set project(e){const{weslSrc:t,rootModuleName:n,conditions:s,packageName:r,libs:o}=e;s!==void 0&&(this._conditions=s),r!==void 0&&(this._packageName=r),o!==void 0&&(this._libs=o),t&&(this.sources=t,n&&(this.activeFile=Yr(n))),this.updateLint()}get activeFile(){return this._activeFile}set activeFile(e){this.switchToFile(e)}get fileNames(){return Array.from(this._files.keys())}get tabs(){return this._tabs}set tabs(e){this._tabs=e,this.renderTabs()}get lint(){return this._lint}set lint(e){this._lint=e,this.updateLint()}get lineNumbers(){return this._lineNumbers}set lineNumbers(e){this._lineNumbers=e,e?this.setAttribute("line-numbers","true"):this.removeAttribute("line-numbers")}get loading(){return this.snackbar.classList.contains("visible")}set loading(e){e?this.showSnack("Loading…"):this.hideSnack()}showSnack(e,t){clearTimeout(this._snackTimer),this.snackbar.textContent=e,this.snackbar.classList.add("visible"),t&&(this._snackTimer=setTimeout(()=>this.hideSnack(),t))}hideSnack(){clearTimeout(this._snackTimer),this.snackbar.classList.remove("visible")}get readonly(){return this.hasAttribute("readonly")}set readonly(e){e?this.setAttribute("readonly",""):this.removeAttribute("readonly")}get theme(){return this._theme}set theme(e){this._theme=e,this.updateTheme()}get shaderRoot(){return this.getAttribute("shader-root")}set shaderRoot(e){e?this.setAttribute("shader-root",e):this.removeAttribute("shader-root")}addFile(e,t=""){this._files.has(e)||(this._files.set(e,{doc:$.of(t.split(`
105
+ `))}),this.switchToFile(e),this.renderTabs(),this.dispatchFileChange("add",e))}removeFile(e){if(!(!this._files.has(e)||this._files.size<=1)){if(this._files.delete(e),this._activeFile===e){const t=this._files.keys().next().value;this.switchToFile(t)}this.renderTabs(),this.dispatchFileChange("remove",e)}}renameFile(e,t){const n=this._files.get(e);!n||this._files.has(t)||(this._files.delete(e),this._files.set(t,n),this._activeFile===e&&(this._activeFile=t),this.renderTabs(),this.dispatchFileChange("rename",t))}switchToFile(e){if(!this._files.has(e)||e===this._activeFile)return;this.saveCurrentFileState(),this._activeFile=e;const t=this._files.get(e);if(this.editorView){const s={from:0,to:this.editorView.state.doc.length,insert:t.doc.toString()},r=Q.scrollIntoView(t.scrollPos??0);this.editorView.dispatch({changes:s,selection:t.selection,effects:r})}this.renderTabs()}saveCurrentFileState(){if(!this.editorView||!this._activeFile)return;const e=this._files.get(this._activeFile);e&&(e.doc=this.editorView.state.doc,e.selection=this.editorView.state.selection,e.scrollPos=this.editorView.scrollDOM.scrollTop)}dispatchFileChange(e,t){this.dispatchEvent(new CustomEvent("file-change",{detail:{action:e,file:t}}))}initEditor(){this.readInitialAttributes(),this.parseInlineContent(),this._mediaQuery=matchMedia("(prefers-color-scheme: dark)"),this._mediaQuery.addEventListener("change",()=>this.updateTheme());const e=this._files.keys().next().value,t=this._pendingSource??(e?this._files.get(e).doc.toString():"");this._pendingSource=null,e&&(this._activeFile=e);const n=K.create({doc:t,extensions:this.buildExtensions()});this.editorView=new Q({state:n,parent:this.editorContainer}),this.renderTabs()}readInitialAttributes(){const e=this.getAttribute("theme");e&&(this._theme=e);const t=this.getAttribute("tabs");t!==null&&(this._tabs=t!=="false");const n=this.getAttribute("lint");n&&(this._lint=n);const s=this.getAttribute("line-numbers");s!==null&&(this._lineNumbers=s==="true");const r=this.getAttribute("lint-from");r&&this.connectLintSource(r)}buildExtensions(){const e=Q.theme({".cm-content":{padding:"0"},".cm-line":{padding:"0"}});return[TC,Zy(),e,this.themeCompartment.of(this.resolveTheme()),this.readonlyCompartment.of(K.readOnly.of(this.readonly)),this.lintCompartment.of(this.resolveLint()),this.lineNumbersCompartment.of(this.resolveLineNumbers()),Q.updateListener.of(t=>{if(t.docChanged){this._externalDiagnostics=[],this.saveCurrentFileState();const{source:n,sources:s,_activeFile:r}=this,o={source:n,sources:s,activeFile:r};this.dispatchEvent(new CustomEvent("change",{detail:o}))}})]}resolveTheme(){const e=this._theme==="dark"||this._theme==="auto"&&matchMedia("(prefers-color-scheme: dark)").matches;return this.classList.toggle("dark",e),[Q.theme({},{dark:e}),e?Tv:Iv]}updateTheme(){this.editorView?.dispatch({effects:this.themeCompartment.reconfigure(this.resolveTheme())})}updateReadonly(){this.editorView?.dispatch({effects:this.readonlyCompartment.reconfigure(K.readOnly.of(this.readonly))}),this.renderTabs()}resolveLint(){return this._lint==="off"?[]:ek({getSources:()=>this.sources,rootModule:()=>ls(this._activeFile),conditions:()=>this._conditions,packageName:()=>this._packageName,getExternalDiagnostics:()=>this._externalDiagnostics,getLibs:()=>this._libs,fetchLibs:e=>this.fetchLibsOnDemand(e),ignorePackages:()=>this._ignorePackages})}async fetchLibsOnDemand(e){const t=e.filter(n=>!this._fetchingPkgs.has(n));if(t.length===0)return[];for(const n of t)this._fetchingPkgs.add(n);this.showSnack(`Loading ${t.join(", ")}…`);try{const n=await vv(t);return this._libs=[...this._libs,...n],n.length>0?this.showSnack(`Loaded ${t.join(", ")}`,3e3):this.hideSnack(),n}catch(n){return console.warn("wgsl-edit: failed to fetch packages:",t,n),this.showSnack(`Failed to load ${t.join(", ")}`,3e3),[]}finally{for(const n of t)this._fetchingPkgs.delete(n)}}updateLint(){this.editorView?.dispatch({effects:this.lintCompartment.reconfigure(this.resolveLint())})}connectLintSource(e){if(this._lintFromEl&&(this._lintFromEl.removeEventListener("compile-error",this._boundCompileError),this._lintFromEl.removeEventListener("compile-success",this._boundCompileSuccess),this._lintFromEl=null),this._externalDiagnostics=[],!e)return;const t=document.getElementById(e);t&&(this._lintFromEl=t,t.addEventListener("compile-error",this._boundCompileError),t.addEventListener("compile-success",this._boundCompileSuccess))}onCompileError(e){const t=e.detail;if(!this.editorView||t.source==="wesl")return;const n=this.editorView.state.doc,s=ls(this._activeFile);this._externalDiagnostics=t.locations.filter(r=>r.file?ls(r.file.replace(/^\.\//,""))===s:!0).map(r=>{const o=n.line(Math.max(1,Math.min(r.line,n.lines))),l=Math.min(o.from+(r.column??0),n.length),a=Math.min(l+(r.length??1),n.length);return{from:l,to:a,severity:r.severity,message:r.message,source:"WebGPU"}}),this._externalDiagnostics.length&&ph(this.editorView)}onCompileSuccess(){this._externalDiagnostics.length!==0&&(this._externalDiagnostics=[],this.editorView&&ph(this.editorView))}resolveLineNumbers(){return this._lineNumbers?[]:Q.theme({".cm-gutters":{display:"none"}})}updateLineNumbers(){this.editorView?.dispatch({effects:this.lineNumbersCompartment.reconfigure(this.resolveLineNumbers())})}parseInlineContent(){const e=Array.from(this.querySelectorAll('script[type="text/wgsl"], script[type="text/wesl"]'));if(e.length===0){const t=this.textContent?.trim()??"";t&&this._files.set("main.wesl",{doc:$.of(t.split(`
106
+ `))});return}for(const t of e){const n=t.getAttribute("data-name")||"main.wesl",s=t.textContent?.trim()??"";this._files.set(n,{doc:$.of(s.split(`
107
+ `))})}}renderTabs(){if(this.tabBar.style.display=this._tabs?"flex":"none",!!this._tabs){this.tabBar.innerHTML="";for(const e of this._files.keys())this.tabBar.appendChild(this.createTab(e));this.readonly||this.tabBar.appendChild(this.createAddButton())}}createTab(e){const t=document.createElement("button");t.className="tab"+(e===this._activeFile?" active":"");const n=document.createElement("span");if(n.className="tab-name",n.textContent=e,this.readonly)t.append(n);else{n.addEventListener("dblclick",r=>{r.stopPropagation(),this.startRenameTab(t,n,e)});const s=document.createElement("button");s.className="tab-close",s.textContent="×",s.addEventListener("click",r=>{r.stopPropagation(),this.removeFile(e)}),t.append(n,s)}return t.addEventListener("click",()=>this.switchToFile(e)),t}createAddButton(){const e=document.createElement("button");return e.className="tab-add",e.textContent="+",e.addEventListener("click",()=>{let t="new.wesl",n=1;for(;this._files.has(t);)t=`new${n++}.wesl`;this.addFile(t)}),e}startRenameTab(e,t,n){const s=document.createElement("input");s.className="tab-rename",s.value=n,s.size=Math.max(n.length,8);const r=()=>{const o=s.value.trim()||n;o!==n&&!this._files.has(o)?this.renameFile(n,o):(t.style.display="",s.remove())};s.addEventListener("keydown",o=>{o.key==="Enter"&&(o.preventDefault(),r()),o.key==="Escape"&&(t.style.display="",s.remove())}),s.addEventListener("blur",r),s.addEventListener("input",()=>{s.size=Math.max(s.value.length,8)}),t.style.display="none",e.insertBefore(s,t),s.focus(),s.select()}async loadFromUrl(e){this.loading=!0;try{const t=await fetch(e);if(!t.ok)throw new Error(`Failed to fetch ${e}: ${t.status}`);this.source=await t.text()}catch(t){console.error("wgsl-edit: Failed to load source:",t)}finally{this.loading=!1}}loadInitialContent(){const e=this.getAttribute("src");e&&this.loadFromUrl(e)}}function Ip(i){return du(Dn.define([{tag:A.variableName,color:i.variable},{tag:A.definition(A.variableName),color:i.variable},{tag:A.propertyName,color:i.variable},{tag:A.keyword,color:i.keyword},{tag:A.definitionKeyword,color:i.keyword},{tag:A.controlKeyword,color:i.control},{tag:A.bool,color:i.keyword},{tag:A.typeName,color:i.type},{tag:A.definition(A.typeName),color:i.type},{tag:A.function(A.variableName),color:i.fn},{tag:A.function(A.definition(A.variableName)),color:i.fn},{tag:A.number,color:i.number},{tag:A.lineComment,color:i.comment},{tag:A.blockComment,color:i.comment},{tag:A.namespace,color:i.modulePath}],{all:{fontWeight:"normal",fontStyle:"normal"}}))}function Lv(){return os||(os=new CSSStyleSheet,os.replaceSync(Pv)),os}function ls(i){return`package::${i.replace(/\.(wesl|wgsl)$/,"").replace(/\//g,"::")}`}function Yr(i){return`${i.replace(/^package::/,"").replace(/::/g,"/")}.wesl`}customElements.get("wgsl-edit")||customElements.define("wgsl-edit",Rv);class Nv{el;_message=null;constructor(e){this.el=document.createElement("div"),this.el.className="error-overlay",e.appendChild(this.el)}show(e){this._message=e,this.el.textContent=e,this.el.classList.add("visible"),console.error("[wgsl-play]",e)}hide(){this._message=null,this.el.classList.remove("visible")}get visible(){return this.el.classList.contains("visible")}get message(){return this._message}}const $v=`<svg viewBox="0 0 24 24" width="20" height="20"><rect x="4" y="4" width="3" height="16" fill="currentColor"/><polygon points="20,4 9,12 20,20" fill="currentColor"/></svg>
108
+ `,bc=`<svg viewBox="0 0 24 24" width="20" height="20"><path d="M3 3h6v2H5v4H3V3zm12 0h6v6h-2V5h-4V3zM3 15h2v4h4v2H3v-6zm16 4h-4v2h6v-6h-2v4z" fill="currentColor"/></svg>
109
+ `,wc=`<svg viewBox="0 0 24 24" width="20" height="20"><rect x="5" y="4" width="4" height="16" fill="currentColor"/><rect x="15" y="4" width="4" height="16" fill="currentColor"/></svg>
110
+ `,Fv=`<svg viewBox="0 0 24 24" width="20" height="20"><polygon points="6,4 20,12 6,20" fill="currentColor"/></svg>
111
+ `,Kv=`<svg viewBox="0 0 24 24" width="20" height="20"><path d="M9 3v6H3v-2h4V3h2zm6 0h2v4h4v2h-6V3zM3 15h6v6H7v-4H3v-2zm12 0h6v2h-4v4h-2v-6z" fill="currentColor"/></svg>
112
+ `;class zv{container;playPauseBtn;fullscreenBtn;playing=!0;constructor(e,t,n,s,r){this.container=document.createElement("div"),this.container.className="controls",this.fullscreenBtn=document.createElement("button"),this.fullscreenBtn.innerHTML=bc,this.fullscreenBtn.addEventListener("click",r);const o=document.createElement("button");o.innerHTML=$v,o.addEventListener("click",s),this.playPauseBtn=document.createElement("button"),this.playPauseBtn.innerHTML=wc,this.playPauseBtn.addEventListener("click",()=>this.playing?n():t()),this.container.append(this.fullscreenBtn,o,this.playPauseBtn),e.appendChild(this.container)}setPlaying(e){this.playing=e,this.playPauseBtn.innerHTML=e?wc:Fv}setFullscreen(e){this.fullscreenBtn.innerHTML=e?Kv:bc}show(){this.container.style.display=""}hide(){this.container.style.display="none"}}const _v=`
113
+ @vertex
114
+ fn vs_main(@builtin(vertex_index) idx: u32) -> @builtin(position) vec4f {
115
+ // Covers viewport with 3 vertices, no vertex buffer needed
116
+ var pos: vec2f;
117
+ if (idx == 0u) {
118
+ pos = vec2f(-1.0, -1.0);
119
+ } else if (idx == 1u) {
120
+ pos = vec2f(3.0, -1.0);
121
+ } else {
122
+ pos = vec2f(-1.0, 3.0);
123
+ }
124
+ return vec4f(pos, 0.0, 1.0);
125
+ }`;function Vv(i,e,t,n,s=[0,0]){const r=new Float32Array([t[0],t[1],n,0,s[0],s[1],0,0]);e.queue.writeBuffer(i,0,r)}function Wv(){return{test:()=>`
126
+ struct Uniforms {
127
+ resolution: vec2f, // Output viewport dimensions
128
+ time: f32, // Elapsed time in seconds
129
+ mouse: vec2f, // Mouse position [0,1] normalized coords
130
+ }
131
+ `}}async function Hv(i){const e=await qv(i);return Gv({device:i.device,module:e,format:i.format,layout:i.layout})}async function qv(i){const{fragmentSource:e,conditions:t,constants:n,packageName:s,config:r}=i,{device:o,resolver:l,libs:a=[],rootModuleName:h="main"}=i,{weslSrc:c,virtualLibs:f}=i,u=`${e}
132
+
133
+ ${_v}`,d=[];d.push(new Cn({[h]:u},{packageName:s})),c&&d.push(new Cn(c,{packageName:s}));let p=d.length===1?d[0]:new vn(d);l&&(p=new vn([p,l]));const m={...Wv(),...f};return(await Ey({resolver:p,rootModuleName:h,packageName:s,libs:a,virtualLibs:m,conditions:t,constants:n,config:r})).createShaderModule(o)}function Gv(i){const{device:e,module:t,format:n,layout:s="auto"}=i;return e.createRenderPipeline({layout:s,vertex:{module:t},fragment:{module:t,targets:[{format:n}]},primitive:{topology:"triangle-list"}})}function Uv(i){const{device:e,pipeline:t,bindGroup:n,targetView:s}=i,r=e.createCommandEncoder(),o=r.beginRenderPass({colorAttachments:[{view:s,clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}]});o.setPipeline(t),n&&o.setBindGroup(0,n),o.draw(3),o.end(),e.queue.submit([r.finish()])}var Yv=jv(i=>" ".repeat(i)),Xv=20;""+Yv(Xv+3);function jv(i){const e=new Map;return function(...t){const n=JSON.stringify(t);if(e.has(n))return e.get(n);{const s=i(...t);return e.set(n,s),s}}}typeof DOMRect>"u"&&(globalThis.DOMRect=function(){});async function Jv(i){const e=await navigator.gpu.requestAdapter();if(!e)throw new Error("WebGPU adapter not available");const t=await zy(e),n=i.getContext("webgpu");if(!n)throw new Error("WebGPU context not available");const s=navigator.gpu.getPreferredCanvasFormat();n.configure({device:t,format:s,alphaMode:"opaque"});const r=t.createBuffer({size:32,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),o=t.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.FRAGMENT,buffer:{}}]}),l=t.createPipelineLayout({bindGroupLayouts:[o]}),a=t.createBindGroup({layout:o,entries:[{binding:0,resource:{buffer:r}}]});return{device:t,canvas:i,context:n,presentationFormat:s,uniformBuffer:r,pipelineLayout:l,bindGroup:a,frameCount:0}}async function Xr(i,e,t){const{weslSrc:n,libs:s=[],conditions:r,constants:o}=t??{},{packageName:l,rootModuleName:a}=t??{};let h;if(n||s.length>0){const u=[];n&&u.push(new Cn(n,{packageName:l}));for(const d of s)u.push(new Il(d));h=u.length===1?u[0]:new vn(u)}i.device.pushErrorScope("validation");const c=await Hv({device:i.device,fragmentSource:e,resolver:h,format:i.presentationFormat,layout:i.pipelineLayout,conditions:r,constants:o,packageName:l,rootModuleName:a}),f=await i.device.popErrorScope();if(f)throw i.pipeline=void 0,f;i.pipeline=c}function Zv(i,e){let t;function n(){if(!i.pipeline){t=requestAnimationFrame(n);return}const s=ex(e),r=[i.canvas.width,i.canvas.height],o=[0,0];Vv(i.uniformBuffer,i.device,r,s,o),Uv({device:i.device,pipeline:i.pipeline,bindGroup:i.bindGroup,targetView:i.context.getCurrentTexture().createView()}),i.frameCount++,t=requestAnimationFrame(n)}return t=requestAnimationFrame(n),()=>cancelAnimationFrame(t)}function ex(i){return((i.isPlaying?performance.now():i.startTime+i.pausedDuration)-i.startTime)/1e3}const tx=":host{--error-bg: rgba(220, 102, 18, .8);--error-color: white;--controls-bg: rgba(0, 0, 0, .4);--controls-color: rgba(255, 255, 255, .8);--controls-hover-color: white;--controls-hover-bg: rgba(255, 255, 255, .15);display:block;position:relative;overflow:hidden}:host(.dark){--error-bg: rgba(180, 60, 10, .85);--controls-bg: rgba(0, 0, 0, .5)}canvas{position:absolute;inset:0;width:100%;height:100%;display:block}.controls{background:var(--controls-bg);position:absolute;bottom:8px;right:8px;display:flex;gap:20px;border-radius:6px;padding:2px;opacity:0;transition:opacity .2s;z-index:1}:host(:hover) .controls{opacity:1}.controls button{border:none;background:none;color:var(--controls-color);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.controls button:hover{color:var(--controls-hover-color);background:var(--controls-hover-bg)}.error-overlay{position:absolute;inset:0;background:var(--error-bg);color:var(--error-color);padding:1rem;font-family:monospace;font-size:.875rem;white-space:pre-wrap;overflow:auto;display:none}.error-overlay.visible{display:block}";let as=null,hs=null;class ix extends HTMLElement{static observedAttributes=["src","shader-root","source","no-controls","theme"];canvas;errorOverlay;controls;resizeObserver;stopRenderLoop;renderState;playback={isPlaying:!0,startTime:performance.now(),pausedDuration:0};_weslSrc={};_rootModuleName="package::main";_libs;_linkOptions={};_fromFullProject=!1;_initialized=!1;_sourceEl=null;_sourceListener=null;_theme="auto";_mediaQuery=null;_onFullscreenChange=()=>this.controls.setFullscreen(!!document.fullscreenElement);getConfigOverrides(){const e=this.getAttribute("shader-root");if(e)return{shaderRoot:e}}constructor(){super();const e=this.attachShadow({mode:"open"});e.adoptedStyleSheets=[sx()],e.appendChild(nx().content.cloneNode(!0)),this.canvas=e.querySelector("canvas"),this.errorOverlay=new Nv(e),this.controls=new zv(e,()=>this.play(),()=>this.pause(),()=>this.rewind(),()=>this.toggleFullscreen()),this.resizeObserver=new ResizeObserver(t=>{for(const n of t){const{width:s,height:r}=n.contentRect;s>0&&r>0&&(this.canvas.width=Math.floor(s*devicePixelRatio),this.canvas.height=Math.floor(r*devicePixelRatio))}})}connectedCallback(){this.resizeObserver.observe(this);const e=this.getAttribute("theme");e&&(this._theme=e),this._mediaQuery=matchMedia("(prefers-color-scheme: dark)"),this._mediaQuery.addEventListener("change",()=>this.updateTheme()),this.updateTheme(),document.addEventListener("fullscreenchange",this._onFullscreenChange),this.initialize()}disconnectedCallback(){this.resizeObserver.disconnect(),this.stopRenderLoop?.(),document.removeEventListener("fullscreenchange",this._onFullscreenChange),this._sourceEl&&this._sourceListener&&this._sourceEl.removeEventListener("change",this._sourceListener)}attributeChangedCallback(e,t,n){if(t!==n){if(e==="no-controls"){n!==null?this.controls.hide():this.controls.show();return}if(e==="theme"){this._theme=n||"auto",this.updateTheme();return}e==="src"&&n&&this._initialized&&this.loadFromUrl(n)}}get source(){return this._weslSrc[this._rootModuleName]??""}set source(e){this._weslSrc={[this._rootModuleName]:e},this._libs=void 0,this._fromFullProject=!1,this.discoverAndRebuild()}set project(e){const{weslSrc:t,rootModuleName:n,libs:s,packageName:r,conditions:o,constants:l}=e;if((r||o||l)&&(this._linkOptions={packageName:r,conditions:o,constants:l}),s&&(this._libs=s),t){this.setProjectSources(t,n);return}Object.keys(this._weslSrc).length!==0&&(this._fromFullProject?this.rebuildPipeline():this.discoverAndRebuild())}setProjectSources(e,t){const n=Object.entries(e).map(([s,r])=>[yc(s),r]);this._weslSrc=Object.fromEntries(n),this._rootModuleName=t?yc(t):"package::main",this._fromFullProject=!0,this.discoverAndRebuild()}get isPlaying(){return this.playback.isPlaying}get time(){const{isPlaying:e,startTime:t,pausedDuration:n}=this.playback;return((e?performance.now():t+n)-t)/1e3}get frameCount(){return this.renderState?.frameCount??0}get hasError(){return this.errorOverlay.visible}get errorMessage(){return this.errorOverlay.message}play(){const{isPlaying:e,pausedDuration:t}=this.playback;e||(this.playback.startTime=performance.now()-t,this.setPlaying(!0))}pause(){this.playback.isPlaying&&(this.playback.pausedDuration=performance.now()-this.playback.startTime,this.setPlaying(!1))}setPlaying(e){this.playback.isPlaying=e,this.controls.setPlaying(e),this.dispatchEvent(new CustomEvent("playback-change",{detail:{isPlaying:e}}))}rewind(){this.playback.startTime=performance.now(),this.playback.pausedDuration=0,this.setPlaying(!1)}showError(e){if(!e){this.errorOverlay.hide();return}this.errorOverlay.show(e),this.pause()}toggleFullscreen(){document.fullscreenElement?document.exitFullscreen():this.requestFullscreen()}updateTheme(){const e=this._theme==="dark"||this._theme==="auto"&&matchMedia("(prefers-color-scheme: dark)").matches;this.classList.toggle("dark",e)}async initialize(){if(this._initialized)return!!this.renderState;this._initialized=!0;try{return this.renderState=await Jv(this.canvas),await this.loadInitialContent(),this.stopRenderLoop=Zv(this.renderState,this.playback),this.dispatchEvent(new CustomEvent("ready")),!0}catch(e){const t=navigator.gpu?`WebGPU initialization failed: ${e}`:`WebGPU is not supported in this browser.
134
+ Try Chrome 113+, Edge 113+, or Safari 18+.`;return this.errorOverlay.show(t),this.pause(),this.dispatchEvent(new CustomEvent("init-error",{detail:{message:t}})),!1}}async loadInitialContent(){const e=this.getAttribute("source");if(e)return this.connectToSource(e);const t=this.getAttribute("src");if(t)return this.loadFromUrl(t);const s=this.querySelector('script[type="text/wgsl"], script[type="text/wesl"]')?.textContent?.trim()??this.textContent?.trim();s&&(this._weslSrc={[this._rootModuleName]:s},this._fromFullProject=!1,await this.discoverAndRebuild())}async connectToSource(e){const t=document.getElementById(e);if(!t){console.error(`wgsl-play: source element "${e}" not found`);return}this._sourceEl=t;const n=()=>{const s=t.sources;if(s&&Object.keys(s).length>0)return s;const r=t.source??t.textContent??"";return{[this._rootModuleName]:r}};this.project={weslSrc:n()},this._sourceListener=s=>{const r=s.detail,o={[this._rootModuleName]:r?.source??""};this.project={weslSrc:r?.sources??o}},t.addEventListener("change",this._sourceListener)}async loadFromUrl(e){if(this.renderState)try{this.errorOverlay.hide();const{weslSrc:t,libs:n,rootModuleName:s}=await Cv(e,this.getConfigOverrides()?.shaderRoot);this._weslSrc=t,this._libs=n,this._fromFullProject=!1,s&&(this._rootModuleName=s);const r=t[this._rootModuleName];if(!r)return;await Xr(this.renderState,r,{...this._linkOptions,weslSrc:t,libs:n,rootModuleName:this._rootModuleName}),this.dispatchEvent(new CustomEvent("compile-success"))}catch(t){this.handleCompileError(t)}}async rebuildPipeline(){if(!await this.initialize())return;const e=this._weslSrc[this._rootModuleName];if(e)try{this.errorOverlay.hide(),await Xr(this.renderState,e,{...this._linkOptions,weslSrc:this._weslSrc,libs:this._libs,rootModuleName:this._rootModuleName}),this.dispatchEvent(new CustomEvent("compile-success"))}catch(t){this.handleCompileError(t)}}async discoverAndRebuild(){if(!await this.initialize())return;const e=this._weslSrc[this._rootModuleName];if(e)try{this.errorOverlay.hide();const{weslSrc:t,libs:n}=await Pp(e,{shaderRoot:this.getConfigOverrides()?.shaderRoot,existingSources:this._weslSrc});this._weslSrc={...this._weslSrc,...t},this._libs=[...this._libs??[],...n],await Xr(this.renderState,e,{...this._linkOptions,weslSrc:this._weslSrc,libs:this._libs,rootModuleName:this._rootModuleName}),this.dispatchEvent(new CustomEvent("compile-success"))}catch(t){this.handleCompileError(t)}}handleCompileError(e){const t=e?.message??String(e);this.errorOverlay.show(t);const n=e instanceof _s?"wesl":"webgpu",s=this.extractLocations(e),r={message:t,source:n,locations:s};this.dispatchEvent(new CustomEvent("compile-error",{detail:r}))}extractLocations(e){const t=e?.weslLocation;if(t)return[{file:t.file,line:t.line,column:t.column-1,length:t.length,severity:"error",message:e?.message??""}];const n=e?.compilationInfo?.messages;return n?n.map(s=>({file:s.module?.url,line:s.lineNum,column:s.linePos-1,length:s.length,severity:s.type==="warning"?"warning":s.type==="info"?"info":"error",message:s.message})):[]}}function nx(){return hs||(hs=document.createElement("template"),hs.innerHTML='<canvas part="canvas"></canvas>'),hs}function sx(){return as||(as=new CSSStyleSheet,as.replaceSync(tx)),as}function yc(i){return Tl(i,"package",!1)}typeof customElements<"u"&&!customElements.get("wgsl-play")&&customElements.define("wgsl-play",ix);const kc=document.querySelector("wgsl-edit"),rx=()=>matchMedia("(prefers-color-scheme: dark)").matches;function Tp(i){const e=i?"dark":"light";kc&&(kc.theme=e),document.body.className=e,document.getElementById("prism-light").toggleAttribute("disabled",i),document.getElementById("prism-dark").toggleAttribute("disabled",!i)}Tp(rx());document.getElementById("theme-toggle").addEventListener("click",()=>{Tp(document.body.className!=="dark")});